@contrast/agent-bundle 5.42.0 → 5.46.0

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 (484) hide show
  1. package/README.md +1 -10
  2. package/node_modules/@contrast/agent/README.md +1 -10
  3. package/node_modules/@contrast/agent/package.json +12 -12
  4. package/node_modules/@contrast/agent-swc-plugin/package.json +3 -3
  5. package/node_modules/@contrast/agentify/lib/rewrite-hooks.js +3 -3
  6. package/node_modules/@contrast/agentify/lib/utils.js +13 -7
  7. package/node_modules/@contrast/agentify/package.json +17 -17
  8. package/node_modules/@contrast/architecture-components/package.json +6 -6
  9. package/node_modules/@contrast/assess/lib/dataflow/propagation/install/ejs/template.js +1 -1
  10. package/node_modules/@contrast/assess/lib/dataflow/propagation/install/pug/index.js +1 -1
  11. package/node_modules/@contrast/assess/lib/dataflow/sinks/install/http/server-response.js +1 -12
  12. package/node_modules/@contrast/assess/lib/dataflow/sinks/install/restify.js +1 -1
  13. package/node_modules/@contrast/assess/lib/dataflow/sources/handler.js +21 -24
  14. package/node_modules/@contrast/assess/lib/dataflow/sources/install/http.js +1 -1
  15. package/node_modules/@contrast/assess/lib/dataflow/tracker.js +1 -1
  16. package/node_modules/@contrast/assess/lib/get-source-context.js +11 -22
  17. package/node_modules/@contrast/assess/lib/index.js +1 -1
  18. package/node_modules/@contrast/assess/lib/make-source-context.js +5 -10
  19. package/node_modules/@contrast/assess/lib/policy.js +400 -0
  20. package/node_modules/@contrast/assess/lib/response-scanning/handlers/index.js +10 -14
  21. package/node_modules/@contrast/assess/lib/response-scanning/install/http.js +0 -12
  22. package/node_modules/@contrast/assess/lib/session-configuration/handlers.js +1 -1
  23. package/node_modules/@contrast/assess/package.json +14 -14
  24. package/node_modules/@contrast/code-events/binding.gyp +1 -1
  25. package/node_modules/@contrast/code-events/package.json +11 -9
  26. package/node_modules/@contrast/code-events/prebuilds/darwin-x64+arm64/@contrast+code-events.abi108.node +0 -0
  27. package/node_modules/@contrast/code-events/prebuilds/darwin-x64+arm64/@contrast+code-events.abi115.node +0 -0
  28. package/node_modules/@contrast/code-events/prebuilds/darwin-x64+arm64/@contrast+code-events.abi127.node +0 -0
  29. package/node_modules/@contrast/code-events/prebuilds/darwin-x64+arm64/{@contrast+code-events.abi93.node → @contrast+code-events.abi137.node} +0 -0
  30. package/node_modules/@contrast/code-events/prebuilds/linux-arm64/@contrast+code-events.abi108.armv8.node +0 -0
  31. package/node_modules/@contrast/code-events/prebuilds/linux-arm64/@contrast+code-events.abi115.armv8.node +0 -0
  32. package/node_modules/@contrast/code-events/prebuilds/linux-arm64/@contrast+code-events.abi127.armv8.node +0 -0
  33. package/node_modules/@contrast/code-events/prebuilds/linux-arm64/@contrast+code-events.abi137.armv8.node +0 -0
  34. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi108.glibc.node +0 -0
  35. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi108.musl.node +0 -0
  36. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi115.glibc.node +0 -0
  37. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi115.musl.node +0 -0
  38. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi127.glibc.node +0 -0
  39. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi127.musl.node +0 -0
  40. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi137.glibc.node +0 -0
  41. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi137.musl.node +0 -0
  42. package/node_modules/@contrast/code-events/prebuilds/win32-x64/@contrast+code-events.abi108.node +0 -0
  43. package/node_modules/@contrast/code-events/prebuilds/win32-x64/@contrast+code-events.abi115.node +0 -0
  44. package/node_modules/@contrast/code-events/prebuilds/win32-x64/@contrast+code-events.abi127.node +0 -0
  45. package/node_modules/@contrast/code-events/prebuilds/win32-x64/@contrast+code-events.abi137.node +0 -0
  46. package/node_modules/@contrast/common/lib/constants.d.ts +1 -1
  47. package/node_modules/@contrast/common/lib/constants.js +1 -1
  48. package/node_modules/@contrast/common/lib/index.js +15 -15
  49. package/node_modules/@contrast/common/lib/primordials.d.ts +22 -20
  50. package/node_modules/@contrast/common/lib/types.d.ts +18 -6
  51. package/node_modules/@contrast/common/package.json +2 -2
  52. package/node_modules/@contrast/config/lib/options.js +37 -4
  53. package/node_modules/@contrast/config/package.json +4 -4
  54. package/node_modules/@contrast/core/lib/app-info.js +53 -74
  55. package/node_modules/@contrast/core/lib/index.d.ts +17 -1
  56. package/node_modules/@contrast/core/lib/sensitive-data-masking/index.js +33 -5
  57. package/node_modules/@contrast/core/package.json +10 -9
  58. package/node_modules/@contrast/deadzones/package.json +6 -6
  59. package/node_modules/@contrast/dep-hooks/lib/export-handler-registry.d.ts +17 -13
  60. package/node_modules/@contrast/dep-hooks/lib/export-handler-registry.js +16 -4
  61. package/node_modules/@contrast/dep-hooks/lib/export-hook-descriptor.d.ts +2 -2
  62. package/node_modules/@contrast/dep-hooks/lib/export-hook-descriptor.js +2 -3
  63. package/node_modules/@contrast/dep-hooks/lib/handler-invoker.d.ts +6 -6
  64. package/node_modules/@contrast/dep-hooks/lib/handler-invoker.js +0 -1
  65. package/node_modules/@contrast/dep-hooks/lib/helpers.d.ts +0 -7
  66. package/node_modules/@contrast/dep-hooks/lib/helpers.js +2 -18
  67. package/node_modules/@contrast/dep-hooks/lib/index.d.ts +17 -12
  68. package/node_modules/@contrast/dep-hooks/lib/index.js +5 -3
  69. package/node_modules/@contrast/dep-hooks/lib/package-finder.d.ts +2 -1
  70. package/node_modules/@contrast/dep-hooks/lib/package-finder.js +6 -6
  71. package/node_modules/@contrast/dep-hooks/package.json +4 -3
  72. package/node_modules/@contrast/distringuish/package.json +7 -6
  73. package/node_modules/@contrast/distringuish/prebuilds/darwin-x64+arm64/@contrast+distringuish.abi108.node +0 -0
  74. package/node_modules/@contrast/distringuish/prebuilds/darwin-x64+arm64/@contrast+distringuish.abi115.node +0 -0
  75. package/node_modules/@contrast/distringuish/prebuilds/darwin-x64+arm64/@contrast+distringuish.abi127.node +0 -0
  76. package/node_modules/@contrast/distringuish/prebuilds/darwin-x64+arm64/{@contrast+distringuish.abi93.node → @contrast+distringuish.abi137.node} +0 -0
  77. package/node_modules/@contrast/distringuish/prebuilds/linux-arm64/@contrast+distringuish.abi108.armv8.node +0 -0
  78. package/node_modules/@contrast/distringuish/prebuilds/linux-arm64/@contrast+distringuish.abi115.armv8.node +0 -0
  79. package/node_modules/@contrast/distringuish/prebuilds/linux-arm64/@contrast+distringuish.abi127.armv8.node +0 -0
  80. package/node_modules/@contrast/distringuish/prebuilds/linux-arm64/@contrast+distringuish.abi137.armv8.node +0 -0
  81. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi108.glibc.node +0 -0
  82. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi108.musl.node +0 -0
  83. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi115.glibc.node +0 -0
  84. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi115.musl.node +0 -0
  85. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi127.glibc.node +0 -0
  86. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi127.musl.node +0 -0
  87. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi137.glibc.node +0 -0
  88. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi137.musl.node +0 -0
  89. package/node_modules/@contrast/distringuish/prebuilds/win32-x64/@contrast+distringuish.abi108.node +0 -0
  90. package/node_modules/@contrast/distringuish/prebuilds/win32-x64/@contrast+distringuish.abi115.node +0 -0
  91. package/node_modules/@contrast/distringuish/prebuilds/win32-x64/@contrast+distringuish.abi127.node +0 -0
  92. package/node_modules/@contrast/distringuish/prebuilds/win32-x64/@contrast+distringuish.abi137.node +0 -0
  93. package/node_modules/@contrast/esm-hooks/lib/debug-methods.mjs +4 -4
  94. package/node_modules/@contrast/esm-hooks/lib/get-file-type.mjs +2 -9
  95. package/node_modules/@contrast/esm-hooks/lib/hooks.mjs +0 -2
  96. package/node_modules/@contrast/esm-hooks/lib/redirects/builtin/fs/promises.mjs +2 -0
  97. package/node_modules/@contrast/esm-hooks/lib/redirects/builtin/fs.mjs +3 -0
  98. package/node_modules/@contrast/esm-hooks/lib/redirects/builtin/util.mjs +1 -0
  99. package/node_modules/@contrast/esm-hooks/package.json +7 -7
  100. package/node_modules/@contrast/fn-inspect/package.json +9 -5
  101. package/node_modules/@contrast/fn-inspect/prebuilds/darwin-x64+arm64/@contrast+fn-inspect.abi108.node +0 -0
  102. package/node_modules/@contrast/fn-inspect/prebuilds/darwin-x64+arm64/@contrast+fn-inspect.abi115.node +0 -0
  103. package/node_modules/@contrast/fn-inspect/prebuilds/darwin-x64+arm64/@contrast+fn-inspect.abi127.node +0 -0
  104. package/node_modules/@contrast/fn-inspect/prebuilds/darwin-x64+arm64/{@contrast+fn-inspect.abi93.node → @contrast+fn-inspect.abi137.node} +0 -0
  105. package/node_modules/@contrast/fn-inspect/prebuilds/linux-arm64/@contrast+fn-inspect.abi108.armv8.node +0 -0
  106. package/node_modules/@contrast/fn-inspect/prebuilds/linux-arm64/@contrast+fn-inspect.abi115.armv8.node +0 -0
  107. package/node_modules/@contrast/fn-inspect/prebuilds/linux-arm64/@contrast+fn-inspect.abi127.armv8.node +0 -0
  108. package/node_modules/@contrast/fn-inspect/prebuilds/linux-arm64/@contrast+fn-inspect.abi137.armv8.node +0 -0
  109. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi108.glibc.node +0 -0
  110. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi108.musl.node +0 -0
  111. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi115.glibc.node +0 -0
  112. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi115.musl.node +0 -0
  113. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi127.glibc.node +0 -0
  114. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi127.musl.node +0 -0
  115. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi137.glibc.node +0 -0
  116. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/{@contrast+fn-inspect.abi93.musl.node → @contrast+fn-inspect.abi137.musl.node} +0 -0
  117. package/node_modules/@contrast/fn-inspect/prebuilds/win32-x64/@contrast+fn-inspect.abi108.node +0 -0
  118. package/node_modules/@contrast/fn-inspect/prebuilds/win32-x64/@contrast+fn-inspect.abi115.node +0 -0
  119. package/node_modules/@contrast/fn-inspect/prebuilds/win32-x64/@contrast+fn-inspect.abi127.node +0 -0
  120. package/node_modules/@contrast/fn-inspect/prebuilds/win32-x64/@contrast+fn-inspect.abi137.node +0 -0
  121. package/node_modules/@contrast/instrumentation/lib/http2.js +0 -11
  122. package/node_modules/@contrast/instrumentation/package.json +6 -6
  123. package/node_modules/@contrast/library-analysis/lib/install/library-reporting/dep.json +312 -224
  124. package/node_modules/@contrast/library-analysis/package.json +6 -6
  125. package/node_modules/@contrast/logger/lib/index.js +18 -8
  126. package/node_modules/@contrast/logger/lib/serializers.js +5 -5
  127. package/node_modules/@contrast/logger/lib/utils.d.ts +0 -6
  128. package/node_modules/@contrast/logger/package.json +4 -4
  129. package/node_modules/@contrast/metrics/lib/index.d.ts +6 -6
  130. package/node_modules/@contrast/metrics/lib/index.js +0 -1
  131. package/node_modules/@contrast/metrics/package.json +7 -7
  132. package/node_modules/@contrast/patcher/package.json +3 -3
  133. package/node_modules/@contrast/perf/package.json +7 -4
  134. package/node_modules/@contrast/protect/lib/hardening/handlers.js +37 -21
  135. package/node_modules/@contrast/protect/lib/index.d.ts +3 -2
  136. package/node_modules/@contrast/protect/lib/index.js +9 -2
  137. package/node_modules/@contrast/protect/lib/input-analysis/handlers.js +269 -238
  138. package/node_modules/@contrast/protect/lib/input-analysis/install/http.js +3 -4
  139. package/node_modules/@contrast/protect/lib/input-tracing/{handlers/index.js → handlers.js} +15 -15
  140. package/node_modules/@contrast/protect/lib/input-tracing/index.js +0 -1
  141. package/node_modules/@contrast/protect/lib/make-source-context.js +5 -7
  142. package/node_modules/@contrast/protect/lib/policy.js +130 -95
  143. package/node_modules/@contrast/protect/lib/semantic-analysis/handlers.js +19 -18
  144. package/node_modules/@contrast/protect/package.json +12 -12
  145. package/node_modules/@contrast/reporter/lib/index.js +1 -1
  146. package/node_modules/@contrast/reporter/lib/reporters/base.d.ts +0 -1
  147. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/application-activity/index.d.ts +4 -2
  148. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/application-activity/index.js +14 -14
  149. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/application-activity/translations.d.ts +43 -6
  150. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/application-activity/translations.js +262 -429
  151. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/server-inventory.d.ts +3 -3
  152. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/traces/index.js +17 -7
  153. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/traces/translations.js +12 -13
  154. package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/utils.js +6 -7
  155. package/node_modules/@contrast/reporter/lib/reporters/file.js +1 -1
  156. package/node_modules/@contrast/reporter/lib/reporters/security-logger/index.d.ts +2 -3
  157. package/node_modules/@contrast/reporter/lib/reporters/security-logger/index.js +72 -86
  158. package/node_modules/@contrast/reporter/lib/reporters/security-logger/messages.js +6 -7
  159. package/node_modules/@contrast/reporter/lib/validators.js +0 -1
  160. package/node_modules/@contrast/reporter/node_modules/sonic-boom/.husky/pre-commit +2 -2
  161. package/node_modules/@contrast/reporter/node_modules/sonic-boom/.taprc +5 -0
  162. package/node_modules/@contrast/reporter/node_modules/sonic-boom/README.md +2 -4
  163. package/node_modules/@contrast/reporter/node_modules/sonic-boom/bench.js +5 -36
  164. package/node_modules/@contrast/reporter/node_modules/sonic-boom/index.js +56 -300
  165. package/node_modules/@contrast/reporter/node_modules/sonic-boom/package.json +12 -7
  166. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test.js +1684 -0
  167. package/node_modules/@contrast/reporter/node_modules/sonic-boom/types/index.d.ts +1 -2
  168. package/node_modules/@contrast/reporter/package.json +10 -10
  169. package/node_modules/@contrast/rewriter/lib/index.js +5 -43
  170. package/node_modules/@contrast/rewriter/package.json +8 -8
  171. package/node_modules/@contrast/route-coverage/lib/install/express/express5.js +0 -5
  172. package/node_modules/@contrast/route-coverage/lib/install/restify.js +1 -1
  173. package/node_modules/@contrast/route-coverage/package.json +10 -10
  174. package/node_modules/@contrast/scopes/package.json +6 -6
  175. package/node_modules/@contrast/sec-obs/lib/traces/http.js +1 -1
  176. package/node_modules/@contrast/sec-obs/lib/traces/http.test.js +1 -1
  177. package/node_modules/@contrast/sec-obs/package.json +10 -10
  178. package/node_modules/@contrast/sources/lib/index.js +1 -1
  179. package/node_modules/@contrast/sources/lib/index.test.js +0 -26
  180. package/node_modules/@contrast/sources/package.json +3 -3
  181. package/node_modules/@contrast/telemetry/package.json +6 -6
  182. package/node_modules/@opentelemetry/semantic-conventions/README.md +3 -2
  183. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.d.ts +4350 -2882
  184. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.js +4350 -2882
  185. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.js.map +1 -1
  186. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_events.d.ts +136 -0
  187. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_events.js +154 -0
  188. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_events.js.map +1 -0
  189. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.d.ts +713 -141
  190. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.js +713 -141
  191. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.js.map +1 -1
  192. package/node_modules/@opentelemetry/semantic-conventions/build/esm/index-incubating.d.ts +2 -0
  193. package/node_modules/@opentelemetry/semantic-conventions/build/esm/index-incubating.js +2 -0
  194. package/node_modules/@opentelemetry/semantic-conventions/build/esm/index-incubating.js.map +1 -1
  195. package/node_modules/@opentelemetry/semantic-conventions/build/esm/index.d.ts +1 -0
  196. package/node_modules/@opentelemetry/semantic-conventions/build/esm/index.js +1 -0
  197. package/node_modules/@opentelemetry/semantic-conventions/build/esm/index.js.map +1 -1
  198. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.d.ts +7 -1
  199. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js +7 -1
  200. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js.map +1 -1
  201. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_events.d.ts +5 -0
  202. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_events.js +23 -0
  203. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_events.js.map +1 -0
  204. package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.d.ts +1 -1
  205. package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.js +1 -1
  206. package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.js.map +1 -1
  207. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.d.ts +4350 -2882
  208. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.js +4350 -2882
  209. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.js.map +1 -1
  210. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_events.d.ts +136 -0
  211. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_events.js +154 -0
  212. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_events.js.map +1 -0
  213. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.d.ts +713 -141
  214. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.js +713 -141
  215. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.js.map +1 -1
  216. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/index-incubating.d.ts +2 -0
  217. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/index-incubating.js +2 -0
  218. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/index-incubating.js.map +1 -1
  219. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/index.d.ts +1 -0
  220. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/index.js +1 -0
  221. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/index.js.map +1 -1
  222. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.d.ts +7 -1
  223. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.js +7 -1
  224. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.js.map +1 -1
  225. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_events.d.ts +5 -0
  226. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_events.js +23 -0
  227. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_events.js.map +1 -0
  228. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.d.ts +1 -1
  229. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.js +1 -1
  230. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.js.map +1 -1
  231. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.d.ts +4350 -2882
  232. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.js +4354 -2883
  233. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.js.map +1 -1
  234. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_events.d.ts +136 -0
  235. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_events.js +157 -0
  236. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_events.js.map +1 -0
  237. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.d.ts +713 -141
  238. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.js +720 -147
  239. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.js.map +1 -1
  240. package/node_modules/@opentelemetry/semantic-conventions/build/src/index-incubating.d.ts +2 -0
  241. package/node_modules/@opentelemetry/semantic-conventions/build/src/index-incubating.js +2 -0
  242. package/node_modules/@opentelemetry/semantic-conventions/build/src/index-incubating.js.map +1 -1
  243. package/node_modules/@opentelemetry/semantic-conventions/build/src/index.d.ts +1 -0
  244. package/node_modules/@opentelemetry/semantic-conventions/build/src/index.js +1 -0
  245. package/node_modules/@opentelemetry/semantic-conventions/build/src/index.js.map +1 -1
  246. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.d.ts +7 -1
  247. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.js +10 -4
  248. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.js.map +1 -1
  249. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_events.d.ts +5 -0
  250. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_events.js +26 -0
  251. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_events.js.map +1 -0
  252. package/node_modules/@opentelemetry/semantic-conventions/build/src/version.d.ts +1 -1
  253. package/node_modules/@opentelemetry/semantic-conventions/build/src/version.js +1 -1
  254. package/node_modules/@opentelemetry/semantic-conventions/build/src/version.js.map +1 -1
  255. package/node_modules/@opentelemetry/semantic-conventions/package.json +6 -7
  256. package/node_modules/@swc/core/README.md +5 -0
  257. package/node_modules/@swc/core/binding.d.ts +2 -2
  258. package/node_modules/@swc/core/index.d.ts +5 -4
  259. package/node_modules/@swc/core/index.js +2 -2
  260. package/node_modules/@swc/core/package.json +12 -12
  261. package/node_modules/@swc/core-darwin-arm64/package.json +1 -1
  262. package/node_modules/@swc/core-darwin-arm64/swc.darwin-arm64.node +0 -0
  263. package/node_modules/@swc/core-darwin-x64/package.json +1 -1
  264. package/node_modules/@swc/core-darwin-x64/swc.darwin-x64.node +0 -0
  265. package/node_modules/@swc/core-linux-arm64-gnu/package.json +1 -1
  266. package/node_modules/@swc/core-linux-arm64-gnu/swc.linux-arm64-gnu.node +0 -0
  267. package/node_modules/@swc/core-linux-arm64-musl/package.json +1 -1
  268. package/node_modules/@swc/core-linux-arm64-musl/swc.linux-arm64-musl.node +0 -0
  269. package/node_modules/@swc/core-linux-x64-gnu/package.json +1 -1
  270. package/node_modules/@swc/core-linux-x64-gnu/swc.linux-x64-gnu.node +0 -0
  271. package/node_modules/@swc/core-linux-x64-musl/package.json +1 -1
  272. package/node_modules/@swc/core-linux-x64-musl/swc.linux-x64-musl.node +0 -0
  273. package/node_modules/@swc/core-win32-arm64-msvc/package.json +1 -1
  274. package/node_modules/@swc/core-win32-arm64-msvc/swc.win32-arm64-msvc.node +0 -0
  275. package/node_modules/@swc/core-win32-x64-msvc/package.json +1 -1
  276. package/node_modules/@swc/core-win32-x64-msvc/swc.win32-x64-msvc.node +0 -0
  277. package/node_modules/@swc/types/index.d.ts +14 -5
  278. package/node_modules/@swc/types/package.json +2 -2
  279. package/node_modules/@types/node/README.md +1 -1
  280. package/node_modules/@types/node/assert/strict.d.ts +105 -2
  281. package/node_modules/@types/node/assert.d.ts +119 -95
  282. package/node_modules/@types/node/buffer.d.ts +1 -1
  283. package/node_modules/@types/node/child_process.d.ts +26 -122
  284. package/node_modules/@types/node/crypto.d.ts +161 -17
  285. package/node_modules/@types/node/dns.d.ts +5 -0
  286. package/node_modules/@types/node/events.d.ts +79 -33
  287. package/node_modules/@types/node/fs/promises.d.ts +41 -26
  288. package/node_modules/@types/node/fs.d.ts +276 -35
  289. package/node_modules/@types/node/globals.d.ts +148 -347
  290. package/node_modules/@types/node/http.d.ts +57 -8
  291. package/node_modules/@types/node/https.d.ts +5 -0
  292. package/node_modules/@types/node/index.d.ts +7 -2
  293. package/node_modules/@types/node/inspector.d.ts +187 -4089
  294. package/node_modules/@types/node/inspector.generated.d.ts +4052 -0
  295. package/node_modules/@types/node/module.d.ts +1 -0
  296. package/node_modules/@types/node/net.d.ts +21 -0
  297. package/node_modules/@types/node/package.json +3 -3
  298. package/node_modules/@types/node/sqlite.d.ts +34 -0
  299. package/node_modules/@types/node/test.d.ts +106 -23
  300. package/node_modules/@types/node/tls.d.ts +32 -0
  301. package/node_modules/@types/node/ts5.6/index.d.ts +7 -2
  302. package/node_modules/@types/node/ts5.7/index.d.ts +7 -2
  303. package/node_modules/@types/node/url.d.ts +25 -6
  304. package/node_modules/@types/node/util.d.ts +11 -4
  305. package/node_modules/@types/node/vm.d.ts +73 -10
  306. package/node_modules/@types/node/wasi.d.ts +21 -0
  307. package/node_modules/@types/node/web-globals/abortcontroller.d.ts +34 -0
  308. package/node_modules/@types/node/web-globals/domexception.d.ts +68 -0
  309. package/node_modules/@types/node/{dom-events.d.ts → web-globals/events.d.ts} +49 -51
  310. package/node_modules/@types/node/web-globals/fetch.d.ts +50 -0
  311. package/node_modules/@types/node/web-globals/navigator.d.ts +25 -0
  312. package/node_modules/@types/node/web-globals/storage.d.ts +24 -0
  313. package/node_modules/@types/node/worker_threads.d.ts +84 -50
  314. package/node_modules/@types/node/zlib.d.ts +6 -0
  315. package/node_modules/axios/CHANGELOG.md +58 -0
  316. package/node_modules/axios/README.md +87 -10
  317. package/node_modules/axios/dist/axios.js +355 -289
  318. package/node_modules/axios/dist/axios.js.map +1 -1
  319. package/node_modules/axios/dist/axios.min.js +2 -2
  320. package/node_modules/axios/dist/axios.min.js.map +1 -1
  321. package/node_modules/axios/dist/browser/axios.cjs +286 -213
  322. package/node_modules/axios/dist/browser/axios.cjs.map +1 -1
  323. package/node_modules/axios/dist/esm/axios.js +286 -213
  324. package/node_modules/axios/dist/esm/axios.js.map +1 -1
  325. package/node_modules/axios/dist/esm/axios.min.js +2 -2
  326. package/node_modules/axios/dist/esm/axios.min.js.map +1 -1
  327. package/node_modules/axios/dist/node/axios.cjs +377 -213
  328. package/node_modules/axios/dist/node/axios.cjs.map +1 -1
  329. package/node_modules/axios/index.d.cts +12 -5
  330. package/node_modules/axios/index.d.ts +13 -4
  331. package/node_modules/axios/lib/adapters/adapters.js +6 -4
  332. package/node_modules/axios/lib/adapters/fetch.js +221 -162
  333. package/node_modules/axios/lib/adapters/http.js +18 -0
  334. package/node_modules/axios/lib/adapters/xhr.js +11 -8
  335. package/node_modules/axios/lib/core/Axios.js +0 -2
  336. package/node_modules/axios/lib/core/AxiosError.js +10 -3
  337. package/node_modules/axios/lib/core/dispatchRequest.js +1 -1
  338. package/node_modules/axios/lib/defaults/index.js +1 -1
  339. package/node_modules/axios/lib/env/data.js +1 -1
  340. package/node_modules/axios/lib/helpers/buildURL.js +1 -3
  341. package/node_modules/axios/lib/helpers/estimateDataURLDecodedBytes.js +73 -0
  342. package/node_modules/axios/lib/helpers/resolveConfig.js +13 -9
  343. package/node_modules/axios/lib/utils.js +5 -3
  344. package/node_modules/axios/package.json +18 -12
  345. package/node_modules/balanced-match/.github/FUNDING.yml +2 -0
  346. package/node_modules/balanced-match/LICENSE.md +21 -0
  347. package/node_modules/balanced-match/README.md +97 -0
  348. package/node_modules/balanced-match/index.js +62 -0
  349. package/node_modules/balanced-match/package.json +48 -0
  350. package/node_modules/brace-expansion/.github/FUNDING.yml +2 -0
  351. package/node_modules/brace-expansion/LICENSE +21 -0
  352. package/node_modules/brace-expansion/README.md +135 -0
  353. package/node_modules/brace-expansion/index.js +203 -0
  354. package/node_modules/brace-expansion/package.json +49 -0
  355. package/node_modules/detect-libc/lib/detect-libc.js +59 -13
  356. package/node_modules/detect-libc/lib/elf.js +39 -0
  357. package/node_modules/detect-libc/lib/filesystem.js +18 -8
  358. package/node_modules/detect-libc/package.json +3 -2
  359. package/node_modules/minimatch/LICENSE +15 -0
  360. package/node_modules/minimatch/README.md +454 -0
  361. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts +2 -0
  362. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts.map +1 -0
  363. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +14 -0
  364. package/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js.map +1 -0
  365. package/node_modules/minimatch/dist/commonjs/ast.d.ts +20 -0
  366. package/node_modules/minimatch/dist/commonjs/ast.d.ts.map +1 -0
  367. package/node_modules/minimatch/dist/commonjs/ast.js +592 -0
  368. package/node_modules/minimatch/dist/commonjs/ast.js.map +1 -0
  369. package/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts +8 -0
  370. package/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts.map +1 -0
  371. package/node_modules/minimatch/dist/commonjs/brace-expressions.js +152 -0
  372. package/node_modules/minimatch/dist/commonjs/brace-expressions.js.map +1 -0
  373. package/node_modules/minimatch/dist/commonjs/escape.d.ts +12 -0
  374. package/node_modules/minimatch/dist/commonjs/escape.d.ts.map +1 -0
  375. package/node_modules/minimatch/dist/commonjs/escape.js +22 -0
  376. package/node_modules/minimatch/dist/commonjs/escape.js.map +1 -0
  377. package/node_modules/minimatch/dist/commonjs/index.d.ts +94 -0
  378. package/node_modules/minimatch/dist/commonjs/index.d.ts.map +1 -0
  379. package/node_modules/minimatch/dist/commonjs/index.js +1017 -0
  380. package/node_modules/minimatch/dist/commonjs/index.js.map +1 -0
  381. package/node_modules/minimatch/dist/commonjs/package.json +3 -0
  382. package/node_modules/minimatch/dist/commonjs/unescape.d.ts +17 -0
  383. package/node_modules/minimatch/dist/commonjs/unescape.d.ts.map +1 -0
  384. package/node_modules/minimatch/dist/commonjs/unescape.js +24 -0
  385. package/node_modules/minimatch/dist/commonjs/unescape.js.map +1 -0
  386. package/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts +2 -0
  387. package/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts.map +1 -0
  388. package/node_modules/minimatch/dist/esm/assert-valid-pattern.js +10 -0
  389. package/node_modules/minimatch/dist/esm/assert-valid-pattern.js.map +1 -0
  390. package/node_modules/minimatch/dist/esm/ast.d.ts +20 -0
  391. package/node_modules/minimatch/dist/esm/ast.d.ts.map +1 -0
  392. package/node_modules/minimatch/dist/esm/ast.js +588 -0
  393. package/node_modules/minimatch/dist/esm/ast.js.map +1 -0
  394. package/node_modules/minimatch/dist/esm/brace-expressions.d.ts +8 -0
  395. package/node_modules/minimatch/dist/esm/brace-expressions.d.ts.map +1 -0
  396. package/node_modules/minimatch/dist/esm/brace-expressions.js +148 -0
  397. package/node_modules/minimatch/dist/esm/brace-expressions.js.map +1 -0
  398. package/node_modules/minimatch/dist/esm/escape.d.ts +12 -0
  399. package/node_modules/minimatch/dist/esm/escape.d.ts.map +1 -0
  400. package/node_modules/minimatch/dist/esm/escape.js +18 -0
  401. package/node_modules/minimatch/dist/esm/escape.js.map +1 -0
  402. package/node_modules/minimatch/dist/esm/index.d.ts +94 -0
  403. package/node_modules/minimatch/dist/esm/index.d.ts.map +1 -0
  404. package/node_modules/minimatch/dist/esm/index.js +1001 -0
  405. package/node_modules/minimatch/dist/esm/index.js.map +1 -0
  406. package/node_modules/minimatch/dist/esm/package.json +3 -0
  407. package/node_modules/minimatch/dist/esm/unescape.d.ts +17 -0
  408. package/node_modules/minimatch/dist/esm/unescape.d.ts.map +1 -0
  409. package/node_modules/minimatch/dist/esm/unescape.js +20 -0
  410. package/node_modules/minimatch/dist/esm/unescape.js.map +1 -0
  411. package/node_modules/minimatch/package.json +82 -0
  412. package/node_modules/node-abi/LICENSE +21 -0
  413. package/node_modules/node-abi/README.md +54 -0
  414. package/node_modules/node-abi/abi_registry.json +408 -0
  415. package/node_modules/node-abi/getNextTarget.js +13 -0
  416. package/node_modules/node-abi/index.js +161 -0
  417. package/node_modules/node-abi/package.json +46 -0
  418. package/node_modules/node-addon-api/README.md +25 -249
  419. package/node_modules/node-addon-api/common.gypi +1 -0
  420. package/node_modules/node-addon-api/index.js +2 -0
  421. package/node_modules/node-addon-api/napi-inl.h +592 -166
  422. package/node_modules/node-addon-api/napi.h +167 -59
  423. package/node_modules/node-addon-api/node_addon_api.gyp +10 -0
  424. package/node_modules/node-addon-api/noexcept.gypi +1 -1
  425. package/node_modules/node-addon-api/package.json +13 -13
  426. package/node_modules/node-addon-api/tools/conversion.js +1 -1
  427. package/node_modules/protobufjs/dist/light/protobuf.js +2 -2
  428. package/node_modules/protobufjs/dist/light/protobuf.min.js +2 -2
  429. package/node_modules/protobufjs/dist/minimal/protobuf.js +2 -2
  430. package/node_modules/protobufjs/dist/minimal/protobuf.min.js +2 -2
  431. package/node_modules/protobufjs/dist/protobuf.js +2 -2
  432. package/node_modules/protobufjs/dist/protobuf.min.js +2 -2
  433. package/node_modules/protobufjs/google/protobuf/descriptor.json +2 -2
  434. package/node_modules/protobufjs/google/protobuf/descriptor.proto +2 -1
  435. package/node_modules/protobufjs/package.json +1 -1
  436. package/node_modules/undici-types/agent.d.ts +0 -4
  437. package/node_modules/undici-types/client.d.ts +0 -2
  438. package/node_modules/undici-types/diagnostics-channel.d.ts +9 -0
  439. package/node_modules/undici-types/dispatcher.d.ts +3 -8
  440. package/node_modules/undici-types/env-http-proxy-agent.d.ts +2 -1
  441. package/node_modules/undici-types/eventsource.d.ts +3 -3
  442. package/node_modules/undici-types/fetch.d.ts +1 -0
  443. package/node_modules/undici-types/h2c-client.d.ts +0 -2
  444. package/node_modules/undici-types/handlers.d.ts +1 -1
  445. package/node_modules/undici-types/index.d.ts +3 -1
  446. package/node_modules/undici-types/mock-client.d.ts +2 -0
  447. package/node_modules/undici-types/mock-interceptor.d.ts +2 -1
  448. package/node_modules/undici-types/mock-pool.d.ts +2 -0
  449. package/node_modules/undici-types/package.json +1 -1
  450. package/node_modules/undici-types/retry-handler.d.ts +9 -0
  451. package/node_modules/undici-types/snapshot-agent.d.ts +107 -0
  452. package/node_modules/undici-types/webidl.d.ts +29 -15
  453. package/node_modules/undici-types/websocket.d.ts +3 -1
  454. package/package.json +3 -3
  455. package/node_modules/@contrast/assess/lib/get-policy.js +0 -336
  456. package/node_modules/@contrast/code-events/prebuilds/linux-arm64/@contrast+code-events.abi93.armv8.node +0 -0
  457. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi93.glibc.node +0 -0
  458. package/node_modules/@contrast/code-events/prebuilds/linux-x64/@contrast+code-events.abi93.musl.node +0 -0
  459. package/node_modules/@contrast/code-events/prebuilds/win32-x64/@contrast+code-events.abi93.node +0 -0
  460. package/node_modules/@contrast/core/lib/sensitive-data-masking/protect-listener.js +0 -111
  461. package/node_modules/@contrast/distringuish/prebuilds/linux-arm64/@contrast+distringuish.abi93.armv8.node +0 -0
  462. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi93.glibc.node +0 -0
  463. package/node_modules/@contrast/distringuish/prebuilds/linux-x64/@contrast+distringuish.abi93.musl.node +0 -0
  464. package/node_modules/@contrast/distringuish/prebuilds/win32-x64/@contrast+distringuish.abi93.node +0 -0
  465. package/node_modules/@contrast/fn-inspect/prebuilds/linux-arm64/@contrast+fn-inspect.abi93.armv8.node +0 -0
  466. package/node_modules/@contrast/fn-inspect/prebuilds/linux-x64/@contrast+fn-inspect.abi93.glibc.node +0 -0
  467. package/node_modules/@contrast/fn-inspect/prebuilds/win32-x64/@contrast+fn-inspect.abi93.node +0 -0
  468. package/node_modules/@contrast/perf/lib/index.test.js +0 -547
  469. package/node_modules/@contrast/perf/lib/tsconfig.json +0 -31
  470. package/node_modules/@contrast/protect/lib/input-tracing/install/spdy.js +0 -63
  471. package/node_modules/@contrast/reporter/node_modules/sonic-boom/.taprc.yaml +0 -11
  472. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/destroy.test.js +0 -49
  473. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/end.test.js +0 -98
  474. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/flush-sync.test.js +0 -140
  475. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/flush.test.js +0 -419
  476. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/fsync.test.js +0 -63
  477. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/helper.js +0 -42
  478. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/minlength.test.js +0 -35
  479. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/mode.test.js +0 -116
  480. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/reopen.test.js +0 -239
  481. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/retry.test.js +0 -414
  482. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/sync.test.js +0 -261
  483. package/node_modules/@contrast/reporter/node_modules/sonic-boom/test/write.test.js +0 -465
  484. package/node_modules/node-addon-api/tools/eslint-format.js +0 -79
