@paciolan/remote-module-loader 3.0.3 → 3.0.6

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.
@@ -0,0 +1,15 @@
1
+ {
2
+ "hooks": {
3
+ "PostToolUse": [
4
+ {
5
+ "matcher": "Edit|Write",
6
+ "hooks": [
7
+ {
8
+ "type": "command",
9
+ "command": "cd \"$CLAUDE_PROJECT_DIR\" && npm run lint"
10
+ }
11
+ ]
12
+ }
13
+ ]
14
+ }
15
+ }
package/CLAUDE.md ADDED
@@ -0,0 +1,5 @@
1
+ # CLAUDE.md
2
+
3
+ ## Project Overview
4
+
5
+ `@paciolan/remote-module-loader` is a TypeScript library that dynamically loads CommonJS modules from remote URLs. It works in both browser (XMLHttpRequest) and Node.js (http/https) environments, auto-detecting which fetcher to use. Modules are evaluated via `new Function()` with dependency injection through a `requires` function.
@@ -0,0 +1,77 @@
1
+ module.exports = {
2
+ list: [
3
+ "test",
4
+ "feat",
5
+ "fix",
6
+ "chore",
7
+ "docs",
8
+ "refactor",
9
+ "style",
10
+ "ci",
11
+ "perf"
12
+ ],
13
+ maxMessageLength: 64,
14
+ minMessageLength: 3,
15
+ questions: [
16
+ "type",
17
+ "scope",
18
+ "subject",
19
+ "body",
20
+ "breaking",
21
+ "issues",
22
+ "lerna"
23
+ ],
24
+ scopes: [],
25
+ types: {
26
+ chore: {
27
+ description: "Build process or auxiliary tool changes",
28
+ emoji: "🛠️",
29
+ value: "chore"
30
+ },
31
+ ci: {
32
+ description: "CI related changes",
33
+ emoji: "🤖",
34
+ value: "ci"
35
+ },
36
+ docs: {
37
+ description: "Documentation only changes",
38
+ emoji: "📚",
39
+ value: "docs"
40
+ },
41
+ feat: {
42
+ description: "A new feature",
43
+ emoji: "✨",
44
+ value: "feat"
45
+ },
46
+ fix: {
47
+ description: "A bug fix",
48
+ emoji: "🐛",
49
+ value: "fix"
50
+ },
51
+ perf: {
52
+ description: "A code change that improves performance",
53
+ emoji: "⚡️",
54
+ value: "perf"
55
+ },
56
+ refactor: {
57
+ description: "A code change that neither fixes a bug or adds a feature",
58
+ emoji: "💡",
59
+ value: "refactor"
60
+ },
61
+ release: {
62
+ description: "Create a release commit",
63
+ emoji: "🚀",
64
+ value: "release"
65
+ },
66
+ style: {
67
+ description: "Markup, white-space, formatting, missing semi-colons...",
68
+ emoji: "🎨",
69
+ value: "style"
70
+ },
71
+ test: {
72
+ description: "Adding missing tests",
73
+ emoji: "🚨",
74
+ value: "test"
75
+ }
76
+ }
77
+ };
package/dist/index.js CHANGED
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2DAA2E;AAAlE,kFAAiC;AAC1C,uDAAsD;AAA7C,6DAAc"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,2DAA2E;AAAlE,kFAAiC;AAC1C,uDAAsD;AAA7C,6DAAc"}
@@ -4,7 +4,7 @@ exports.createRequires = void 0;
4
4
  var createRequires = function (dependencies) { return function (name) {
5
5
  var _dependencies = dependencies || {};
6
6
  if (!(name in _dependencies)) {
7
- throw new Error("Could not require '" + name + "'. '" + name + "' does not exist in dependencies.");
7
+ throw new Error("Could not require '".concat(name, "'. '").concat(name, "' does not exist in dependencies."));
8
8
  }
9
9
  return _dependencies[name];
10
10
  }; };
