@socketsecurity/cli-with-sentry 1.0.94 → 1.0.96

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 (81) hide show
  1. package/README.md +2 -1
  2. package/dist/cli.js +133 -102
  3. package/dist/cli.js.map +1 -1
  4. package/dist/constants.js +7 -3
  5. package/dist/constants.js.map +1 -1
  6. package/dist/tsconfig.dts.tsbuildinfo +1 -1
  7. package/dist/types/commands/analytics/fetch-org-analytics.d.mts +1 -1
  8. package/dist/types/commands/analytics/fetch-org-analytics.d.mts.map +1 -1
  9. package/dist/types/commands/analytics/fetch-repo-analytics.d.mts +1 -1
  10. package/dist/types/commands/analytics/fetch-repo-analytics.d.mts.map +1 -1
  11. package/dist/types/commands/audit-log/fetch-audit-log.d.mts +1 -1
  12. package/dist/types/commands/audit-log/fetch-audit-log.d.mts.map +1 -1
  13. package/dist/types/commands/config/discover-config-value.d.mts.map +1 -1
  14. package/dist/types/commands/fix/cmd-fix.d.mts.map +1 -1
  15. package/dist/types/commands/login/attempt-login.d.mts.map +1 -1
  16. package/dist/types/commands/organization/fetch-dependencies.d.mts +1 -1
  17. package/dist/types/commands/organization/fetch-dependencies.d.mts.map +1 -1
  18. package/dist/types/commands/organization/fetch-license-policy.d.mts +1 -1
  19. package/dist/types/commands/organization/fetch-license-policy.d.mts.map +1 -1
  20. package/dist/types/commands/organization/fetch-organization-list.d.mts +15 -3
  21. package/dist/types/commands/organization/fetch-organization-list.d.mts.map +1 -1
  22. package/dist/types/commands/organization/fetch-quota.d.mts +1 -1
  23. package/dist/types/commands/organization/fetch-quota.d.mts.map +1 -1
  24. package/dist/types/commands/organization/fetch-security-policy.d.mts +1 -1
  25. package/dist/types/commands/organization/fetch-security-policy.d.mts.map +1 -1
  26. package/dist/types/commands/organization/output-organization-list.d.mts +3 -3
  27. package/dist/types/commands/organization/output-organization-list.d.mts.map +1 -1
  28. package/dist/types/commands/package/fetch-purls-shallow-score.d.mts +1 -1
  29. package/dist/types/commands/package/fetch-purls-shallow-score.d.mts.map +1 -1
  30. package/dist/types/commands/repository/fetch-create-repo.d.mts +1 -1
  31. package/dist/types/commands/repository/fetch-create-repo.d.mts.map +1 -1
  32. package/dist/types/commands/repository/fetch-delete-repo.d.mts +1 -1
  33. package/dist/types/commands/repository/fetch-delete-repo.d.mts.map +1 -1
  34. package/dist/types/commands/repository/fetch-list-all-repos.d.mts +1 -1
  35. package/dist/types/commands/repository/fetch-list-all-repos.d.mts.map +1 -1
  36. package/dist/types/commands/repository/fetch-list-repos.d.mts +1 -1
  37. package/dist/types/commands/repository/fetch-list-repos.d.mts.map +1 -1
  38. package/dist/types/commands/repository/fetch-update-repo.d.mts +1 -1
  39. package/dist/types/commands/repository/fetch-update-repo.d.mts.map +1 -1
  40. package/dist/types/commands/repository/fetch-view-repo.d.mts +1 -1
  41. package/dist/types/commands/repository/fetch-view-repo.d.mts.map +1 -1
  42. package/dist/types/commands/scan/cmd-scan-reach.d.mts.map +1 -1
  43. package/dist/types/commands/scan/fetch-create-org-full-scan.d.mts +1 -1
  44. package/dist/types/commands/scan/fetch-create-org-full-scan.d.mts.map +1 -1
  45. package/dist/types/commands/scan/fetch-delete-org-full-scan.d.mts +1 -1
  46. package/dist/types/commands/scan/fetch-delete-org-full-scan.d.mts.map +1 -1
  47. package/dist/types/commands/scan/fetch-list-scans.d.mts +1 -1
  48. package/dist/types/commands/scan/fetch-list-scans.d.mts.map +1 -1
  49. package/dist/types/commands/scan/fetch-report-data.d.mts +1 -1
  50. package/dist/types/commands/scan/fetch-report-data.d.mts.map +1 -1
  51. package/dist/types/commands/scan/fetch-scan-metadata.d.mts +1 -1
  52. package/dist/types/commands/scan/fetch-scan-metadata.d.mts.map +1 -1
  53. package/dist/types/commands/scan/fetch-supported-scan-file-names.d.mts +1 -1
  54. package/dist/types/commands/scan/fetch-supported-scan-file-names.d.mts.map +1 -1
  55. package/dist/types/commands/scan/handle-create-new-scan.d.mts.map +1 -1
  56. package/dist/types/commands/scan/perform-reachability-analysis.d.mts.map +1 -1
  57. package/dist/types/commands/scan/stream-scan.d.mts +1 -1
  58. package/dist/types/commands/scan/stream-scan.d.mts.map +1 -1
  59. package/dist/types/commands/scan/suggest-repo-slug.d.mts +1 -1
  60. package/dist/types/commands/scan/suggest-repo-slug.d.mts.map +1 -1
  61. package/dist/types/constants.d.mts +1 -0
  62. package/dist/types/constants.d.mts.map +1 -1
  63. package/dist/types/utils/meow-with-subcommands.d.mts.map +1 -1
  64. package/dist/types/utils/organization.d.mts +5 -0
  65. package/dist/types/utils/organization.d.mts.map +1 -0
  66. package/dist/types/utils/sdk.d.mts.map +1 -1
  67. package/dist/types/utils/serialize-result-json.d.mts.map +1 -1
  68. package/dist/utils.js +55 -29
  69. package/dist/utils.js.map +1 -1
  70. package/dist/vendor.js +12 -4
  71. package/external/@coana-tech/cli/README.md +5 -0
  72. package/external/@coana-tech/cli/cli.mjs +2 -2
  73. package/external/@coana-tech/cli/repos/coana-tech/alucard/alucard.jar +0 -0
  74. package/external/@coana-tech/cli/repos/coana-tech/goana/bin/goana-darwin-amd64.gz +0 -0
  75. package/external/@coana-tech/cli/repos/coana-tech/goana/bin/goana-darwin-arm64.gz +0 -0
  76. package/external/@coana-tech/cli/repos/coana-tech/goana/bin/goana-linux-amd64.gz +0 -0
  77. package/external/@coana-tech/cli/repos/coana-tech/goana/bin/goana-linux-arm64.gz +0 -0
  78. package/external/@socketsecurity/registry/README.md +9 -0
  79. package/external/@socketsecurity/registry/lib/env.js +11 -0
  80. package/external/blessed/README.md +2421 -0
  81. package/package.json +7 -7
