socket 0.14.21 → 0.14.23

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/link.js CHANGED
@@ -2,7 +2,7 @@
2
2
 
3
3
  var require$$0 = require('node:fs');
4
4
  var require$$1 = require('node:path');
5
- var require$$6 = require('which');
5
+ var require$$8 = require('which');
6
6
 
7
7
  var link = {};
8
8
 
@@ -12,7 +12,7 @@ Object.defineProperty(link, "__esModule", {
12
12
  link.installLinks = installLinks;
13
13
  var _nodeFs = require$$0;
14
14
  var _nodePath = require$$1;
15
- var _which = require$$6;
15
+ var _which = require$$8;
16
16
  function installLinks(realDirname, binName) {
17
17
  const realShadowBinDir = realDirname;
18
18
  // find package manager being shadowed by this process
@@ -2,19 +2,19 @@
2
2
 
3
3
  var vendor = require('./vendor.js');
4
4
  var require$$0 = require('node:fs');
5
- var require$$1 = require('node:path');
5
+ var require$$1$1 = require('node:path');
6
6
  var link = require('./link.js');
7
- var require$$2$1 = require('node:events');
7
+ var require$$2 = require('node:events');
8
8
  var require$$4 = require('node:https');
9
9
  var require$$3 = require('node:readline');
10
10
  var require$$5 = require('node:stream');
11
11
  var require$$8 = require('node:timers/promises');
12
12
  var require$$3$1 = require('@socketsecurity/config');
13
13
  var require$$7 = require('npm-package-arg');
14
- var require$$3$2 = require('semver');
14
+ var require$$14 = require('semver');
15
15
  var sdk = require('./sdk.js');
16
- var require$$1$1 = require('node:net');
17
- var require$$2 = require('node:os');
16
+ var require$$1$2 = require('node:net');
17
+ var require$$1 = require('node:os');
18
18
  var require$$6 = require('../package.json');
19
19
  var pathResolve = require('./path-resolve.js');
20
20
 
@@ -31,9 +31,9 @@ Object.defineProperty(ttyServer$1, "__esModule", {
31
31
  });
32
32
  ttyServer$1.createTTYServer = createTTYServer;
33
33
  var _nodeFs$2 = require$$0;
34
- var _nodeNet = require$$1$1;
35
- var _nodeOs = require$$2;
36
- var _nodePath$2 = require$$1;
34
+ var _nodeNet = require$$1$2;
35
+ var _nodeOs = require$$1;
36
+ var _nodePath$2 = require$$1$1;
37
37
  var _nodeReadline$1 = require$$3;
38
38
  var _nodeStream$1 = require$$5;
39
39
  var _package = require$$6;
@@ -312,7 +312,6 @@ function issueRuleValueDoesNotDefer(issueRule) {
312
312
 
313
313
  /**
314
314
  * Handles booleans for backwards compatibility
315
-
316
315
  */
317
316
  function uxForDefinedNonDeferValue(issueRuleValue) {
318
317
  if (typeof issueRuleValue === 'boolean') {
@@ -383,10 +382,10 @@ Object.defineProperty(arborist, "__esModule", {
383
382
  });
384
383
  arborist.SafeArborist = void 0;
385
384
  arborist.installSafeArborist = installSafeArborist;
386
- var _nodeEvents = require$$2$1;
385
+ var _nodeEvents = require$$2;
387
386
  var _nodeFs$1 = require$$0;
388
387
  var _nodeHttps = require$$4;
389
- var _nodePath$1 = require$$1;
388
+ var _nodePath$1 = require$$1$1;
390
389
  var _nodeReadline = require$$3;
391
390
  var _nodeStream = require$$5;
392
391
  var _promises = require$$8;
@@ -395,13 +394,13 @@ var _chalk = _interopRequireDefault(vendor.source);
395
394
  var _isInteractive = _interopRequireDefault(vendor.isInteractive);
396
395
  var _ora = _interopRequireWildcard(vendor.ora);
397
396
  var _npmPackageArg = require$$7;
398
- var _semver = require$$3$2;
397
+ var _semver = require$$14;
399
398
  var _constants = sdk.constants;
400
399
  var _ttyServer = ttyServer$1;
401
400
  var _chalkMarkdown = sdk.chalkMarkdown;
402
401
  var _issueRules = issueRules;
403
402
  var _misc = sdk.misc;
404
- var _objects = sdk.objects;
403
+ var _objects = vendor.objects;
405
404
  var _pathResolve = pathResolve.pathResolve;
406
405
  var _sdk = sdk.sdk;
407
406
  var _settings = sdk.settings;
@@ -519,6 +518,12 @@ async function* batchScan(pkgIds) {
519
518
  yield JSON.parse(line);
520
519
  }
521
520
  }
521
+
522
+ // Patch adding doOverrideSetsConflict is based on
523
+ // https://github.com/npm/cli/pull/7025.
524
+ function doOverrideSetsConflict(first, second) {
525
+ return findSpecificOverrideSet(first, second) === undefined;
526
+ }
522
527
  function findSocketYmlSync() {
523
528
  let prevDir = null;
524
529
  let dir = process.cwd();
@@ -805,7 +810,7 @@ class SafeEdge extends Edge {
805
810
  }
806
811
  // Patch adding "else if" condition is based on
807
812
  // https://github.com/npm/cli/pull/7025.
808
- else if (this.overrides && this.#safeTo.edgesOut.size && !findSpecificOverrideSet(this.overrides, this.#safeTo.overrides)) {
813
+ else if (this.overrides && this.#safeTo.edgesOut.size && doOverrideSetsConflict(this.overrides, this.#safeTo.overrides)) {
809
814
  // Any inconsistency between the edge's override set and the target's
810
815
  // override set is potentially problematic. But we only say the edge is
811
816
  // in error if the override sets are plainly conflicting. Note that if
@@ -1015,7 +1020,7 @@ class SafeNode extends Node {
1015
1020
  return false;
1016
1021
  }
1017
1022
  // It's a top level pkg, or a dep of one.
1018
- if (!this.resolveParent || !this.resolveParent.resolveParent) {
1023
+ if (!this.resolveParent?.resolveParent) {
1019
1024
  return false;
1020
1025
  }
1021
1026
  // No one wants it, remove it.
@@ -1232,7 +1237,7 @@ class SafeNode extends Node {
1232
1237
  }
1233
1238
  // This is an error condition. We can only get here if the new override set
1234
1239
  // is in conflict with the existing.
1235
- log.silly(`Conflicting override requirements for node ${this.name}`, this);
1240
+ log.silly('Conflicting override sets', this.name);
1236
1241
  return false;
1237
1242
  }
1238
1243
 
@@ -1488,7 +1493,7 @@ void (async () => {
1488
1493
  const socketSdk = await (0, _sdk.setupSdk)(pubToken);
1489
1494
  const orgResult = await socketSdk.getOrganizations();
1490
1495
  if (!orgResult.success) {
1491
- throw new Error('Failed to fetch Socket organization info: ' + orgResult.error.message);
1496
+ throw new Error(`Failed to fetch Socket organization info: ${orgResult.error.message}`);
1492
1497
  }
1493
1498
  const orgs = [];
1494
1499
  for (const org of Object.values(orgResult.data.organizations)) {
@@ -1500,7 +1505,7 @@ void (async () => {
1500
1505
  organization: org.id
1501
1506
  })));
1502
1507
  if (!result.success) {
1503
- throw new Error('Failed to fetch API key settings: ' + result.error.message);
1508
+ throw new Error(`Failed to fetch API key settings: ${result.error.message}`);
1504
1509
  }
1505
1510
  return {
1506
1511
  orgs,
@@ -1541,10 +1546,14 @@ void (async () => {
1541
1546
  if (socketYml) {
1542
1547
  settings.entries.push({
1543
1548
  start: socketYml.path,
1544
- // @ts-ignore
1545
1549
  settings: {
1546
1550
  [socketYml.path]: {
1547
1551
  deferTo: null,
1552
+ // TODO: TypeScript complains about the type not matching. We should
1553
+ // figure out why are providing
1554
+ // issueRules: { [issueName: string]: boolean }
1555
+ // but expecting
1556
+ // issueRules: { [issueName: string]: { action: 'defer' | 'error' | 'ignore' | 'monitor' | 'warn' } }
1548
1557
  issueRules: socketYml.parsed.issueRules
1549
1558
  }
1550
1559
  }
@@ -1554,7 +1563,7 @@ void (async () => {
1554
1563
  })();
1555
1564
 
1556
1565
  var _nodeFs = require$$0;
1557
- var _nodePath = require$$1;
1566
+ var _nodePath = require$$1$1;
1558
1567
  var _link = link.link;
1559
1568
  var _arborist = arborist;
1560
1569
  const distPath = __dirname;
@@ -4,7 +4,7 @@ var require$$1$1 = require('node:fs/promises');
4
4
  var require$$1 = require('node:path');
5
5
  var require$$2 = require('ignore');
6
6
  var require$$3 = require('micromatch');
7
- var require$$11 = require('tinyglobby');
7
+ var require$$15 = require('tinyglobby');
8
8
 
9
9
  var pathResolve = {};
10
10
 
@@ -51,7 +51,7 @@ var _promises = require$$1$1;
51
51
  var _nodePath = require$$1;
52
52
  var _ignore = require$$2;
53
53
  var _micromatch = require$$3;
54
- var _tinyglobby = require$$11;
54
+ var _tinyglobby = require$$15;
55
55
  var _ignoreByDefault = ignoreByDefault;
56
56
  async function filterGlobResultToSupportedFiles(entries, supportedFiles) {
57
57
  const patterns = ['golang', 'npm', 'pypi'].reduce((r, n) => {
package/dist/sdk.d.ts CHANGED
@@ -1,12 +1,5 @@
1
1
  /// <reference types="node" />
2
2
  import { SocketSdk } from '@socketsecurity/sdk';
3
- declare function hasOwn(obj: any, propKey: PropertyKey): boolean;
4
- declare function isObject(value: any): value is object;
5
- declare function isObjectObject(value: any): value is {
6
- [key: string]: any;
7
- };
8
- declare function objectSome(obj: Record<string, any>): boolean;
9
- declare function pick<T extends Record<string, any>, K extends keyof T>(input: T, keys: K[] | ReadonlyArray<K>): Pick<T, K>;
10
3
  declare function createDebugLogger(printDebugLogs?: boolean): typeof console.error;
11
4
  declare function isErrnoException(value: unknown): value is NodeJS.ErrnoException;
12
5
  declare function stringJoinWithSeparateFinalSeparator(list: (string | undefined)[], separator?: string): string;
@@ -14,9 +7,7 @@ declare const API_V0_URL = "https://api.socket.dev/v0";
14
7
  declare const ENV: Readonly<{
15
8
  UPDATE_SOCKET_OVERRIDES_IN_PACKAGE_LOCK_FILE: boolean;
16
9
  }>;
17
- declare const packumentCache: Map<any, any>;
18
- declare const pacoteCachePath: any;
19
10
  declare const FREE_API_KEY = "sktsec_t_--RAN5U4ivauy4w37-6aoKyYPDt5ZbaT5JBVMqiwKo_api";
20
11
  declare function getDefaultKey(): string | undefined;
21
12
  declare function setupSdk(apiKey?: string | undefined, apiBaseUrl?: string | undefined, proxy?: string | undefined): Promise<SocketSdk>;
22
- export { hasOwn, isObject, isObjectObject, objectSome, pick, createDebugLogger, isErrnoException, stringJoinWithSeparateFinalSeparator, API_V0_URL, ENV, packumentCache, pacoteCachePath, FREE_API_KEY, getDefaultKey, setupSdk };
13
+ export { createDebugLogger, isErrnoException, stringJoinWithSeparateFinalSeparator, API_V0_URL, ENV, FREE_API_KEY, getDefaultKey, setupSdk };
package/dist/sdk.js CHANGED
@@ -1,14 +1,13 @@
1
1
  'use strict';
2
2
 
3
- var require$$0 = require('pacote');
4
3
  var vendor = require('./vendor.js');
5
- var require$$1$1 = require('node:fs/promises');
6
- var require$$1 = require('node:path');
7
- var require$$1$2 = require('@inquirer/prompts');
4
+ var require$$1$2 = require('node:fs/promises');
5
+ var require$$1$1 = require('node:path');
6
+ var require$$1$3 = require('@inquirer/prompts');
8
7
  var require$$4 = require('@socketsecurity/sdk');
9
8
  var require$$5 = require('hpagent');
10
- var require$$0$1 = require('node:fs');
11
- var require$$2 = require('node:os');
9
+ var require$$0 = require('node:fs');
10
+ var require$$1 = require('node:os');
12
11
 
13
12
  var errors = {};
14
13
 
@@ -31,21 +30,13 @@ var constants = {};
31
30
  Object.defineProperty(constants, "__esModule", {
32
31
  value: true
33
32
  });
34
- constants.pacoteCachePath = constants.packumentCache = constants.ENV = constants.API_V0_URL = void 0;
35
- var _pacote = require$$0;
36
- function envAsBoolean(value) {
37
- return typeof value === 'string' && (value === '1' || value.toLowerCase() === 'true');
38
- }
33
+ constants.ENV = constants.API_V0_URL = void 0;
34
+ var _env = vendor.env;
39
35
  constants.API_V0_URL = 'https://api.socket.dev/v0';
40
36
  constants.ENV = Object.freeze({
41
37
  // Flag set by the optimize command to bypass the packagesHaveRiskyIssues check.
42
- UPDATE_SOCKET_OVERRIDES_IN_PACKAGE_LOCK_FILE: envAsBoolean(process.env['UPDATE_SOCKET_OVERRIDES_IN_PACKAGE_LOCK_FILE'])
38
+ UPDATE_SOCKET_OVERRIDES_IN_PACKAGE_LOCK_FILE: (0, _env.envAsBoolean)(process.env['UPDATE_SOCKET_OVERRIDES_IN_PACKAGE_LOCK_FILE'])
43
39
  });
44
- constants.packumentCache = new Map();
45
- const {
46
- constructor: PacoteFetcherBase
47
- } = Reflect.getPrototypeOf(_pacote.RegistryFetcher.prototype);
48
- constants.pacoteCachePath = new PacoteFetcherBase(/*dummy package spec*/'x', {}).cache;
49
40
 
50
41
  var chalkMarkdown = {};
51
42
 
@@ -150,42 +141,6 @@ function stringJoinWithSeparateFinalSeparator(list, separator = ' and ') {
150
141
  return values.join(', ') + separator + finalValue;
151
142
  }
152
143
 
153
- var objects = {};
154
-
155
- Object.defineProperty(objects, "__esModule", {
156
- value: true
157
- });
158
- objects.hasOwn = hasOwn;
159
- objects.isObject = isObject;
160
- objects.isObjectObject = isObjectObject;
161
- objects.objectSome = objectSome;
162
- objects.pick = pick;
163
- function hasOwn(obj, propKey) {
164
- if (obj === null || obj === undefined) return false;
165
- return Object.hasOwn(obj, propKey);
166
- }
167
- function isObject(value) {
168
- return value !== null && typeof value === 'object';
169
- }
170
- function isObjectObject(value) {
171
- return value !== null && typeof value === 'object' && !Array.isArray(value);
172
- }
173
- function objectSome(obj) {
174
- for (const key in obj) {
175
- if (obj[key]) {
176
- return true;
177
- }
178
- }
179
- return false;
180
- }
181
- function pick(input, keys) {
182
- const result = {};
183
- for (const key of keys) {
184
- result[key] = input[key];
185
- }
186
- return result;
187
- }
188
-
189
144
  var sdk = {};
190
145
 
191
146
  var settings$1 = {};
@@ -196,9 +151,9 @@ Object.defineProperty(settings$1, "__esModule", {
196
151
  });
197
152
  settings$1.getSetting = getSetting;
198
153
  settings$1.updateSetting = updateSetting;
199
- var _nodeFs = require$$0$1;
200
- var _nodeOs = require$$2;
201
- var _nodePath$1 = require$$1;
154
+ var _nodeFs = require$$0;
155
+ var _nodeOs = require$$1;
156
+ var _nodePath$1 = require$$1$1;
202
157
  var _ora = _interopRequireDefault$1(vendor.ora);
203
158
  let dataHome = process.platform === 'win32' ? process.env['LOCALAPPDATA'] : process.env['XDG_DATA_HOME'];
204
159
  if (!dataHome) {
@@ -242,9 +197,9 @@ Object.defineProperty(sdk, "__esModule", {
242
197
  sdk.FREE_API_KEY = void 0;
243
198
  sdk.getDefaultKey = getDefaultKey;
244
199
  sdk.setupSdk = setupSdk;
245
- var _promises = require$$1$1;
246
- var _nodePath = require$$1;
247
- var _prompts = require$$1$2;
200
+ var _promises = require$$1$2;
201
+ var _nodePath = require$$1$1;
202
+ var _prompts = require$$1$3;
248
203
  var _sdk = require$$4;
249
204
  var _hpagent = require$$5;
250
205
  var _isInteractive = _interopRequireDefault(vendor.isInteractive);
@@ -309,6 +264,5 @@ exports.chalkMarkdown = chalkMarkdown;
309
264
  exports.constants = constants;
310
265
  exports.errors = errors;
311
266
  exports.misc = misc;
312
- exports.objects = objects;
313
267
  exports.sdk = sdk;
314
268
  exports.settings = settings$1;