@vltpkg/cli-sdk 0.0.0-9 → 1.0.0-rc.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (149) hide show
  1. package/dist/esm/commands/build.d.ts +25 -0
  2. package/dist/esm/commands/build.d.ts.map +1 -0
  3. package/dist/esm/commands/build.js +102 -0
  4. package/dist/esm/commands/build.js.map +1 -0
  5. package/dist/esm/commands/cache.d.ts +18 -0
  6. package/dist/esm/commands/cache.d.ts.map +1 -1
  7. package/dist/esm/commands/cache.js +48 -2
  8. package/dist/esm/commands/cache.js.map +1 -1
  9. package/dist/esm/commands/ci.d.ts +11 -0
  10. package/dist/esm/commands/ci.d.ts.map +1 -0
  11. package/dist/esm/commands/ci.js +32 -0
  12. package/dist/esm/commands/ci.js.map +1 -0
  13. package/dist/esm/commands/config.d.ts +3 -2
  14. package/dist/esm/commands/config.d.ts.map +1 -1
  15. package/dist/esm/commands/config.js +372 -101
  16. package/dist/esm/commands/config.js.map +1 -1
  17. package/dist/esm/commands/docs.d.ts +18 -0
  18. package/dist/esm/commands/docs.d.ts.map +1 -0
  19. package/dist/esm/commands/docs.js +154 -0
  20. package/dist/esm/commands/docs.js.map +1 -0
  21. package/dist/esm/commands/exec-cache.d.ts +49 -0
  22. package/dist/esm/commands/exec-cache.d.ts.map +1 -0
  23. package/dist/esm/commands/exec-cache.js +146 -0
  24. package/dist/esm/commands/exec-cache.js.map +1 -0
  25. package/dist/esm/commands/exec-local.d.ts +1 -0
  26. package/dist/esm/commands/exec-local.d.ts.map +1 -1
  27. package/dist/esm/commands/exec-local.js +2 -0
  28. package/dist/esm/commands/exec-local.js.map +1 -1
  29. package/dist/esm/commands/exec.d.ts +6 -1
  30. package/dist/esm/commands/exec.d.ts.map +1 -1
  31. package/dist/esm/commands/exec.js +79 -5
  32. package/dist/esm/commands/exec.js.map +1 -1
  33. package/dist/esm/commands/help.d.ts +1 -1
  34. package/dist/esm/commands/help.d.ts.map +1 -1
  35. package/dist/esm/commands/help.js +32 -3
  36. package/dist/esm/commands/help.js.map +1 -1
  37. package/dist/esm/commands/init.d.ts +3 -3
  38. package/dist/esm/commands/init.d.ts.map +1 -1
  39. package/dist/esm/commands/init.js +95 -9
  40. package/dist/esm/commands/init.js.map +1 -1
  41. package/dist/esm/commands/install/reporter.d.ts +3 -2
  42. package/dist/esm/commands/install/reporter.d.ts.map +1 -1
  43. package/dist/esm/commands/install/reporter.js +42 -15
  44. package/dist/esm/commands/install/reporter.js.map +1 -1
  45. package/dist/esm/commands/install.d.ts +21 -3
  46. package/dist/esm/commands/install.d.ts.map +1 -1
  47. package/dist/esm/commands/install.js +27 -3
  48. package/dist/esm/commands/install.js.map +1 -1
  49. package/dist/esm/commands/list.d.ts +2 -2
  50. package/dist/esm/commands/list.d.ts.map +1 -1
  51. package/dist/esm/commands/list.js +149 -49
  52. package/dist/esm/commands/list.js.map +1 -1
  53. package/dist/esm/commands/pack.d.ts +32 -0
  54. package/dist/esm/commands/pack.d.ts.map +1 -0
  55. package/dist/esm/commands/pack.js +147 -0
  56. package/dist/esm/commands/pack.js.map +1 -0
  57. package/dist/esm/commands/pkg.d.ts +1 -2
  58. package/dist/esm/commands/pkg.d.ts.map +1 -1
  59. package/dist/esm/commands/pkg.js +123 -38
  60. package/dist/esm/commands/pkg.js.map +1 -1
  61. package/dist/esm/commands/publish.d.ts +22 -0
  62. package/dist/esm/commands/publish.d.ts.map +1 -0
  63. package/dist/esm/commands/publish.js +245 -0
  64. package/dist/esm/commands/publish.js.map +1 -0
  65. package/dist/esm/commands/query.d.ts +2 -3
  66. package/dist/esm/commands/query.d.ts.map +1 -1
  67. package/dist/esm/commands/query.js +132 -38
  68. package/dist/esm/commands/query.js.map +1 -1
  69. package/dist/esm/commands/run-exec.d.ts +1 -0
  70. package/dist/esm/commands/run-exec.d.ts.map +1 -1
  71. package/dist/esm/commands/run-exec.js +1 -0
  72. package/dist/esm/commands/run-exec.js.map +1 -1
  73. package/dist/esm/commands/run.d.ts +1 -0
  74. package/dist/esm/commands/run.d.ts.map +1 -1
  75. package/dist/esm/commands/run.js +13 -16
  76. package/dist/esm/commands/run.js.map +1 -1
  77. package/dist/esm/commands/serve.d.ts +14 -0
  78. package/dist/esm/commands/serve.d.ts.map +1 -0
  79. package/dist/esm/commands/serve.js +103 -0
  80. package/dist/esm/commands/serve.js.map +1 -0
  81. package/dist/esm/commands/uninstall.d.ts +8 -2
  82. package/dist/esm/commands/uninstall.d.ts.map +1 -1
  83. package/dist/esm/commands/uninstall.js +8 -3
  84. package/dist/esm/commands/uninstall.js.map +1 -1
  85. package/dist/esm/commands/update.d.ts +14 -0
  86. package/dist/esm/commands/update.d.ts.map +1 -0
  87. package/dist/esm/commands/update.js +41 -0
  88. package/dist/esm/commands/update.js.map +1 -0
  89. package/dist/esm/commands/version.d.ts +26 -0
  90. package/dist/esm/commands/version.d.ts.map +1 -0
  91. package/dist/esm/commands/version.js +226 -0
  92. package/dist/esm/commands/version.js.map +1 -0
  93. package/dist/esm/config/definition.d.ts +118 -15
  94. package/dist/esm/config/definition.d.ts.map +1 -1
  95. package/dist/esm/config/definition.js +185 -37
  96. package/dist/esm/config/definition.js.map +1 -1
  97. package/dist/esm/config/index.d.ts +41 -37
  98. package/dist/esm/config/index.d.ts.map +1 -1
  99. package/dist/esm/config/index.js +109 -172
  100. package/dist/esm/config/index.js.map +1 -1
  101. package/dist/esm/config/merge.d.ts +3 -1
  102. package/dist/esm/config/merge.d.ts.map +1 -1
  103. package/dist/esm/config/merge.js +11 -6
  104. package/dist/esm/config/merge.js.map +1 -1
  105. package/dist/esm/custom-help.d.ts +9 -0
  106. package/dist/esm/custom-help.d.ts.map +1 -0
  107. package/dist/esm/custom-help.js +400 -0
  108. package/dist/esm/custom-help.js.map +1 -0
  109. package/dist/esm/exec-command.d.ts +33 -14
  110. package/dist/esm/exec-command.d.ts.map +1 -1
  111. package/dist/esm/exec-command.js +213 -64
  112. package/dist/esm/exec-command.js.map +1 -1
  113. package/dist/esm/index.d.ts +1 -14
  114. package/dist/esm/index.d.ts.map +1 -1
  115. package/dist/esm/index.js +45 -19
  116. package/dist/esm/index.js.map +1 -1
  117. package/dist/esm/load-command.d.ts +16 -0
  118. package/dist/esm/load-command.d.ts.map +1 -0
  119. package/dist/esm/load-command.js +21 -0
  120. package/dist/esm/load-command.js.map +1 -0
  121. package/dist/esm/output.d.ts +6 -11
  122. package/dist/esm/output.d.ts.map +1 -1
  123. package/dist/esm/output.js +64 -27
  124. package/dist/esm/output.js.map +1 -1
  125. package/dist/esm/pack-tarball.d.ts +22 -0
  126. package/dist/esm/pack-tarball.d.ts.map +1 -0
  127. package/dist/esm/pack-tarball.js +249 -0
  128. package/dist/esm/pack-tarball.js.map +1 -0
  129. package/dist/esm/print-err.d.ts +9 -2
  130. package/dist/esm/print-err.d.ts.map +1 -1
  131. package/dist/esm/print-err.js +130 -46
  132. package/dist/esm/print-err.js.map +1 -1
  133. package/dist/esm/query-host-contexts.d.ts +16 -0
  134. package/dist/esm/query-host-contexts.d.ts.map +1 -0
  135. package/dist/esm/query-host-contexts.js +135 -0
  136. package/dist/esm/query-host-contexts.js.map +1 -0
  137. package/dist/esm/start-gui.d.ts +1 -0
  138. package/dist/esm/start-gui.d.ts.map +1 -1
  139. package/dist/esm/start-gui.js +28 -8
  140. package/dist/esm/start-gui.js.map +1 -1
  141. package/dist/esm/view.d.ts +2 -3
  142. package/dist/esm/view.d.ts.map +1 -1
  143. package/dist/esm/view.js +1 -1
  144. package/dist/esm/view.js.map +1 -1
  145. package/package.json +51 -37
  146. package/dist/esm/commands/gui.d.ts +0 -6
  147. package/dist/esm/commands/gui.d.ts.map +0 -1
  148. package/dist/esm/commands/gui.js +0 -13
  149. package/dist/esm/commands/gui.js.map +0 -1