package/README.md CHANGED
@@ -92,9 +92,10 @@ npm exec socket
92
92
 
93
93
  - `SOCKET_CLI_API_BASE_URL` - Change the base URL for Socket API calls<br>
94
94
  *Defaults:* The "apiBaseUrl" value of socket/settings local app data if present, else `https://api.socket.dev/v0/`<br>
95
- - `SOCKET_CLI_API_PROXY` - Set the proxy all requests are routed through, e.g. if set to<br>
95
+ - `SOCKET_CLI_API_PROXY` - Set the proxy Socket API requests are routed through, e.g. if set to<br>
96
96
  [`http://127.0.0.1:9090`](https://docs.proxyman.io/troubleshooting/couldnt-see-any-requests-from-3rd-party-network-libraries), then all request are passed through that proxy<br>
97
97
  *Aliases:* `HTTPS_PROXY`, `https_proxy`, `HTTP_PROXY`, and `http_proxy`<br>
98
+ - `SOCKET_CLI_API_TIMEOUT` - Set the timeout in milliseconds for Socket API requests
98
99
  - `SOCKET_CLI_DEBUG` - Enable debug logging in Socket CLI
99
100
  - `DEBUG` - Enable debug logging based on the [`debug`](https://socket.dev/npm/package/debug) package
100
101
 
package/dist/cli.js CHANGED
@@ -10,10 +10,10 @@ var fs = require('node:fs/promises');
10
10
  var require$$5 = require('node:module');
11
11
  var constants = require('./constants.js');
12
12
  var flags = require('./flags.js');
13
+ var path = require('node:path');
13
14
  var words = require('../external/@socketsecurity/registry/lib/words');
14
15
  var prompts = require('../external/@socketsecurity/registry/lib/prompts');
15
16
  var fs$1 = require('node:fs');
16
- var path = require('node:path');
17
17
  var spawn = require('../external/@socketsecurity/registry/lib/spawn');
18
18
  var fs$2 = require('../external/@socketsecurity/registry/lib/fs');
19
19
  var strings = require('../external/@socketsecurity/registry/lib/strings');
@@ -35,12 +35,12 @@ var promises = require('node:stream/promises');
35
35
  var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
36
36
  async function fetchOrgAnalyticsData(time, options) {
37
37
  const {
38
- sdkOptions
38
+ sdkOpts
39
39
  } = {
40
40
  __proto__: null,
41
41
  ...options
42
42
  };
43
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
43
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
44
44
  if (!sockSdkCResult.ok) {
45
45
  return sockSdkCResult;
46
46
  }
@@ -52,12 +52,12 @@ async function fetchOrgAnalyticsData(time, options) {
52
52
 
53
53
  async function fetchRepoAnalyticsData(repo, time, options) {
54
54
  const {
55
- sdkOptions
55
+ sdkOpts
56
56
  } = {
57
57
  __proto__: null,
58
58
  ...options
59
59
  };
60
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
60
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
61
61
  if (!sockSdkCResult.ok) {
62
62
  return sockSdkCResult;
63
63
  }
@@ -464,12 +464,12 @@ async function run$P(argv, importMeta, {
464
464
 
465
465
  async function fetchAuditLog(config, options) {
466
466
  const {
467
- sdkOptions
467
+ sdkOpts
468
468
  } = {
469
469
  __proto__: null,
470
470
  ...options
471
471
  };
472
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
472
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
473
473
  if (!sockSdkCResult.ok) {
474
474
  return sockSdkCResult;
475
475
  }
@@ -901,13 +901,13 @@ async function fetchCreateOrgFullScan(packagePaths, orgSlug, config, options) {
901
901
  cwd = process.cwd(),
902
902
  defaultBranch,
903
903
  pendingHead,
904
- sdkOptions,
904
+ sdkOpts,
905
905
  tmp
906
906
  } = {
907
907
  __proto__: null,
908
908
  ...options
909
909
  };
910
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
910
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
911
911
  if (!sockSdkCResult.ok) {
912
912
  return sockSdkCResult;
913
913
  }
@@ -939,12 +939,12 @@ async function fetchCreateOrgFullScan(packagePaths, orgSlug, config, options) {
939
939
 
940
940
  async function fetchSupportedScanFileNames(options) {
941
941
  const {
942
- sdkOptions
942
+ sdkOpts
943
943
  } = {
944
944
  __proto__: null,
945
945
  ...options
946
946
  };
947
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
947
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
948
948
  if (!sockSdkCResult.ok) {
949
949
  return sockSdkCResult;
950
950
  }
@@ -978,12 +978,12 @@ async function finalizeTier1Scan(tier1ReachabilityScanId, scanId) {
978
978
  async function fetchScanData(orgSlug, scanId, options) {
979
979
  const {
980
980
  includeLicensePolicy,
981
- sdkOptions
981
+ sdkOpts
982
982
  } = {
983
983
  __proto__: null,
984
984
  ...options
985
985
  };
986
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
986
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
987
987
  if (!sockSdkCResult.ok) {
988
988
  return sockSdkCResult;
989
989
  }
@@ -1561,6 +1561,26 @@ async function performReachabilityAnalysis(options) {
1561
1561
  __proto__: null,
1562
1562
  ...options
1563
1563
  };
1564
+
1565
+ // Check if user has enterprise plan for reachability analysis
1566
+ const orgsCResult = await utils.fetchOrganization();
1567
+ if (!orgsCResult.ok) {
1568
+ return {
1569
+ ok: false,
1570
+ message: 'Unable to verify plan permissions',
1571
+ cause: 'Failed to fetch organization information to verify enterprise plan access'
1572
+ };
1573
+ }
1574
+ const {
1575
+ organizations
1576
+ } = orgsCResult.data;
1577
+ if (!utils.hasEnterpriseOrgPlan(organizations)) {
1578
+ return {
1579
+ ok: false,
1580
+ message: 'Tier 1 Reachability analysis requires an enterprise plan',
1581
+ cause: `This feature is only available for organizations with an enterprise plan. Please ${vendor.terminalLinkExports('upgrade your plan', 'https://socket.dev/pricing')}.`
1582
+ };
1583
+ }
1564
1584
  let tarHash;
1565
1585
  if (uploadManifests && orgSlug && packagePaths) {
1566
1586
  // Setup SDK for uploading manifests
@@ -1571,8 +1591,9 @@ async function performReachabilityAnalysis(options) {
1571
1591
  const sockSdk = sockSdkCResult.data;
1572
1592
  const wasSpinning = !!spinner?.isSpinning;
1573
1593
 
1574
- // Exclude .socket.facts.json from upload.
1575
- const filepathsToUpload = packagePaths.filter(p => !p.endsWith(constants.DOT_SOCKET_DOT_FACTS_JSON));
1594
+ // Exclude any .socket.facts.json files that happen to be in the scan
1595
+ // folder before the analysis was run.
1596
+ const filepathsToUpload = packagePaths.filter(p => path.basename(p).toLowerCase() !== constants.DOT_SOCKET_DOT_FACTS_JSON);
1576
1597
  spinner?.start('Uploading manifests for reachability analysis...');
1577
1598
  const uploadCResult = await utils.handleApiCall(sockSdk.uploadManifestFiles(orgSlug, filepathsToUpload), {
1578
1599
  desc: 'upload manifests',
@@ -1604,7 +1625,7 @@ async function performReachabilityAnalysis(options) {
1604
1625
 
1605
1626
  // Build Coana arguments.
1606
1627
  const coanaArgs = ['run', cwd, '--output-dir', cwd, '--socket-mode', constants.DOT_SOCKET_DOT_FACTS_JSON, '--disable-report-submission', ...(reachabilityOptions.reachAnalysisTimeout ? ['--analysis-timeout', `${reachabilityOptions.reachAnalysisTimeout}`] : []), ...(reachabilityOptions.reachAnalysisMemoryLimit ? ['--memory-limit', `${reachabilityOptions.reachAnalysisMemoryLimit}`] : []), ...(reachabilityOptions.reachDisableAnalytics ? ['--disable-analytics-sharing'] : []), ...(tarHash ? ['--run-without-docker', '--manifests-tar-hash', tarHash] : []),
1607
- // Empty reachEcosystems implies scan all ecosystems.
1628
+ // Empty reachEcosystems implies scanning all ecosystems.
1608
1629
  ...(reachabilityOptions.reachEcosystems.length ? ['--purl-types', ...reachabilityOptions.reachEcosystems] : []), ...(reachabilityOptions.reachExcludePaths.length ? ['--exclude-dirs', ...reachabilityOptions.reachExcludePaths] : [])];
1609
1630
 
1610
1631
  // Build environment variables.
@@ -2215,7 +2236,11 @@ async function handleCreateNewScan({
2215
2236
  return;
2216
2237
  }
2217
2238
  logger.logger.success('Reachability analysis completed successfully');
2218
- scanPaths = reachResult.data?.reachabilityReport ? [reachResult.data.reachabilityReport] : [];
2239
+ const reachabilityReport = reachResult.data?.reachabilityReport;
2240
+ scanPaths = [...packagePaths.filter(
2241
+ // Ensure the .socket.facts.json isn't duplicated in case it happened
2242
+ // to be in the scan folder before the analysis was run.
2243
+ p => path.basename(p).toLowerCase() !== constants.DOT_SOCKET_DOT_FACTS_JSON), ...(reachabilityReport ? [reachabilityReport] : [])];
2219
2244
  tier1ReachabilityScanId = reachResult.data?.tier1ReachabilityScanId;
2220
2245
  }
2221
2246
  const fullScanCResult = await fetchCreateOrgFullScan(scanPaths, orgSlug, {
@@ -2481,10 +2506,10 @@ async function getDefaultOrgFromToken() {
2481
2506
  const {
2482
2507
  organizations
2483
2508
  } = orgsCResult.data;
2484
- const slugs = Array.from(Object.values(organizations)).map(o => o.slug);
2485
- if (slugs.length === 0) {
2509
+ if (organizations.length === 0) {
2486
2510
  return undefined;
2487
2511
  }
2512
+ const slugs = utils.getOrgSlugs(organizations);
2488
2513
  if (slugs.length === 1) {
2489
2514
  return slugs[0];
2490
2515
  }
@@ -2498,11 +2523,7 @@ async function getEnforceableOrgsFromToken() {
2498
2523
  const {
2499
2524
  organizations
2500
2525
  } = orgsCResult.data;
2501
- const slugs = Array.from(Object.values(organizations)).map(o => o.slug);
2502
- if (!slugs.length) {
2503
- return undefined;
2504
- }
2505
- return slugs;
2526
+ return organizations.length ? utils.getOrgSlugs(organizations) : undefined;
2506
2527
  }
2507
2528
 
2508
2529
  async function outputConfigAuto(key, result, outputKind) {
@@ -4923,6 +4944,7 @@ async function run$H(argv, importMeta, {
4923
4944
  hidden: hidden$p,
4924
4945
  flags: {
4925
4946
  ...flags.commonFlags,
4947
+ ...flags.outputFlags,
4926
4948
  autoMerge: {
4927
4949
  type: 'boolean',
4928
4950
  default: false,
@@ -5046,6 +5068,11 @@ Available styles:
5046
5068
  test: utils.RangeStyles.includes(rangeStyle),
5047
5069
  message: `Expecting range style of ${arrays.joinOr(utils.RangeStyles)}`,
5048
5070
  fail: 'invalid'
5071
+ }, {
5072
+ nook: true,
5073
+ test: !cli.flags['json'] || !cli.flags['markdown'],
5074
+ message: 'The json and markdown flags cannot be both set, pick one',
5075
+ fail: 'omit one'
5049
5076
  });
5050
5077
  if (!wasValidInput) {
5051
5078
  return;
@@ -5399,8 +5426,9 @@ async function attemptLogin(apiBaseUrl, apiProxy) {
5399
5426
  return;
5400
5427
  }
5401
5428
  const sockSdk = sockSdkCResult.data;
5402
- const orgsCResult = await utils.handleApiCall(sockSdk.getOrganizations(), {
5403
- desc: 'token verification'
5429
+ const orgsCResult = await utils.fetchOrganization({
5430
+ desc: 'token verification',
5431
+ sdk: sockSdk
5404
5432
  });
5405
5433
  if (!orgsCResult.ok) {
5406
5434
  process.exitCode = 1;
@@ -5410,9 +5438,10 @@ async function attemptLogin(apiBaseUrl, apiProxy) {
5410
5438
  const {
5411
5439
  organizations
5412
5440
  } = orgsCResult.data;
5413
- const orgSlugs = Object.values(organizations).map(obj => obj.slug);
5414
- logger.logger.success(`API token verified: ${orgSlugs}`);
5415
- const enforcedChoices = Object.values(organizations).filter(org => org?.plan === 'enterprise').map(org => ({
5441
+ const orgSlugs = utils.getOrgSlugs(organizations);
5442
+ logger.logger.success(`API token verified: ${arrays.joinAnd(orgSlugs)}`);
5443
+ const enterpriseOrgs = utils.getEnterpriseOrgs(organizations);
5444
+ const enforcedChoices = enterpriseOrgs.map(org => ({
5416
5445
  name: org.name ?? 'undefined',
5417
5446
  value: org.id
5418
5447
  }));
@@ -5420,11 +5449,11 @@ async function attemptLogin(apiBaseUrl, apiProxy) {
5420
5449
  if (enforcedChoices.length > 1) {
5421
5450
  const id = await prompts.select({
5422
5451
  message: "Which organization's policies should Socket enforce system-wide?",
5423
- choices: enforcedChoices.concat({
5452
+ choices: [...enforcedChoices, {
5424
5453
  name: 'None',
5425
5454
  value: '',
5426
5455
  description: 'Pick "None" if this is a personal device'
5427
- })
5456
+ }]
5428
5457
  });
5429
5458
  if (id === undefined) {
5430
5459
  logger.logger.fail('Canceled by user');
@@ -8313,12 +8342,12 @@ async function run$r(argv, importMeta, {
8313
8342
 
8314
8343
  async function fetchDependencies(config, options) {
8315
8344
  const {
8316
- sdkOptions
8345
+ sdkOpts
8317
8346
  } = {
8318
8347
  __proto__: null,
8319
8348
  ...options
8320
8349
  };
8321
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
8350
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
8322
8351
  if (!sockSdkCResult.ok) {
8323
8352
  return sockSdkCResult;
8324
8353
  }
@@ -8503,12 +8532,12 @@ async function run$q(argv, importMeta, {
8503
8532
 
8504
8533
  async function fetchLicensePolicy(orgSlug, options) {
8505
8534
  const {
8506
- sdkOptions
8535
+ sdkOpts
8507
8536
  } = {
8508
8537
  __proto__: null,
8509
8538
  ...options
8510
8539
  };
8511
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
8540
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
8512
8541
  if (!sockSdkCResult.ok) {
8513
8542
  return sockSdkCResult;
8514
8543
  }
@@ -8639,12 +8668,12 @@ async function run$p(argv, importMeta, {
8639
8668
 
8640
8669
  async function fetchSecurityPolicy(orgSlug, options) {
8641
8670
  const {
8642
- sdkOptions
8671
+ sdkOpts
8643
8672
  } = {
8644
8673
  __proto__: null,
8645
8674
  ...options
8646
8675
  };
8647
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
8676
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
8648
8677
  if (!sockSdkCResult.ok) {
8649
8678
  return sockSdkCResult;
8650
8679
  }
@@ -8774,54 +8803,51 @@ async function run$o(argv, importMeta, {
8774
8803
  await handleSecurityPolicy(orgSlug, outputKind);
8775
8804
  }
8776
8805
 
8777
- async function outputOrganizationList(result, outputKind = 'text') {
8778
- if (!result.ok) {
8779
- process.exitCode = result.code ?? 1;
8806
+ async function outputOrganizationList(orgsCResult, outputKind = 'text') {
8807
+ if (!orgsCResult.ok) {
8808
+ process.exitCode = orgsCResult.code ?? 1;
8780
8809
  }
8781
8810
  if (outputKind === 'json') {
8782
- logger.logger.log(utils.serializeResultJson(result));
8811
+ logger.logger.log(utils.serializeResultJson(orgsCResult));
8783
8812
  return;
8784
8813
  }
8785
- if (!result.ok) {
8786
- logger.logger.fail(utils.failMsgWithBadge(result.message, result.cause));
8814
+ if (!orgsCResult.ok) {
8815
+ logger.logger.fail(utils.failMsgWithBadge(orgsCResult.message, orgsCResult.cause));
8787
8816
  return;
8788
8817
  }
8789
- const organizations = Object.values(result.data.organizations);
8818
+ const {
8819
+ organizations
8820
+ } = orgsCResult.data;
8790
8821
  const visibleTokenPrefix = utils.getVisibleTokenPrefix();
8791
- switch (outputKind) {
8792
- case 'markdown':
8793
- {
8794
- // | Syntax | Description |
8795
- // | ----------- | ----------- |
8796
- // | Header | Title |
8797
- // | Paragraph | Text |
8798
- let mw1 = 4;
8799
- let mw2 = 2;
8800
- let mw3 = 4;
8801
- for (const o of organizations) {
8802
- mw1 = Math.max(mw1, o.name?.length ?? 0);
8803
- mw2 = Math.max(mw2, o.id.length);
8804
- mw3 = Math.max(mw3, o.plan.length);
8805
- }
8806
- logger.logger.log('# Organizations\n');
8807
- logger.logger.log(`List of organizations associated with your API token, starting with: ${vendor.yoctocolorsCjsExports.italic(visibleTokenPrefix)}\n`);
8808
- logger.logger.log(`| Name${' '.repeat(mw1 - 4)} | ID${' '.repeat(mw2 - 2)} | Plan${' '.repeat(mw3 - 4)} |`);
8809
- logger.logger.log(`| ${'-'.repeat(mw1)} | ${'-'.repeat(mw2)} | ${'-'.repeat(mw3)} |`);
8810
- for (const o of organizations) {
8811
- logger.logger.log(`| ${(o.name || '').padEnd(mw1, ' ')} | ${(o.id || '').padEnd(mw2, ' ')} | ${(o.plan || '').padEnd(mw3, ' ')} |`);
8812
- }
8813
- logger.logger.log(`| ${'-'.repeat(mw1)} | ${'-'.repeat(mw2)} | ${'-'.repeat(mw3)} |`);
8814
- return;
8815
- }
8816
- default:
8817
- {
8818
- logger.logger.log(`List of organizations associated with your API token, starting with: ${vendor.yoctocolorsCjsExports.italic(visibleTokenPrefix)}\n`);
8819
- // Just dump
8820
- for (const o of organizations) {
8821
- logger.logger.log(`- Name: ${vendor.yoctocolorsCjsExports.bold(o.name ?? 'undefined')}, ID: ${vendor.yoctocolorsCjsExports.bold(o.id)}, Plan: ${vendor.yoctocolorsCjsExports.bold(o.plan)}`);
8822
- }
8823
- }
8822
+ if (outputKind !== 'markdown') {
8823
+ logger.logger.log(`List of organizations associated with your API token, starting with: ${vendor.yoctocolorsCjsExports.italic(visibleTokenPrefix)}\n`);
8824
+ // Just dump.
8825
+ for (const o of organizations) {
8826
+ logger.logger.log(`- Name: ${vendor.yoctocolorsCjsExports.bold(o.name ?? 'undefined')}, ID: ${vendor.yoctocolorsCjsExports.bold(o.id)}, Plan: ${vendor.yoctocolorsCjsExports.bold(o.plan)}`);
8827
+ }
8828
+ return;
8829
+ }
8830
+
8831
+ // | Syntax | Description |
8832
+ // | ----------- | ----------- |
8833
+ // | Header | Title |
8834
+ // | Paragraph | Text |
8835
+ let mw1 = 4;
8836
+ let mw2 = 2;
8837
+ let mw3 = 4;
8838
+ for (const o of organizations) {
8839
+ mw1 = Math.max(mw1, o.name?.length ?? 0);
8840
+ mw2 = Math.max(mw2, o.id.length);
8841
+ mw3 = Math.max(mw3, o.plan.length);
8824
8842
  }
8843
+ logger.logger.log('# Organizations\n');
8844
+ logger.logger.log(`List of organizations associated with your API token, starting with: ${vendor.yoctocolorsCjsExports.italic(visibleTokenPrefix)}\n`);
8845
+ logger.logger.log(`| Name${' '.repeat(mw1 - 4)} | ID${' '.repeat(mw2 - 2)} | Plan${' '.repeat(mw3 - 4)} |`);
8846
+ logger.logger.log(`| ${'-'.repeat(mw1)} | ${'-'.repeat(mw2)} | ${'-'.repeat(mw3)} |`);
8847
+ for (const o of organizations) {
8848
+ logger.logger.log(`| ${(o.name || '').padEnd(mw1, ' ')} | ${(o.id || '').padEnd(mw2, ' ')} | ${(o.plan || '').padEnd(mw3, ' ')} |`);
8849
+ }
8850
+ logger.logger.log(`| ${'-'.repeat(mw1)} | ${'-'.repeat(mw2)} | ${'-'.repeat(mw3)} |`);
8825
8851
  }
8826
8852
 
8827
8853
  async function handleOrganizationList(outputKind = 'text') {
@@ -8927,12 +8953,12 @@ const cmdOrganizationPolicy = {
8927
8953
 
8928
8954
  async function fetchQuota(options) {
8929
8955
  const {
8930
- sdkOptions
8956
+ sdkOpts
8931
8957
  } = {
8932
8958
  __proto__: null,
8933
8959
  ...options
8934
8960
  };
8935
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
8961
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
8936
8962
  if (!sockSdkCResult.ok) {
8937
8963
  return sockSdkCResult;
8938
8964
  }
@@ -9396,12 +9422,12 @@ async function run$l(argv, importMeta, {
9396
9422
 
9397
9423
  async function fetchPurlsShallowScore(purls, options) {
9398
9424
  const {
9399
- sdkOptions
9425
+ sdkOpts
9400
9426
  } = {
9401
9427
  __proto__: null,
9402
9428
  ...options
9403
9429
  };
9404
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
9430
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
9405
9431
  if (!sockSdkCResult.ok) {
9406
9432
  return sockSdkCResult;
9407
9433
  }
@@ -9948,12 +9974,12 @@ async function fetchCreateRepo(config, options) {
9948
9974
  visibility
9949
9975
  } = config;
9950
9976
  const {
9951
- sdkOptions
9977
+ sdkOpts
9952
9978
  } = {
9953
9979
  __proto__: null,
9954
9980
  ...options
9955
9981
  };
9956
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
9982
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
9957
9983
  if (!sockSdkCResult.ok) {
9958
9984
  return sockSdkCResult;
9959
9985
  }
@@ -10131,12 +10157,12 @@ async function run$h(argv, importMeta, {
10131
10157
 
10132
10158
  async function fetchDeleteRepo(orgSlug, repoName, options) {
10133
10159
  const {
10134
- sdkOptions
10160
+ sdkOpts
10135
10161
  } = {
10136
10162
  __proto__: null,
10137
10163
  ...options
10138
10164
  };
10139
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
10165
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
10140
10166
  if (!sockSdkCResult.ok) {
10141
10167
  return sockSdkCResult;
10142
10168
  }
@@ -10262,13 +10288,13 @@ async function run$g(argv, importMeta, {
10262
10288
  async function fetchListAllRepos(orgSlug, options) {
10263
10289
  const {
10264
10290
  direction,
10265
- sdkOptions,
10291
+ sdkOpts,
10266
10292
  sort
10267
10293
  } = {
10268
10294
  __proto__: null,
10269
10295
  ...options
10270
10296
  };
10271
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
10297
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
10272
10298
  if (!sockSdkCResult.ok) {
10273
10299
  return sockSdkCResult;
10274
10300
  }
@@ -10321,12 +10347,12 @@ async function fetchListRepos(config, options) {
10321
10347
  ...config
10322
10348
  };
10323
10349
  const {
10324
- sdkOptions
10350
+ sdkOpts
10325
10351
  } = {
10326
10352
  __proto__: null,
10327
10353
  ...options
10328
10354
  };
10329
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
10355
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
10330
10356
  if (!sockSdkCResult.ok) {
10331
10357
  return sockSdkCResult;
10332
10358
  }
@@ -10574,12 +10600,12 @@ async function fetchUpdateRepo(config, options) {
10574
10600
  ...config
10575
10601
  };
10576
10602
  const {
10577
- sdkOptions
10603
+ sdkOpts
10578
10604
  } = {
10579
10605
  __proto__: null,
10580
10606
  ...options
10581
10607
  };
10582
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
10608
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
10583
10609
  if (!sockSdkCResult.ok) {
10584
10610
  return sockSdkCResult;
10585
10611
  }
@@ -10757,12 +10783,12 @@ async function run$e(argv, importMeta, {
10757
10783
 
10758
10784
  async function fetchViewRepo(orgSlug, repoName, options) {
10759
10785
  const {
10760
- sdkOptions
10786
+ sdkOpts
10761
10787
  } = {
10762
10788
  __proto__: null,
10763
10789
  ...options
10764
10790
  };
10765
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
10791
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
10766
10792
  if (!sockSdkCResult.ok) {
10767
10793
  return sockSdkCResult;
10768
10794
  }
@@ -11360,12 +11386,12 @@ async function run$c(argv, importMeta, {
11360
11386
 
11361
11387
  async function fetchDeleteOrgFullScan(orgSlug, scanId, options) {
11362
11388
  const {
11363
- sdkOptions
11389
+ sdkOpts
11364
11390
  } = {
11365
11391
  __proto__: null,
11366
11392
  ...options
11367
11393
  };
11368
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
11394
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
11369
11395
  if (!sockSdkCResult.ok) {
11370
11396
  return sockSdkCResult;
11371
11397
  }
@@ -12661,12 +12687,12 @@ async function run$9(argv, importMeta, {
12661
12687
 
12662
12688
  async function fetchOrgFullScanList(config, options) {
12663
12689
  const {
12664
- sdkOptions
12690
+ sdkOpts
12665
12691
  } = {
12666
12692
  __proto__: null,
12667
12693
  ...options
12668
12694
  };
12669
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
12695
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
12670
12696
  if (!sockSdkCResult.ok) {
12671
12697
  return sockSdkCResult;
12672
12698
  }
@@ -12930,12 +12956,12 @@ async function run$8(argv, importMeta, {
12930
12956
 
12931
12957
  async function fetchScanMetadata(orgSlug, scanId, options) {
12932
12958
  const {
12933
- sdkOptions
12959
+ sdkOpts
12934
12960
  } = {
12935
12961
  __proto__: null,
12936
12962
  ...options
12937
12963
  };
12938
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
12964
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
12939
12965
  if (!sockSdkCResult.ok) {
12940
12966
  return sockSdkCResult;
12941
12967
  }
@@ -13263,6 +13289,11 @@ async function run$6(argv, importMeta, {
13263
13289
  test: hasApiToken,
13264
13290
  message: 'This command requires an API token for access',
13265
13291
  fail: 'try `socket login`'
13292
+ }, {
13293
+ nook: true,
13294
+ test: !json || !markdown,
13295
+ message: 'The json and markdown flags cannot be both set, pick one',
13296
+ fail: 'omit one'
13266
13297
  });
13267
13298
  if (!wasValidInput) {
13268
13299
  return;
@@ -13919,12 +13950,12 @@ async function handleScanView(orgSlug, scanId, filePath, outputKind) {
13919
13950
  async function streamScan(orgSlug, scanId, options) {
13920
13951
  const {
13921
13952
  file,
13922
- sdkOptions
13953
+ sdkOpts
13923
13954
  } = {
13924
13955
  __proto__: null,
13925
13956
  ...options
13926
13957
  };
13927
- const sockSdkCResult = await utils.setupSdk(sdkOptions);
13958
+ const sockSdkCResult = await utils.setupSdk(sdkOpts);
13928
13959
  if (!sockSdkCResult.ok) {
13929
13960
  return sockSdkCResult;
13930
13961
  }
@@ -15072,5 +15103,5 @@ void (async () => {
15072
15103
  await utils.captureException(e);
15073
15104
  }
15074
15105
  })();
15075
- //# debugId=81b47540-775f-4f45-886a-8772911e83e
15106
+ //# debugId=9a03c00b-a929-45e3-8075-54853c769f02
15076
15107
  //# sourceMappingURL=cli.js.map