@socketsecurity/cli 0.14.3 → 0.14.4
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.
- package/dist/chalk-markdown.d.ts +23 -0
- package/dist/chalk-markdown.js +224 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +4701 -0
- package/dist/errors.d.ts +7 -0
- package/dist/link.d.ts +2 -0
- package/dist/link.js +45 -0
- package/dist/npm-cli.d.ts +2 -0
- package/dist/npm-cli.js +84 -0
- package/dist/npm-injection.d.ts +1 -0
- package/dist/npm-injection.js +1249 -0
- package/dist/npx-cli.d.ts +2 -0
- package/dist/npx-cli.js +61 -0
- package/dist/optimize.d.ts +3 -0
- package/dist/optimize.d.ts.map +1 -0
- package/dist/optimize.js +3 -0
- package/dist/path-resolve.d.ts +11 -0
- package/dist/path-resolve.js +136 -0
- package/dist/sdk.d.ts +13 -0
- package/dist/sdk.js +270 -0
- package/dist/settings.d.ts +9 -0
- package/dist/vendor.d.ts +0 -0
- package/dist/vendor.js +16250 -0
- package/package.json +1 -1
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
declare const logSymbols: {
|
|
2
|
+
__proto__: null;
|
|
3
|
+
info: string;
|
|
4
|
+
success: string;
|
|
5
|
+
warning: string;
|
|
6
|
+
error: string;
|
|
7
|
+
};
|
|
8
|
+
declare class ChalkOrMarkdown {
|
|
9
|
+
useMarkdown: boolean;
|
|
10
|
+
constructor(useMarkdown: boolean);
|
|
11
|
+
header(text: string, level?: number): string;
|
|
12
|
+
bold(text: string): string;
|
|
13
|
+
italic(text: string): string;
|
|
14
|
+
hyperlink(text: string, url: string | undefined, { fallback, fallbackToUrl }?: {
|
|
15
|
+
fallback?: boolean;
|
|
16
|
+
fallbackToUrl?: boolean;
|
|
17
|
+
}): string;
|
|
18
|
+
list(items: string[]): string;
|
|
19
|
+
get logSymbols(): typeof logSymbols;
|
|
20
|
+
indent(text: string, level?: number): string;
|
|
21
|
+
json(value: unknown): string;
|
|
22
|
+
}
|
|
23
|
+
export { logSymbols, ChalkOrMarkdown };
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var vendor = require('./vendor.js');
|
|
4
|
+
var require$$1$1 = require('node:fs/promises');
|
|
5
|
+
var require$$1 = require('node:path');
|
|
6
|
+
var require$$1$2 = require('@inquirer/prompts');
|
|
7
|
+
var require$$4 = require('@socketsecurity/sdk');
|
|
8
|
+
var require$$5 = require('hpagent');
|
|
9
|
+
var require$$0$1 = require('node:fs');
|
|
10
|
+
var require$$0 = require('node:os');
|
|
11
|
+
|
|
12
|
+
var errors = {};
|
|
13
|
+
|
|
14
|
+
Object.defineProperty(errors, "__esModule", {
|
|
15
|
+
value: true
|
|
16
|
+
});
|
|
17
|
+
errors.InputError = errors.AuthError = void 0;
|
|
18
|
+
class AuthError extends Error {}
|
|
19
|
+
errors.AuthError = AuthError;
|
|
20
|
+
class InputError extends Error {
|
|
21
|
+
constructor(message, body) {
|
|
22
|
+
super(message);
|
|
23
|
+
this.body = body;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
errors.InputError = InputError;
|
|
27
|
+
|
|
28
|
+
var sdk = {};
|
|
29
|
+
|
|
30
|
+
var settings$1 = {};
|
|
31
|
+
|
|
32
|
+
var _interopRequireDefault$2 = vendor.interopRequireDefault.default;
|
|
33
|
+
var _interopRequireWildcard = vendor.interopRequireWildcard.default;
|
|
34
|
+
Object.defineProperty(settings$1, "__esModule", {
|
|
35
|
+
value: true
|
|
36
|
+
});
|
|
37
|
+
settings$1.getSetting = getSetting;
|
|
38
|
+
settings$1.updateSetting = updateSetting;
|
|
39
|
+
var _nodeFs = require$$0$1;
|
|
40
|
+
var os = _interopRequireWildcard(require$$0, true);
|
|
41
|
+
var path = _interopRequireWildcard(require$$1, true);
|
|
42
|
+
var _ora = _interopRequireDefault$2(vendor.ora);
|
|
43
|
+
let dataHome = process.platform === 'win32' ? process.env['LOCALAPPDATA'] : process.env['XDG_DATA_HOME'];
|
|
44
|
+
if (!dataHome) {
|
|
45
|
+
if (process.platform === 'win32') throw new Error('missing %LOCALAPPDATA%');
|
|
46
|
+
const home = os.homedir();
|
|
47
|
+
dataHome = path.join(home, ...(process.platform === 'darwin' ? ['Library', 'Application Support'] : ['.local', 'share']));
|
|
48
|
+
}
|
|
49
|
+
const settingsPath = path.join(dataHome, 'socket', 'settings');
|
|
50
|
+
let settings = {};
|
|
51
|
+
if ((0, _nodeFs.existsSync)(settingsPath)) {
|
|
52
|
+
const raw = (0, _nodeFs.readFileSync)(settingsPath, 'utf-8');
|
|
53
|
+
try {
|
|
54
|
+
settings = JSON.parse(Buffer.from(raw, 'base64').toString());
|
|
55
|
+
} catch {
|
|
56
|
+
(0, _ora.default)(`Failed to parse settings at ${settingsPath}`).warn();
|
|
57
|
+
}
|
|
58
|
+
} else {
|
|
59
|
+
(0, _nodeFs.mkdirSync)(path.dirname(settingsPath), {
|
|
60
|
+
recursive: true
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
function getSetting(key) {
|
|
64
|
+
return settings[key];
|
|
65
|
+
}
|
|
66
|
+
let pendingSave = false;
|
|
67
|
+
function updateSetting(key, value) {
|
|
68
|
+
settings[key] = value;
|
|
69
|
+
if (!pendingSave) {
|
|
70
|
+
pendingSave = true;
|
|
71
|
+
process.nextTick(() => {
|
|
72
|
+
pendingSave = false;
|
|
73
|
+
(0, _nodeFs.writeFileSync)(settingsPath, Buffer.from(JSON.stringify(settings)).toString('base64'));
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
var _interopRequireDefault$1 = vendor.interopRequireDefault.default;
|
|
79
|
+
Object.defineProperty(sdk, "__esModule", {
|
|
80
|
+
value: true
|
|
81
|
+
});
|
|
82
|
+
sdk.FREE_API_KEY = void 0;
|
|
83
|
+
sdk.getDefaultKey = getDefaultKey;
|
|
84
|
+
sdk.setupSdk = setupSdk;
|
|
85
|
+
var _promises = require$$1$1;
|
|
86
|
+
var _nodePath = require$$1;
|
|
87
|
+
var _prompts = require$$1$2;
|
|
88
|
+
var _sdk = require$$4;
|
|
89
|
+
var _hpagent = require$$5;
|
|
90
|
+
var _isInteractive = _interopRequireDefault$1(vendor.isInteractive);
|
|
91
|
+
var _errors = errors;
|
|
92
|
+
var _settings = settings$1;
|
|
93
|
+
const distPath = __dirname;
|
|
94
|
+
const rootPath = _nodePath.resolve(distPath, '..');
|
|
95
|
+
sdk.FREE_API_KEY = 'sktsec_t_--RAN5U4ivauy4w37-6aoKyYPDt5ZbaT5JBVMqiwKo_api';
|
|
96
|
+
|
|
97
|
+
// This API key should be stored globally for the duration of the CLI execution
|
|
98
|
+
let defaultKey;
|
|
99
|
+
function getDefaultKey() {
|
|
100
|
+
defaultKey = process.env['SOCKET_SECURITY_API_KEY'] || (0, _settings.getSetting)('apiKey') || defaultKey;
|
|
101
|
+
return defaultKey;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
// The API server that should be used for operations
|
|
105
|
+
let defaultAPIBaseUrl;
|
|
106
|
+
function getDefaultAPIBaseUrl() {
|
|
107
|
+
defaultAPIBaseUrl = process.env['SOCKET_SECURITY_API_BASE_URL'] || (0, _settings.getSetting)('apiBaseUrl') || undefined;
|
|
108
|
+
return defaultAPIBaseUrl;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
// The API server that should be used for operations
|
|
112
|
+
let defaultApiProxy;
|
|
113
|
+
function getDefaultHTTPProxy() {
|
|
114
|
+
defaultApiProxy = process.env['SOCKET_SECURITY_API_PROXY'] || (0, _settings.getSetting)('apiProxy') || undefined;
|
|
115
|
+
return defaultApiProxy;
|
|
116
|
+
}
|
|
117
|
+
async function setupSdk(apiKey = getDefaultKey(), apiBaseUrl = getDefaultAPIBaseUrl(), proxy = getDefaultHTTPProxy()) {
|
|
118
|
+
if (typeof apiKey !== 'string' && (0, _isInteractive.default)()) {
|
|
119
|
+
apiKey = await (0, _prompts.password)({
|
|
120
|
+
message: 'Enter your Socket.dev API key (not saved, use socket login to persist)'
|
|
121
|
+
});
|
|
122
|
+
defaultKey = apiKey;
|
|
123
|
+
}
|
|
124
|
+
if (!apiKey) {
|
|
125
|
+
throw new _errors.AuthError('You need to provide an API key');
|
|
126
|
+
}
|
|
127
|
+
let agent;
|
|
128
|
+
if (proxy) {
|
|
129
|
+
agent = {
|
|
130
|
+
http: new _hpagent.HttpProxyAgent({
|
|
131
|
+
proxy
|
|
132
|
+
}),
|
|
133
|
+
https: new _hpagent.HttpsProxyAgent({
|
|
134
|
+
proxy
|
|
135
|
+
})
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
const packageJsonPath = _nodePath.join(rootPath, 'package.json');
|
|
139
|
+
const packageJson = await _promises.readFile(packageJsonPath, 'utf8');
|
|
140
|
+
const sdkOptions = {
|
|
141
|
+
agent,
|
|
142
|
+
baseUrl: apiBaseUrl,
|
|
143
|
+
userAgent: (0, _sdk.createUserAgentFromPkgJson)(JSON.parse(packageJson))
|
|
144
|
+
};
|
|
145
|
+
return new _sdk.SocketSdk(apiKey || '', sdkOptions);
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
var chalkMarkdown = {};
|
|
149
|
+
|
|
150
|
+
var _interopRequireDefault = vendor.interopRequireDefault.default;
|
|
151
|
+
Object.defineProperty(chalkMarkdown, "__esModule", {
|
|
152
|
+
value: true
|
|
153
|
+
});
|
|
154
|
+
chalkMarkdown.logSymbols = chalkMarkdown.ChalkOrMarkdown = void 0;
|
|
155
|
+
var _chalk = _interopRequireDefault(vendor.source);
|
|
156
|
+
var _isUnicodeSupported = _interopRequireDefault(vendor.isUnicodeSupported);
|
|
157
|
+
var _terminalLink = _interopRequireDefault(vendor.terminalLink);
|
|
158
|
+
// From the 'log-symbols' module
|
|
159
|
+
const unicodeLogSymbols = {
|
|
160
|
+
info: _chalk.default.blue('ℹ'),
|
|
161
|
+
success: _chalk.default.green('✔'),
|
|
162
|
+
warning: _chalk.default.yellow('⚠'),
|
|
163
|
+
error: _chalk.default.red('✖')
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
// From the 'log-symbols' module
|
|
167
|
+
const fallbackLogSymbols = {
|
|
168
|
+
info: _chalk.default.blue('i'),
|
|
169
|
+
success: _chalk.default.green('√'),
|
|
170
|
+
warning: _chalk.default.yellow('‼'),
|
|
171
|
+
error: _chalk.default.red('×')
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
// From the 'log-symbols' module
|
|
175
|
+
const logSymbols = chalkMarkdown.logSymbols = (0, _isUnicodeSupported.default)() ? unicodeLogSymbols : fallbackLogSymbols;
|
|
176
|
+
const markdownLogSymbols = {
|
|
177
|
+
info: ':information_source:',
|
|
178
|
+
error: ':stop_sign:',
|
|
179
|
+
success: ':white_check_mark:',
|
|
180
|
+
warning: ':warning:'
|
|
181
|
+
};
|
|
182
|
+
class ChalkOrMarkdown {
|
|
183
|
+
constructor(useMarkdown) {
|
|
184
|
+
this.useMarkdown = !!useMarkdown;
|
|
185
|
+
}
|
|
186
|
+
header(text, level = 1) {
|
|
187
|
+
return this.useMarkdown ? `\n${''.padStart(level, '#')} ${text}\n` : _chalk.default.underline(`\n${level === 1 ? _chalk.default.bold(text) : text}\n`);
|
|
188
|
+
}
|
|
189
|
+
bold(text) {
|
|
190
|
+
return this.useMarkdown ? `**${text}**` : _chalk.default.bold(`${text}`);
|
|
191
|
+
}
|
|
192
|
+
italic(text) {
|
|
193
|
+
return this.useMarkdown ? `_${text}_` : _chalk.default.italic(`${text}`);
|
|
194
|
+
}
|
|
195
|
+
hyperlink(text, url, {
|
|
196
|
+
fallback = true,
|
|
197
|
+
fallbackToUrl
|
|
198
|
+
} = {}) {
|
|
199
|
+
if (!url) return text;
|
|
200
|
+
return this.useMarkdown ? `[${text}](${url})` : (0, _terminalLink.default)(text, url, {
|
|
201
|
+
fallback: fallbackToUrl ? (_text, url) => url : fallback
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
list(items) {
|
|
205
|
+
const indentedContent = items.map(item => this.indent(item).trimStart());
|
|
206
|
+
return this.useMarkdown ? '* ' + indentedContent.join('\n* ') + '\n' : indentedContent.join('\n') + '\n';
|
|
207
|
+
}
|
|
208
|
+
get logSymbols() {
|
|
209
|
+
return this.useMarkdown ? markdownLogSymbols : logSymbols;
|
|
210
|
+
}
|
|
211
|
+
indent(text, level = 1) {
|
|
212
|
+
const indent = ''.padStart(level * 2, ' ');
|
|
213
|
+
return indent + text.split('\n').join('\n' + indent);
|
|
214
|
+
}
|
|
215
|
+
json(value) {
|
|
216
|
+
return this.useMarkdown ? '```json\n' + JSON.stringify(value) + '\n```' : JSON.stringify(value);
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
chalkMarkdown.ChalkOrMarkdown = ChalkOrMarkdown;
|
|
220
|
+
|
|
221
|
+
exports.chalkMarkdown = chalkMarkdown;
|
|
222
|
+
exports.errors = errors;
|
|
223
|
+
exports.sdk = sdk;
|
|
224
|
+
exports.settings = settings$1;
|
package/dist/cli.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts","../src/utils/formatting.ts","../src/utils/sorts.ts","../src/utils/meow-with-subcommands.ts","../src/commands/cdxgen.ts","../src/flags.ts","../src/utils/api-helpers.ts","../src/utils/objects.ts","../src/utils/format-issues.ts","../src/commands/info.ts","../src/commands/login.ts","../src/commands/logout.ts","../src/commands/npm.ts","../src/commands/npx.ts","../src/utils/fs.ts","../src/utils/json.ts","../src/utils/strings.ts","../src/utils/package-manager-detector.ts","../src/utils/regexps.ts","../src/commands/optimize.ts","../src/commands/organization.ts","../src/commands/raw-npm.ts","../src/commands/raw-npx.ts","../src/commands/report/view.ts","../src/commands/report/create.ts","../src/commands/report/index.ts","../src/commands/wrapper.ts","../src/commands/scan/create.ts","../src/commands/scan/delete.ts","../src/commands/scan/list.ts","../src/commands/scan/metadata.ts","../src/commands/scan/stream.ts","../src/commands/scan/index.ts","../src/commands/audit-log.ts","../src/commands/repos/create.ts","../src/commands/repos/delete.ts","../src/commands/repos/list.ts","../src/commands/repos/update.ts","../src/commands/repos/view.ts","../src/commands/repos/index.ts","../src/commands/dependencies.ts","../src/commands/analytics.ts","../src/commands/diff-scan/get.ts","../src/commands/diff-scan/index.ts","../src/commands/threat-feed.ts","../src/commands/index.ts"],"names":[],"mappings":""}
|