@@ -1 +1 @@
1
- {"version":3,"file":"createRequires.js","sourceRoot":"","sources":["../../src/lib/createRequires.ts"],"names":[],"mappings":";;;AAQO,IAAM,cAAc,GAAmB,UAAA,YAAY,IAAI,OAAA,UAAA,IAAI;IAChE,IAAM,aAAa,GAAG,YAAY,IAAI,EAAE,CAAC;IAEzC,IAAI,CAAC,CAAC,IAAI,IAAI,aAAa,CAAC,EAAE;QAC5B,MAAM,IAAI,KAAK,CACb,wBAAsB,IAAI,YAAO,IAAI,sCAAmC,CACzE,CAAC;KACH;IAED,OAAO,aAAa,CAAC,IAAI,CAAC,CAAC;AAC7B,CAAC,EAV6D,CAU7D,CAAC;AAVW,QAAA,cAAc,kBAUzB"}
1
+ {"version":3,"file":"createRequires.js","sourceRoot":"","sources":["../../src/lib/createRequires.ts"],"names":[],"mappings":";;;AAQO,IAAM,cAAc,GAAmB,UAAA,YAAY,IAAI,OAAA,UAAA,IAAI;IAChE,IAAM,aAAa,GAAG,YAAY,IAAI,EAAE,CAAC;IAEzC,IAAI,CAAC,CAAC,IAAI,IAAI,aAAa,CAAC,EAAE;QAC5B,MAAM,IAAI,KAAK,CACb,6BAAsB,IAAI,iBAAO,IAAI,sCAAmC,CACzE,CAAC;KACH;IAED,OAAO,aAAa,CAAC,IAAI,CAAC,CAAC;AAC7B,CAAC,EAV6D,CAU7D,CAAC;AAVW,QAAA,cAAc,kBAUzB"}
@@ -4,11 +4,12 @@ exports.createLoadRemoteModule = void 0;
4
4
  var memoize_1 = require("./memoize");
5
5
  var nodeFetcher_1 = require("./nodeFetcher");
6
6
  var index_1 = require("./xmlHttpRequestFetcher/index");
7
+ /* istanbul ignore next - environment detection */
7
8
  var isBrowser = typeof window !== "undefined" && typeof window.document !== "undefined";
8
9
  /* istanbul ignore next - difficult to test */
9
10
  var defaultFetcher = isBrowser ? index_1["default"] : nodeFetcher_1["default"];
10
11
  var defaultRequires = function (name) {
11
- throw new Error("Could not require '" + name + "'. The 'requires' function was not provided.");
12
+ throw new Error("Could not require '".concat(name, "'. The 'requires' function was not provided."));
12
13
  };