@@ -1,153 +1,424 @@
1
+ import assert from 'node:assert';
2
+ import * as dotProp from '@vltpkg/dot-prop';
1
3
  import { error } from '@vltpkg/error-cause';
2
- import { spawnSync } from 'node:child_process';
3
- import { definition, isRecordField, pairsToRecords, recordsToPairs, } from "../config/index.js";
4
4
  import { commandUsage } from "../config/usage.js";
5
+ import { get, set, edit, list, del } from '@vltpkg/config';
6
+ import { load, find } from '@vltpkg/vlt-json';
7
+ export const views = {
8
+ human: results => {
9
+ // Handle string arrays (like list output)
10
+ if (Array.isArray(results) && typeof results[0] === 'string') {
11
+ return results.join('\n');
12
+ }
13
+ // For all other values (primitives, objects, arrays), use JSON formatting like vlt pkg
14
+ return JSON.stringify(results, null, 2);
15
+ },
16
+ };
5
17
  export const usage = () => commandUsage({
6
18
  command: 'config',
7
- usage: '<command> [flags]',
8
- description: 'Work with vlt configuration',
19
+ usage: '[<command>] [<args>]',
20
+ description: 'Get or manipulate vlt configuration values',
9
21
  subcommands: {
10
22
  get: {
11
- usage: '<key> [<key> ...]',
12
- description: 'Print the named config value',
23
+ usage: '[<key>] [--config=<all | user | project>]',
24
+ description: 'Get a single config value. Use --config to specify which config to read from.',
25
+ },
26
+ pick: {
27
+ usage: '[<key> [<key> ...]] [--config=<all | user | project>]',
28
+ description: 'Get multiple config values or all configuration. Use --config to specify which config to read from.',
13
29
  },
14
30
  list: {
15
- description: 'Print all configuration settings currently in effect',
31
+ usage: '[--config=<all | user | project>]',
32
+ description: 'Print configuration settings. --config=all shows merged config (default), --config=user shows only user config, --config=project shows only project config.',
16
33
  },
17
34
  set: {
18
- usage: '<key>=<value> [<key>=<value> ...] [--config=<user | project>]',
19
- description: `Set config values. By default, these are
35
+ usage: '<key>=<value> [<key>=<value> ...] [--config=<all | user | project>]',
36
+ description: `Set config values. By default (or with --config=all), these are
20
37
  written to the project config file, \`vlt.json\`
21
38
  in the root of the project. To set things for all
22
- projects, run with \`--config=user\``,
39
+ projects, run with \`--config=user\`.`,
23
40
  },
24
- del: {
25
- usage: '<key> [<key> ...] [--config=<user | project>]',
41
+ delete: {
42
+ usage: '<key> [<key> ...] [--config=<all | user | project>]',
26
43
  description: `Delete the named config fields. If no values remain in
27
- the config file, delete the file as well. By default,
28
- operates on the \`vlt.json\` file in the root of the
29
- current project. To delete a config field from the user
30
- config file, specify \`--config=user\`.`,
44
+ the config file, delete the file as well. By default
45
+ (or with --config=all), operates on the \`vlt.json\` file in
46
+ the root of the current project. To delete a config field from
47
+ the user config file, specify \`--config=user\`.`,
31
48
  },
32
49
  edit: {
33
- usage: '[--config=<user | project>]',
34
- description: 'Edit the configuration file',
50
+ usage: '[--config=<all | user | project>]',
51
+ description: 'Edit the configuration file. By default (or with --config=all), edits the project config file.',
35
52
  },
36
- help: {
37
- usage: '[field ...]',
38
- description: `Get information about a config field, or show a list
39
- of known config field names.`,
53
+ location: {
54
+ usage: '[--config=<user | project>]',
55
+ description: 'Show the file path of the configuration file. Defaults to project config.',
40
56
  },
41
57
  },
42
58
  });
43
59
  export const command = async (conf) => {
44
- const sub = conf.positionals[0];
60
+ const [sub] = conf.positionals;
61
+ assert(sub, error('config command requires a subcommand', {
62
+ code: 'EUSAGE',
63
+ validOptions: [
64
+ 'get',
65
+ 'pick',
66
+ 'set',
67
+ 'delete',
68
+ 'list',
69
+ 'edit',
70
+ 'location',
71
+ ],
72
+ }));
45
73
  switch (sub) {
46
74
  case 'set':
47
- return set(conf);
75
+ return configSet(conf);
48
76
  case 'get':
49
- return get(conf);
77
+ return configGet(conf);
78
+ case 'pick':
79
+ return configPick(conf);
50
80
  case 'ls':
51
81
  case 'list':
52
- return list(conf);
82
+ return configList(conf);
53
83
  case 'edit':
54
- return edit(conf);
55
- case 'help':
56
- return help(conf);
84
+ return configEdit(conf);
85
+ case 'location':
86
+ return configLocation(conf);
57
87
  case 'del':
58
- return del(conf);
88
+ case 'delete':
89
+ case 'rm':
90
+ case 'remove':
91
+ case 'unset':
92
+ return configDelete(conf);
59
93
  default: {
60
94
  throw error('Unrecognized config command', {
61
95
  code: 'EUSAGE',
62
96
  found: sub,
63
- validOptions: ['set', 'get', 'list', 'edit', 'help', 'del'],
97
+ validOptions: [
98
+ 'get',
99
+ 'pick',
100
+ 'set',
101
+ 'delete',
102
+ 'list',
103
+ 'edit',
104
+ 'location',
105
+ ],
64
106
  });
65
107
  }
66
108
  }
67
109
  };
68
- const help = (conf) => {
69
- const j = definition.toJSON();
70
- const fields = conf.positionals.slice(1);
71
- if (!fields.length) {
72
- return [
73
- 'Specify one or more options to see information:',
74
- ...Object.keys(j)
75
- .sort((a, b) => a.localeCompare(b, 'en'))
76
- .map(c => ` ${c}`),
77
- ].join('\n');
78
- }
79
- // TODO: some kind of fuzzy search?
80
- const res = [];
81
- for (const f of fields) {
82
- const def = j[f];
83
- if (!def) {
84
- res.push(`unknown config field: ${f}`);
110
+ // Enhanced get function that supports multiple keys (falls back to pick behavior)
111
+ const configGet = async (conf) => {
112
+ const keys = conf.positionals.slice(1);
113
+ const configOption = conf.get('config');
114
+ // If no keys provided, show all config (like pkg get with no args)
115
+ if (keys.length === 0) {
116
+ return configPick(conf);
117
+ }
118
+ // If exactly one key, get the value based on --config option
119
+ if (keys.length === 1) {
120
+ const key = keys[0];
121
+ if (!key) {
122
+ throw error('Key is required', { code: 'EUSAGE' });
123
+ }
124
+ switch (configOption) {
125
+ case 'all': {
126
+ // Default behavior - get from merged/consolidated config (like original get function)
127
+ const result = await get(conf);
128
+ return result;
129
+ }
130
+ case 'user': {
131
+ return getUserConfigValue(key);
132
+ }
133
+ case 'project': {
134
+ return getProjectConfigValue(key);
135
+ }
136
+ default: {
137
+ // Fallback to merged config
138
+ const result = await get(conf);
139
+ return result;
140
+ }
141
+ }
142
+ }
143
+ // Multiple keys: use pick behavior
144
+ return configPick(conf);
145
+ };
146
+ // New pick function for getting multiple config values (like vlt pkg pick)
147
+ const configPick = async (conf) => {
148
+ const keys = conf.positionals.slice(1);
149
+ const configOption = conf.get('config');
150
+ // If no keys provided, return entire config object based on --config option (like vlt pkg pick)
151
+ if (keys.length === 0) {
152
+ switch (configOption) {
153
+ case 'all':
154
+ // For 'all', return the merged config as a serializable object
155
+ return getSerializableConfig(conf);
156
+ case 'user': {
157
+ // Return entire user config object
158
+ const userConfig = getUserConfigObject();
159
+ return userConfig /* c8 ignore next */ ?? {};
160
+ }
161
+ case 'project': {
162
+ // Return entire project config object
163
+ const projectConfig = getProjectConfigObject();
164
+ return projectConfig /* c8 ignore next */ ?? {};
165
+ }
166
+ }
167
+ }
168
+ // Multiple keys: build an object with the requested keys (like vlt pkg pick)
169
+ const result = {};
170
+ for (const key of keys) {
171
+ if (!key) /* c8 ignore next */
172
+ continue;
173
+ switch (configOption) {
174
+ case 'all':
175
+ // Get from merged config (default behavior)
176
+ result[key] = await get(Object.assign(Object.create(Object.getPrototypeOf(conf)), conf, {
177
+ positionals: ['get', key],
178
+ }));
179
+ break;
180
+ case 'user':
181
+ result[key] = getUserConfigValue(key);
182
+ break;
183
+ case 'project':
184
+ result[key] = getProjectConfigValue(key);
185
+ break;
186
+ }
187
+ }
188
+ return result;
189
+ };
190
+ // Enhanced list function that respects --config option
191
+ const configList = (conf) => {
192
+ const configOption = conf.get('config');
193
+ switch (configOption) {
194
+ case 'all':
195
+ // Default behavior - show merged config
196
+ return list(conf);
197
+ case 'user':
198
+ // Show only user config
199
+ return getUserConfigList();
200
+ case 'project':
201
+ // Show only project config
202
+ return getProjectConfigList();
203
+ default:
204
+ // Fallback to merged config
205
+ return list(conf);
206
+ }
207
+ };
208
+ // Convert RecordPairs to string array in key=value format
209
+ const configToStringArray = (config) => {
210
+ const result = [];
211
+ for (const [key, value] of Object.entries(config)) {
212
+ if (value === undefined || value === null) {
213
+ continue;
214
+ }
215
+ if (Array.isArray(value)) {
216
+ // Handle array values (like registries)
217
+ for (const item of value) {
218
+ if (typeof item === 'string') {
219
+ result.push(`${key}=${item}`);
220
+ }
221
+ }
222
+ }
223
+ else if (typeof value === 'object') {
224
+ // Handle object values
225
+ for (const [subKey, subValue] of Object.entries(value)) {
226
+ if (subValue !== undefined && subValue !== null) {
227
+ result.push(`${key}.${subKey}=${String(subValue)}`);
228
+ }
229
+ }
85
230
  }
86
231
  else {
87
- const hint = def.hint ? `=<${def.hint}>` : '';
88
- const type = isRecordField(f) ?
89
- 'Record<string, string>'
90
- : def.type + (def.multiple ? '[]' : '');
91
- res.push(`--${f}${hint}`);
92
- res.push(` type: ${type}`);
93
- if (def.default) {
94
- res.push(` default: ${JSON.stringify(def.default)}`);
232
+ // Handle primitive values
233
+ let stringValue;
234
+ if (typeof value === 'string') {
235
+ stringValue = value;
95
236
  }
96
- if (def.description) {
97
- res.push(def.description);
237
+ else if (typeof value === 'number' ||
238
+ typeof value === 'boolean') {
239
+ stringValue = String(value);
98
240
  }
241
+ else {
242
+ stringValue = '[object]';
243
+ }
244
+ result.push(`${key}=${stringValue}`);
99
245
  }
100
246
  }
101
- return res.join('\n');
247
+ return result.sort();
102
248
  };
103
- const list = (conf) => {
104
- return recordsToPairs(conf.options);
249
+ // Get user config as key=value pairs
250
+ const getUserConfigList = () => {
251
+ try {
252
+ const userConfig = load('config', (x, file) => {
253
+ if (x !== null &&
254
+ typeof x === 'object' &&
255
+ !Array.isArray(x)) {
256
+ return;
257
+ }
258
+ throw new Error(`Invalid config in ${file}`);
259
+ }, 'user');
260
+ if (!userConfig)
261
+ return /* c8 ignore next */ [];
262
+ return configToStringArray(userConfig);
263
+ }
264
+ catch (_err) {
265
+ return [];
266
+ }
105
267
  };
106
- const del = async (conf) => {
107
- const fields = conf.positionals.slice(1);
108
- if (!fields.length) {
109
- throw error('At least one key is required', {
110
- code: 'EUSAGE',
111
- });
268
+ // Get project config as key=value pairs
269
+ const getProjectConfigList = () => {
270
+ try {
271
+ const projectConfig = load('config', (x, file) => {
272
+ if (x !== null &&
273
+ typeof x === 'object' &&
274
+ !Array.isArray(x)) {
275
+ return;
276
+ }
277
+ throw new Error(`Invalid config in ${file}`);
278
+ }, 'project');
279
+ if (!projectConfig)
280
+ return /* c8 ignore next */ [];
281
+ return configToStringArray(projectConfig);
282
+ }
283
+ catch (_err) {
284
+ return [];
112
285
  }
113
- await conf.deleteConfigKeys(conf.get('config'), fields);
114
286
  };
115
- const get = async (conf) => {
116
- const keys = conf.positionals.slice(1);
117
- const k = keys[0];
118
- if (!k || keys.length > 1) {
119
- throw error('Exactly one key is required', {
120
- code: 'EUSAGE',
121
- });
122
- }
123
- return conf.get(k);
124
- };
125
- const edit = async (conf) => {
126
- const [command, ...args] = conf.get('editor').split(' ');
127
- if (!command) {
128
- throw error(`editor is empty`);
129
- }
130
- await conf.editConfigFile(conf.get('config'), file => {
131
- args.push(file);
132
- const res = spawnSync(command, args, {
133
- stdio: 'inherit',
134
- });
135
- if (res.status !== 0) {
136
- throw error(`${command} command failed`, {
137
- ...res,
138
- command,
139
- args,
140
- });
287
+ // Get the entire user config object
288
+ const getUserConfigObject = () => {
289
+ try {
290
+ const userConfig = load('config', (x, file) => {
291
+ if (x !== null &&
292
+ typeof x === 'object' &&
293
+ !Array.isArray(x)) {
294
+ return;
295
+ }
296
+ throw new Error(`Invalid config in ${file}`);
297
+ }, 'user');
298
+ if (!userConfig || typeof userConfig !== 'object')
299
+ /* c8 ignore next */
300
+ return;
301
+ return userConfig;
302
+ }
303
+ catch (_err) {
304
+ return;
305
+ }
306
+ };
307
+ // Get a specific value from user config
308
+ const getUserConfigValue = (key) => {
309
+ const userConfig = getUserConfigObject();
310
+ if (!userConfig)
311
+ return;
312
+ // Use dotProp.get like vlt pkg get does
313
+ return dotProp.get(userConfig, key);
314
+ };
315
+ // Get the entire project config object
316
+ const getProjectConfigObject = () => {
317
+ try {
318
+ const projectConfig = load('config', (x, file) => {
319
+ if (x !== null &&
320
+ typeof x === 'object' &&
321
+ !Array.isArray(x)) {
322
+ return;
323
+ }
324
+ throw new Error(`Invalid config in ${file}`);
325
+ }, 'project');
326
+ if (!projectConfig || typeof projectConfig !== 'object')
327
+ /* c8 ignore next */
328
+ return;
329
+ return projectConfig;
330
+ }
331
+ catch (_err) {
332
+ return;
333
+ }
334
+ };
335
+ // Get a specific value from project config
336
+ const getProjectConfigValue = (key) => {
337
+ const projectConfig = getProjectConfigObject();
338
+ if (!projectConfig)
339
+ return;
340
+ // Use dotProp.get like vlt pkg get does
341
+ return dotProp.get(projectConfig, key);
342
+ };
343
+ // Helper function to get the effective config option for write operations
344
+ const getWriteConfigOption = (conf) => {
345
+ const configOption = conf.get('config');
346
+ if (configOption === 'all') {
347
+ // For write operations, 'all' defaults to 'project'
348
+ return 'project';
349
+ }
350
+ return configOption;
351
+ };
352
+ // Wrapper for set command that handles --config option appropriately
353
+ const configSet = async (conf) => {
354
+ const effectiveConfig = getWriteConfigOption(conf);
355
+ // Temporarily modify the config value for the set operation
356
+ const originalGet = conf.get;
357
+ conf.get = ((key) => {
358
+ if (key === 'config') {
359
+ return effectiveConfig;
360
+ }
361
+ return originalGet.call(conf, key);
362
+ });
363
+ try {
364
+ return await set(conf);
365
+ }
366
+ finally {
367
+ // Restore the original get method
368
+ conf.get = originalGet;
369
+ }
370
+ };
371
+ // Wrapper for delete command that handles --config option appropriately
372
+ const configDelete = async (conf) => {
373
+ const effectiveConfig = getWriteConfigOption(conf);
374
+ // Temporarily modify the config value for the delete operation
375
+ const originalGet = conf.get;
376
+ conf.get = ((key) => {
377
+ if (key === 'config') {
378
+ return effectiveConfig;
141
379
  }
380
+ return originalGet.call(conf, key);
142
381
  });
382
+ try {
383
+ return await del(conf);
384
+ }
385
+ finally {
386
+ // Restore the original get method
387
+ conf.get = originalGet;
388
+ }
143
389
  };
144
- const set = async (conf) => {
145
- const pairs = conf.positionals.slice(1);
146
- if (!pairs.length) {
147
- throw error('At least one key=value pair is required', {
148
- code: 'EUSAGE',
149
- });
390
+ // Wrapper for edit command that handles --config option appropriately
391
+ const configEdit = async (conf) => {
392
+ const effectiveConfig = getWriteConfigOption(conf);
393
+ // Temporarily modify the config value for the edit operation
394
+ const originalGet = conf.get;
395
+ conf.get = ((key) => {
396
+ if (key === 'config') {
397
+ return effectiveConfig;
398
+ }
399
+ return originalGet.call(conf, key);
400
+ });
401
+ try {
402
+ return await edit(conf);
403
+ }
404
+ finally {
405
+ // Restore the original get method
406
+ conf.get = originalGet;
150
407
  }
151
- await conf.addConfigToFile(conf.get('config'), pairsToRecords(conf.jack.parseRaw(pairs.map(kv => `--${kv}`)).values));
408
+ };
409
+ // Get a serializable config object from LoadedConfig (without circular references)
410
+ const getSerializableConfig = (conf) => {
411
+ // Use the list function which calls recordsToPairs to get a clean config object
412
+ return list(conf);
413
+ };
414
+ // Location command that shows config file paths
415
+ const configLocation = (conf) => {
416
+ const configOption = conf.get('config');
417
+ // For location command, default to 'project' when 'all' is specified
418
+ // since there's no single "all" file to show
419
+ const effectiveConfig = configOption === 'all' ? 'project' : configOption;
420
+ // Get the config file path
421
+ const configPath = find(effectiveConfig);
422
+ return configPath;
152
423
  };
153
424
  //# sourceMappingURL=config.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/commands/config.ts"],"names":[],"mappings":"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","sourcesContent":["import { error } from '@vltpkg/error-cause'\nimport { spawnSync } from 'node:child_process'\nimport {\n definition,\n isRecordField,\n pairsToRecords,\n recordsToPairs,\n} from '../config/index.ts'\nimport type {\n ConfigDefinitions,\n LoadedConfig,\n RecordPairs,\n} from '../config/index.ts'\nimport { commandUsage } from '../config/usage.ts'\nimport type { CommandFn, CommandUsage } from '../index.ts'\n\nexport const usage: CommandUsage = () =>\n commandUsage({\n command: 'config',\n usage: '<command> [flags]',\n description: 'Work with vlt configuration',\n\n subcommands: {\n get: {\n usage: '<key> [<key> ...]',\n description: 'Print the named config value',\n },\n\n list: {\n description:\n 'Print all configuration settings currently in effect',\n },\n\n set: {\n usage:\n '<key>=<value> [<key>=<value> ...] [--config=<user | project>]',\n description: `Set config values. By default, these are\n written to the project config file, \\`vlt.json\\`\n in the root of the project. To set things for all\n projects, run with \\`--config=user\\``,\n },\n\n del: {\n usage: '<key> [<key> ...] [--config=<user | project>]',\n description: `Delete the named config fields. If no values remain in\n the config file, delete the file as well. By default,\n operates on the \\`vlt.json\\` file in the root of the\n current project. To delete a config field from the user\n config file, specify \\`--config=user\\`.`,\n },\n\n edit: {\n usage: '[--config=<user | project>]',\n description: 'Edit the configuration file',\n },\n\n help: {\n usage: '[field ...]',\n description: `Get information about a config field, or show a list\n of known config field names.`,\n },\n },\n })\n\nexport const command: CommandFn<\n string | number | boolean | void | string[] | RecordPairs\n> = async conf => {\n const sub = conf.positionals[0]\n switch (sub) {\n case 'set':\n return set(conf)\n\n case 'get':\n return get(conf)\n\n case 'ls':\n case 'list':\n return list(conf)\n\n case 'edit':\n return edit(conf)\n\n case 'help':\n return help(conf)\n\n case 'del':\n return del(conf)\n\n default: {\n throw error('Unrecognized config command', {\n code: 'EUSAGE',\n found: sub,\n validOptions: ['set', 'get', 'list', 'edit', 'help', 'del'],\n })\n }\n }\n}\n\nconst help = (conf: LoadedConfig) => {\n const j = definition.toJSON()\n const fields = conf.positionals.slice(1)\n if (!fields.length) {\n return [\n 'Specify one or more options to see information:',\n ...Object.keys(j)\n .sort((a, b) => a.localeCompare(b, 'en'))\n .map(c => ` ${c}`),\n ].join('\\n')\n }\n\n // TODO: some kind of fuzzy search?\n const res: string[] = []\n for (const f of fields) {\n const def = j[f]\n if (!def) {\n res.push(`unknown config field: ${f}`)\n } else {\n const hint = def.hint ? `=<${def.hint}>` : ''\n const type =\n isRecordField(f) ?\n 'Record<string, string>'\n : def.type + (def.multiple ? '[]' : '')\n\n res.push(`--${f}${hint}`)\n res.push(` type: ${type}`)\n if (def.default) {\n res.push(` default: ${JSON.stringify(def.default)}`)\n }\n if (def.description) {\n res.push(def.description)\n }\n }\n }\n return res.join('\\n')\n}\n\nconst list = (conf: LoadedConfig) => {\n return recordsToPairs(conf.options)\n}\n\nconst del = async (conf: LoadedConfig) => {\n const fields = conf.positionals.slice(1)\n if (!fields.length) {\n throw error('At least one key is required', {\n code: 'EUSAGE',\n })\n }\n await conf.deleteConfigKeys(conf.get('config'), fields)\n}\n\nconst get = async (conf: LoadedConfig) => {\n const keys = conf.positionals.slice(1)\n const k = keys[0]\n if (!k || keys.length > 1) {\n throw error('Exactly one key is required', {\n code: 'EUSAGE',\n })\n }\n return conf.get(k as keyof ConfigDefinitions)\n}\n\nconst edit = async (conf: LoadedConfig) => {\n const [command, ...args] = conf.get('editor').split(' ')\n if (!command) {\n throw error(`editor is empty`)\n }\n await conf.editConfigFile(conf.get('config'), file => {\n args.push(file)\n const res = spawnSync(command, args, {\n stdio: 'inherit',\n })\n if (res.status !== 0) {\n throw error(`${command} command failed`, {\n ...res,\n command,\n args,\n })\n }\n })\n}\n\nconst set = async (conf: LoadedConfig) => {\n const pairs = conf.positionals.slice(1)\n if (!pairs.length) {\n throw error('At least one key=value pair is required', {\n code: 'EUSAGE',\n })\n }\n await conf.addConfigToFile(\n conf.get('config'),\n pairsToRecords(\n conf.jack.parseRaw(pairs.map(kv => `--${kv}`)).values,\n ),\n )\n}\n"]}
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/commands/config.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'node:assert'\nimport * as dotProp from '@vltpkg/dot-prop'\nimport { error } from '@vltpkg/error-cause'\nimport { commandUsage } from '../config/usage.ts'\nimport { get, set, edit, list, del } from '@vltpkg/config'\nimport { load, find } from '@vltpkg/vlt-json'\nimport type { LoadedConfig, RecordPairs } from '../config/index.ts'\nimport type { CommandFn, CommandUsage } from '../index.ts'\nimport type { Views } from '../view.ts'\n\n// Type for the CLI config option (includes 'all' for merged config)\ntype ConfigOption = 'all' | 'user' | 'project'\n\nexport const views: Views = {\n human: results => {\n // Handle string arrays (like list output)\n if (Array.isArray(results) && typeof results[0] === 'string') {\n return results.join('\\n')\n }\n\n // For all other values (primitives, objects, arrays), use JSON formatting like vlt pkg\n return JSON.stringify(results, null, 2)\n },\n} as const satisfies Views\n\nexport const usage: CommandUsage = () =>\n commandUsage({\n command: 'config',\n usage: '[<command>] [<args>]',\n description: 'Get or manipulate vlt configuration values',\n\n subcommands: {\n get: {\n usage: '[<key>] [--config=<all | user | project>]',\n description:\n 'Get a single config value. Use --config to specify which config to read from.',\n },\n\n pick: {\n usage:\n '[<key> [<key> ...]] [--config=<all | user | project>]',\n description:\n 'Get multiple config values or all configuration. Use --config to specify which config to read from.',\n },\n\n list: {\n usage: '[--config=<all | user | project>]',\n description:\n 'Print configuration settings. --config=all shows merged config (default), --config=user shows only user config, --config=project shows only project config.',\n },\n\n set: {\n usage:\n '<key>=<value> [<key>=<value> ...] [--config=<all | user | project>]',\n description: `Set config values. By default (or with --config=all), these are\n written to the project config file, \\`vlt.json\\`\n in the root of the project. To set things for all\n projects, run with \\`--config=user\\`.`,\n },\n\n delete: {\n usage: '<key> [<key> ...] [--config=<all | user | project>]',\n description: `Delete the named config fields. If no values remain in\n the config file, delete the file as well. By default\n (or with --config=all), operates on the \\`vlt.json\\` file in\n the root of the current project. To delete a config field from\n the user config file, specify \\`--config=user\\`.`,\n },\n\n edit: {\n usage: '[--config=<all | user | project>]',\n description:\n 'Edit the configuration file. By default (or with --config=all), edits the project config file.',\n },\n\n location: {\n usage: '[--config=<user | project>]',\n description:\n 'Show the file path of the configuration file. Defaults to project config.',\n },\n },\n })\n\nexport const command: CommandFn = async conf => {\n const [sub] = conf.positionals\n\n assert(\n sub,\n error('config command requires a subcommand', {\n code: 'EUSAGE',\n validOptions: [\n 'get',\n 'pick',\n 'set',\n 'delete',\n 'list',\n 'edit',\n 'location',\n ],\n }),\n )\n\n switch (sub) {\n case 'set':\n return configSet(conf)\n\n case 'get':\n return configGet(conf)\n\n case 'pick':\n return configPick(conf)\n\n case 'ls':\n case 'list':\n return configList(conf)\n\n case 'edit':\n return configEdit(conf)\n\n case 'location':\n return configLocation(conf)\n\n case 'del':\n case 'delete':\n case 'rm':\n case 'remove':\n case 'unset':\n return configDelete(conf)\n\n default: {\n throw error('Unrecognized config command', {\n code: 'EUSAGE',\n found: sub,\n validOptions: [\n 'get',\n 'pick',\n 'set',\n 'delete',\n 'list',\n 'edit',\n 'location',\n ],\n })\n }\n }\n}\n\n// Enhanced get function that supports multiple keys (falls back to pick behavior)\nconst configGet = async (conf: LoadedConfig): Promise<unknown> => {\n const keys = conf.positionals.slice(1)\n const configOption = conf.get('config') as ConfigOption\n\n // If no keys provided, show all config (like pkg get with no args)\n if (keys.length === 0) {\n return configPick(conf)\n }\n\n // If exactly one key, get the value based on --config option\n if (keys.length === 1) {\n const key = keys[0]\n if (!key) {\n throw error('Key is required', { code: 'EUSAGE' })\n }\n\n switch (configOption) {\n case 'all': {\n // Default behavior - get from merged/consolidated config (like original get function)\n const result = await get(conf)\n return result\n }\n case 'user': {\n return getUserConfigValue(key)\n }\n case 'project': {\n return getProjectConfigValue(key)\n }\n default: {\n // Fallback to merged config\n const result = await get(conf)\n return result\n }\n }\n }\n\n // Multiple keys: use pick behavior\n return configPick(conf)\n}\n\n// New pick function for getting multiple config values (like vlt pkg pick)\nconst configPick = async (conf: LoadedConfig) => {\n const keys = conf.positionals.slice(1)\n const configOption = conf.get('config') as ConfigOption\n\n // If no keys provided, return entire config object based on --config option (like vlt pkg pick)\n if (keys.length === 0) {\n switch (configOption) {\n case 'all':\n // For 'all', return the merged config as a serializable object\n return getSerializableConfig(conf)\n\n case 'user': {\n // Return entire user config object\n const userConfig = getUserConfigObject()\n return userConfig /* c8 ignore next */ ?? {}\n }\n\n case 'project': {\n // Return entire project config object\n const projectConfig = getProjectConfigObject()\n return projectConfig /* c8 ignore next */ ?? {}\n }\n }\n }\n\n // Multiple keys: build an object with the requested keys (like vlt pkg pick)\n const result: Record<string, unknown> = {}\n\n for (const key of keys) {\n if (!key) /* c8 ignore next */ continue\n\n switch (configOption) {\n case 'all':\n // Get from merged config (default behavior)\n result[key] = await get(\n Object.assign(\n Object.create(Object.getPrototypeOf(conf) as object),\n conf,\n {\n positionals: ['get', key],\n },\n ) as LoadedConfig,\n )\n break\n\n case 'user':\n result[key] = getUserConfigValue(key)\n break\n\n case 'project':\n result[key] = getProjectConfigValue(key)\n break\n }\n }\n\n return result\n}\n\n// Enhanced list function that respects --config option\nconst configList = (conf: LoadedConfig) => {\n const configOption = conf.get('config') as ConfigOption\n\n switch (configOption) {\n case 'all':\n // Default behavior - show merged config\n return list(conf)\n\n case 'user':\n // Show only user config\n return getUserConfigList()\n\n case 'project':\n // Show only project config\n return getProjectConfigList()\n\n default:\n // Fallback to merged config\n return list(conf)\n }\n}\n\n// Convert RecordPairs to string array in key=value format\nconst configToStringArray = (config: RecordPairs): string[] => {\n const result: string[] = []\n\n for (const [key, value] of Object.entries(config)) {\n if (value === undefined || value === null) {\n continue\n }\n\n if (Array.isArray(value)) {\n // Handle array values (like registries)\n for (const item of value) {\n if (typeof item === 'string') {\n result.push(`${key}=${item}`)\n }\n }\n } else if (typeof value === 'object') {\n // Handle object values\n for (const [subKey, subValue] of Object.entries(value)) {\n if (subValue !== undefined && subValue !== null) {\n result.push(`${key}.${subKey}=${String(subValue)}`)\n }\n }\n } else {\n // Handle primitive values\n let stringValue: string\n if (typeof value === 'string') {\n stringValue = value\n } else if (\n typeof value === 'number' ||\n typeof value === 'boolean'\n ) {\n stringValue = String(value)\n } else {\n stringValue = '[object]'\n }\n result.push(`${key}=${stringValue}`)\n }\n }\n\n return result.sort()\n}\n\n// Get user config as key=value pairs\nconst getUserConfigList = (): string[] => {\n try {\n const userConfig = load(\n 'config',\n (x: unknown, file: string): asserts x is RecordPairs => {\n if (\n x !== null &&\n typeof x === 'object' &&\n !Array.isArray(x)\n ) {\n return\n }\n throw new Error(`Invalid config in ${file}`)\n },\n 'user',\n )\n\n if (!userConfig) return /* c8 ignore next */ []\n\n return configToStringArray(userConfig)\n } catch (_err) {\n return []\n }\n}\n\n// Get project config as key=value pairs\nconst getProjectConfigList = (): string[] => {\n try {\n const projectConfig = load(\n 'config',\n (x: unknown, file: string): asserts x is RecordPairs => {\n if (\n x !== null &&\n typeof x === 'object' &&\n !Array.isArray(x)\n ) {\n return\n }\n throw new Error(`Invalid config in ${file}`)\n },\n 'project',\n )\n\n if (!projectConfig) return /* c8 ignore next */ []\n\n return configToStringArray(projectConfig)\n } catch (_err) {\n return []\n }\n}\n\n// Get the entire user config object\nconst getUserConfigObject = ():\n | Record<string, unknown>\n | undefined => {\n try {\n const userConfig = load(\n 'config',\n (x: unknown, file: string): asserts x is RecordPairs => {\n if (\n x !== null &&\n typeof x === 'object' &&\n !Array.isArray(x)\n ) {\n return\n }\n throw new Error(`Invalid config in ${file}`)\n },\n 'user',\n )\n\n if (!userConfig || typeof userConfig !== 'object')\n /* c8 ignore next */\n return\n\n return userConfig as Record<string, unknown>\n } catch (_err) {\n return\n }\n}\n\n// Get a specific value from user config\nconst getUserConfigValue = (key: string): unknown => {\n const userConfig = getUserConfigObject()\n if (!userConfig) return\n\n // Use dotProp.get like vlt pkg get does\n return dotProp.get(userConfig as Record<PropertyKey, unknown>, key)\n}\n\n// Get the entire project config object\nconst getProjectConfigObject = ():\n | Record<string, unknown>\n | undefined => {\n try {\n const projectConfig = load(\n 'config',\n (x: unknown, file: string): asserts x is RecordPairs => {\n if (\n x !== null &&\n typeof x === 'object' &&\n !Array.isArray(x)\n ) {\n return\n }\n throw new Error(`Invalid config in ${file}`)\n },\n 'project',\n )\n\n if (!projectConfig || typeof projectConfig !== 'object')\n /* c8 ignore next */\n return\n\n return projectConfig as Record<string, unknown>\n } catch (_err) {\n return\n }\n}\n\n// Get a specific value from project config\nconst getProjectConfigValue = (key: string): unknown => {\n const projectConfig = getProjectConfigObject()\n if (!projectConfig) return\n\n // Use dotProp.get like vlt pkg get does\n return dotProp.get(\n projectConfig as Record<PropertyKey, unknown>,\n key,\n )\n}\n\n// Helper function to get the effective config option for write operations\nconst getWriteConfigOption = (\n conf: LoadedConfig,\n): 'user' | 'project' => {\n const configOption = conf.get('config') as ConfigOption\n\n if (configOption === 'all') {\n // For write operations, 'all' defaults to 'project'\n return 'project'\n }\n\n return configOption\n}\n\n// Wrapper for set command that handles --config option appropriately\nconst configSet = async (conf: LoadedConfig) => {\n const effectiveConfig = getWriteConfigOption(conf)\n\n // Temporarily modify the config value for the set operation\n const originalGet = conf.get\n conf.get = ((key: string) => {\n if (key === 'config') {\n return effectiveConfig\n }\n return originalGet.call(conf, key as any)\n }) as typeof originalGet\n\n try {\n return await set(conf)\n } finally {\n // Restore the original get method\n conf.get = originalGet\n }\n}\n\n// Wrapper for delete command that handles --config option appropriately\nconst configDelete = async (conf: LoadedConfig) => {\n const effectiveConfig = getWriteConfigOption(conf)\n\n // Temporarily modify the config value for the delete operation\n const originalGet = conf.get\n conf.get = ((key: string) => {\n if (key === 'config') {\n return effectiveConfig\n }\n return originalGet.call(conf, key as any)\n }) as typeof originalGet\n\n try {\n return await del(conf)\n } finally {\n // Restore the original get method\n conf.get = originalGet\n }\n}\n\n// Wrapper for edit command that handles --config option appropriately\nconst configEdit = async (conf: LoadedConfig) => {\n const effectiveConfig = getWriteConfigOption(conf)\n\n // Temporarily modify the config value for the edit operation\n const originalGet = conf.get\n conf.get = ((key: string) => {\n if (key === 'config') {\n return effectiveConfig\n }\n return originalGet.call(conf, key as any)\n }) as typeof originalGet\n\n try {\n return await edit(conf)\n } finally {\n // Restore the original get method\n conf.get = originalGet\n }\n}\n\n// Get a serializable config object from LoadedConfig (without circular references)\nconst getSerializableConfig = (\n conf: LoadedConfig,\n): Record<string, unknown> => {\n // Use the list function which calls recordsToPairs to get a clean config object\n return list(conf) as Record<string, unknown>\n}\n\n// Location command that shows config file paths\nconst configLocation = (conf: LoadedConfig): string => {\n const configOption = conf.get('config') as ConfigOption\n\n // For location command, default to 'project' when 'all' is specified\n // since there's no single \"all\" file to show\n const effectiveConfig =\n configOption === 'all' ? 'project' : configOption\n\n // Get the config file path\n const configPath = find(effectiveConfig)\n\n return configPath\n}\n"]}
@@ -0,0 +1,18 @@
1
+ import type { CommandFn, CommandUsage } from '../index.ts';
2
+ export declare const usage: CommandUsage;
3
+ type CommandResultSingle = {
4
+ url: string;
5
+ name: string;
6
+ };
7
+ type CommandResultMultiple = {
8
+ url: string;
9
+ name: string;
10
+ }[];
11
+ export type CommandResult = CommandResultSingle | CommandResultMultiple;
12
+ export declare const views: {
13
+ readonly human: (r: CommandResult) => string;
14
+ readonly json: (r: CommandResult) => CommandResult;
15
+ };
16
+ export declare const command: CommandFn<CommandResult>;
17
+ export {};
18
+ //# sourceMappingURL=docs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"docs.d.ts","sourceRoot":"","sources":["../../../src/commands/docs.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAQ1D,eAAO,MAAM,KAAK,EAAE,YA2BhB,CAAA;AAEJ,KAAK,mBAAmB,GAAG;IACzB,GAAG,EAAE,MAAM,CAAA;IACX,IAAI,EAAE,MAAM,CAAA;CACb,CAAA;AAED,KAAK,qBAAqB,GAAG;IAC3B,GAAG,EAAE,MAAM,CAAA;IACX,IAAI,EAAE,MAAM,CAAA;CACb,EAAE,CAAA;AAEH,MAAM,MAAM,aAAa,GACrB,mBAAmB,GACnB,qBAAqB,CAAA;AAEzB,eAAO,MAAM,KAAK;;;CAUuB,CAAA;AA0CzC,eAAO,MAAM,OAAO,EAAE,SAAS,CAAC,aAAa,CA4F5C,CAAA"}