@contrast/agent-bundle 5.39.1 → 5.41.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.
- package/node_modules/@contrast/agent/lib/start-agent.js +50 -40
- package/node_modules/@contrast/agent/package.json +11 -11
- package/node_modules/@contrast/agent-swc-plugin/index.js +9 -3
- package/node_modules/@contrast/agent-swc-plugin/methods.js +15 -1
- package/node_modules/@contrast/agent-swc-plugin/package.json +5 -8
- package/node_modules/@contrast/agent-swc-plugin/rewriter.wasm +0 -0
- package/node_modules/@contrast/agentify/lib/index.js +2 -2
- package/node_modules/@contrast/agentify/package.json +15 -14
- package/node_modules/@contrast/architecture-components/package.json +5 -5
- package/node_modules/@contrast/assess/lib/dataflow/propagation/install/string/replace.js +6 -3
- package/node_modules/@contrast/assess/lib/dataflow/propagation/install/util-format.js +44 -21
- package/node_modules/@contrast/assess/lib/dataflow/sources/index.js +1 -1
- package/node_modules/@contrast/assess/lib/dataflow/sources/install/{body-parser1.js → body-parser.js} +2 -2
- package/node_modules/@contrast/assess/lib/dataflow/sources/install/koa/koa-bodyparsers.js +3 -1
- package/node_modules/@contrast/assess/lib/dataflow/sources/install/qs6.js +5 -5
- package/node_modules/@contrast/assess/lib/dataflow/sources/install/querystring.js +2 -1
- package/node_modules/@contrast/assess/lib/index.d.ts +0 -1
- package/node_modules/@contrast/assess/lib/make-source-context.js +7 -37
- package/node_modules/@contrast/assess/lib/sampler/common.js +7 -11
- package/node_modules/@contrast/assess/package.json +12 -11
- package/node_modules/@contrast/common/lib/constants.d.ts +6 -0
- package/node_modules/@contrast/common/lib/constants.js +8 -1
- package/node_modules/@contrast/common/lib/types.d.ts +7 -1
- package/node_modules/@contrast/common/package.json +1 -1
- package/node_modules/@contrast/config/lib/common.js +1 -1
- package/node_modules/@contrast/config/lib/config.js +49 -27
- package/node_modules/@contrast/config/lib/index.d.ts +3 -2
- package/node_modules/@contrast/config/lib/options.js +4 -4
- package/node_modules/@contrast/config/package.json +4 -3
- package/node_modules/@contrast/core/lib/sensitive-data-masking/protect-listener.js +15 -15
- package/node_modules/@contrast/core/package.json +6 -6
- package/node_modules/@contrast/deadzones/package.json +5 -5
- package/node_modules/@contrast/dep-hooks/package.json +3 -3
- package/node_modules/@contrast/esm-hooks/package.json +6 -6
- package/node_modules/@contrast/instrumentation/lib/index.js +0 -1
- package/node_modules/@contrast/instrumentation/package.json +5 -5
- package/node_modules/@contrast/library-analysis/lib/install/library-reporting/dep.json +300 -152
- package/node_modules/@contrast/library-analysis/lib/install/library-reporting/index.js +9 -2
- package/node_modules/@contrast/library-analysis/lib/install/library-reporting/utils.js +54 -43
- package/node_modules/@contrast/library-analysis/package.json +4 -4
- package/node_modules/@contrast/logger/lib/serializers.js +2 -2
- package/node_modules/@contrast/logger/package.json +3 -3
- package/node_modules/@contrast/metrics/package.json +6 -6
- package/node_modules/@contrast/patcher/package.json +2 -2
- package/node_modules/@contrast/protect/lib/get-source-context.js +3 -1
- package/node_modules/@contrast/protect/lib/index.js +6 -1
- package/node_modules/@contrast/protect/lib/input-analysis/handlers.js +7 -9
- package/node_modules/@contrast/protect/lib/input-analysis/index.js +1 -1
- package/node_modules/@contrast/protect/lib/input-analysis/install/{body-parser1.js → body-parser.js} +1 -1
- package/node_modules/@contrast/protect/lib/input-analysis/install/http.js +18 -19
- package/node_modules/@contrast/protect/lib/input-analysis/install/qs6.js +18 -17
- package/node_modules/@contrast/protect/lib/input-analysis/install/universal-cookie4.js +2 -3
- package/node_modules/@contrast/protect/lib/make-source-context.js +22 -66
- package/node_modules/@contrast/protect/lib/semantic-analysis/handlers.js +73 -72
- package/node_modules/@contrast/protect/package.json +11 -11
- package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/application-activity/index.js +7 -7
- package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/application-activity/translations.d.ts +3 -3
- package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/application-activity/translations.js +24 -21
- package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/routes-observed.js +2 -1
- package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/traces/index.js +1 -1
- package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/traces/translations.d.ts +1 -2
- package/node_modules/@contrast/reporter/lib/reporters/contrast-ui/endpoints/traces/translations.js +8 -2
- package/node_modules/@contrast/reporter/lib/reporters/security-logger/index.d.ts +2 -2
- package/node_modules/@contrast/reporter/lib/reporters/security-logger/index.js +22 -20
- package/node_modules/@contrast/reporter/package.json +7 -7
- package/node_modules/@contrast/rewriter/lib/index.js +2 -2
- package/node_modules/@contrast/rewriter/package.json +6 -6
- package/node_modules/@contrast/route-coverage/lib/index.d.ts +2 -0
- package/node_modules/@contrast/route-coverage/lib/index.js +15 -17
- package/node_modules/@contrast/route-coverage/lib/install/express/express5.js +489 -202
- package/node_modules/@contrast/route-coverage/package.json +9 -9
- package/node_modules/@contrast/scopes/package.json +5 -5
- package/node_modules/@contrast/sec-obs/lib/traces/http.js +2 -2
- package/node_modules/@contrast/sec-obs/lib/traces/http.test.js +17 -0
- package/node_modules/@contrast/sec-obs/lib/traces/outbound-service-call.js +2 -2
- package/node_modules/@contrast/sec-obs/lib/traces/outbound-service-call.test.js +17 -0
- package/node_modules/@contrast/sec-obs/package.json +9 -9
- package/node_modules/@contrast/sources/lib/index.js +109 -0
- package/node_modules/@contrast/sources/lib/index.test.js +120 -0
- package/node_modules/@contrast/{route-coverage/lib/normalized-url-mapper.js → sources/lib/normalized-uri-mapper.js} +10 -3
- package/node_modules/@contrast/sources/lib/normalized-uri-mapper.test.js +59 -0
- package/node_modules/@contrast/{sec-obs/node_modules/@contrast/core/lib/sensitive-data-masking/constants.js → sources/lib/req-data.js} +0 -6
- package/node_modules/@contrast/sources/lib/source-info.js +183 -0
- package/node_modules/@contrast/sources/lib/source-info.test.js +68 -0
- package/node_modules/@contrast/sources/package.json +16 -0
- package/node_modules/@contrast/telemetry/package.json +6 -6
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.d.ts +2831 -77
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.js +2831 -77
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.d.ts +415 -98
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.js +415 -98
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.d.ts +106 -0
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js +106 -0
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.d.ts +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.js +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.d.ts +2831 -77
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.js +2831 -77
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.d.ts +415 -98
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.js +415 -98
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.d.ts +106 -0
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.js +106 -0
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.d.ts +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.js +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.d.ts +2831 -77
- package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.js +2858 -103
- package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.d.ts +415 -98
- package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.js +420 -102
- package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.d.ts +106 -0
- package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.js +106 -0
- package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/src/version.d.ts +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/src/version.js +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/build/src/version.js.map +1 -1
- package/node_modules/@opentelemetry/semantic-conventions/package.json +3 -3
- package/node_modules/@types/node/README.md +2 -2
- package/node_modules/@types/node/buffer.d.ts +5 -0
- package/node_modules/@types/node/dns/promises.d.ts +11 -10
- package/node_modules/@types/node/dns.d.ts +18 -19
- package/node_modules/@types/node/fs.d.ts +13 -1
- package/node_modules/@types/node/http.d.ts +4 -19
- package/node_modules/@types/node/inspector.d.ts +53 -0
- package/node_modules/@types/node/package.json +2 -82
- package/node_modules/@types/node/stream/web.d.ts +4 -0
- package/node_modules/axios/CHANGELOG.md +17 -0
- package/node_modules/axios/README.md +1 -4
- package/node_modules/axios/dist/axios.js +39 -5
- package/node_modules/axios/dist/axios.js.map +1 -1
- package/node_modules/axios/dist/axios.min.js +2 -2
- package/node_modules/axios/dist/axios.min.js.map +1 -1
- package/node_modules/axios/dist/browser/axios.cjs +46 -9
- package/node_modules/axios/dist/browser/axios.cjs.map +1 -1
- package/node_modules/axios/dist/esm/axios.js +46 -9
- package/node_modules/axios/dist/esm/axios.js.map +1 -1
- package/node_modules/axios/dist/esm/axios.min.js +2 -2
- package/node_modules/axios/dist/esm/axios.min.js.map +1 -1
- package/node_modules/axios/dist/node/axios.cjs +46 -9
- package/node_modules/axios/dist/node/axios.cjs.map +1 -1
- package/node_modules/axios/index.d.cts +13 -2
- package/node_modules/axios/lib/core/Axios.js +2 -2
- package/node_modules/axios/lib/core/mergeConfig.js +1 -1
- package/node_modules/axios/lib/env/data.js +1 -1
- package/node_modules/axios/lib/helpers/throttle.js +1 -1
- package/node_modules/axios/lib/helpers/toURLEncodedForm.js +4 -3
- package/node_modules/axios/lib/utils.js +36 -0
- package/node_modules/axios/package.json +5 -5
- package/node_modules/deepmerge/.editorconfig +7 -0
- package/node_modules/deepmerge/.eslintcache +1 -0
- package/node_modules/deepmerge/changelog.md +167 -0
- package/node_modules/deepmerge/dist/cjs.js +133 -0
- package/node_modules/deepmerge/dist/umd.js +139 -0
- package/node_modules/deepmerge/index.d.ts +20 -0
- package/node_modules/deepmerge/index.js +106 -0
- package/node_modules/{path-to-regexp/LICENSE → deepmerge/license.txt} +1 -1
- package/node_modules/deepmerge/package.json +42 -0
- package/node_modules/deepmerge/readme.md +264 -0
- package/node_modules/deepmerge/rollup.config.js +22 -0
- package/node_modules/follow-redirects/package.json +1 -1
- package/node_modules/form-data/CHANGELOG.md +601 -0
- package/node_modules/form-data/{Readme.md → README.md} +4 -4
- package/node_modules/form-data/lib/form_data.js +2 -6
- package/node_modules/form-data/package.json +22 -6
- package/node_modules/nan/.github/workflows/ci.yml +8 -10
- package/node_modules/nan/.pre-commit-config.yaml +8 -0
- package/node_modules/nan/CHANGELOG.md +5 -1
- package/node_modules/nan/README.md +4 -4
- package/node_modules/nan/nan.h +16 -12
- package/node_modules/nan/nan_callbacks.h +13 -0
- package/node_modules/nan/nan_callbacks_12_inl.h +16 -2
- package/node_modules/nan/nan_callbacks_pre_12_inl.h +6 -2
- package/node_modules/nan/nan_maybe_43_inl.h +1 -1
- package/node_modules/nan/nan_maybe_pre_43_inl.h +1 -1
- package/node_modules/nan/nan_scriptorigin.h +11 -9
- package/node_modules/nan/nan_typedarray_contents.h +1 -1
- package/node_modules/nan/package.json +2 -2
- package/package.json +5 -3
- package/node_modules/@contrast/agentify/lib/sources.js +0 -94
- package/node_modules/@contrast/route-coverage/lib/install/http.js +0 -44
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/constants.d.ts +0 -385
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/constants.js +0 -270
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/index.d.ts +0 -40
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/index.js +0 -228
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/primordials.d.ts +0 -65
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/primordials.js +0 -66
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/types.d.ts +0 -383
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/lib/types.js +0 -30
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/common/package.json +0 -23
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/README.md +0 -44
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/lib/common.js +0 -131
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/lib/config.js +0 -290
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/lib/index.d.ts +0 -328
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/lib/index.js +0 -29
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/lib/options.js +0 -836
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/lib/validators.js +0 -23
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/config/package.json +0 -27
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/README.md +0 -98
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/agent-info.js +0 -36
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/app-info.js +0 -233
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/build-id.js +0 -51
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/capture-stacktrace.js +0 -256
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/contrast-methods.js +0 -155
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/index.d.ts +0 -52
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/ioc/core.js +0 -95
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/is-agent-path.js +0 -37
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/messages.js +0 -28
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/sensitive-data-masking/index.js +0 -63
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/sensitive-data-masking/protect-listener.js +0 -111
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/sensitive-data-masking/server-settings-listener.js +0 -44
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/system-info/cloud-provider-metadata.js +0 -146
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/system-info/index.js +0 -225
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/system-info/linux-os-info.js +0 -137
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/lib/system-info/utils.js +0 -35
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/core/package.json +0 -33
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/README.md +0 -94
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/export-handler-registry.d.ts +0 -121
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/export-handler-registry.js +0 -206
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/export-hook-descriptor.d.ts +0 -72
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/export-hook-descriptor.js +0 -88
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/handler-invoker.d.ts +0 -46
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/handler-invoker.js +0 -106
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/helpers.d.ts +0 -28
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/helpers.js +0 -66
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/index.d.ts +0 -115
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/index.js +0 -208
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/package-finder.d.ts +0 -43
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/lib/package-finder.js +0 -79
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/dep-hooks/package.json +0 -29
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/README.md +0 -270
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/lib/index.d.ts +0 -16
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/lib/index.js +0 -132
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/lib/serializers.d.ts +0 -33
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/lib/serializers.js +0 -75
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/lib/utils.d.ts +0 -15
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/lib/utils.js +0 -34
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/logger/package.json +0 -28
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/patcher/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/patcher/README.md +0 -51
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/patcher/lib/index.d.ts +0 -101
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/patcher/lib/index.js +0 -544
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/patcher/package.json +0 -25
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/rewriter/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/rewriter/README.md +0 -6
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/rewriter/lib/cache.js +0 -318
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/rewriter/lib/index.js +0 -216
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/rewriter/lib/rewrite-is-deadzoned.js +0 -143
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/rewriter/package.json +0 -30
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/LICENSE +0 -12
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/constants.js +0 -26
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/index.d.ts +0 -46
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/index.js +0 -70
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/bluebird.js +0 -128
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/index.js +0 -34
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/mongodb-core.js +0 -83
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/mongodb3.js +0 -89
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/mongodb4.js +0 -80
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/mongodb6.js +0 -46
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/mysql.js +0 -151
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/install/redis.js +0 -79
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/lib/utils.js +0 -35
- package/node_modules/@contrast/sec-obs/node_modules/@contrast/scopes/package.json +0 -28
- package/node_modules/form-data/README.md.bak +0 -355
- package/node_modules/path-to-regexp/Readme.md +0 -216
- package/node_modules/path-to-regexp/dist/index.d.ts +0 -136
- package/node_modules/path-to-regexp/dist/index.js +0 -403
- package/node_modules/path-to-regexp/dist/index.js.map +0 -1
- package/node_modules/path-to-regexp/package.json +0 -62
|
@@ -6,7 +6,7 @@ type MethodsHeaders = Partial<{
|
|
|
6
6
|
[Key in axios.Method as Lowercase<Key>]: AxiosHeaders;
|
|
7
7
|
} & {common: AxiosHeaders}>;
|
|
8
8
|
|
|
9
|
-
type AxiosHeaderMatcher = (this: AxiosHeaders, value: string, name: string
|
|
9
|
+
type AxiosHeaderMatcher = string | RegExp | ((this: AxiosHeaders, value: string, name: string) => boolean);
|
|
10
10
|
|
|
11
11
|
type AxiosHeaderParser = (this: AxiosHeaders, value: axios.AxiosHeaderValue, header: string) => any;
|
|
12
12
|
|
|
@@ -77,6 +77,8 @@ declare class AxiosHeaders {
|
|
|
77
77
|
getAuthorization(matcher?: AxiosHeaderMatcher): axios.AxiosHeaderValue;
|
|
78
78
|
hasAuthorization(matcher?: AxiosHeaderMatcher): boolean;
|
|
79
79
|
|
|
80
|
+
getSetCookie(): string[];
|
|
81
|
+
|
|
80
82
|
[Symbol.iterator](): IterableIterator<[string, axios.AxiosHeaderValue]>;
|
|
81
83
|
}
|
|
82
84
|
|
|
@@ -97,6 +99,14 @@ declare class AxiosError<T = unknown, D = any> extends Error {
|
|
|
97
99
|
status?: number;
|
|
98
100
|
toJSON: () => object;
|
|
99
101
|
cause?: Error;
|
|
102
|
+
static from<T = unknown, D = any>(
|
|
103
|
+
error: Error | unknown,
|
|
104
|
+
code?: string,
|
|
105
|
+
config?: axios.InternalAxiosRequestConfig<D>,
|
|
106
|
+
request?: any,
|
|
107
|
+
response?: axios.AxiosResponse<T, D>,
|
|
108
|
+
customProps?: object,
|
|
109
|
+
): AxiosError<T, D>;
|
|
100
110
|
static readonly ERR_FR_TOO_MANY_REDIRECTS = "ERR_FR_TOO_MANY_REDIRECTS";
|
|
101
111
|
static readonly ERR_BAD_OPTION_VALUE = "ERR_BAD_OPTION_VALUE";
|
|
102
112
|
static readonly ERR_BAD_OPTION = "ERR_BAD_OPTION";
|
|
@@ -424,7 +434,7 @@ declare namespace axios {
|
|
|
424
434
|
// Alias
|
|
425
435
|
type RawAxiosRequestConfig<D = any> = AxiosRequestConfig<D>;
|
|
426
436
|
|
|
427
|
-
interface InternalAxiosRequestConfig<D = any> extends AxiosRequestConfig {
|
|
437
|
+
interface InternalAxiosRequestConfig<D = any> extends AxiosRequestConfig<D> {
|
|
428
438
|
headers: AxiosRequestHeaders;
|
|
429
439
|
}
|
|
430
440
|
|
|
@@ -542,6 +552,7 @@ declare namespace axios {
|
|
|
542
552
|
formToJSON(form: GenericFormData|GenericHTMLFormElement): object;
|
|
543
553
|
getAdapter(adapters: AxiosAdapterConfig | AxiosAdapterConfig[] | undefined): AxiosAdapter;
|
|
544
554
|
AxiosHeaders: typeof AxiosHeaders;
|
|
555
|
+
mergeConfig<D = any>(config1: AxiosRequestConfig<D>, config2: AxiosRequestConfig<D>): AxiosRequestConfig<D>;
|
|
545
556
|
}
|
|
546
557
|
}
|
|
547
558
|
|
|
@@ -153,8 +153,8 @@ class Axios {
|
|
|
153
153
|
|
|
154
154
|
if (!synchronousRequestInterceptors) {
|
|
155
155
|
const chain = [dispatchRequest.bind(this), undefined];
|
|
156
|
-
chain.unshift
|
|
157
|
-
chain.push
|
|
156
|
+
chain.unshift(...requestInterceptorChain);
|
|
157
|
+
chain.push(...responseInterceptorChain);
|
|
158
158
|
len = chain.length;
|
|
159
159
|
|
|
160
160
|
promise = Promise.resolve(config);
|
|
@@ -96,7 +96,7 @@ export default function mergeConfig(config1, config2) {
|
|
|
96
96
|
headers: (a, b , prop) => mergeDeepProperties(headersToObject(a), headersToObject(b),prop, true)
|
|
97
97
|
};
|
|
98
98
|
|
|
99
|
-
utils.forEach(Object.keys(
|
|
99
|
+
utils.forEach(Object.keys({...config1, ...config2}), function computeConfigValue(prop) {
|
|
100
100
|
const merge = mergeMap[prop] || mergeDeepProperties;
|
|
101
101
|
const configValue = merge(config1[prop], config2[prop], prop);
|
|
102
102
|
(utils.isUndefined(configValue) && merge !== mergeDirectKeys) || (config[prop] = configValue);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const VERSION = "1.
|
|
1
|
+
export const VERSION = "1.11.0";
|
|
@@ -5,7 +5,7 @@ import toFormData from './toFormData.js';
|
|
|
5
5
|
import platform from '../platform/index.js';
|
|
6
6
|
|
|
7
7
|
export default function toURLEncodedForm(data, options) {
|
|
8
|
-
return toFormData(data, new platform.classes.URLSearchParams(),
|
|
8
|
+
return toFormData(data, new platform.classes.URLSearchParams(), {
|
|
9
9
|
visitor: function(value, key, path, helpers) {
|
|
10
10
|
if (platform.isNode && utils.isBuffer(value)) {
|
|
11
11
|
this.append(key, value.toString('base64'));
|
|
@@ -13,6 +13,7 @@ export default function toURLEncodedForm(data, options) {
|
|
|
13
13
|
}
|
|
14
14
|
|
|
15
15
|
return helpers.defaultVisitor.apply(this, arguments);
|
|
16
|
-
}
|
|
17
|
-
|
|
16
|
+
},
|
|
17
|
+
...options
|
|
18
|
+
});
|
|
18
19
|
}
|
|
@@ -136,6 +136,27 @@ const isPlainObject = (val) => {
|
|
|
136
136
|
return (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(toStringTag in val) && !(iterator in val);
|
|
137
137
|
}
|
|
138
138
|
|
|
139
|
+
/**
|
|
140
|
+
* Determine if a value is an empty object (safely handles Buffers)
|
|
141
|
+
*
|
|
142
|
+
* @param {*} val The value to test
|
|
143
|
+
*
|
|
144
|
+
* @returns {boolean} True if value is an empty object, otherwise false
|
|
145
|
+
*/
|
|
146
|
+
const isEmptyObject = (val) => {
|
|
147
|
+
// Early return for non-objects or Buffers to prevent RangeError
|
|
148
|
+
if (!isObject(val) || isBuffer(val)) {
|
|
149
|
+
return false;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
try {
|
|
153
|
+
return Object.keys(val).length === 0 && Object.getPrototypeOf(val) === Object.prototype;
|
|
154
|
+
} catch (e) {
|
|
155
|
+
// Fallback for any other objects that might cause RangeError with Object.keys()
|
|
156
|
+
return false;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
|
|
139
160
|
/**
|
|
140
161
|
* Determine if a value is a Date
|
|
141
162
|
*
|
|
@@ -258,6 +279,11 @@ function forEach(obj, fn, {allOwnKeys = false} = {}) {
|
|
|
258
279
|
fn.call(null, obj[i], i, obj);
|
|
259
280
|
}
|
|
260
281
|
} else {
|
|
282
|
+
// Buffer check
|
|
283
|
+
if (isBuffer(obj)) {
|
|
284
|
+
return;
|
|
285
|
+
}
|
|
286
|
+
|
|
261
287
|
// Iterate over object keys
|
|
262
288
|
const keys = allOwnKeys ? Object.getOwnPropertyNames(obj) : Object.keys(obj);
|
|
263
289
|
const len = keys.length;
|
|
@@ -271,6 +297,10 @@ function forEach(obj, fn, {allOwnKeys = false} = {}) {
|
|
|
271
297
|
}
|
|
272
298
|
|
|
273
299
|
function findKey(obj, key) {
|
|
300
|
+
if (isBuffer(obj)){
|
|
301
|
+
return null;
|
|
302
|
+
}
|
|
303
|
+
|
|
274
304
|
key = key.toLowerCase();
|
|
275
305
|
const keys = Object.keys(obj);
|
|
276
306
|
let i = keys.length;
|
|
@@ -624,6 +654,11 @@ const toJSONObject = (obj) => {
|
|
|
624
654
|
return;
|
|
625
655
|
}
|
|
626
656
|
|
|
657
|
+
//Buffer check
|
|
658
|
+
if (isBuffer(source)) {
|
|
659
|
+
return source;
|
|
660
|
+
}
|
|
661
|
+
|
|
627
662
|
if(!('toJSON' in source)) {
|
|
628
663
|
stack[i] = source;
|
|
629
664
|
const target = isArray(source) ? [] : {};
|
|
@@ -695,6 +730,7 @@ export default {
|
|
|
695
730
|
isBoolean,
|
|
696
731
|
isObject,
|
|
697
732
|
isPlainObject,
|
|
733
|
+
isEmptyObject,
|
|
698
734
|
isReadableStream,
|
|
699
735
|
isRequest,
|
|
700
736
|
isResponse,
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "axios",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.11.0",
|
|
4
4
|
"description": "Promise based HTTP client for the browser and node.js",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"exports": {
|
|
@@ -157,7 +157,7 @@
|
|
|
157
157
|
"typings": "./index.d.ts",
|
|
158
158
|
"dependencies": {
|
|
159
159
|
"follow-redirects": "^1.15.6",
|
|
160
|
-
"form-data": "^4.0.
|
|
160
|
+
"form-data": "^4.0.4",
|
|
161
161
|
"proxy-from-env": "^1.1.0"
|
|
162
162
|
},
|
|
163
163
|
"bundlesize": [
|
|
@@ -176,10 +176,10 @@
|
|
|
176
176
|
"Justin Beckwith (https://github.com/JustinBeckwith)",
|
|
177
177
|
"Martti Laine (https://github.com/codeclown)",
|
|
178
178
|
"Xianming Zhong (https://github.com/chinesedfan)",
|
|
179
|
-
"Rikki Gibson (https://github.com/RikkiGibson)",
|
|
180
179
|
"Remco Haszing (https://github.com/remcohaszing)",
|
|
181
|
-
"
|
|
182
|
-
"Ben Carp (https://github.com/carpben)"
|
|
180
|
+
"Rikki Gibson (https://github.com/RikkiGibson)",
|
|
181
|
+
"Ben Carp (https://github.com/carpben)",
|
|
182
|
+
"Yasu Flores (https://github.com/yasuf)"
|
|
183
183
|
],
|
|
184
184
|
"sideEffects": false,
|
|
185
185
|
"release-it": {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
[{"/Users/joshduff/code/deepmerge/test/custom-is-mergeable-object.js":"1"},{"size":1990,"mtime":1679007485753,"results":"2","hashOfConfig":"3"},{"filePath":"4","messages":"5","suppressedMessages":"6","errorCount":0,"fatalErrorCount":0,"warningCount":0,"fixableErrorCount":0,"fixableWarningCount":0},"ktjd5k","/Users/joshduff/code/deepmerge/test/custom-is-mergeable-object.js",[],[]]
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
# [4.3.1](https://github.com/TehShrike/deepmerge/releases/tag/v4.3.1)
|
|
2
|
+
|
|
3
|
+
- Fix type definition for arrayMerge options. [#239](https://github.com/TehShrike/deepmerge/pull/239)
|
|
4
|
+
|
|
5
|
+
# [4.3.0](https://github.com/TehShrike/deepmerge/releases/tag/v4.3.0)
|
|
6
|
+
|
|
7
|
+
- Avoid thrown errors if the target doesn't have `propertyIsEnumerable`. [#252](https://github.com/TehShrike/deepmerge/pull/252)
|
|
8
|
+
|
|
9
|
+
# [4.2.2](https://github.com/TehShrike/deepmerge/releases/tag/v4.2.2)
|
|
10
|
+
|
|
11
|
+
- `isMergeableObject` is now only called if there are two values that could be merged. [a34dd4d2](https://github.com/TehShrike/deepmerge/commit/a34dd4d25bf5e250653540a2022bc832c7b00a19)
|
|
12
|
+
|
|
13
|
+
# [4.2.1](https://github.com/TehShrike/deepmerge/releases/tag/v4.2.1)
|
|
14
|
+
|
|
15
|
+
- Fix: falsey values can now be merged. [#170](https://github.com/TehShrike/deepmerge/issues/170)
|
|
16
|
+
|
|
17
|
+
# [4.2.0](https://github.com/TehShrike/deepmerge/releases/tag/v4.2.0)
|
|
18
|
+
|
|
19
|
+
- Properties are now only overwritten if they exist on the target object and are enumerable. [#164](https://github.com/TehShrike/deepmerge/pull/164)
|
|
20
|
+
|
|
21
|
+
Technically this could probably be a patch release since "which properties get overwritten" wasn't documented and accidentally overwriting a built-in function or some function up the property chain would almost certainly be undesirable, but it feels like a gray area, so here we are with a feature version bump.
|
|
22
|
+
|
|
23
|
+
# [4.1.2](https://github.com/TehShrike/deepmerge/releases/tag/v4.1.2)
|
|
24
|
+
|
|
25
|
+
- Rolled back #167 since `Object.assign` breaks ES5 support. [55067352](https://github.com/TehShrike/deepmerge/commit/55067352a92c65a6c44a5165f3387720aae1e192)
|
|
26
|
+
|
|
27
|
+
# [4.1.1](https://github.com/TehShrike/deepmerge/releases/tag/v4.1.1)
|
|
28
|
+
|
|
29
|
+
- The `options` argument is no longer mutated [#167](https://github.com/TehShrike/deepmerge/pull/167)
|
|
30
|
+
|
|
31
|
+
# [4.1.0](https://github.com/TehShrike/deepmerge/releases/tag/v4.1.0)
|
|
32
|
+
|
|
33
|
+
- `cloneUnlessOtherwiseSpecified` is now exposed to the `arrayMerge` function [#165](https://github.com/TehShrike/deepmerge/pull/165)
|
|
34
|
+
|
|
35
|
+
# [4.0.0](https://github.com/TehShrike/deepmerge/releases/tag/v4.0.0)
|
|
36
|
+
|
|
37
|
+
- The `main` entry point in `package.json` is now a CommonJS module instead of a UMD module [#155](https://github.com/TehShrike/deepmerge/pull/155)
|
|
38
|
+
|
|
39
|
+
# [3.3.0](https://github.com/TehShrike/deepmerge/releases/tag/v3.3.0)
|
|
40
|
+
|
|
41
|
+
- Enumerable Symbol properties are now copied [#151](https://github.com/TehShrike/deepmerge/pull/151)
|
|
42
|
+
|
|
43
|
+
# [3.2.1](https://github.com/TehShrike/deepmerge/releases/tag/v3.2.1)
|
|
44
|
+
|
|
45
|
+
- bumping dev dependency versions to try to shut up bogus security warnings from Github/npm [#149](https://github.com/TehShrike/deepmerge/pull/149)
|
|
46
|
+
|
|
47
|
+
# [3.2.0](https://github.com/TehShrike/deepmerge/releases/tag/v3.2.0)
|
|
48
|
+
|
|
49
|
+
- feature: added the [`customMerge`](https://github.com/TehShrike/deepmerge#custommerge) option [#133](https://github.com/TehShrike/deepmerge/pull/133)
|
|
50
|
+
|
|
51
|
+
# [3.1.0](https://github.com/TehShrike/deepmerge/releases/tag/v3.1.0)
|
|
52
|
+
|
|
53
|
+
- typescript typing: make the `all` function generic [#129](https://github.com/TehShrike/deepmerge/pull/129)
|
|
54
|
+
|
|
55
|
+
# [3.0.0](https://github.com/TehShrike/deepmerge/releases/tag/v3.0.0)
|
|
56
|
+
|
|
57
|
+
- drop ES module build [#123](https://github.com/TehShrike/deepmerge/issues/123)
|
|
58
|
+
|
|
59
|
+
# [2.2.1](https://github.com/TehShrike/deepmerge/releases/tag/v2.2.1)
|
|
60
|
+
|
|
61
|
+
- bug: typescript export type was wrong [#121](https://github.com/TehShrike/deepmerge/pull/121)
|
|
62
|
+
|
|
63
|
+
# [2.2.0](https://github.com/TehShrike/deepmerge/releases/tag/v2.2.0)
|
|
64
|
+
|
|
65
|
+
- feature: added TypeScript typings [#119](https://github.com/TehShrike/deepmerge/pull/119)
|
|
66
|
+
|
|
67
|
+
# [2.1.1](https://github.com/TehShrike/deepmerge/releases/tag/v2.1.1)
|
|
68
|
+
|
|
69
|
+
- documentation: Rename "methods" to "api", note ESM syntax [#103](https://github.com/TehShrike/deepmerge/pull/103)
|
|
70
|
+
- documentation: Fix grammar [#107](https://github.com/TehShrike/deepmerge/pull/107)
|
|
71
|
+
- documentation: Restructure headers for clarity + some wording tweaks [108](https://github.com/TehShrike/deepmerge/pull/108) + [109](https://github.com/TehShrike/deepmerge/pull/109)
|
|
72
|
+
|
|
73
|
+
|
|
74
|
+
# [2.1.0](https://github.com/TehShrike/deepmerge/releases/tag/v2.1.0)
|
|
75
|
+
|
|
76
|
+
- feature: Support a custom `isMergeableObject` function [#96](https://github.com/TehShrike/deepmerge/pull/96)
|
|
77
|
+
- documentation: note a Webpack bug that some users might need to work around [#100](https://github.com/TehShrike/deepmerge/pull/100)
|
|
78
|
+
|
|
79
|
+
# [2.0.1](https://github.com/TehShrike/deepmerge/releases/tag/v2.0.1)
|
|
80
|
+
|
|
81
|
+
- documentation: fix the old array merge algorithm in the readme. [#84](https://github.com/TehShrike/deepmerge/pull/84)
|
|
82
|
+
|
|
83
|
+
# [2.0.0](https://github.com/TehShrike/deepmerge/releases/tag/v2.0.0)
|
|
84
|
+
|
|
85
|
+
- breaking: the array merge algorithm has changed from a complicated thing to `target.concat(source).map(element => cloneUnlessOtherwiseSpecified(element, optionsArgument))`
|
|
86
|
+
- breaking: The `clone` option now defaults to `true`
|
|
87
|
+
- feature: `merge.all` now accepts an array of any size, even 0 or 1 elements
|
|
88
|
+
|
|
89
|
+
See [pull request 77](https://github.com/TehShrike/deepmerge/pull/77).
|
|
90
|
+
|
|
91
|
+
# [1.5.2](https://github.com/TehShrike/deepmerge/releases/tag/v1.5.2)
|
|
92
|
+
|
|
93
|
+
- fix: no longer attempts to merge React elements [#76](https://github.com/TehShrike/deepmerge/issues/76)
|
|
94
|
+
|
|
95
|
+
# [1.5.1](https://github.com/TehShrike/deepmerge/releases/tag/v1.5.1)
|
|
96
|
+
|
|
97
|
+
- bower support: officially dropping bower support. If you use bower, please depend on the [unpkg distribution](https://unpkg.com/deepmerge/dist/umd.js). See [#63](https://github.com/TehShrike/deepmerge/issues/63)
|
|
98
|
+
|
|
99
|
+
# [1.5.0](https://github.com/TehShrike/deepmerge/releases/tag/v1.5.0)
|
|
100
|
+
|
|
101
|
+
- bug fix: merging objects into arrays was allowed, and doesn't make any sense. [#65](https://github.com/TehShrike/deepmerge/issues/65) published as a feature release instead of a patch because it is a decent behavior change.
|
|
102
|
+
|
|
103
|
+
# [1.4.4](https://github.com/TehShrike/deepmerge/releases/tag/v1.4.4)
|
|
104
|
+
|
|
105
|
+
- bower support: updated `main` in bower.json
|
|
106
|
+
|
|
107
|
+
# [1.4.3](https://github.com/TehShrike/deepmerge/releases/tag/v1.4.3)
|
|
108
|
+
|
|
109
|
+
- bower support: inline is-mergeable-object in a new CommonJS build, so that people using both bower and CommonJS can bundle the library [0b34e6](https://github.com/TehShrike/deepmerge/commit/0b34e6e95f989f2fc8091d25f0d291c08f3d2d24)
|
|
110
|
+
|
|
111
|
+
# [1.4.2](https://github.com/TehShrike/deepmerge/releases/tag/v1.4.2)
|
|
112
|
+
|
|
113
|
+
- performance: bump is-mergeable-object dependency version for a slight performance improvement [5906c7](https://github.com/TehShrike/deepmerge/commit/5906c765d691d48e83d76efbb0d4b9ca150dc12c)
|
|
114
|
+
|
|
115
|
+
# [1.4.1](https://github.com/TehShrike/deepmerge/releases/tag/v1.4.1)
|
|
116
|
+
|
|
117
|
+
- documentation: fix unpkg link [acc45b](https://github.com/TehShrike/deepmerge/commit/acc45be85519c1df906a72ecb24764b622d18d47)
|
|
118
|
+
|
|
119
|
+
# [1.4.0](https://github.com/TehShrike/deepmerge/releases/tag/v1.4.0)
|
|
120
|
+
|
|
121
|
+
- api: instead of only exporting a UMD module, expose a UMD module with `pkg.main`, a CJS module with `pkg.browser`, and an ES module with `pkg.module` [#62](https://github.com/TehShrike/deepmerge/pull/62)
|
|
122
|
+
|
|
123
|
+
# [1.3.2](https://github.com/TehShrike/deepmerge/releases/tag/v1.3.2)
|
|
124
|
+
|
|
125
|
+
- documentation: note the minified/gzipped file sizes [56](https://github.com/TehShrike/deepmerge/pull/56)
|
|
126
|
+
- documentation: make data structures more readable in merge example: pull request [57](https://github.com/TehShrike/deepmerge/pull/57)
|
|
127
|
+
|
|
128
|
+
# [1.3.1](https://github.com/TehShrike/deepmerge/releases/tag/v1.3.1)
|
|
129
|
+
|
|
130
|
+
- documentation: clarify and test some array merging documentation: pull request [51](https://github.com/TehShrike/deepmerge/pull/51)
|
|
131
|
+
|
|
132
|
+
# [1.3.0](https://github.com/TehShrike/deepmerge/releases/tag/v1.3.0)
|
|
133
|
+
|
|
134
|
+
- feature: `merge.all`, a merge function that merges any number of objects: pull request [50](https://github.com/TehShrike/deepmerge/pull/50)
|
|
135
|
+
|
|
136
|
+
# [1.2.0](https://github.com/TehShrike/deepmerge/releases/tag/v1.2.0)
|
|
137
|
+
|
|
138
|
+
- fix: an error that would be thrown when an array would be merged onto a truthy non-array value: pull request [46](https://github.com/TehShrike/deepmerge/pull/46)
|
|
139
|
+
- feature: the ability to clone: Issue [28](https://github.com/TehShrike/deepmerge/issues/28), pull requests [44](https://github.com/TehShrike/deepmerge/pull/44) and [48](https://github.com/TehShrike/deepmerge/pull/48)
|
|
140
|
+
- maintenance: added tests + travis to `.npmignore`: pull request [47](https://github.com/TehShrike/deepmerge/pull/47)
|
|
141
|
+
|
|
142
|
+
# [1.1.1](https://github.com/TehShrike/deepmerge/releases/tag/v1.1.1)
|
|
143
|
+
|
|
144
|
+
- fix an issue where an error was thrown when merging an array onto a non-array: [Pull request 46](https://github.com/TehShrike/deepmerge/pull/46)
|
|
145
|
+
|
|
146
|
+
# [1.1.0](https://github.com/TehShrike/deepmerge/releases/tag/v1.1.0)
|
|
147
|
+
|
|
148
|
+
- allow consumers to specify their own array merging algorithm: [Pull request 37](https://github.com/TehShrike/deepmerge/pull/37)
|
|
149
|
+
|
|
150
|
+
# [1.0.3](https://github.com/TehShrike/deepmerge/releases/tag/v1.0.3)
|
|
151
|
+
|
|
152
|
+
- adding bower.json back: [Issue 38](https://github.com/TehShrike/deepmerge/pull/38)
|
|
153
|
+
- updating keywords and Github links in package.json [bc3898e](https://github.com/TehShrike/deepmerge/commit/bc3898e587a56f74591328f40f656b0152c1d5eb)
|
|
154
|
+
|
|
155
|
+
# [1.0.2](https://github.com/TehShrike/deepmerge/releases/tag/v1.0.2)
|
|
156
|
+
|
|
157
|
+
- Updating the readme: dropping bower, testing that the example works: [7102fc](https://github.com/TehShrike/deepmerge/commit/7102fcc4ddec11e2d33205866f9f18df14e5aeb5)
|
|
158
|
+
|
|
159
|
+
# [1.0.1](https://github.com/TehShrike/deepmerge/releases/tag/v1.0.1)
|
|
160
|
+
|
|
161
|
+
- `null`, dates, and regular expressions are now properly merged in arrays: [Issue 18](https://github.com/TehShrike/deepmerge/pull/18), plus commit: [ef1c6b](https://github.com/TehShrike/deepmerge/commit/ef1c6bac8350ba12a24966f0bc7da02560827586)
|
|
162
|
+
|
|
163
|
+
# 1.0.0
|
|
164
|
+
|
|
165
|
+
- Should only be a patch change, because this module is READY. [Issue 15](https://github.com/TehShrike/deepmerge/issues/15)
|
|
166
|
+
- Regular expressions are now treated like primitive values when merging: [Issue 30](https://github.com/TehShrike/deepmerge/pull/30)
|
|
167
|
+
- Dates are now treated like primitives when merging: [Issue 31](https://github.com/TehShrike/deepmerge/issues/31)
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var isMergeableObject = function isMergeableObject(value) {
|
|
4
|
+
return isNonNullObject(value)
|
|
5
|
+
&& !isSpecial(value)
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
function isNonNullObject(value) {
|
|
9
|
+
return !!value && typeof value === 'object'
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
function isSpecial(value) {
|
|
13
|
+
var stringValue = Object.prototype.toString.call(value);
|
|
14
|
+
|
|
15
|
+
return stringValue === '[object RegExp]'
|
|
16
|
+
|| stringValue === '[object Date]'
|
|
17
|
+
|| isReactElement(value)
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
// see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25
|
|
21
|
+
var canUseSymbol = typeof Symbol === 'function' && Symbol.for;
|
|
22
|
+
var REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7;
|
|
23
|
+
|
|
24
|
+
function isReactElement(value) {
|
|
25
|
+
return value.$$typeof === REACT_ELEMENT_TYPE
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
function emptyTarget(val) {
|
|
29
|
+
return Array.isArray(val) ? [] : {}
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
function cloneUnlessOtherwiseSpecified(value, options) {
|
|
33
|
+
return (options.clone !== false && options.isMergeableObject(value))
|
|
34
|
+
? deepmerge(emptyTarget(value), value, options)
|
|
35
|
+
: value
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
function defaultArrayMerge(target, source, options) {
|
|
39
|
+
return target.concat(source).map(function(element) {
|
|
40
|
+
return cloneUnlessOtherwiseSpecified(element, options)
|
|
41
|
+
})
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
function getMergeFunction(key, options) {
|
|
45
|
+
if (!options.customMerge) {
|
|
46
|
+
return deepmerge
|
|
47
|
+
}
|
|
48
|
+
var customMerge = options.customMerge(key);
|
|
49
|
+
return typeof customMerge === 'function' ? customMerge : deepmerge
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function getEnumerableOwnPropertySymbols(target) {
|
|
53
|
+
return Object.getOwnPropertySymbols
|
|
54
|
+
? Object.getOwnPropertySymbols(target).filter(function(symbol) {
|
|
55
|
+
return Object.propertyIsEnumerable.call(target, symbol)
|
|
56
|
+
})
|
|
57
|
+
: []
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
function getKeys(target) {
|
|
61
|
+
return Object.keys(target).concat(getEnumerableOwnPropertySymbols(target))
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
function propertyIsOnObject(object, property) {
|
|
65
|
+
try {
|
|
66
|
+
return property in object
|
|
67
|
+
} catch(_) {
|
|
68
|
+
return false
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// Protects from prototype poisoning and unexpected merging up the prototype chain.
|
|
73
|
+
function propertyIsUnsafe(target, key) {
|
|
74
|
+
return propertyIsOnObject(target, key) // Properties are safe to merge if they don't exist in the target yet,
|
|
75
|
+
&& !(Object.hasOwnProperty.call(target, key) // unsafe if they exist up the prototype chain,
|
|
76
|
+
&& Object.propertyIsEnumerable.call(target, key)) // and also unsafe if they're nonenumerable.
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
function mergeObject(target, source, options) {
|
|
80
|
+
var destination = {};
|
|
81
|
+
if (options.isMergeableObject(target)) {
|
|
82
|
+
getKeys(target).forEach(function(key) {
|
|
83
|
+
destination[key] = cloneUnlessOtherwiseSpecified(target[key], options);
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
getKeys(source).forEach(function(key) {
|
|
87
|
+
if (propertyIsUnsafe(target, key)) {
|
|
88
|
+
return
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (propertyIsOnObject(target, key) && options.isMergeableObject(source[key])) {
|
|
92
|
+
destination[key] = getMergeFunction(key, options)(target[key], source[key], options);
|
|
93
|
+
} else {
|
|
94
|
+
destination[key] = cloneUnlessOtherwiseSpecified(source[key], options);
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
return destination
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
function deepmerge(target, source, options) {
|
|
101
|
+
options = options || {};
|
|
102
|
+
options.arrayMerge = options.arrayMerge || defaultArrayMerge;
|
|
103
|
+
options.isMergeableObject = options.isMergeableObject || isMergeableObject;
|
|
104
|
+
// cloneUnlessOtherwiseSpecified is added to `options` so that custom arrayMerge()
|
|
105
|
+
// implementations can use it. The caller may not replace it.
|
|
106
|
+
options.cloneUnlessOtherwiseSpecified = cloneUnlessOtherwiseSpecified;
|
|
107
|
+
|
|
108
|
+
var sourceIsArray = Array.isArray(source);
|
|
109
|
+
var targetIsArray = Array.isArray(target);
|
|
110
|
+
var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;
|
|
111
|
+
|
|
112
|
+
if (!sourceAndTargetTypesMatch) {
|
|
113
|
+
return cloneUnlessOtherwiseSpecified(source, options)
|
|
114
|
+
} else if (sourceIsArray) {
|
|
115
|
+
return options.arrayMerge(target, source, options)
|
|
116
|
+
} else {
|
|
117
|
+
return mergeObject(target, source, options)
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
deepmerge.all = function deepmergeAll(array, options) {
|
|
122
|
+
if (!Array.isArray(array)) {
|
|
123
|
+
throw new Error('first argument should be an array')
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
return array.reduce(function(prev, next) {
|
|
127
|
+
return deepmerge(prev, next, options)
|
|
128
|
+
}, {})
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
var deepmerge_1 = deepmerge;
|
|
132
|
+
|
|
133
|
+
module.exports = deepmerge_1;
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
(function (global, factory) {
|
|
2
|
+
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
|
|
3
|
+
typeof define === 'function' && define.amd ? define(factory) :
|
|
4
|
+
(global = global || self, global.deepmerge = factory());
|
|
5
|
+
}(this, function () { 'use strict';
|
|
6
|
+
|
|
7
|
+
var isMergeableObject = function isMergeableObject(value) {
|
|
8
|
+
return isNonNullObject(value)
|
|
9
|
+
&& !isSpecial(value)
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
function isNonNullObject(value) {
|
|
13
|
+
return !!value && typeof value === 'object'
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
function isSpecial(value) {
|
|
17
|
+
var stringValue = Object.prototype.toString.call(value);
|
|
18
|
+
|
|
19
|
+
return stringValue === '[object RegExp]'
|
|
20
|
+
|| stringValue === '[object Date]'
|
|
21
|
+
|| isReactElement(value)
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
// see https://github.com/facebook/react/blob/b5ac963fb791d1298e7f396236383bc955f916c1/src/isomorphic/classic/element/ReactElement.js#L21-L25
|
|
25
|
+
var canUseSymbol = typeof Symbol === 'function' && Symbol.for;
|
|
26
|
+
var REACT_ELEMENT_TYPE = canUseSymbol ? Symbol.for('react.element') : 0xeac7;
|
|
27
|
+
|
|
28
|
+
function isReactElement(value) {
|
|
29
|
+
return value.$$typeof === REACT_ELEMENT_TYPE
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
function emptyTarget(val) {
|
|
33
|
+
return Array.isArray(val) ? [] : {}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
function cloneUnlessOtherwiseSpecified(value, options) {
|
|
37
|
+
return (options.clone !== false && options.isMergeableObject(value))
|
|
38
|
+
? deepmerge(emptyTarget(value), value, options)
|
|
39
|
+
: value
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
function defaultArrayMerge(target, source, options) {
|
|
43
|
+
return target.concat(source).map(function(element) {
|
|
44
|
+
return cloneUnlessOtherwiseSpecified(element, options)
|
|
45
|
+
})
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
function getMergeFunction(key, options) {
|
|
49
|
+
if (!options.customMerge) {
|
|
50
|
+
return deepmerge
|
|
51
|
+
}
|
|
52
|
+
var customMerge = options.customMerge(key);
|
|
53
|
+
return typeof customMerge === 'function' ? customMerge : deepmerge
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
function getEnumerableOwnPropertySymbols(target) {
|
|
57
|
+
return Object.getOwnPropertySymbols
|
|
58
|
+
? Object.getOwnPropertySymbols(target).filter(function(symbol) {
|
|
59
|
+
return Object.propertyIsEnumerable.call(target, symbol)
|
|
60
|
+
})
|
|
61
|
+
: []
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
function getKeys(target) {
|
|
65
|
+
return Object.keys(target).concat(getEnumerableOwnPropertySymbols(target))
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
function propertyIsOnObject(object, property) {
|
|
69
|
+
try {
|
|
70
|
+
return property in object
|
|
71
|
+
} catch(_) {
|
|
72
|
+
return false
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// Protects from prototype poisoning and unexpected merging up the prototype chain.
|
|
77
|
+
function propertyIsUnsafe(target, key) {
|
|
78
|
+
return propertyIsOnObject(target, key) // Properties are safe to merge if they don't exist in the target yet,
|
|
79
|
+
&& !(Object.hasOwnProperty.call(target, key) // unsafe if they exist up the prototype chain,
|
|
80
|
+
&& Object.propertyIsEnumerable.call(target, key)) // and also unsafe if they're nonenumerable.
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
function mergeObject(target, source, options) {
|
|
84
|
+
var destination = {};
|
|
85
|
+
if (options.isMergeableObject(target)) {
|
|
86
|
+
getKeys(target).forEach(function(key) {
|
|
87
|
+
destination[key] = cloneUnlessOtherwiseSpecified(target[key], options);
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
getKeys(source).forEach(function(key) {
|
|
91
|
+
if (propertyIsUnsafe(target, key)) {
|
|
92
|
+
return
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
if (propertyIsOnObject(target, key) && options.isMergeableObject(source[key])) {
|
|
96
|
+
destination[key] = getMergeFunction(key, options)(target[key], source[key], options);
|
|
97
|
+
} else {
|
|
98
|
+
destination[key] = cloneUnlessOtherwiseSpecified(source[key], options);
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
return destination
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
function deepmerge(target, source, options) {
|
|
105
|
+
options = options || {};
|
|
106
|
+
options.arrayMerge = options.arrayMerge || defaultArrayMerge;
|
|
107
|
+
options.isMergeableObject = options.isMergeableObject || isMergeableObject;
|
|
108
|
+
// cloneUnlessOtherwiseSpecified is added to `options` so that custom arrayMerge()
|
|
109
|
+
// implementations can use it. The caller may not replace it.
|
|
110
|
+
options.cloneUnlessOtherwiseSpecified = cloneUnlessOtherwiseSpecified;
|
|
111
|
+
|
|
112
|
+
var sourceIsArray = Array.isArray(source);
|
|
113
|
+
var targetIsArray = Array.isArray(target);
|
|
114
|
+
var sourceAndTargetTypesMatch = sourceIsArray === targetIsArray;
|
|
115
|
+
|
|
116
|
+
if (!sourceAndTargetTypesMatch) {
|
|
117
|
+
return cloneUnlessOtherwiseSpecified(source, options)
|
|
118
|
+
} else if (sourceIsArray) {
|
|
119
|
+
return options.arrayMerge(target, source, options)
|
|
120
|
+
} else {
|
|
121
|
+
return mergeObject(target, source, options)
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
deepmerge.all = function deepmergeAll(array, options) {
|
|
126
|
+
if (!Array.isArray(array)) {
|
|
127
|
+
throw new Error('first argument should be an array')
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
return array.reduce(function(prev, next) {
|
|
131
|
+
return deepmerge(prev, next, options)
|
|
132
|
+
}, {})
|
|
133
|
+
};
|
|
134
|
+
|
|
135
|
+
var deepmerge_1 = deepmerge;
|
|
136
|
+
|
|
137
|
+
return deepmerge_1;
|
|
138
|
+
|
|
139
|
+
}));
|