13
14
  var createLoadRemoteModule = function (_a) {
14
15
  var _b = _a === void 0 ? {} : _a, requires = _b.requires, fetcher = _b.fetcher;
@@ -1 +1 @@
1
- {"version":3,"file":"loadRemoteModule.js","sourceRoot":"","sources":["../../src/lib/loadRemoteModule.ts"],"names":[],"mappings":";;;AACA,qCAAgC;AAChC,6CAAwC;AACxC,uDAAkE;AAElE,IAAM,SAAS,GACb,OAAO,MAAM,KAAK,WAAW,IAAI,OAAO,MAAM,CAAC,QAAQ,KAAK,WAAW,CAAC;AAE1E,8CAA8C;AAC9C,IAAM,cAAc,GAAG,SAAS,CAAC,CAAC,CAAC,kBAAqB,CAAC,CAAC,CAAC,wBAAW,CAAC;AAEvE,IAAM,eAAe,GAAG,UAAA,IAAI;IAC1B,MAAM,IAAI,KAAK,CACb,wBAAsB,IAAI,iDAA8C,CACzE,CAAC;AACJ,CAAC,CAAC;AAeK,IAAM,sBAAsB,GAA2B,UAAC,EAGzD;QAHyD,qBAG3D,EAAE,KAAA,EAFJ,QAAQ,cAAA,EACR,OAAO,aAAA;IAEP,IAAM,SAAS,GAAG,QAAQ,IAAI,eAAe,CAAC;IAC9C,IAAM,QAAQ,GAAG,OAAO,IAAI,cAAc,CAAC;IAE3C,OAAO,IAAA,oBAAO,EAAC,UAAA,GAAG;QAChB,OAAA,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,UAAA,IAAI;YACrB,IAAM,OAAO,GAAG,EAAE,CAAC;YACnB,IAAM,MAAM,GAAG,EAAE,OAAO,SAAA,EAAE,CAAC;YAC3B,IAAM,IAAI,GAAG,IAAI,QAAQ,CAAC,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;YAChE,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;YACjC,OAAO,MAAM,CAAC,OAAO,CAAC;QACxB,CAAC,CAAC;IANF,CAME,CACH,CAAC;AACJ,CAAC,CAAC;AAhBW,QAAA,sBAAsB,0BAgBjC"}
1
+ {"version":3,"file":"loadRemoteModule.js","sourceRoot":"","sources":["../../src/lib/loadRemoteModule.ts"],"names":[],"mappings":";;;AACA,qCAAgC;AAChC,6CAAwC;AACxC,uDAAkE;AAElE,kDAAkD;AAClD,IAAM,SAAS,GACb,OAAO,MAAM,KAAK,WAAW,IAAI,OAAO,MAAM,CAAC,QAAQ,KAAK,WAAW,CAAC;AAE1E,8CAA8C;AAC9C,IAAM,cAAc,GAAG,SAAS,CAAC,CAAC,CAAC,kBAAqB,CAAC,CAAC,CAAC,wBAAW,CAAC;AAEvE,IAAM,eAAe,GAAG,UAAA,IAAI;IAC1B,MAAM,IAAI,KAAK,CACb,6BAAsB,IAAI,iDAA8C,CACzE,CAAC;AACJ,CAAC,CAAC;AAeK,IAAM,sBAAsB,GAA2B,UAAC,EAGzD;QAHyD,qBAG3D,EAAE,KAAA,EAFJ,QAAQ,cAAA,EACR,OAAO,aAAA;IAEP,IAAM,SAAS,GAAG,QAAQ,IAAI,eAAe,CAAC;IAC9C,IAAM,QAAQ,GAAG,OAAO,IAAI,cAAc,CAAC;IAE3C,OAAO,IAAA,oBAAO,EAAC,UAAA,GAAG;QAChB,OAAA,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,UAAA,IAAI;YACrB,IAAM,OAAO,GAAG,EAAE,CAAC;YACnB,IAAM,MAAM,GAAG,EAAE,OAAO,SAAA,EAAE,CAAC;YAC3B,IAAM,IAAI,GAAG,IAAI,QAAQ,CAAC,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;YAChE,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;YACjC,OAAO,MAAM,CAAC,OAAO,CAAC;QACxB,CAAC,CAAC;IANF,CAME,CACH,CAAC;AACJ,CAAC,CAAC;AAhBW,QAAA,sBAAsB,0BAgBjC"}
@@ -37,7 +37,7 @@ var nodeFetcher = function (url) {
37
37
  return new Promise(function (resolve, reject) {
38
38
  get(url, function (res) {
39
39
  if (res.statusCode !== status_1.OK) {
40
- return reject(new Error("HTTP Error Response: " + res.statusCode + " " + res.statusMessage + " (" + url + ")"));
40
+ return reject(new Error("HTTP Error Response: ".concat(res.statusCode, " ").concat(res.statusMessage, " (").concat(url, ")")));
41
41
  }
42
42
  var data = null;
43
43
  // called when a data chunk is received.
@@ -50,6 +50,12 @@ var nodeFetcher = function (url) {
50
50
  });
51
51
  // called when the complete response is received.
52
52
  res.on("end", function () { return resolve(data); });
53
+ // called when the connection is closed.
54
+ res.on("close", function () {
55
+ if (!res.complete) {
56
+ reject(new Error("Connection closed before response was complete (".concat(url, ")")));
57
+ }
58
+ });
53
59
  }).on("error", reject);
54
60
  });
55
61
  };
