UNPKG

5.35 kBTypeScriptView Raw
1/// <reference types="node" />
2/// <reference types="node" />
3import { packageJson } from 'mrm-core';
4import { SpawnSyncReturns, StdioOptions } from 'child_process';
5import { File } from '../Base/File';
6type InstallerNotifier = (list: string[], dev: boolean) => void;
7type Dependencies = {
8 list: string[];
9 versions?: any;
10 dev: boolean;
11};
12type SupportedPackageManager = 'yarn' | 'pnpm' | 'npm';
13/**
14 * Exposes the API to work with `package.json` file. The file is
15 * same as a standard JSON file, but with some special methods
16 * related to package file itself.
17 */
18export declare class PackageJsonFile extends File {
19 private installerOutput;
20 filePointer: ReturnType<typeof packageJson>;
21 /**
22 * Collection of actions to be executed on package file
23 */
24 protected actions: never[];
25 /**
26 * A copy of install instructions
27 */
28 protected packages: {
29 install: {
30 dependency: string;
31 version: string;
32 dev: boolean;
33 }[];
34 uninstall: {
35 dependency: string;
36 dev: boolean;
37 }[];
38 };
39 /**
40 * Explicitly force to use another client instead of npm
41 */
42 private packageManager;
43 /**
44 * Method invoked before installing dependencies
45 */
46 private beforeInstallHooks?;
47 /**
48 * Method invoked before uninstalling dependencies
49 */
50 private beforeUninstallHooks?;
51 constructor(basePath: string, installerOutput?: StdioOptions);
52 /**
53 * Run hooks for action or uninstall action
54 */
55 private runHooks;
56 /**
57 * Sets installation client
58 */
59 private setClient;
60 /**
61 * Executes the installer `install` or `uninstall` action. Use
62 * `this.installerFnAsync` for async version
63 */
64 private installerFn;
65 /**
66 * Executes the installer `install` or `uninstall` action. Use
67 * `this.installerFn` for sync version
68 */
69 private installerFnAsync;
70 /**
71 * Install and uninstall packages defined via `this.install`
72 * and `this.uninstall`
73 */
74 private commitDependencies;
75 /**
76 * Performing uninstalling as a rollback step. Which means, this method
77 * will remove packages marked for installation.
78 */
79 private rollbackDependencies;
80 /**
81 * Same as `commitInstalls` but async
82 */
83 private commitDependenciesAsync;
84 /**
85 * Same as `rollbackInstalls` but async.
86 */
87 private rollbackDependenciesAsync;
88 /**
89 * Commits actions defined on the given file
90 */
91 private commitActions;
92 /**
93 * Rollsback actions defined on the package file
94 */
95 private rollbackActions;
96 /**
97 * Set key/value pair in the package.json file
98 */
99 set(key: string, value: any): this;
100 /**
101 * Set a specific client to be used
102 */
103 useClient(client: SupportedPackageManager): this;
104 /**
105 * Enable/disable use of yarn
106 * @deprecated The "yarn" method is deprecated. Please use "useClient('yarn')" instead.
107 */
108 yarn(_useYarn: boolean): this;
109 /**
110 * Unset key/value pair from the package.json file
111 */
112 unset(key: string): this;
113 /**
114 * Set package.json script
115 */
116 setScript(name: string, script: string): this;
117 /**
118 * Append to existing package.json script
119 */
120 appendScript(name: string, script: string): this;
121 /**
122 * Prepend to existing package.json script
123 */
124 prependScript(name: string, script: string): this;
125 /**
126 * Remove existing script or remove a given action from an
127 * existing script
128 */
129 removeScript(name: string, script?: string | RegExp): this;
130 /**
131 * Install dependencies
132 */
133 install(dependency: string, version?: string, dev?: boolean): this;
134 /**
135 * Uninstall dependencies
136 */
137 uninstall(dependency: string, dev?: boolean): this;
138 /**
139 * Remove file
140 */
141 delete(): this;
142 /**
143 * Returns value for a given key from the file
144 */
145 get(): any;
146 get(address: string | string[], defaultValue?: any): any;
147 /**
148 * A boolean telling if the file already exists
149 */
150 exists(): boolean;
151 /**
152 * Returns a list of dependencies along with specific versions (if any)
153 */
154 getInstalls(dev?: boolean): Dependencies;
155 /**
156 * Returns uninstalls list for prod or development
157 * dependencies.
158 */
159 getUninstalls(dev: boolean): Dependencies;
160 /**
161 * Define a function to be called before installing dependencies
162 */
163 beforeInstall(callback: InstallerNotifier): this;
164 /**
165 * Define a function to be called before uninstalling dependencies
166 */
167 beforeUninstall(callback: InstallerNotifier): this;
168 /**
169 * Commit mutations
170 */
171 commit(): SpawnSyncReturns<Buffer> | undefined;
172 /**
173 * Commits async. The files are still written using synchronous
174 * API. However, the install and uninstall becomes async.
175 */
176 commitAsync(): Promise<SpawnSyncReturns<Buffer> | undefined>;
177 /**
178 * Rollback mutations
179 */
180 rollback(): SpawnSyncReturns<Buffer> | undefined;
181 /**
182 * Rollsback async. The files are still written using synchronous
183 * API. However, the uninstall becomes async.
184 */
185 rollbackAsync(): Promise<SpawnSyncReturns<Buffer> | undefined>;
186}
187export {};