@@ -0,0 +1,588 @@
1
+ // parse a single path portion
2
+ import { parseClass } from './brace-expressions.js';
3
+ import { unescape } from './unescape.js';
4
+ const types = new Set(['!', '?', '+', '*', '@']);
5
+ const isExtglobType = (c) => types.has(c);
6
+ // Patterns that get prepended to bind to the start of either the
7
+ // entire string, or just a single path portion, to prevent dots
8
+ // and/or traversal patterns, when needed.
9
+ // Exts don't need the ^ or / bit, because the root binds that already.
10
+ const startNoTraversal = '(?!(?:^|/)\\.\\.?(?:$|/))';
11
+ const startNoDot = '(?!\\.)';
12
+ // characters that indicate a start of pattern needs the "no dots" bit,
13
+ // because a dot *might* be matched. ( is not in the list, because in
14
+ // the case of a child extglob, it will handle the prevention itself.
15
+ const addPatternStart = new Set(['[', '.']);
16
+ // cases where traversal is A-OK, no dot prevention needed
17
+ const justDots = new Set(['..', '.']);
18
+ const reSpecials = new Set('().*{}+?[]^$\\!');
19
+ const regExpEscape = (s) => s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
20
+ // any single thing other than /
21
+ const qmark = '[^/]';
22
+ // * => any number of characters
23
+ const star = qmark + '*?';
24
+ // use + when we need to ensure that *something* matches, because the * is
25
+ // the only thing in the path portion.
26
+ const starNoEmpty = qmark + '+?';
27
+ // remove the \ chars that we added if we end up doing a nonmagic compare
28
+ // const deslash = (s: string) => s.replace(/\\(.)/g, '$1')
29
+ export class AST {
30
+ type;
31
+ #root;
32
+ #hasMagic;
33
+ #uflag = false;
34
+ #parts = [];
35
+ #parent;
36
+ #parentIndex;
37
+ #negs;
38
+ #filledNegs = false;
39
+ #options;
40
+ #toString;
41
+ // set to true if it's an extglob with no children
42
+ // (which really means one child of '')
43
+ #emptyExt = false;
44
+ constructor(type, parent, options = {}) {
45
+ this.type = type;
46
+ // extglobs are inherently magical
47
+ if (type)
48
+ this.#hasMagic = true;
49
+ this.#parent = parent;
50
+ this.#root = this.#parent ? this.#parent.#root : this;
51
+ this.#options = this.#root === this ? options : this.#root.#options;
52
+ this.#negs = this.#root === this ? [] : this.#root.#negs;
53
+ if (type === '!' && !this.#root.#filledNegs)
54
+ this.#negs.push(this);
55
+ this.#parentIndex = this.#parent ? this.#parent.#parts.length : 0;
56
+ }
57
+ get hasMagic() {
58
+ /* c8 ignore start */
59
+ if (this.#hasMagic !== undefined)
60
+ return this.#hasMagic;
61
+ /* c8 ignore stop */
62
+ for (const p of this.#parts) {
63
+ if (typeof p === 'string')
64
+ continue;
65
+ if (p.type || p.hasMagic)
66
+ return (this.#hasMagic = true);
67
+ }
68
+ // note: will be undefined until we generate the regexp src and find out
69
+ return this.#hasMagic;
70
+ }
71
+ // reconstructs the pattern
72
+ toString() {
73
+ if (this.#toString !== undefined)
74
+ return this.#toString;
75
+ if (!this.type) {
76
+ return (this.#toString = this.#parts.map(p => String(p)).join(''));
77
+ }
78
+ else {
79
+ return (this.#toString =
80
+ this.type + '(' + this.#parts.map(p => String(p)).join('|') + ')');
81
+ }
82
+ }
83
+ #fillNegs() {
84
+ /* c8 ignore start */
85
+ if (this !== this.#root)
86
+ throw new Error('should only call on root');
87
+ if (this.#filledNegs)
88
+ return this;
89
+ /* c8 ignore stop */
90
+ // call toString() once to fill this out
91
+ this.toString();
92
+ this.#filledNegs = true;
93
+ let n;
94
+ while ((n = this.#negs.pop())) {
95
+ if (n.type !== '!')
96
+ continue;
97
+ // walk up the tree, appending everthing that comes AFTER parentIndex
98
+ let p = n;
99
+ let pp = p.#parent;
100
+ while (pp) {
101
+ for (let i = p.#parentIndex + 1; !pp.type && i < pp.#parts.length; i++) {
102
+ for (const part of n.#parts) {
103
+ /* c8 ignore start */
104
+ if (typeof part === 'string') {
105
+ throw new Error('string part in extglob AST??');
106
+ }
107
+ /* c8 ignore stop */
108
+ part.copyIn(pp.#parts[i]);
109
+ }
110
+ }
111
+ p = pp;
112
+ pp = p.#parent;
113
+ }
114
+ }
115
+ return this;
116
+ }
117
+ push(...parts) {
118
+ for (const p of parts) {
119
+ if (p === '')
120
+ continue;
121
+ /* c8 ignore start */
122
+ if (typeof p !== 'string' && !(p instanceof AST && p.#parent === this)) {
123
+ throw new Error('invalid part: ' + p);
124
+ }
125
+ /* c8 ignore stop */
126
+ this.#parts.push(p);
127
+ }
128
+ }
129
+ toJSON() {
130
+ const ret = this.type === null
131
+ ? this.#parts.slice().map(p => (typeof p === 'string' ? p : p.toJSON()))
132
+ : [this.type, ...this.#parts.map(p => p.toJSON())];
133
+ if (this.isStart() && !this.type)
134
+ ret.unshift([]);
135
+ if (this.isEnd() &&
136
+ (this === this.#root ||
137
+ (this.#root.#filledNegs && this.#parent?.type === '!'))) {
138
+ ret.push({});
139
+ }
140
+ return ret;
141
+ }
142
+ isStart() {
143
+ if (this.#root === this)
144
+ return true;
145
+ // if (this.type) return !!this.#parent?.isStart()
146
+ if (!this.#parent?.isStart())
147
+ return false;
148
+ if (this.#parentIndex === 0)
149
+ return true;
150
+ // if everything AHEAD of this is a negation, then it's still the "start"
151
+ const p = this.#parent;
152
+ for (let i = 0; i < this.#parentIndex; i++) {
153
+ const pp = p.#parts[i];
154
+ if (!(pp instanceof AST && pp.type === '!')) {
155
+ return false;
156
+ }
157
+ }
158
+ return true;
159
+ }
160
+ isEnd() {
161
+ if (this.#root === this)
162
+ return true;
163
+ if (this.#parent?.type === '!')
164
+ return true;
165
+ if (!this.#parent?.isEnd())
166
+ return false;
167
+ if (!this.type)
168
+ return this.#parent?.isEnd();
169
+ // if not root, it'll always have a parent
170
+ /* c8 ignore start */
171
+ const pl = this.#parent ? this.#parent.#parts.length : 0;
172
+ /* c8 ignore stop */
173
+ return this.#parentIndex === pl - 1;
174
+ }
175
+ copyIn(part) {
176
+ if (typeof part === 'string')
177
+ this.push(part);
178
+ else
179
+ this.push(part.clone(this));
180
+ }
181
+ clone(parent) {
182
+ const c = new AST(this.type, parent);
183
+ for (const p of this.#parts) {
184
+ c.copyIn(p);
185
+ }
186
+ return c;
187
+ }
188
+ static #parseAST(str, ast, pos, opt) {
189
+ let escaping = false;
190
+ let inBrace = false;
191
+ let braceStart = -1;
192
+ let braceNeg = false;
193
+ if (ast.type === null) {
194
+ // outside of a extglob, append until we find a start
195
+ let i = pos;
196
+ let acc = '';
197
+ while (i < str.length) {
198
+ const c = str.charAt(i++);
199
+ // still accumulate escapes at this point, but we do ignore
200
+ // starts that are escaped
201
+ if (escaping || c === '\\') {
202
+ escaping = !escaping;
203
+ acc += c;
204
+ continue;
205
+ }
206
+ if (inBrace) {
207
+ if (i === braceStart + 1) {
208
+ if (c === '^' || c === '!') {
209
+ braceNeg = true;
210
+ }
211
+ }
212
+ else if (c === ']' && !(i === braceStart + 2 && braceNeg)) {
213
+ inBrace = false;
214
+ }
215
+ acc += c;
216
+ continue;
217
+ }
218
+ else if (c === '[') {
219
+ inBrace = true;
220
+ braceStart = i;
221
+ braceNeg = false;
222
+ acc += c;
223
+ continue;
224
+ }
225
+ if (!opt.noext && isExtglobType(c) && str.charAt(i) === '(') {
226
+ ast.push(acc);
227
+ acc = '';
228
+ const ext = new AST(c, ast);
229
+ i = AST.#parseAST(str, ext, i, opt);
230
+ ast.push(ext);
231
+ continue;
232
+ }
233
+ acc += c;
234
+ }
235
+ ast.push(acc);
236
+ return i;
237
+ }
238
+ // some kind of extglob, pos is at the (
239
+ // find the next | or )
240
+ let i = pos + 1;
241
+ let part = new AST(null, ast);
242
+ const parts = [];
243
+ let acc = '';
244
+ while (i < str.length) {
245
+ const c = str.charAt(i++);
246
+ // still accumulate escapes at this point, but we do ignore
247
+ // starts that are escaped
248
+ if (escaping || c === '\\') {
249
+ escaping = !escaping;
250
+ acc += c;
251
+ continue;
252
+ }
253
+ if (inBrace) {
254
+ if (i === braceStart + 1) {
255
+ if (c === '^' || c === '!') {
256
+ braceNeg = true;
257
+ }
258
+ }
259
+ else if (c === ']' && !(i === braceStart + 2 && braceNeg)) {
260
+ inBrace = false;
261
+ }
262
+ acc += c;
263
+ continue;
264
+ }
265
+ else if (c === '[') {
266
+ inBrace = true;
267
+ braceStart = i;
268
+ braceNeg = false;
269
+ acc += c;
270
+ continue;
271
+ }
272
+ if (isExtglobType(c) && str.charAt(i) === '(') {
273
+ part.push(acc);
274
+ acc = '';
275
+ const ext = new AST(c, part);
276
+ part.push(ext);
277
+ i = AST.#parseAST(str, ext, i, opt);
278
+ continue;
279
+ }
280
+ if (c === '|') {
281
+ part.push(acc);
282
+ acc = '';
283
+ parts.push(part);
284
+ part = new AST(null, ast);
285
+ continue;
286
+ }
287
+ if (c === ')') {
288
+ if (acc === '' && ast.#parts.length === 0) {
289
+ ast.#emptyExt = true;
290
+ }
291
+ part.push(acc);
292
+ acc = '';
293
+ ast.push(...parts, part);
294
+ return i;
295
+ }
296
+ acc += c;
297
+ }
298
+ // unfinished extglob
299
+ // if we got here, it was a malformed extglob! not an extglob, but
300
+ // maybe something else in there.
301
+ ast.type = null;
302
+ ast.#hasMagic = undefined;
303
+ ast.#parts = [str.substring(pos - 1)];
304
+ return i;
305
+ }
306
+ static fromGlob(pattern, options = {}) {
307
+ const ast = new AST(null, undefined, options);
308
+ AST.#parseAST(pattern, ast, 0, options);
309
+ return ast;
310
+ }
311
+ // returns the regular expression if there's magic, or the unescaped
312
+ // string if not.
313
+ toMMPattern() {
314
+ // should only be called on root
315
+ /* c8 ignore start */
316
+ if (this !== this.#root)
317
+ return this.#root.toMMPattern();
318
+ /* c8 ignore stop */
319
+ const glob = this.toString();
320
+ const [re, body, hasMagic, uflag] = this.toRegExpSource();
321
+ // if we're in nocase mode, and not nocaseMagicOnly, then we do
322
+ // still need a regular expression if we have to case-insensitively
323
+ // match capital/lowercase characters.
324
+ const anyMagic = hasMagic ||
325
+ this.#hasMagic ||
326
+ (this.#options.nocase &&
327
+ !this.#options.nocaseMagicOnly &&
328
+ glob.toUpperCase() !== glob.toLowerCase());
329
+ if (!anyMagic) {
330
+ return body;
331
+ }
332
+ const flags = (this.#options.nocase ? 'i' : '') + (uflag ? 'u' : '');
333
+ return Object.assign(new RegExp(`^${re}$`, flags), {
334
+ _src: re,
335
+ _glob: glob,
336
+ });
337
+ }
338
+ get options() {
339
+ return this.#options;
340
+ }
341
+ // returns the string match, the regexp source, whether there's magic
342
+ // in the regexp (so a regular expression is required) and whether or
343
+ // not the uflag is needed for the regular expression (for posix classes)
344
+ // TODO: instead of injecting the start/end at this point, just return
345
+ // the BODY of the regexp, along with the start/end portions suitable
346
+ // for binding the start/end in either a joined full-path makeRe context
347
+ // (where we bind to (^|/), or a standalone matchPart context (where
348
+ // we bind to ^, and not /). Otherwise slashes get duped!
349
+ //
350
+ // In part-matching mode, the start is:
351
+ // - if not isStart: nothing
352
+ // - if traversal possible, but not allowed: ^(?!\.\.?$)
353
+ // - if dots allowed or not possible: ^
354
+ // - if dots possible and not allowed: ^(?!\.)
355
+ // end is:
356
+ // - if not isEnd(): nothing
357
+ // - else: $
358
+ //
359
+ // In full-path matching mode, we put the slash at the START of the
360
+ // pattern, so start is:
361
+ // - if first pattern: same as part-matching mode
362
+ // - if not isStart(): nothing
363
+ // - if traversal possible, but not allowed: /(?!\.\.?(?:$|/))
364
+ // - if dots allowed or not possible: /
365
+ // - if dots possible and not allowed: /(?!\.)
366
+ // end is:
367
+ // - if last pattern, same as part-matching mode
368
+ // - else nothing
369
+ //
370
+ // Always put the (?:$|/) on negated tails, though, because that has to be
371
+ // there to bind the end of the negated pattern portion, and it's easier to
372
+ // just stick it in now rather than try to inject it later in the middle of
373
+ // the pattern.
374
+ //
375
+ // We can just always return the same end, and leave it up to the caller
376
+ // to know whether it's going to be used joined or in parts.
377
+ // And, if the start is adjusted slightly, can do the same there:
378
+ // - if not isStart: nothing
379
+ // - if traversal possible, but not allowed: (?:/|^)(?!\.\.?$)
380
+ // - if dots allowed or not possible: (?:/|^)
381
+ // - if dots possible and not allowed: (?:/|^)(?!\.)
382
+ //
383
+ // But it's better to have a simpler binding without a conditional, for
384
+ // performance, so probably better to return both start options.
385
+ //
386
+ // Then the caller just ignores the end if it's not the first pattern,
387
+ // and the start always gets applied.
388
+ //
389
+ // But that's always going to be $ if it's the ending pattern, or nothing,
390
+ // so the caller can just attach $ at the end of the pattern when building.
391
+ //
392
+ // So the todo is:
393
+ // - better detect what kind of start is needed
394
+ // - return both flavors of starting pattern
395
+ // - attach $ at the end of the pattern when creating the actual RegExp
396
+ //
397
+ // Ah, but wait, no, that all only applies to the root when the first pattern
398
+ // is not an extglob. If the first pattern IS an extglob, then we need all
399
+ // that dot prevention biz to live in the extglob portions, because eg
400
+ // +(*|.x*) can match .xy but not .yx.
401
+ //
402
+ // So, return the two flavors if it's #root and the first child is not an
403
+ // AST, otherwise leave it to the child AST to handle it, and there,
404
+ // use the (?:^|/) style of start binding.
405
+ //
406
+ // Even simplified further:
407
+ // - Since the start for a join is eg /(?!\.) and the start for a part
408
+ // is ^(?!\.), we can just prepend (?!\.) to the pattern (either root
409
+ // or start or whatever) and prepend ^ or / at the Regexp construction.
410
+ toRegExpSource(allowDot) {
411
+ const dot = allowDot ?? !!this.#options.dot;
412
+ if (this.#root === this)
413
+ this.#fillNegs();
414
+ if (!this.type) {
415
+ const noEmpty = this.isStart() && this.isEnd();
416
+ const src = this.#parts
417
+ .map(p => {
418
+ const [re, _, hasMagic, uflag] = typeof p === 'string'
419
+ ? AST.#parseGlob(p, this.#hasMagic, noEmpty)
420
+ : p.toRegExpSource(allowDot);
421
+ this.#hasMagic = this.#hasMagic || hasMagic;
422
+ this.#uflag = this.#uflag || uflag;
423
+ return re;
424
+ })
425
+ .join('');
426
+ let start = '';
427
+ if (this.isStart()) {
428
+ if (typeof this.#parts[0] === 'string') {
429
+ // this is the string that will match the start of the pattern,
430
+ // so we need to protect against dots and such.
431
+ // '.' and '..' cannot match unless the pattern is that exactly,
432
+ // even if it starts with . or dot:true is set.
433
+ const dotTravAllowed = this.#parts.length === 1 && justDots.has(this.#parts[0]);
434
+ if (!dotTravAllowed) {
435
+ const aps = addPatternStart;
436
+ // check if we have a possibility of matching . or ..,
437
+ // and prevent that.
438
+ const needNoTrav =
439
+ // dots are allowed, and the pattern starts with [ or .
440
+ (dot && aps.has(src.charAt(0))) ||
441
+ // the pattern starts with \., and then [ or .
442
+ (src.startsWith('\\.') && aps.has(src.charAt(2))) ||
443
+ // the pattern starts with \.\., and then [ or .
444
+ (src.startsWith('\\.\\.') && aps.has(src.charAt(4)));
445
+ // no need to prevent dots if it can't match a dot, or if a
446
+ // sub-pattern will be preventing it anyway.
447
+ const needNoDot = !dot && !allowDot && aps.has(src.charAt(0));
448
+ start = needNoTrav ? startNoTraversal : needNoDot ? startNoDot : '';
449
+ }
450
+ }
451
+ }
452
+ // append the "end of path portion" pattern to negation tails
453
+ let end = '';
454
+ if (this.isEnd() &&
455
+ this.#root.#filledNegs &&
456
+ this.#parent?.type === '!') {
457
+ end = '(?:$|\\/)';
458
+ }
459
+ const final = start + src + end;
460
+ return [
461
+ final,
462
+ unescape(src),
463
+ (this.#hasMagic = !!this.#hasMagic),
464
+ this.#uflag,
465
+ ];
466
+ }
467
+ // We need to calculate the body *twice* if it's a repeat pattern
468
+ // at the start, once in nodot mode, then again in dot mode, so a
469
+ // pattern like *(?) can match 'x.y'
470
+ const repeated = this.type === '*' || this.type === '+';
471
+ // some kind of extglob
472
+ const start = this.type === '!' ? '(?:(?!(?:' : '(?:';
473
+ let body = this.#partsToRegExp(dot);
474
+ if (this.isStart() && this.isEnd() && !body && this.type !== '!') {
475
+ // invalid extglob, has to at least be *something* present, if it's
476
+ // the entire path portion.
477
+ const s = this.toString();
478
+ this.#parts = [s];
479
+ this.type = null;
480
+ this.#hasMagic = undefined;
481
+ return [s, unescape(this.toString()), false, false];
482
+ }
483
+ // XXX abstract out this map method
484
+ let bodyDotAllowed = !repeated || allowDot || dot || !startNoDot
485
+ ? ''
486
+ : this.#partsToRegExp(true);
487
+ if (bodyDotAllowed === body) {
488
+ bodyDotAllowed = '';
489
+ }
490
+ if (bodyDotAllowed) {
491
+ body = `(?:${body})(?:${bodyDotAllowed})*?`;
492
+ }
493
+ // an empty !() is exactly equivalent to a starNoEmpty
494
+ let final = '';
495
+ if (this.type === '!' && this.#emptyExt) {
496
+ final = (this.isStart() && !dot ? startNoDot : '') + starNoEmpty;
497
+ }
498
+ else {
499
+ const close = this.type === '!'
500
+ ? // !() must match something,but !(x) can match ''
501
+ '))' +
502
+ (this.isStart() && !dot && !allowDot ? startNoDot : '') +
503
+ star +
504
+ ')'
505
+ : this.type === '@'
506
+ ? ')'
507
+ : this.type === '?'
508
+ ? ')?'
509
+ : this.type === '+' && bodyDotAllowed
510
+ ? ')'
511
+ : this.type === '*' && bodyDotAllowed
512
+ ? `)?`
513
+ : `)${this.type}`;
514
+ final = start + body + close;
515
+ }
516
+ return [
517
+ final,
518
+ unescape(body),
519
+ (this.#hasMagic = !!this.#hasMagic),
520
+ this.#uflag,
521
+ ];
522
+ }
523
+ #partsToRegExp(dot) {
524
+ return this.#parts
525
+ .map(p => {
526
+ // extglob ASTs should only contain parent ASTs
527
+ /* c8 ignore start */
528
+ if (typeof p === 'string') {
529
+ throw new Error('string type in extglob ast??');
530
+ }
531
+ /* c8 ignore stop */
532
+ // can ignore hasMagic, because extglobs are already always magic
533
+ const [re, _, _hasMagic, uflag] = p.toRegExpSource(dot);
534
+ this.#uflag = this.#uflag || uflag;
535
+ return re;
536
+ })
537
+ .filter(p => !(this.isStart() && this.isEnd()) || !!p)
538
+ .join('|');
539
+ }
540
+ static #parseGlob(glob, hasMagic, noEmpty = false) {
541
+ let escaping = false;
542
+ let re = '';
543
+ let uflag = false;
544
+ for (let i = 0; i < glob.length; i++) {
545
+ const c = glob.charAt(i);
546
+ if (escaping) {
547
+ escaping = false;
548
+ re += (reSpecials.has(c) ? '\\' : '') + c;
549
+ continue;
550
+ }
551
+ if (c === '\\') {
552
+ if (i === glob.length - 1) {
553
+ re += '\\\\';
554
+ }
555
+ else {
556
+ escaping = true;
557
+ }
558
+ continue;
559
+ }
560
+ if (c === '[') {
561
+ const [src, needUflag, consumed, magic] = parseClass(glob, i);
562
+ if (consumed) {
563
+ re += src;
564
+ uflag = uflag || needUflag;
565
+ i += consumed - 1;
566
+ hasMagic = hasMagic || magic;
567
+ continue;
568
+ }
569
+ }
570
+ if (c === '*') {
571
+ if (noEmpty && glob === '*')
572
+ re += starNoEmpty;
573
+ else
574
+ re += star;
575
+ hasMagic = true;
576
+ continue;
577
+ }
578
+ if (c === '?') {
579
+ re += qmark;
580
+ hasMagic = true;
581
+ continue;
582
+ }
583
+ re += regExpEscape(c);
584
+ }
585
+ return [re, unescape(glob), !!hasMagic, uflag];
586
+ }
587
+ }
588
+ //# sourceMappingURL=ast.js.map