@@ -1 +1 @@
1
- {"version":3,"file":"nodeFetcher.js","sourceRoot":"","sources":["../../src/lib/nodeFetcher.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,2BAA6B;AAC7B,6BAA+B;AAE/B,mCAA6B;AAM7B;;GAEG;AACH,IAAM,GAAG,GAAY,UAAC,GAAG;IAAE,cAAO;SAAP,UAAO,EAAP,qBAAO,EAAP,IAAO;QAAP,6BAAO;;IAChC,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE;QAC3B,OAAO;YACL,EAAE,YAAC,SAAS,EAAE,QAAQ;gBACpB,QAAQ,CAAC,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC,CAAC;YAC/C,CAAC;SACoB,CAAC;KACzB;IACD,OAAO,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC;QAClC,CAAC,CAAC,KAAK,CAAC,GAAG,OAAT,KAAK,iBAAK,GAAG,GAAK,IAAI,UACxB,CAAC,CAAC,IAAI,CAAC,GAAG,OAAR,IAAI,iBAAK,GAAG,GAAK,IAAI,SAAC,CAAC;AAC7B,CAAC,CAAC;AAEF;;GAEG;AACH,IAAM,WAAW,GAAY,UAAA,GAAG;IAC9B,OAAA,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;QAC1B,GAAG,CAAC,GAAG,EAAE,UAAA,GAAG;YACV,IAAI,GAAG,CAAC,UAAU,KAAK,WAAE,EAAE;gBACzB,OAAO,MAAM,CAAC,IAAI,KAAK,CAAC,0BAAwB,GAAG,CAAC,UAAU,SAAI,GAAG,CAAC,aAAa,UAAK,GAAG,MAAG,CAAC,CAAC,CAAA;aACjG;YAED,IAAI,IAAI,GAAG,IAAI,CAAC;YAEhB,wCAAwC;YACxC,GAAG,CAAC,EAAE,CAAC,MAAM,EAAE,UAAA,KAAK;gBAClB,IAAI,IAAI,KAAK,IAAI,EAAE;oBACjB,IAAI,GAAG,KAAK,CAAC;oBACb,OAAO;iBACR;gBACD,IAAI,IAAI,KAAK,CAAC;YAChB,CAAC,CAAC,CAAC;YAEH,iDAAiD;YACjD,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,cAAM,OAAA,OAAO,CAAC,IAAI,CAAC,EAAb,CAAa,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACzB,CAAC,CAAC;AApBF,CAoBE,CAAC;AAEL,qBAAe,WAAW,CAAC"}
1
+ {"version":3,"file":"nodeFetcher.js","sourceRoot":"","sources":["../../src/lib/nodeFetcher.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,2BAA6B;AAC7B,6BAA+B;AAE/B,mCAA6B;AAM7B;;GAEG;AACH,IAAM,GAAG,GAAY,UAAC,GAAG;IAAE,cAAO;SAAP,UAAO,EAAP,qBAAO,EAAP,IAAO;QAAP,6BAAO;;IAChC,IAAI,OAAO,GAAG,KAAK,QAAQ,EAAE;QAC3B,OAAO;YACL,EAAE,YAAC,SAAS,EAAE,QAAQ;gBACpB,QAAQ,CAAC,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC,CAAC;YAC/C,CAAC;SACoB,CAAC;KACzB;IACD,OAAO,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC;QAClC,CAAC,CAAC,KAAK,CAAC,GAAG,OAAT,KAAK,iBAAK,GAAG,GAAK,IAAI,UACxB,CAAC,CAAC,IAAI,CAAC,GAAG,OAAR,IAAI,iBAAK,GAAG,GAAK,IAAI,SAAC,CAAC;AAC7B,CAAC,CAAC;AAEF;;GAEG;AACH,IAAM,WAAW,GAAY,UAAA,GAAG;IAC9B,OAAA,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;QAC1B,GAAG,CAAC,GAAG,EAAE,UAAA,GAAG;YACV,IAAI,GAAG,CAAC,UAAU,KAAK,WAAE,EAAE;gBACzB,OAAO,MAAM,CAAC,IAAI,KAAK,CAAC,+BAAwB,GAAG,CAAC,UAAU,cAAI,GAAG,CAAC,aAAa,eAAK,GAAG,MAAG,CAAC,CAAC,CAAA;aACjG;YAED,IAAI,IAAI,GAAG,IAAI,CAAC;YAEhB,wCAAwC;YACxC,GAAG,CAAC,EAAE,CAAC,MAAM,EAAE,UAAA,KAAK;gBAClB,IAAI,IAAI,KAAK,IAAI,EAAE;oBACjB,IAAI,GAAG,KAAK,CAAC;oBACb,OAAO;iBACR;gBACD,IAAI,IAAI,KAAK,CAAC;YAChB,CAAC,CAAC,CAAC;YAEH,iDAAiD;YACjD,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,cAAM,OAAA,OAAO,CAAC,IAAI,CAAC,EAAb,CAAa,CAAC,CAAC;YAEnC,wCAAwC;YACxC,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE;gBACd,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE;oBACjB,MAAM,CAAC,IAAI,KAAK,CAAC,0DAAmD,GAAG,MAAG,CAAC,CAAC,CAAC;iBAC9E;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACzB,CAAC,CAAC;AA3BF,CA2BE,CAAC;AAEL,qBAAe,WAAW,CAAC"}
@@ -10,7 +10,7 @@ var xmlHttpRequestFetcher = function (url) {
10
10
  return;
11
11
  xhr.status === status_1.OK
12
12
  ? resolve(xhr.responseText)
13
- : reject(new Error("HTTP Error Response: " + xhr.status + " " + xhr.statusText + " (" + url + ")"));
13
+ : reject(new Error("HTTP Error Response: ".concat(xhr.status, " ").concat(xhr.statusText, " (").concat(url, ")")));
14
14
  };
15
15
  xhr.open("GET", url, true);
16
16
  xhr.send();
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/lib/xmlHttpRequestFetcher/index.ts"],"names":[],"mappings":";;AACA,oCAA+B;AAC/B,2CAAoC;AAEpC,IAAM,qBAAqB,GAAY,UAAA,GAAG;IACxC,OAAA,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;QAC1B,IAAM,GAAG,GAAG,IAAI,cAAc,EAAE,CAAC;QACjC,GAAG,CAAC,kBAAkB,GAAG;YACvB,IAAI,GAAG,CAAC,UAAU,KAAK,iBAAI;gBAAE,OAAO;YACpC,GAAG,CAAC,MAAM,KAAK,WAAE;gBACf,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC;gBAC3B,CAAC,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,0BAAwB,GAAG,CAAC,MAAM,SAAI,GAAG,CAAC,UAAU,UAAK,GAAG,MAAG,CAAC,CAAC,CAAA;QACxF,CAAC,CAAC;QACF,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAC3B,GAAG,CAAC,IAAI,EAAE,CAAC;IACb,CAAC,CAAC;AAVF,CAUE,CAAC;AAEL,qBAAe,qBAAqB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/lib/xmlHttpRequestFetcher/index.ts"],"names":[],"mappings":";;AACA,oCAA+B;AAC/B,2CAAoC;AAEpC,IAAM,qBAAqB,GAAY,UAAA,GAAG;IACxC,OAAA,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;QAC1B,IAAM,GAAG,GAAG,IAAI,cAAc,EAAE,CAAC;QACjC,GAAG,CAAC,kBAAkB,GAAG;YACvB,IAAI,GAAG,CAAC,UAAU,KAAK,iBAAI;gBAAE,OAAO;YACpC,GAAG,CAAC,MAAM,KAAK,WAAE;gBACf,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC;gBAC3B,CAAC,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,+BAAwB,GAAG,CAAC,MAAM,cAAI,GAAG,CAAC,UAAU,eAAK,GAAG,MAAG,CAAC,CAAC,CAAA;QACxF,CAAC,CAAC;QACF,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,CAAC,CAAC;QAC3B,GAAG,CAAC,IAAI,EAAE,CAAC;IACb,CAAC,CAAC;AAVF,CAUE,CAAC;AAEL,qBAAe,qBAAqB,CAAC"}
@@ -0,0 +1,45 @@
1
+ {
2
+ "scan": {
3
+ "analyzer": {
4
+ "id": "semgrep",
5
+ "name": "Semgrep",
6
+ "url": "https://gitlab.com/gitlab-org/security-products/analyzers/semgrep",
7
+ "vendor": {
8
+ "name": "GitLab"
9
+ },
10
+ "version": "6.14.0"
11
+ },
12
+ "scanner": {
13
+ "id": "semgrep",
14
+ "name": "Semgrep",
15
+ "url": "https://github.com/returntocorp/semgrep",
16
+ "vendor": {
17
+ "name": "GitLab"
18
+ },
19
+ "version": "1.145.0"
20
+ },
21
+ "type": "sast",
22
+ "start_time": "2026-03-03T00:06:40",
23
+ "end_time": "2026-03-03T00:06:54",
24
+ "status": "success",
25
+ "observability": {
26
+ "events": [
27
+ {
28
+ "event": "collect_sast_scan_metrics_from_pipeline",
29
+ "property": "8b093df0-0c50-48b3-a592-48b84daca42d",
30
+ "label": "semgrep",
31
+ "value": 0,
32
+ "version": "6.14.0",
33
+ "exit_code": 0,
34
+ "override_count": 0,
35
+ "passthrough_count": 4,
36
+ "custom_exclude_path_count": 0,
37
+ "time_s": 13,
38
+ "file_count": 20
39
+ }
40
+ ]
41
+ }
42
+ },
43
+ "version": "15.2.2",
44
+ "vulnerabilities": []
45
+ }