autotel 3.6.0 → 4.0.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/dist/attribute-redacting-processor-DtTS9xxh.d.cts +175 -0
- package/dist/attribute-redacting-processor-DtTS9xxh.d.cts.map +1 -0
- package/dist/attribute-redacting-processor-DtTS9xxh.d.ts +175 -0
- package/dist/attribute-redacting-processor-DtTS9xxh.d.ts.map +1 -0
- package/dist/attribute-redacting-processor.cjs +374 -33
- package/dist/attribute-redacting-processor.cjs.map +1 -1
- package/dist/attribute-redacting-processor.d.cts +2 -207
- package/dist/attribute-redacting-processor.d.ts +2 -207
- package/dist/attribute-redacting-processor.js +368 -2
- package/dist/attribute-redacting-processor.js.map +1 -1
- package/dist/attributes-CmYpdqCN.js +591 -0
- package/dist/attributes-CmYpdqCN.js.map +1 -0
- package/dist/attributes-PZ5doLgw.cjs +704 -0
- package/dist/attributes-PZ5doLgw.cjs.map +1 -0
- package/dist/attributes.cjs +21 -85
- package/dist/attributes.d.cts +2 -20
- package/dist/attributes.d.ts +2 -20
- package/dist/attributes.js +3 -5
- package/dist/auto.cjs +50 -28
- package/dist/auto.cjs.map +1 -1
- package/dist/auto.d.cts +1 -2
- package/dist/auto.d.ts +1 -2
- package/dist/auto.js +49 -23
- package/dist/auto.js.map +1 -1
- package/dist/business-baggage.cjs +357 -13
- package/dist/business-baggage.cjs.map +1 -1
- package/dist/business-baggage.d.cts +106 -139
- package/dist/business-baggage.d.cts.map +1 -0
- package/dist/business-baggage.d.ts +106 -139
- package/dist/business-baggage.d.ts.map +1 -0
- package/dist/business-baggage.js +357 -2
- package/dist/business-baggage.js.map +1 -1
- package/dist/canonical-log-line-processor--RlFDHhm.cjs +377 -0
- package/dist/canonical-log-line-processor--RlFDHhm.cjs.map +1 -0
- package/dist/canonical-log-line-processor-BcRuAdRk.d.ts +147 -0
- package/dist/canonical-log-line-processor-BcRuAdRk.d.ts.map +1 -0
- package/dist/canonical-log-line-processor-DbBQT5vY.js +366 -0
- package/dist/canonical-log-line-processor-DbBQT5vY.js.map +1 -0
- package/dist/canonical-log-line-processor-xvjMgtpF.d.cts +147 -0
- package/dist/canonical-log-line-processor-xvjMgtpF.d.cts.map +1 -0
- package/dist/config.cjs +118 -22
- package/dist/config.cjs.map +1 -1
- package/dist/config.d.cts +33 -45
- package/dist/config.d.cts.map +1 -0
- package/dist/config.d.ts +33 -45
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +116 -3
- package/dist/config.js.map +1 -1
- package/dist/correlated-events-Bzh5y-UB.js +28 -0
- package/dist/correlated-events-Bzh5y-UB.js.map +1 -0
- package/dist/correlated-events-kSwLo3mi.cjs +34 -0
- package/dist/correlated-events-kSwLo3mi.cjs.map +1 -0
- package/dist/correlation-id.cjs +11 -54
- package/dist/correlation-id.d.cts +6 -5
- package/dist/correlation-id.d.cts.map +1 -0
- package/dist/correlation-id.d.ts +6 -5
- package/dist/correlation-id.d.ts.map +1 -0
- package/dist/correlation-id.js +3 -17
- package/dist/db.cjs +244 -209
- package/dist/db.cjs.map +1 -1
- package/dist/db.d.cts +28 -26
- package/dist/db.d.cts.map +1 -0
- package/dist/db.d.ts +28 -26
- package/dist/db.d.ts.map +1 -0
- package/dist/db.js +243 -207
- package/dist/db.js.map +1 -1
- package/dist/decorators.cjs +39 -66
- package/dist/decorators.cjs.map +1 -1
- package/dist/decorators.d.cts +10 -37
- package/dist/decorators.d.cts.map +1 -0
- package/dist/decorators.d.ts +10 -37
- package/dist/decorators.d.ts.map +1 -0
- package/dist/decorators.js +38 -64
- package/dist/decorators.js.map +1 -1
- package/dist/define-event-CreknLm3.d.ts +25 -0
- package/dist/define-event-CreknLm3.d.ts.map +1 -0
- package/dist/define-event-HZRizPwz.d.cts +25 -0
- package/dist/define-event-HZRizPwz.d.cts.map +1 -0
- package/dist/drain-pipeline.cjs +111 -9
- package/dist/drain-pipeline.cjs.map +1 -1
- package/dist/drain-pipeline.d.cts +27 -32
- package/dist/drain-pipeline.d.cts.map +1 -0
- package/dist/drain-pipeline.d.ts +27 -32
- package/dist/drain-pipeline.d.ts.map +1 -0
- package/dist/drain-pipeline.js +111 -2
- package/dist/drain-pipeline.js.map +1 -1
- package/dist/enrichers.cjs +59 -66
- package/dist/enrichers.cjs.map +1 -1
- package/dist/enrichers.d.cts +15 -13
- package/dist/enrichers.d.cts.map +1 -0
- package/dist/enrichers.d.ts +15 -13
- package/dist/enrichers.d.ts.map +1 -0
- package/dist/enrichers.js +58 -65
- package/dist/enrichers.js.map +1 -1
- package/dist/event-Dlqr4ZNL.cjs +778 -0
- package/dist/event-Dlqr4ZNL.cjs.map +1 -0
- package/dist/event-_58ryBjh.js +761 -0
- package/dist/event-_58ryBjh.js.map +1 -0
- package/dist/event-subscriber-D1XLkPzi.d.cts +223 -0
- package/dist/event-subscriber-D1XLkPzi.d.cts.map +1 -0
- package/dist/event-subscriber-D1XLkPzi.d.ts +223 -0
- package/dist/event-subscriber-D1XLkPzi.d.ts.map +1 -0
- package/dist/event-subscriber.cjs +0 -6
- package/dist/event-subscriber.d.cts +2 -221
- package/dist/event-subscriber.d.ts +2 -221
- package/dist/event-subscriber.js +1 -3
- package/dist/event-testing-BqRnI0z4.d.cts +106 -0
- package/dist/event-testing-BqRnI0z4.d.cts.map +1 -0
- package/dist/event-testing-CfFs3to2.d.ts +106 -0
- package/dist/event-testing-CfFs3to2.d.ts.map +1 -0
- package/dist/event-testing.cjs +93 -17
- package/dist/event-testing.cjs.map +1 -1
- package/dist/event-testing.d.cts +2 -110
- package/dist/event-testing.d.ts +2 -110
- package/dist/event-testing.js +91 -2
- package/dist/event-testing.js.map +1 -1
- package/dist/event.cjs +5 -37
- package/dist/event.d.cts +295 -340
- package/dist/event.d.cts.map +1 -0
- package/dist/event.d.ts +295 -340
- package/dist/event.d.ts.map +1 -0
- package/dist/event.js +3 -21
- package/dist/exporters.cjs +12 -16
- package/dist/exporters.d.cts +86 -111
- package/dist/exporters.d.cts.map +1 -0
- package/dist/exporters.d.ts +86 -111
- package/dist/exporters.d.ts.map +1 -0
- package/dist/exporters.js +4 -4
- package/dist/filtering-span-processor-B8R8B7Uk.d.cts +59 -0
- package/dist/filtering-span-processor-B8R8B7Uk.d.cts.map +1 -0
- package/dist/filtering-span-processor-B8R8B7Uk.d.ts +59 -0
- package/dist/filtering-span-processor-B8R8B7Uk.d.ts.map +1 -0
- package/dist/filtering-span-processor.cjs +49 -9
- package/dist/filtering-span-processor.cjs.map +1 -1
- package/dist/filtering-span-processor.d.cts +2 -80
- package/dist/filtering-span-processor.d.ts +2 -80
- package/dist/filtering-span-processor.js +49 -2
- package/dist/filtering-span-processor.js.map +1 -1
- package/dist/functional-BGkT8J-h.js +1265 -0
- package/dist/functional-BGkT8J-h.js.map +1 -0
- package/dist/functional-C4CzoVrX.cjs +1312 -0
- package/dist/functional-C4CzoVrX.cjs.map +1 -0
- package/dist/functional.cjs +11 -57
- package/dist/functional.d.cts +96 -97
- package/dist/functional.d.cts.map +1 -0
- package/dist/functional.d.ts +96 -97
- package/dist/functional.d.ts.map +1 -0
- package/dist/functional.js +3 -20
- package/dist/http.cjs +276 -176
- package/dist/http.cjs.map +1 -1
- package/dist/http.d.cts +17 -37
- package/dist/http.d.cts.map +1 -0
- package/dist/http.d.ts +17 -37
- package/dist/http.d.ts.map +1 -0
- package/dist/http.js +275 -174
- package/dist/http.js.map +1 -1
- package/dist/index-Ck06vlW2.d.ts +678 -0
- package/dist/index-Ck06vlW2.d.ts.map +1 -0
- package/dist/index-eKuioqT1.d.cts +678 -0
- package/dist/index-eKuioqT1.d.cts.map +1 -0
- package/dist/index.cjs +751 -1218
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +341 -659
- package/dist/index.d.cts.map +1 -0
- package/dist/index.d.ts +341 -659
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +606 -737
- package/dist/index.js.map +1 -1
- package/dist/init-CNp-ee80.d.cts +1157 -0
- package/dist/init-CNp-ee80.d.cts.map +1 -0
- package/dist/init-Ch6t7MNI.js +1015 -0
- package/dist/init-Ch6t7MNI.js.map +1 -0
- package/dist/init-DJQOdVlN.d.ts +1157 -0
- package/dist/init-DJQOdVlN.d.ts.map +1 -0
- package/dist/init-DvapOXCc.cjs +1092 -0
- package/dist/init-DvapOXCc.cjs.map +1 -0
- package/dist/instrumentation.cjs +159 -185
- package/dist/instrumentation.cjs.map +1 -1
- package/dist/instrumentation.d.cts +42 -40
- package/dist/instrumentation.d.cts.map +1 -0
- package/dist/instrumentation.d.ts +42 -40
- package/dist/instrumentation.d.ts.map +1 -0
- package/dist/instrumentation.js +158 -183
- package/dist/instrumentation.js.map +1 -1
- package/dist/logger-BauSUhUv.d.cts +313 -0
- package/dist/logger-BauSUhUv.d.cts.map +1 -0
- package/dist/logger-BauSUhUv.d.ts +313 -0
- package/dist/logger-BauSUhUv.d.ts.map +1 -0
- package/dist/logger.cjs +225 -25
- package/dist/logger.cjs.map +1 -1
- package/dist/logger.d.cts +2 -348
- package/dist/logger.d.ts +2 -348
- package/dist/logger.js +204 -4
- package/dist/logger.js.map +1 -1
- package/dist/messaging-adapters.cjs +292 -187
- package/dist/messaging-adapters.cjs.map +1 -1
- package/dist/messaging-adapters.d.cts +28 -66
- package/dist/messaging-adapters.d.cts.map +1 -0
- package/dist/messaging-adapters.d.ts +28 -66
- package/dist/messaging-adapters.d.ts.map +1 -0
- package/dist/messaging-adapters.js +291 -185
- package/dist/messaging-adapters.js.map +1 -1
- package/dist/messaging-testing.cjs +306 -372
- package/dist/messaging-testing.cjs.map +1 -1
- package/dist/messaging-testing.d.cts +194 -223
- package/dist/messaging-testing.d.cts.map +1 -0
- package/dist/messaging-testing.d.ts +194 -223
- package/dist/messaging-testing.d.ts.map +1 -0
- package/dist/messaging-testing.js +305 -371
- package/dist/messaging-testing.js.map +1 -1
- package/dist/messaging.cjs +757 -36
- package/dist/messaging.cjs.map +1 -1
- package/dist/messaging.d.cts +603 -644
- package/dist/messaging.d.cts.map +1 -0
- package/dist/messaging.d.ts +603 -644
- package/dist/messaging.d.ts.map +1 -0
- package/dist/messaging.js +756 -21
- package/dist/messaging.js.map +1 -1
- package/dist/metric-helpers.cjs +27 -27
- package/dist/metric-helpers.cjs.map +1 -1
- package/dist/metric-helpers.d.cts +4 -2
- package/dist/metric-helpers.d.cts.map +1 -0
- package/dist/metric-helpers.d.ts +4 -2
- package/dist/metric-helpers.d.ts.map +1 -0
- package/dist/metric-helpers.js +24 -4
- package/dist/metric-helpers.js.map +1 -1
- package/dist/metric-testing-DXdK3-Q3.d.ts +106 -0
- package/dist/metric-testing-DXdK3-Q3.d.ts.map +1 -0
- package/dist/metric-testing-MxvzChDp.d.cts +106 -0
- package/dist/metric-testing-MxvzChDp.d.cts.map +1 -0
- package/dist/metric-testing.cjs +93 -17
- package/dist/metric-testing.cjs.map +1 -1
- package/dist/metric-testing.d.cts +2 -110
- package/dist/metric-testing.d.ts +2 -110
- package/dist/metric-testing.js +91 -2
- package/dist/metric-testing.js.map +1 -1
- package/dist/metric.cjs +306 -22
- package/dist/metric.cjs.map +1 -1
- package/dist/metric.d.cts +170 -198
- package/dist/metric.d.cts.map +1 -0
- package/dist/metric.d.ts +170 -198
- package/dist/metric.d.ts.map +1 -0
- package/dist/metric.js +277 -7
- package/dist/metric.js.map +1 -1
- package/dist/node-require-DF5QBX6z.cjs +99 -0
- package/dist/node-require-DF5QBX6z.cjs.map +1 -0
- package/dist/node-require-Db1oDpLj.js +88 -0
- package/dist/node-require-Db1oDpLj.js.map +1 -0
- package/dist/operation-context-C-2hmmtP.js +59 -0
- package/dist/operation-context-C-2hmmtP.js.map +1 -0
- package/dist/operation-context-n4_obUwq.cjs +70 -0
- package/dist/operation-context-n4_obUwq.cjs.map +1 -0
- package/dist/parse-error.cjs +55 -9
- package/dist/parse-error.cjs.map +1 -1
- package/dist/parse-error.d.cts +12 -10
- package/dist/parse-error.d.cts.map +1 -0
- package/dist/parse-error.d.ts +12 -10
- package/dist/parse-error.d.ts.map +1 -0
- package/dist/parse-error.js +55 -2
- package/dist/parse-error.js.map +1 -1
- package/dist/pretty-console-exporter-CMzlrRNg.cjs +232 -0
- package/dist/pretty-console-exporter-CMzlrRNg.cjs.map +1 -0
- package/dist/pretty-console-exporter-DqKl_q9z.js +227 -0
- package/dist/pretty-console-exporter-DqKl_q9z.js.map +1 -0
- package/dist/processors.cjs +13 -17
- package/dist/processors.d.cts +3 -171
- package/dist/processors.d.ts +3 -171
- package/dist/processors.js +4 -4
- package/dist/register.cjs +35 -6
- package/dist/register.cjs.map +1 -1
- package/dist/register.d.cts +1 -2
- package/dist/register.d.ts +1 -2
- package/dist/register.js +36 -3
- package/dist/register.js.map +1 -1
- package/dist/registry-DVSmWg6Y.js +175 -0
- package/dist/registry-DVSmWg6Y.js.map +1 -0
- package/dist/registry-DYgvb62e.cjs +319 -0
- package/dist/registry-DYgvb62e.cjs.map +1 -0
- package/dist/sampling-CR0Va1VB.d.ts +351 -0
- package/dist/sampling-CR0Va1VB.d.ts.map +1 -0
- package/dist/sampling-DfYhDJij.d.cts +351 -0
- package/dist/sampling-DfYhDJij.d.cts.map +1 -0
- package/dist/sampling.cjs +452 -60
- package/dist/sampling.cjs.map +1 -1
- package/dist/sampling.d.cts +2 -379
- package/dist/sampling.d.ts +2 -379
- package/dist/sampling.js +441 -5
- package/dist/sampling.js.map +1 -1
- package/dist/security-schema.cjs +65 -46
- package/dist/security-schema.cjs.map +1 -1
- package/dist/security-schema.d.cts +23 -26
- package/dist/security-schema.d.cts.map +1 -0
- package/dist/security-schema.d.ts +23 -26
- package/dist/security-schema.d.ts.map +1 -0
- package/dist/security-schema.js +64 -45
- package/dist/security-schema.js.map +1 -1
- package/dist/semantic-conventions-FhSxv-bK.d.cts +32 -0
- package/dist/semantic-conventions-FhSxv-bK.d.cts.map +1 -0
- package/dist/semantic-conventions-FhSxv-bK.d.ts +32 -0
- package/dist/semantic-conventions-FhSxv-bK.d.ts.map +1 -0
- package/dist/semantic-conventions.cjs +15 -26
- package/dist/semantic-conventions.cjs.map +1 -1
- package/dist/semantic-conventions.d.cts +2 -29
- package/dist/semantic-conventions.d.ts +2 -29
- package/dist/semantic-conventions.js +12 -3
- package/dist/semantic-conventions.js.map +1 -1
- package/dist/semantic-helpers.cjs +327 -39
- package/dist/semantic-helpers.cjs.map +1 -1
- package/dist/semantic-helpers.d.cts +30 -150
- package/dist/semantic-helpers.d.cts.map +1 -0
- package/dist/semantic-helpers.d.ts +30 -150
- package/dist/semantic-helpers.d.ts.map +1 -0
- package/dist/semantic-helpers.js +326 -20
- package/dist/semantic-helpers.js.map +1 -1
- package/dist/span-name-normalizer-8ZOGJuwv.d.cts +70 -0
- package/dist/span-name-normalizer-8ZOGJuwv.d.cts.map +1 -0
- package/dist/span-name-normalizer-8ZOGJuwv.d.ts +70 -0
- package/dist/span-name-normalizer-8ZOGJuwv.d.ts.map +1 -0
- package/dist/span-name-normalizer.cjs +95 -17
- package/dist/span-name-normalizer.cjs.map +1 -1
- package/dist/span-name-normalizer.d.cts +2 -94
- package/dist/span-name-normalizer.d.ts +2 -94
- package/dist/span-name-normalizer.js +93 -2
- package/dist/span-name-normalizer.js.map +1 -1
- package/dist/stable-hash-BNTMrmdB.cjs +28 -0
- package/dist/stable-hash-BNTMrmdB.cjs.map +1 -0
- package/dist/stable-hash-Cg5cT34Q.js +23 -0
- package/dist/stable-hash-Cg5cT34Q.js.map +1 -0
- package/dist/structured-error-9--cxBay.js +143 -0
- package/dist/structured-error-9--cxBay.js.map +1 -0
- package/dist/structured-error-CHg7DoIQ.cjs +178 -0
- package/dist/structured-error-CHg7DoIQ.cjs.map +1 -0
- package/dist/tail-sampling-processor.cjs +26 -13
- package/dist/tail-sampling-processor.cjs.map +1 -1
- package/dist/tail-sampling-processor.d.cts +11 -23
- package/dist/tail-sampling-processor.d.cts.map +1 -0
- package/dist/tail-sampling-processor.d.ts +11 -23
- package/dist/tail-sampling-processor.d.ts.map +1 -0
- package/dist/tail-sampling-processor.js +27 -6
- package/dist/tail-sampling-processor.js.map +1 -1
- package/dist/test-span-collector.cjs +70 -72
- package/dist/test-span-collector.cjs.map +1 -1
- package/dist/test-span-collector.d.cts +25 -43
- package/dist/test-span-collector.d.cts.map +1 -0
- package/dist/test-span-collector.d.ts +25 -43
- package/dist/test-span-collector.d.ts.map +1 -0
- package/dist/test-span-collector.js +69 -70
- package/dist/test-span-collector.js.map +1 -1
- package/dist/testing.cjs +389 -278
- package/dist/testing.cjs.map +1 -1
- package/dist/testing.d.cts +39 -62
- package/dist/testing.d.cts.map +1 -0
- package/dist/testing.d.ts +39 -62
- package/dist/testing.d.ts.map +1 -0
- package/dist/testing.js +386 -265
- package/dist/testing.js.map +1 -1
- package/dist/trace-context-Cijqoi6e.d.cts +212 -0
- package/dist/trace-context-Cijqoi6e.d.cts.map +1 -0
- package/dist/trace-context-Cijqoi6e.d.ts +212 -0
- package/dist/trace-context-Cijqoi6e.d.ts.map +1 -0
- package/dist/trace-helpers.cjs +634 -54
- package/dist/trace-helpers.cjs.map +1 -1
- package/dist/trace-helpers.d.cts +17 -49
- package/dist/trace-helpers.d.cts.map +1 -0
- package/dist/trace-helpers.d.ts +17 -49
- package/dist/trace-helpers.d.ts.map +1 -0
- package/dist/trace-helpers.js +624 -3
- package/dist/trace-helpers.js.map +1 -1
- package/dist/tracer-provider.cjs +227 -16
- package/dist/tracer-provider.cjs.map +1 -1
- package/dist/tracer-provider.d.cts +5 -4
- package/dist/tracer-provider.d.cts.map +1 -0
- package/dist/tracer-provider.d.ts +5 -4
- package/dist/tracer-provider.d.ts.map +1 -0
- package/dist/tracer-provider.js +227 -2
- package/dist/tracer-provider.js.map +1 -1
- package/dist/track-3HY4NGV-.cjs +1212 -0
- package/dist/track-3HY4NGV-.cjs.map +1 -0
- package/dist/track-nsKVy-pj.js +1111 -0
- package/dist/track-nsKVy-pj.js.map +1 -0
- package/dist/validate.cjs +178 -115
- package/dist/validate.cjs.map +1 -1
- package/dist/validate.d.cts +40 -64
- package/dist/validate.d.cts.map +1 -0
- package/dist/validate.d.ts +40 -64
- package/dist/validate.d.ts.map +1 -0
- package/dist/validate.js +177 -113
- package/dist/validate.js.map +1 -1
- package/dist/validation-attributes.cjs +42 -17
- package/dist/validation-attributes.cjs.map +1 -1
- package/dist/validation-attributes.d.cts +13 -20
- package/dist/validation-attributes.d.cts.map +1 -0
- package/dist/validation-attributes.d.ts +13 -20
- package/dist/validation-attributes.d.ts.map +1 -0
- package/dist/validation-attributes.js +40 -2
- package/dist/validation-attributes.js.map +1 -1
- package/dist/webhook.cjs +286 -256
- package/dist/webhook.cjs.map +1 -1
- package/dist/webhook.d.cts +157 -192
- package/dist/webhook.d.cts.map +1 -0
- package/dist/webhook.d.ts +157 -192
- package/dist/webhook.d.ts.map +1 -0
- package/dist/webhook.js +285 -254
- package/dist/webhook.js.map +1 -1
- package/dist/workflow-distributed.cjs +498 -412
- package/dist/workflow-distributed.cjs.map +1 -1
- package/dist/workflow-distributed.d.cts +163 -173
- package/dist/workflow-distributed.d.cts.map +1 -0
- package/dist/workflow-distributed.d.ts +163 -173
- package/dist/workflow-distributed.d.ts.map +1 -0
- package/dist/workflow-distributed.js +497 -410
- package/dist/workflow-distributed.js.map +1 -1
- package/dist/workflow.cjs +405 -40
- package/dist/workflow.cjs.map +1 -1
- package/dist/workflow.d.cts +78 -131
- package/dist/workflow.d.cts.map +1 -0
- package/dist/workflow.d.ts +78 -131
- package/dist/workflow.d.ts.map +1 -0
- package/dist/workflow.js +403 -21
- package/dist/workflow.js.map +1 -1
- package/dist/yaml-config-B3dQ82GR.cjs +272 -0
- package/dist/yaml-config-B3dQ82GR.cjs.map +1 -0
- package/dist/yaml-config.cjs +5 -24
- package/dist/yaml-config.d.cts +30 -64
- package/dist/yaml-config.d.cts.map +1 -0
- package/dist/yaml-config.d.ts +30 -64
- package/dist/yaml-config.d.ts.map +1 -0
- package/dist/yaml-config.js +226 -7
- package/dist/yaml-config.js.map +1 -1
- package/package.json +4 -4
- package/skills/analyze-traces/SKILL.md +14 -12
- package/skills/review-otel-patterns/SKILL.md +4 -2
- package/skills/tune-sampling/SKILL.md +8 -3
- package/src/attributes/builders.ts +2 -20
- package/src/attributes/index.ts +0 -1
- package/src/attributes/registry.ts +2 -9
- package/src/attributes/types.ts +0 -8
- package/src/index.ts +7 -41
- package/src/request-logger.test.ts +53 -1
- package/src/request-logger.ts +58 -0
- package/src/semantic-helpers.test.ts +2 -87
- package/src/semantic-helpers.ts +0 -146
- package/src/validate.test.ts +3 -1
- package/src/validate.ts +9 -3
- package/dist/attributes.cjs.map +0 -1
- package/dist/attributes.js.map +0 -1
- package/dist/chunk-2ZKEORFN.cjs +0 -14
- package/dist/chunk-2ZKEORFN.cjs.map +0 -1
- package/dist/chunk-3QXBFGKP.js +0 -344
- package/dist/chunk-3QXBFGKP.js.map +0 -1
- package/dist/chunk-454CH4OV.js +0 -744
- package/dist/chunk-454CH4OV.js.map +0 -1
- package/dist/chunk-4A53YIAX.js +0 -180
- package/dist/chunk-4A53YIAX.js.map +0 -1
- package/dist/chunk-4IFSYQVX.js +0 -337
- package/dist/chunk-4IFSYQVX.js.map +0 -1
- package/dist/chunk-4P6ZOARG.cjs +0 -33
- package/dist/chunk-4P6ZOARG.cjs.map +0 -1
- package/dist/chunk-55ER2KD5.js +0 -228
- package/dist/chunk-55ER2KD5.js.map +0 -1
- package/dist/chunk-5ZN622AO.js +0 -73
- package/dist/chunk-5ZN622AO.js.map +0 -1
- package/dist/chunk-66YJ66GG.js +0 -1021
- package/dist/chunk-66YJ66GG.js.map +0 -1
- package/dist/chunk-6S5RUKU3.cjs +0 -347
- package/dist/chunk-6S5RUKU3.cjs.map +0 -1
- package/dist/chunk-6UQRVUN3.js +0 -222
- package/dist/chunk-6UQRVUN3.js.map +0 -1
- package/dist/chunk-7552UTQW.js +0 -11
- package/dist/chunk-7552UTQW.js.map +0 -1
- package/dist/chunk-7EQ4G4SI.cjs +0 -146
- package/dist/chunk-7EQ4G4SI.cjs.map +0 -1
- package/dist/chunk-7SAWIN74.js +0 -285
- package/dist/chunk-7SAWIN74.js.map +0 -1
- package/dist/chunk-A4E5AQFK.js +0 -30
- package/dist/chunk-A4E5AQFK.js.map +0 -1
- package/dist/chunk-ALPYR2GC.js +0 -1061
- package/dist/chunk-ALPYR2GC.js.map +0 -1
- package/dist/chunk-B7SWBE4P.cjs +0 -799
- package/dist/chunk-B7SWBE4P.cjs.map +0 -1
- package/dist/chunk-BZHG5IZ4.js +0 -73
- package/dist/chunk-BZHG5IZ4.js.map +0 -1
- package/dist/chunk-CEAQK2QY.cjs +0 -32
- package/dist/chunk-CEAQK2QY.cjs.map +0 -1
- package/dist/chunk-CMHVQR6P.js +0 -170
- package/dist/chunk-CMHVQR6P.js.map +0 -1
- package/dist/chunk-CU6IDACR.cjs +0 -224
- package/dist/chunk-CU6IDACR.cjs.map +0 -1
- package/dist/chunk-D4TM63S3.js +0 -795
- package/dist/chunk-D4TM63S3.js.map +0 -1
- package/dist/chunk-DCEDJQGG.js +0 -28
- package/dist/chunk-DCEDJQGG.js.map +0 -1
- package/dist/chunk-DPSA4QLA.js +0 -344
- package/dist/chunk-DPSA4QLA.js.map +0 -1
- package/dist/chunk-E6TERL5O.cjs +0 -23
- package/dist/chunk-E6TERL5O.cjs.map +0 -1
- package/dist/chunk-EE6CPXKH.cjs +0 -164
- package/dist/chunk-EE6CPXKH.cjs.map +0 -1
- package/dist/chunk-EOFB7XCL.cjs +0 -837
- package/dist/chunk-EOFB7XCL.cjs.map +0 -1
- package/dist/chunk-ESLWRGAG.cjs +0 -92
- package/dist/chunk-ESLWRGAG.cjs.map +0 -1
- package/dist/chunk-ESMHTKLJ.cjs +0 -206
- package/dist/chunk-ESMHTKLJ.cjs.map +0 -1
- package/dist/chunk-FMTHVSYY.cjs +0 -1039
- package/dist/chunk-FMTHVSYY.cjs.map +0 -1
- package/dist/chunk-FU6R566Y.cjs +0 -236
- package/dist/chunk-FU6R566Y.cjs.map +0 -1
- package/dist/chunk-GYR5K654.js +0 -91
- package/dist/chunk-GYR5K654.js.map +0 -1
- package/dist/chunk-HA2WBOGQ.js +0 -57
- package/dist/chunk-HA2WBOGQ.js.map +0 -1
- package/dist/chunk-HT5JQKN2.js +0 -118
- package/dist/chunk-HT5JQKN2.js.map +0 -1
- package/dist/chunk-INJD3G4K.cjs +0 -340
- package/dist/chunk-INJD3G4K.cjs.map +0 -1
- package/dist/chunk-IOYFAFHJ.cjs +0 -95
- package/dist/chunk-IOYFAFHJ.cjs.map +0 -1
- package/dist/chunk-J5QENANM.js +0 -87
- package/dist/chunk-J5QENANM.js.map +0 -1
- package/dist/chunk-J7VGRIAJ.js +0 -64
- package/dist/chunk-J7VGRIAJ.js.map +0 -1
- package/dist/chunk-KFOHQK7X.js +0 -144
- package/dist/chunk-KFOHQK7X.js.map +0 -1
- package/dist/chunk-KIL5CUN6.js +0 -31
- package/dist/chunk-KIL5CUN6.js.map +0 -1
- package/dist/chunk-KYXZS3EA.cjs +0 -100
- package/dist/chunk-KYXZS3EA.cjs.map +0 -1
- package/dist/chunk-LITNXTTT.js +0 -3
- package/dist/chunk-LITNXTTT.js.map +0 -1
- package/dist/chunk-LVIPBYFE.js +0 -157
- package/dist/chunk-LVIPBYFE.js.map +0 -1
- package/dist/chunk-M3LFHHTN.cjs +0 -764
- package/dist/chunk-M3LFHHTN.cjs.map +0 -1
- package/dist/chunk-N25JDZSC.js +0 -95
- package/dist/chunk-N25JDZSC.js.map +0 -1
- package/dist/chunk-NEIB3TLD.cjs +0 -360
- package/dist/chunk-NEIB3TLD.cjs.map +0 -1
- package/dist/chunk-NENU7E6V.cjs +0 -344
- package/dist/chunk-NENU7E6V.cjs.map +0 -1
- package/dist/chunk-NVAI5CCN.cjs +0 -39
- package/dist/chunk-NVAI5CCN.cjs.map +0 -1
- package/dist/chunk-NZ72VDNY.cjs +0 -4
- package/dist/chunk-NZ72VDNY.cjs.map +0 -1
- package/dist/chunk-OPPXYVEZ.cjs +0 -131
- package/dist/chunk-OPPXYVEZ.cjs.map +0 -1
- package/dist/chunk-Q4EULJQY.js +0 -35
- package/dist/chunk-Q4EULJQY.js.map +0 -1
- package/dist/chunk-QF7ARNUM.js +0 -339
- package/dist/chunk-QF7ARNUM.js.map +0 -1
- package/dist/chunk-QWW3E3JM.cjs +0 -178
- package/dist/chunk-QWW3E3JM.cjs.map +0 -1
- package/dist/chunk-R7QYGZUP.cjs +0 -1075
- package/dist/chunk-R7QYGZUP.cjs.map +0 -1
- package/dist/chunk-RUPKBKUF.js +0 -352
- package/dist/chunk-RUPKBKUF.js.map +0 -1
- package/dist/chunk-SEO6NAQT.js +0 -14
- package/dist/chunk-SEO6NAQT.js.map +0 -1
- package/dist/chunk-T4B5LB6E.cjs +0 -66
- package/dist/chunk-T4B5LB6E.cjs.map +0 -1
- package/dist/chunk-T5WRA76K.cjs +0 -32
- package/dist/chunk-T5WRA76K.cjs.map +0 -1
- package/dist/chunk-T7JO2TCP.js +0 -1233
- package/dist/chunk-T7JO2TCP.js.map +0 -1
- package/dist/chunk-TC5ZPWM4.cjs +0 -289
- package/dist/chunk-TC5ZPWM4.cjs.map +0 -1
- package/dist/chunk-TQ5UWA7S.js +0 -26
- package/dist/chunk-TQ5UWA7S.js.map +0 -1
- package/dist/chunk-UIKYE2QZ.js +0 -833
- package/dist/chunk-UIKYE2QZ.js.map +0 -1
- package/dist/chunk-UNPLAVE7.js +0 -21
- package/dist/chunk-UNPLAVE7.js.map +0 -1
- package/dist/chunk-UY3UYPBZ.cjs +0 -77
- package/dist/chunk-UY3UYPBZ.cjs.map +0 -1
- package/dist/chunk-V7UBMJAB.cjs +0 -1242
- package/dist/chunk-V7UBMJAB.cjs.map +0 -1
- package/dist/chunk-VH77IPJN.cjs +0 -358
- package/dist/chunk-VH77IPJN.cjs.map +0 -1
- package/dist/chunk-VQTCQKHQ.cjs +0 -17
- package/dist/chunk-VQTCQKHQ.cjs.map +0 -1
- package/dist/chunk-WGWSHJ2N.js +0 -38
- package/dist/chunk-WGWSHJ2N.js.map +0 -1
- package/dist/chunk-WJH6IYU2.cjs +0 -32
- package/dist/chunk-WJH6IYU2.cjs.map +0 -1
- package/dist/chunk-YREV3LGG.cjs +0 -61
- package/dist/chunk-YREV3LGG.cjs.map +0 -1
- package/dist/chunk-YTXEZ4SD.cjs +0 -77
- package/dist/chunk-YTXEZ4SD.cjs.map +0 -1
- package/dist/chunk-ZNMBW67B.cjs +0 -40
- package/dist/chunk-ZNMBW67B.cjs.map +0 -1
- package/dist/correlation-id.cjs.map +0 -1
- package/dist/correlation-id.js.map +0 -1
- package/dist/define-event-BL6Li7CM.d.ts +0 -23
- package/dist/define-event-ClP3T1Jx.d.cts +0 -23
- package/dist/event-subscriber.cjs.map +0 -1
- package/dist/event-subscriber.js.map +0 -1
- package/dist/event.cjs.map +0 -1
- package/dist/event.js.map +0 -1
- package/dist/exporters.cjs.map +0 -1
- package/dist/exporters.js.map +0 -1
- package/dist/functional.cjs.map +0 -1
- package/dist/functional.js.map +0 -1
- package/dist/init-DIowiiCh.d.ts +0 -1167
- package/dist/init-j-A1zI16.d.cts +0 -1167
- package/dist/processors.cjs.map +0 -1
- package/dist/processors.js.map +0 -1
- package/dist/trace-context-DbGKd1Rn.d.cts +0 -213
- package/dist/trace-context-DbGKd1Rn.d.ts +0 -213
- package/dist/utils-BahBCFtJ.d.cts +0 -712
- package/dist/utils-CLKwaUlG.d.ts +0 -712
- package/dist/yaml-config.cjs.map +0 -1
- package/src/gen-ai-cost.test.ts +0 -81
- package/src/gen-ai-cost.ts +0 -145
- package/src/gen-ai-events.test.ts +0 -135
- package/src/gen-ai-events.ts +0 -208
- package/src/gen-ai-metrics.test.ts +0 -96
- package/src/gen-ai-metrics.ts +0 -128
package/dist/chunk-4IFSYQVX.js
DELETED
|
@@ -1,337 +0,0 @@
|
|
|
1
|
-
import { propagation, context } from '@opentelemetry/api';
|
|
2
|
-
|
|
3
|
-
// src/business-baggage.ts
|
|
4
|
-
var DEFAULT_MAX_KEY_LENGTH = 64;
|
|
5
|
-
var DEFAULT_MAX_VALUE_LENGTH = 256;
|
|
6
|
-
var DEFAULT_MAX_TOTAL_SIZE = 8192;
|
|
7
|
-
var PII_PATTERNS = [
|
|
8
|
-
/\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b/,
|
|
9
|
-
// Email
|
|
10
|
-
/\b\d{3}[-.]?\d{3}[-.]?\d{4}\b/,
|
|
11
|
-
// Phone (US)
|
|
12
|
-
/\b\d{3}[-]?\d{2}[-]?\d{4}\b/,
|
|
13
|
-
// SSN
|
|
14
|
-
/\b\d{16}\b/
|
|
15
|
-
// Credit card (basic)
|
|
16
|
-
];
|
|
17
|
-
var HIGH_CARDINALITY_PATTERNS = [
|
|
18
|
-
/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i,
|
|
19
|
-
// UUID
|
|
20
|
-
/^\d{13,}$/,
|
|
21
|
-
// Timestamps
|
|
22
|
-
/^[A-Za-z0-9+/]{20,}={0,2}$/
|
|
23
|
-
// Base64
|
|
24
|
-
];
|
|
25
|
-
function createSafeBaggageSchema(schema, options = {}) {
|
|
26
|
-
const {
|
|
27
|
-
maxKeyLength = DEFAULT_MAX_KEY_LENGTH,
|
|
28
|
-
maxValueLength = DEFAULT_MAX_VALUE_LENGTH,
|
|
29
|
-
maxTotalSize = DEFAULT_MAX_TOTAL_SIZE,
|
|
30
|
-
prefix = "",
|
|
31
|
-
hashHighCardinality = false,
|
|
32
|
-
redactPII = false,
|
|
33
|
-
allowedKeys,
|
|
34
|
-
onError
|
|
35
|
-
} = options;
|
|
36
|
-
const schemaKeys = new Set(Object.keys(schema));
|
|
37
|
-
if (allowedKeys) {
|
|
38
|
-
for (const key of schemaKeys) {
|
|
39
|
-
if (!allowedKeys.includes(key)) {
|
|
40
|
-
throw new Error(`Key "${key}" not in allowedKeys whitelist`);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
const prefixKey = (key) => prefix ? `${prefix}.${key}` : key;
|
|
45
|
-
const hashValue = (value) => {
|
|
46
|
-
let hash = 2166136261;
|
|
47
|
-
for (let i = 0; i < value.length; i++) {
|
|
48
|
-
hash ^= value.codePointAt(i) ?? 0;
|
|
49
|
-
hash = hash * 16777619 >>> 0;
|
|
50
|
-
}
|
|
51
|
-
return `h_${hash.toString(16)}`;
|
|
52
|
-
};
|
|
53
|
-
const containsPII = (value) => {
|
|
54
|
-
return PII_PATTERNS.some((pattern) => pattern.test(value));
|
|
55
|
-
};
|
|
56
|
-
const isHighCardinality = (value) => {
|
|
57
|
-
return HIGH_CARDINALITY_PATTERNS.some((pattern) => pattern.test(value));
|
|
58
|
-
};
|
|
59
|
-
const validateAndTransform = (key, value, fieldDef) => {
|
|
60
|
-
const fullKey = prefixKey(key);
|
|
61
|
-
if (fullKey.length > maxKeyLength) {
|
|
62
|
-
onError?.({
|
|
63
|
-
type: "key_length",
|
|
64
|
-
key,
|
|
65
|
-
message: `Key "${key}" exceeds max length ${maxKeyLength}`
|
|
66
|
-
});
|
|
67
|
-
return null;
|
|
68
|
-
}
|
|
69
|
-
if (value === void 0 || value === null) {
|
|
70
|
-
if (fieldDef.required) {
|
|
71
|
-
onError?.({
|
|
72
|
-
type: "validation",
|
|
73
|
-
key,
|
|
74
|
-
message: `Required field "${key}" is missing`
|
|
75
|
-
});
|
|
76
|
-
return null;
|
|
77
|
-
}
|
|
78
|
-
if (fieldDef.defaultValue === void 0) {
|
|
79
|
-
return null;
|
|
80
|
-
} else {
|
|
81
|
-
value = fieldDef.defaultValue;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
let stringValue;
|
|
85
|
-
switch (fieldDef.type) {
|
|
86
|
-
case "string": {
|
|
87
|
-
if (typeof value !== "string") {
|
|
88
|
-
onError?.({
|
|
89
|
-
type: "validation",
|
|
90
|
-
key,
|
|
91
|
-
message: `Field "${key}" expected string, got ${typeof value}`,
|
|
92
|
-
value
|
|
93
|
-
});
|
|
94
|
-
return null;
|
|
95
|
-
}
|
|
96
|
-
stringValue = value;
|
|
97
|
-
break;
|
|
98
|
-
}
|
|
99
|
-
case "number": {
|
|
100
|
-
if (typeof value !== "number" || Number.isNaN(value)) {
|
|
101
|
-
onError?.({
|
|
102
|
-
type: "validation",
|
|
103
|
-
key,
|
|
104
|
-
message: `Field "${key}" expected number, got ${typeof value}`,
|
|
105
|
-
value
|
|
106
|
-
});
|
|
107
|
-
return null;
|
|
108
|
-
}
|
|
109
|
-
stringValue = String(value);
|
|
110
|
-
break;
|
|
111
|
-
}
|
|
112
|
-
case "boolean": {
|
|
113
|
-
if (typeof value !== "boolean") {
|
|
114
|
-
onError?.({
|
|
115
|
-
type: "validation",
|
|
116
|
-
key,
|
|
117
|
-
message: `Field "${key}" expected boolean, got ${typeof value}`,
|
|
118
|
-
value
|
|
119
|
-
});
|
|
120
|
-
return null;
|
|
121
|
-
}
|
|
122
|
-
stringValue = String(value);
|
|
123
|
-
break;
|
|
124
|
-
}
|
|
125
|
-
case "enum": {
|
|
126
|
-
if (!fieldDef.values?.includes(String(value))) {
|
|
127
|
-
onError?.({
|
|
128
|
-
type: "validation",
|
|
129
|
-
key,
|
|
130
|
-
message: `Field "${key}" value "${value}" not in allowed values: ${fieldDef.values?.join(", ")}`,
|
|
131
|
-
value
|
|
132
|
-
});
|
|
133
|
-
return null;
|
|
134
|
-
}
|
|
135
|
-
stringValue = String(value);
|
|
136
|
-
break;
|
|
137
|
-
}
|
|
138
|
-
default: {
|
|
139
|
-
stringValue = String(value);
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
if (fieldDef.validate && !fieldDef.validate(value)) {
|
|
143
|
-
onError?.({
|
|
144
|
-
type: "validation",
|
|
145
|
-
key,
|
|
146
|
-
message: `Field "${key}" failed custom validation`,
|
|
147
|
-
value
|
|
148
|
-
});
|
|
149
|
-
return null;
|
|
150
|
-
}
|
|
151
|
-
if (redactPII && containsPII(stringValue)) {
|
|
152
|
-
onError?.({
|
|
153
|
-
type: "pii",
|
|
154
|
-
key,
|
|
155
|
-
message: `Field "${key}" contains PII pattern`,
|
|
156
|
-
value: "[REDACTED]"
|
|
157
|
-
});
|
|
158
|
-
stringValue = hashValue(stringValue);
|
|
159
|
-
}
|
|
160
|
-
if (fieldDef.hash || hashHighCardinality && isHighCardinality(stringValue)) {
|
|
161
|
-
stringValue = hashValue(stringValue);
|
|
162
|
-
}
|
|
163
|
-
const maxLen = fieldDef.maxLength ?? maxValueLength;
|
|
164
|
-
if (stringValue.length > maxLen) {
|
|
165
|
-
onError?.({
|
|
166
|
-
type: "value_length",
|
|
167
|
-
key,
|
|
168
|
-
message: `Field "${key}" value exceeds max length ${maxLen}`,
|
|
169
|
-
value: stringValue
|
|
170
|
-
});
|
|
171
|
-
stringValue = stringValue.slice(0, maxLen);
|
|
172
|
-
}
|
|
173
|
-
return stringValue;
|
|
174
|
-
};
|
|
175
|
-
const parseValue = (key, stringValue, fieldDef) => {
|
|
176
|
-
switch (fieldDef.type) {
|
|
177
|
-
case "number": {
|
|
178
|
-
return Number.parseFloat(stringValue);
|
|
179
|
-
}
|
|
180
|
-
case "boolean": {
|
|
181
|
-
return stringValue === "true";
|
|
182
|
-
}
|
|
183
|
-
default: {
|
|
184
|
-
return stringValue;
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
};
|
|
188
|
-
return {
|
|
189
|
-
get() {
|
|
190
|
-
const baggage = propagation.getBaggage(context.active());
|
|
191
|
-
if (!baggage) {
|
|
192
|
-
return {};
|
|
193
|
-
}
|
|
194
|
-
const result = {};
|
|
195
|
-
for (const [key, fieldDef] of Object.entries(schema)) {
|
|
196
|
-
const fullKey = prefixKey(key);
|
|
197
|
-
const entry = baggage.getEntry(fullKey);
|
|
198
|
-
if (entry) {
|
|
199
|
-
result[key] = parseValue(key, entry.value, fieldDef);
|
|
200
|
-
} else if (fieldDef.defaultValue !== void 0) {
|
|
201
|
-
result[key] = fieldDef.defaultValue;
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
return result;
|
|
205
|
-
},
|
|
206
|
-
set(ctx, values) {
|
|
207
|
-
let baggage = propagation.getBaggage(context.active()) ?? propagation.createBaggage();
|
|
208
|
-
let totalSize = 0;
|
|
209
|
-
for (const [key, entry] of baggage.getAllEntries()) {
|
|
210
|
-
totalSize += key.length + entry.value.length;
|
|
211
|
-
}
|
|
212
|
-
for (const [key, value] of Object.entries(values)) {
|
|
213
|
-
const fieldDef = schema[key];
|
|
214
|
-
if (!fieldDef) continue;
|
|
215
|
-
const fullKey = prefixKey(key);
|
|
216
|
-
const stringValue = validateAndTransform(key, value, fieldDef);
|
|
217
|
-
if (stringValue !== null) {
|
|
218
|
-
const entrySize = fullKey.length + stringValue.length;
|
|
219
|
-
if (totalSize + entrySize > maxTotalSize) {
|
|
220
|
-
onError?.({
|
|
221
|
-
type: "size",
|
|
222
|
-
key,
|
|
223
|
-
message: `Adding "${key}" would exceed max baggage size ${maxTotalSize}`,
|
|
224
|
-
value
|
|
225
|
-
});
|
|
226
|
-
continue;
|
|
227
|
-
}
|
|
228
|
-
baggage = baggage.setEntry(fullKey, { value: stringValue });
|
|
229
|
-
totalSize += entrySize;
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
const newContext = propagation.setBaggage(context.active(), baggage);
|
|
233
|
-
propagation.setBaggage(newContext, baggage);
|
|
234
|
-
},
|
|
235
|
-
getValue(key) {
|
|
236
|
-
const baggage = propagation.getBaggage(context.active());
|
|
237
|
-
if (!baggage) return void 0;
|
|
238
|
-
const fullKey = prefixKey(String(key));
|
|
239
|
-
const entry = baggage.getEntry(fullKey);
|
|
240
|
-
const fieldDef = schema[String(key)];
|
|
241
|
-
if (!entry) {
|
|
242
|
-
return fieldDef?.defaultValue;
|
|
243
|
-
}
|
|
244
|
-
if (!fieldDef) {
|
|
245
|
-
return void 0;
|
|
246
|
-
}
|
|
247
|
-
return parseValue(
|
|
248
|
-
String(key),
|
|
249
|
-
entry.value,
|
|
250
|
-
fieldDef
|
|
251
|
-
);
|
|
252
|
-
},
|
|
253
|
-
setValue(key, value, ctx) {
|
|
254
|
-
this.set(ctx, { [key]: value });
|
|
255
|
-
},
|
|
256
|
-
clear() {
|
|
257
|
-
let baggage = propagation.getBaggage(context.active());
|
|
258
|
-
if (!baggage) return;
|
|
259
|
-
for (const key of Object.keys(schema)) {
|
|
260
|
-
const fullKey = prefixKey(key);
|
|
261
|
-
baggage = baggage.removeEntry(fullKey);
|
|
262
|
-
}
|
|
263
|
-
propagation.setBaggage(context.active(), baggage);
|
|
264
|
-
},
|
|
265
|
-
toHeaders() {
|
|
266
|
-
const headers = {};
|
|
267
|
-
propagation.inject(context.active(), headers);
|
|
268
|
-
return headers;
|
|
269
|
-
},
|
|
270
|
-
fromHeaders(headers, ctx) {
|
|
271
|
-
const extractedContext = propagation.extract(context.active(), headers);
|
|
272
|
-
const baggage = propagation.getBaggage(extractedContext);
|
|
273
|
-
if (baggage) {
|
|
274
|
-
const values = {};
|
|
275
|
-
for (const [key, fieldDef] of Object.entries(schema)) {
|
|
276
|
-
const fullKey = prefixKey(key);
|
|
277
|
-
const entry = baggage.getEntry(fullKey);
|
|
278
|
-
if (entry) {
|
|
279
|
-
values[key] = parseValue(key, entry.value, fieldDef);
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
this.set(ctx, values);
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
};
|
|
286
|
-
}
|
|
287
|
-
var BusinessBaggage = createSafeBaggageSchema(
|
|
288
|
-
{
|
|
289
|
-
tenantId: {
|
|
290
|
-
type: "string",
|
|
291
|
-
maxLength: 64
|
|
292
|
-
},
|
|
293
|
-
userId: {
|
|
294
|
-
type: "string",
|
|
295
|
-
hash: true,
|
|
296
|
-
// Auto-hash for privacy
|
|
297
|
-
maxLength: 64
|
|
298
|
-
},
|
|
299
|
-
correlationId: {
|
|
300
|
-
type: "string",
|
|
301
|
-
maxLength: 128
|
|
302
|
-
},
|
|
303
|
-
workflowId: {
|
|
304
|
-
type: "string",
|
|
305
|
-
maxLength: 128
|
|
306
|
-
},
|
|
307
|
-
priority: {
|
|
308
|
-
type: "enum",
|
|
309
|
-
values: ["low", "normal", "high", "critical"],
|
|
310
|
-
defaultValue: "normal"
|
|
311
|
-
},
|
|
312
|
-
region: {
|
|
313
|
-
type: "string",
|
|
314
|
-
maxLength: 32
|
|
315
|
-
},
|
|
316
|
-
channel: {
|
|
317
|
-
type: "enum",
|
|
318
|
-
values: [
|
|
319
|
-
"web",
|
|
320
|
-
"mobile",
|
|
321
|
-
"api",
|
|
322
|
-
"internal",
|
|
323
|
-
"webhook",
|
|
324
|
-
"scheduled"
|
|
325
|
-
]
|
|
326
|
-
}
|
|
327
|
-
},
|
|
328
|
-
{
|
|
329
|
-
prefix: "biz",
|
|
330
|
-
redactPII: true,
|
|
331
|
-
hashHighCardinality: true
|
|
332
|
-
}
|
|
333
|
-
);
|
|
334
|
-
|
|
335
|
-
export { BusinessBaggage, createSafeBaggageSchema };
|
|
336
|
-
//# sourceMappingURL=chunk-4IFSYQVX.js.map
|
|
337
|
-
//# sourceMappingURL=chunk-4IFSYQVX.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/business-baggage.ts"],"names":[],"mappings":"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","file":"chunk-4IFSYQVX.js","sourcesContent":["/**\n * Safe baggage propagation with guardrails\n *\n * Provides type-safe baggage schemas with built-in protection against\n * common pitfalls: high-cardinality values, PII leakage, and oversized payloads.\n *\n * @example Define a custom schema\n * ```typescript\n * import { createSafeBaggageSchema } from 'autotel/business-baggage';\n *\n * const OrderBaggage = createSafeBaggageSchema({\n * orderId: { type: 'string' },\n * customerId: { type: 'string', hash: true }, // Auto-hash for privacy\n * priority: { type: 'enum', values: ['low', 'normal', 'high'] },\n * });\n *\n * // Usage in traced function\n * OrderBaggage.set(ctx, { orderId: 'ord-123', customerId: 'cust-456', priority: 'high' });\n * const { orderId, priority } = OrderBaggage.get(ctx);\n * ```\n *\n * @example Use pre-built BusinessBaggage\n * ```typescript\n * import { BusinessBaggage } from 'autotel/business-baggage';\n *\n * BusinessBaggage.set(ctx, { tenantId: 'acme', userId: 'user-123' });\n * const { tenantId } = BusinessBaggage.get(ctx);\n * ```\n *\n * @module\n */\n\nimport { context, propagation } from '@opentelemetry/api';\nimport type { TraceContext } from './trace-context';\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/**\n * Supported field types in baggage schema\n */\nexport type BaggageFieldType = 'string' | 'number' | 'boolean' | 'enum';\n\n/**\n * Field definition in a baggage schema\n */\nexport interface BaggageFieldDefinition {\n /** Field type */\n type: BaggageFieldType;\n\n /** Maximum length for string values (default: 256) */\n maxLength?: number;\n\n /** Hash value before storing (for privacy) */\n hash?: boolean;\n\n /** Allowed values for enum type */\n values?: readonly string[];\n\n /** Default value if not provided */\n defaultValue?: string | number | boolean;\n\n /** Whether field is required */\n required?: boolean;\n\n /** Custom validation function */\n validate?: (value: unknown) => boolean;\n}\n\n/**\n * Options for creating a safe baggage schema\n */\nexport interface SafeBaggageOptions {\n /** Maximum key length (default: 64) */\n maxKeyLength?: number;\n\n /** Maximum value length (default: 256) */\n maxValueLength?: number;\n\n /** Maximum total baggage size in bytes (default: 8192) */\n maxTotalSize?: number;\n\n /** Prefix for all keys (default: none) */\n prefix?: string;\n\n /** Hash high-cardinality values automatically */\n hashHighCardinality?: boolean;\n\n /** Detect and redact PII patterns */\n redactPII?: boolean;\n\n /** Allowed keys whitelist (others rejected) */\n allowedKeys?: string[];\n\n /** Custom error handler */\n onError?: (error: BaggageError) => void;\n}\n\n/**\n * Schema definition type - maps field names to definitions\n */\nexport type BaggageSchemaDefinition = Record<string, BaggageFieldDefinition>;\n\n/**\n * Inferred type from schema definition\n */\nexport type InferBaggageType<T extends BaggageSchemaDefinition> = {\n [K in keyof T]?: T[K]['type'] extends 'string'\n ? string\n : T[K]['type'] extends 'number'\n ? number\n : T[K]['type'] extends 'boolean'\n ? boolean\n : T[K]['type'] extends 'enum'\n ? T[K]['values'] extends readonly string[]\n ? T[K]['values'][number]\n : string\n : unknown;\n};\n\n/**\n * Baggage error details\n */\nexport interface BaggageError {\n type: 'validation' | 'size' | 'pii' | 'key_length' | 'value_length';\n key: string;\n message: string;\n value?: unknown;\n}\n\n/**\n * Safe baggage schema interface\n */\nexport interface SafeBaggageSchema<T extends BaggageSchemaDefinition> {\n /**\n * Get baggage values from context\n */\n get(ctx?: TraceContext): Partial<InferBaggageType<T>>;\n\n /**\n * Set baggage values in context\n * Returns new context with baggage (for context propagation)\n */\n set(\n ctx: TraceContext | undefined,\n values: Partial<InferBaggageType<T>>,\n ): void;\n\n /**\n * Get a single baggage value\n */\n getValue<K extends keyof T>(\n key: K,\n ctx?: TraceContext,\n ): InferBaggageType<T>[K] | undefined;\n\n /**\n * Set a single baggage value\n */\n setValue<K extends keyof T>(\n key: K,\n value: InferBaggageType<T>[K],\n ctx?: TraceContext,\n ): void;\n\n /**\n * Clear all schema baggage values\n */\n clear(ctx?: TraceContext): void;\n\n /**\n * Get all baggage as headers for propagation\n */\n toHeaders(ctx?: TraceContext): Record<string, string>;\n\n /**\n * Restore baggage from headers\n */\n fromHeaders(headers: Record<string, string>, ctx?: TraceContext): void;\n}\n\n// ============================================================================\n// Constants\n// ============================================================================\n\nconst DEFAULT_MAX_KEY_LENGTH = 64;\nconst DEFAULT_MAX_VALUE_LENGTH = 256;\nconst DEFAULT_MAX_TOTAL_SIZE = 8192;\n\n// PII patterns to detect and redact\nconst PII_PATTERNS = [\n /\\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Z|a-z]{2,}\\b/, // Email\n /\\b\\d{3}[-.]?\\d{3}[-.]?\\d{4}\\b/, // Phone (US)\n /\\b\\d{3}[-]?\\d{2}[-]?\\d{4}\\b/, // SSN\n /\\b\\d{16}\\b/, // Credit card (basic)\n];\n\n// High-cardinality value patterns\nconst HIGH_CARDINALITY_PATTERNS = [\n /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i, // UUID\n /^\\d{13,}$/, // Timestamps\n /^[A-Za-z0-9+/]{20,}={0,2}$/, // Base64\n];\n\n// ============================================================================\n// Implementation\n// ============================================================================\n\n/**\n * Create a safe baggage schema with validation and guardrails\n *\n * @param schema - Field definitions\n * @param options - Safety options\n * @returns Type-safe baggage schema\n *\n * @example\n * ```typescript\n * const MyBaggage = createSafeBaggageSchema({\n * userId: { type: 'string', hash: true },\n * region: { type: 'enum', values: ['us', 'eu', 'ap'] },\n * debug: { type: 'boolean', defaultValue: false },\n * });\n * ```\n */\nexport function createSafeBaggageSchema<T extends BaggageSchemaDefinition>(\n schema: T,\n options: SafeBaggageOptions = {},\n): SafeBaggageSchema<T> {\n const {\n maxKeyLength = DEFAULT_MAX_KEY_LENGTH,\n maxValueLength = DEFAULT_MAX_VALUE_LENGTH,\n maxTotalSize = DEFAULT_MAX_TOTAL_SIZE,\n prefix = '',\n hashHighCardinality = false,\n redactPII = false,\n allowedKeys,\n onError,\n } = options;\n\n // Validate schema keys\n const schemaKeys = new Set(Object.keys(schema));\n if (allowedKeys) {\n for (const key of schemaKeys) {\n if (!allowedKeys.includes(key)) {\n throw new Error(`Key \"${key}\" not in allowedKeys whitelist`);\n }\n }\n }\n\n // Prefix a key\n const prefixKey = (key: string): string =>\n prefix ? `${prefix}.${key}` : key;\n\n // Hash a value using simple FNV-1a (synchronous, no crypto dependency)\n const hashValue = (value: string): string => {\n let hash = 2_166_136_261;\n for (let i = 0; i < value.length; i++) {\n hash ^= value.codePointAt(i) ?? 0;\n hash = (hash * 16_777_619) >>> 0;\n }\n return `h_${hash.toString(16)}`;\n };\n\n // Check for PII\n const containsPII = (value: string): boolean => {\n return PII_PATTERNS.some((pattern) => pattern.test(value));\n };\n\n // Check for high-cardinality\n const isHighCardinality = (value: string): boolean => {\n return HIGH_CARDINALITY_PATTERNS.some((pattern) => pattern.test(value));\n };\n\n // Validate and transform a single value\n const validateAndTransform = (\n key: string,\n value: unknown,\n fieldDef: BaggageFieldDefinition,\n ): string | null => {\n const fullKey = prefixKey(key);\n\n // Check key length\n if (fullKey.length > maxKeyLength) {\n onError?.({\n type: 'key_length',\n key,\n message: `Key \"${key}\" exceeds max length ${maxKeyLength}`,\n });\n return null;\n }\n\n // Handle undefined/null with default\n if (value === undefined || value === null) {\n if (fieldDef.required) {\n onError?.({\n type: 'validation',\n key,\n message: `Required field \"${key}\" is missing`,\n });\n return null;\n }\n if (fieldDef.defaultValue === undefined) {\n return null;\n } else {\n value = fieldDef.defaultValue;\n }\n }\n\n // Type validation\n let stringValue: string;\n\n switch (fieldDef.type) {\n case 'string': {\n if (typeof value !== 'string') {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" expected string, got ${typeof value}`,\n value,\n });\n return null;\n }\n stringValue = value;\n break;\n }\n\n case 'number': {\n if (typeof value !== 'number' || Number.isNaN(value)) {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" expected number, got ${typeof value}`,\n value,\n });\n return null;\n }\n stringValue = String(value);\n break;\n }\n\n case 'boolean': {\n if (typeof value !== 'boolean') {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" expected boolean, got ${typeof value}`,\n value,\n });\n return null;\n }\n stringValue = String(value);\n break;\n }\n\n case 'enum': {\n if (!fieldDef.values?.includes(String(value))) {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" value \"${value}\" not in allowed values: ${fieldDef.values?.join(', ')}`,\n value,\n });\n return null;\n }\n stringValue = String(value);\n break;\n }\n\n default: {\n stringValue = String(value);\n }\n }\n\n // Custom validation\n if (fieldDef.validate && !fieldDef.validate(value)) {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" failed custom validation`,\n value,\n });\n return null;\n }\n\n // PII check\n if (redactPII && containsPII(stringValue)) {\n onError?.({\n type: 'pii',\n key,\n message: `Field \"${key}\" contains PII pattern`,\n value: '[REDACTED]',\n });\n stringValue = hashValue(stringValue);\n }\n\n // Hash if requested or high-cardinality\n if (\n fieldDef.hash ||\n (hashHighCardinality && isHighCardinality(stringValue))\n ) {\n stringValue = hashValue(stringValue);\n }\n\n // Length validation\n const maxLen = fieldDef.maxLength ?? maxValueLength;\n if (stringValue.length > maxLen) {\n onError?.({\n type: 'value_length',\n key,\n message: `Field \"${key}\" value exceeds max length ${maxLen}`,\n value: stringValue,\n });\n stringValue = stringValue.slice(0, maxLen);\n }\n\n return stringValue;\n };\n\n // Parse value back from baggage string\n const parseValue = (\n key: string,\n stringValue: string,\n fieldDef: BaggageFieldDefinition,\n ): unknown => {\n switch (fieldDef.type) {\n case 'number': {\n return Number.parseFloat(stringValue);\n }\n case 'boolean': {\n return stringValue === 'true';\n }\n default: {\n return stringValue;\n }\n }\n };\n\n return {\n get(): Partial<InferBaggageType<T>> {\n const baggage = propagation.getBaggage(context.active());\n if (!baggage) {\n return {};\n }\n\n const result: Record<string, unknown> = {};\n\n for (const [key, fieldDef] of Object.entries(schema)) {\n const fullKey = prefixKey(key);\n const entry = baggage.getEntry(fullKey);\n\n if (entry) {\n result[key] = parseValue(key, entry.value, fieldDef);\n } else if (fieldDef.defaultValue !== undefined) {\n result[key] = fieldDef.defaultValue;\n }\n }\n\n return result as Partial<InferBaggageType<T>>;\n },\n\n set(\n ctx: TraceContext | undefined,\n values: Partial<InferBaggageType<T>>,\n ): void {\n let baggage =\n propagation.getBaggage(context.active()) ?? propagation.createBaggage();\n let totalSize = 0;\n\n // Calculate existing size\n for (const [key, entry] of baggage.getAllEntries()) {\n totalSize += key.length + entry.value.length;\n }\n\n for (const [key, value] of Object.entries(values)) {\n const fieldDef = schema[key];\n if (!fieldDef) continue;\n\n const fullKey = prefixKey(key);\n const stringValue = validateAndTransform(key, value, fieldDef);\n\n if (stringValue !== null) {\n // Check total size\n const entrySize = fullKey.length + stringValue.length;\n if (totalSize + entrySize > maxTotalSize) {\n onError?.({\n type: 'size',\n key,\n message: `Adding \"${key}\" would exceed max baggage size ${maxTotalSize}`,\n value,\n });\n continue;\n }\n\n baggage = baggage.setEntry(fullKey, { value: stringValue });\n totalSize += entrySize;\n }\n }\n\n // Update context with new baggage\n const newContext = propagation.setBaggage(context.active(), baggage);\n // Note: This only works if the caller propagates the context\n // In OTel, baggage propagation happens via context.with()\n // For now we set on active context\n propagation.setBaggage(newContext, baggage);\n },\n\n getValue<K extends keyof T>(key: K): InferBaggageType<T>[K] | undefined {\n const baggage = propagation.getBaggage(context.active());\n if (!baggage) return undefined;\n\n const fullKey = prefixKey(String(key));\n const entry = baggage.getEntry(fullKey);\n const fieldDef = schema[String(key)];\n\n if (!entry) {\n return fieldDef?.defaultValue as InferBaggageType<T>[K] | undefined;\n }\n\n if (!fieldDef) {\n return undefined;\n }\n\n return parseValue(\n String(key),\n entry.value,\n fieldDef,\n ) as InferBaggageType<T>[K];\n },\n\n setValue<K extends keyof T>(\n key: K,\n value: InferBaggageType<T>[K],\n ctx?: TraceContext,\n ): void {\n this.set(ctx, { [key]: value } as Partial<InferBaggageType<T>>);\n },\n\n clear(): void {\n let baggage = propagation.getBaggage(context.active());\n if (!baggage) return;\n\n for (const key of Object.keys(schema)) {\n const fullKey = prefixKey(key);\n baggage = baggage.removeEntry(fullKey);\n }\n\n propagation.setBaggage(context.active(), baggage);\n },\n\n toHeaders(): Record<string, string> {\n const headers: Record<string, string> = {};\n propagation.inject(context.active(), headers);\n return headers;\n },\n\n fromHeaders(headers: Record<string, string>, ctx?: TraceContext): void {\n const extractedContext = propagation.extract(context.active(), headers);\n const baggage = propagation.getBaggage(extractedContext);\n\n if (baggage) {\n const values: Record<string, unknown> = {};\n\n for (const [key, fieldDef] of Object.entries(schema)) {\n const fullKey = prefixKey(key);\n const entry = baggage.getEntry(fullKey);\n\n if (entry) {\n values[key] = parseValue(key, entry.value, fieldDef);\n }\n }\n\n this.set(ctx, values as Partial<InferBaggageType<T>>);\n }\n },\n };\n}\n\n// ============================================================================\n// Pre-built Business Context Schema\n// ============================================================================\n\n/**\n * Pre-built baggage schema for common business context fields\n *\n * Fields:\n * - `tenantId`: Multi-tenant identifier (string, max 64 chars)\n * - `userId`: User identifier (hashed for privacy)\n * - `correlationId`: Request correlation ID (string)\n * - `workflowId`: Workflow/saga instance ID (string)\n * - `priority`: Request priority (low, normal, high, critical)\n * - `region`: Geographic region (string)\n * - `channel`: Request channel (web, mobile, api, internal)\n *\n * @example\n * ```typescript\n * import { BusinessBaggage } from 'autotel/business-baggage';\n *\n * // Set business context at entry point\n * BusinessBaggage.set(ctx, {\n * tenantId: 'acme-corp',\n * userId: 'user-123',\n * priority: 'high',\n * channel: 'api',\n * });\n *\n * // Access anywhere in the trace\n * const { tenantId, priority } = BusinessBaggage.get(ctx);\n * ```\n */\nexport const BusinessBaggage = createSafeBaggageSchema(\n {\n tenantId: {\n type: 'string',\n maxLength: 64,\n },\n userId: {\n type: 'string',\n hash: true, // Auto-hash for privacy\n maxLength: 64,\n },\n correlationId: {\n type: 'string',\n maxLength: 128,\n },\n workflowId: {\n type: 'string',\n maxLength: 128,\n },\n priority: {\n type: 'enum',\n values: ['low', 'normal', 'high', 'critical'] as const,\n defaultValue: 'normal',\n },\n region: {\n type: 'string',\n maxLength: 32,\n },\n channel: {\n type: 'enum',\n values: [\n 'web',\n 'mobile',\n 'api',\n 'internal',\n 'webhook',\n 'scheduled',\n ] as const,\n },\n },\n {\n prefix: 'biz',\n redactPII: true,\n hashHighCardinality: true,\n },\n);\n\n/**\n * Type alias for BusinessBaggage values\n */\nexport type BusinessBaggageValues = {\n tenantId?: string;\n userId?: string;\n correlationId?: string;\n workflowId?: string;\n priority?: 'low' | 'normal' | 'high' | 'critical';\n region?: string;\n channel?: 'web' | 'mobile' | 'api' | 'internal' | 'webhook' | 'scheduled';\n};\n"]}
|
package/dist/chunk-4P6ZOARG.cjs
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
// src/correlated-events.ts
|
|
4
|
-
function sanitizeEventKey(input) {
|
|
5
|
-
return input.replaceAll(/[^a-zA-Z0-9_.-]/g, "_");
|
|
6
|
-
}
|
|
7
|
-
var sequenceByTarget = /* @__PURE__ */ new WeakMap();
|
|
8
|
-
function nextSequence(target) {
|
|
9
|
-
const n = (sequenceByTarget.get(target) ?? 0) + 1;
|
|
10
|
-
sequenceByTarget.set(target, n);
|
|
11
|
-
return n;
|
|
12
|
-
}
|
|
13
|
-
function emitCorrelatedEvent(ctx, name, attrs = {}) {
|
|
14
|
-
const eventName = sanitizeEventKey(name);
|
|
15
|
-
if (typeof ctx.addEvent === "function") {
|
|
16
|
-
ctx.addEvent.call(ctx, eventName, attrs);
|
|
17
|
-
return;
|
|
18
|
-
}
|
|
19
|
-
const seq = nextSequence(ctx);
|
|
20
|
-
const prefix = `autotel.event.${seq}.${eventName}`;
|
|
21
|
-
const flattened = {
|
|
22
|
-
[`${prefix}.name`]: eventName,
|
|
23
|
-
[`${prefix}.ts`]: (/* @__PURE__ */ new Date()).toISOString()
|
|
24
|
-
};
|
|
25
|
-
for (const [k, v] of Object.entries(attrs)) {
|
|
26
|
-
flattened[`${prefix}.${sanitizeEventKey(k)}`] = v;
|
|
27
|
-
}
|
|
28
|
-
ctx.setAttributes(flattened);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
exports.emitCorrelatedEvent = emitCorrelatedEvent;
|
|
32
|
-
//# sourceMappingURL=chunk-4P6ZOARG.cjs.map
|
|
33
|
-
//# sourceMappingURL=chunk-4P6ZOARG.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/correlated-events.ts"],"names":[],"mappings":";;;AAUA,SAAS,iBAAiB,KAAA,EAAuB;AAC/C,EAAA,OAAO,KAAA,CAAM,UAAA,CAAW,kBAAA,EAAoB,GAAG,CAAA;AACjD;AAMA,IAAM,gBAAA,uBAAuB,OAAA,EAAwB;AAErD,SAAS,aAAa,MAAA,EAAwB;AAC5C,EAAA,MAAM,CAAA,GAAA,CAAK,gBAAA,CAAiB,GAAA,CAAI,MAAM,KAAK,CAAA,IAAK,CAAA;AAChD,EAAA,gBAAA,CAAiB,GAAA,CAAI,QAAQ,CAAC,CAAA;AAC9B,EAAA,OAAO,CAAA;AACT;AAEO,SAAS,mBAAA,CACd,GAAA,EACA,IAAA,EACA,KAAA,GAAwC,EAAC,EACnC;AACN,EAAA,MAAM,SAAA,GAAY,iBAAiB,IAAI,CAAA;AACvC,EAAA,IAAI,OAAO,GAAA,CAAI,QAAA,KAAa,UAAA,EAAY;AACtC,IAAA,GAAA,CAAI,QAAA,CAAS,IAAA,CAAK,GAAA,EAAK,SAAA,EAAW,KAAK,CAAA;AACvC,IAAA;AAAA,EACF;AACA,EAAA,MAAM,GAAA,GAAM,aAAa,GAAG,CAAA;AAC5B,EAAA,MAAM,MAAA,GAAS,CAAA,cAAA,EAAiB,GAAG,CAAA,CAAA,EAAI,SAAS,CAAA,CAAA;AAChD,EAAA,MAAM,SAAA,GAA4C;AAAA,IAChD,CAAC,CAAA,EAAG,MAAM,CAAA,KAAA,CAAO,GAAG,SAAA;AAAA,IACpB,CAAC,GAAG,MAAM,CAAA,GAAA,CAAK,oBAAG,IAAI,IAAA,IAAO,WAAA;AAAY,GAC3C;AACA,EAAA,KAAA,MAAW,CAAC,CAAA,EAAG,CAAC,KAAK,MAAA,CAAO,OAAA,CAAQ,KAAK,CAAA,EAAG;AAC1C,IAAA,SAAA,CAAU,GAAG,MAAM,CAAA,CAAA,EAAI,iBAAiB,CAAC,CAAC,EAAE,CAAA,GAAI,CAAA;AAAA,EAClD;AACA,EAAA,GAAA,CAAI,cAAc,SAAS,CAAA;AAC7B","file":"chunk-4P6ZOARG.cjs","sourcesContent":["import type { AttributeValue } from './trace-context';\n\nexport interface CorrelatedEventTarget {\n setAttribute(key: string, value: AttributeValue): unknown;\n setAttributes(attrs: Record<string, AttributeValue>): unknown;\n addEvent?(name: string, attrs?: Record<string, AttributeValue>): unknown;\n}\n\n// OTel attribute keys are dot-namespaced flat strings; we keep `.`/`-`/`_` and\n// drop everything else so user-supplied event names can't break attribute keys.\nfunction sanitizeEventKey(input: string): string {\n return input.replaceAll(/[^a-zA-Z0-9_.-]/g, '_');\n}\n\n// Per-target sequence so the fallback path can encode multiple events with the\n// same name without one overwriting the previous (attributes are\n// last-write-wins; events are not). Today the addEvent path is always taken;\n// this keeps the fallback correct if/when the runtime stops binding addEvent.\nconst sequenceByTarget = new WeakMap<object, number>();\n\nfunction nextSequence(target: object): number {\n const n = (sequenceByTarget.get(target) ?? 0) + 1;\n sequenceByTarget.set(target, n);\n return n;\n}\n\nexport function emitCorrelatedEvent(\n ctx: CorrelatedEventTarget,\n name: string,\n attrs: Record<string, AttributeValue> = {},\n): void {\n const eventName = sanitizeEventKey(name);\n if (typeof ctx.addEvent === 'function') {\n ctx.addEvent.call(ctx, eventName, attrs);\n return;\n }\n const seq = nextSequence(ctx);\n const prefix = `autotel.event.${seq}.${eventName}`;\n const flattened: Record<string, AttributeValue> = {\n [`${prefix}.name`]: eventName,\n [`${prefix}.ts`]: new Date().toISOString(),\n };\n for (const [k, v] of Object.entries(attrs)) {\n flattened[`${prefix}.${sanitizeEventKey(k)}`] = v;\n }\n ctx.setAttributes(flattened);\n}\n"]}
|
package/dist/chunk-55ER2KD5.js
DELETED
|
@@ -1,228 +0,0 @@
|
|
|
1
|
-
import { getConfig } from './chunk-J5QENANM.js';
|
|
2
|
-
import { createContextKey, context, SpanStatusCode, trace } from '@opentelemetry/api';
|
|
3
|
-
|
|
4
|
-
var LOG_LEVEL_KEY = createContextKey("autotel-log-level");
|
|
5
|
-
function getActiveLogLevel() {
|
|
6
|
-
return context.active().getValue(LOG_LEVEL_KEY);
|
|
7
|
-
}
|
|
8
|
-
function runWithLogLevel(level, callback) {
|
|
9
|
-
const ctx = context.active().setValue(LOG_LEVEL_KEY, level);
|
|
10
|
-
return context.with(ctx, callback);
|
|
11
|
-
}
|
|
12
|
-
function getTraceContextInternal() {
|
|
13
|
-
const span = trace.getActiveSpan();
|
|
14
|
-
if (!span) return null;
|
|
15
|
-
const ctx = span.spanContext();
|
|
16
|
-
return {
|
|
17
|
-
traceId: ctx.traceId,
|
|
18
|
-
spanId: ctx.spanId,
|
|
19
|
-
correlationId: ctx.traceId.slice(0, 16)
|
|
20
|
-
// First 16 chars for grouping
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
function getTraceContext() {
|
|
24
|
-
return getTraceContextInternal();
|
|
25
|
-
}
|
|
26
|
-
function createBuiltinLogger(service, options) {
|
|
27
|
-
const defaultLevel = options?.level || "info";
|
|
28
|
-
const pretty = options?.pretty || false;
|
|
29
|
-
const levelPriority = {
|
|
30
|
-
none: -1,
|
|
31
|
-
debug: 0,
|
|
32
|
-
info: 1,
|
|
33
|
-
warn: 2,
|
|
34
|
-
error: 3
|
|
35
|
-
};
|
|
36
|
-
const shouldLog = (level) => {
|
|
37
|
-
const activeLevel = getActiveLogLevel() ?? defaultLevel;
|
|
38
|
-
if (activeLevel === "none") return false;
|
|
39
|
-
return levelPriority[level] >= levelPriority[activeLevel];
|
|
40
|
-
};
|
|
41
|
-
const log = (level, msg, attrs) => {
|
|
42
|
-
if (!shouldLog(level)) return;
|
|
43
|
-
const ctx = getTraceContextInternal();
|
|
44
|
-
const logEntry = {
|
|
45
|
-
level,
|
|
46
|
-
service,
|
|
47
|
-
msg,
|
|
48
|
-
...attrs,
|
|
49
|
-
...ctx,
|
|
50
|
-
// Auto-inject traceId, spanId, correlationId
|
|
51
|
-
timestamp: (/* @__PURE__ */ new Date()).toISOString()
|
|
52
|
-
};
|
|
53
|
-
if (pretty) {
|
|
54
|
-
const traceInfo = ctx ? ` [${ctx.traceId.slice(0, 8)}.../${ctx.spanId.slice(0, 8)}...]` : "";
|
|
55
|
-
console.log(
|
|
56
|
-
`[${level.toUpperCase()}]${traceInfo} ${service}: ${msg}`,
|
|
57
|
-
attrs || ""
|
|
58
|
-
);
|
|
59
|
-
} else {
|
|
60
|
-
console.log(JSON.stringify(logEntry));
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
const createLogMethod = (level) => {
|
|
64
|
-
return (extraOrMessage, message) => {
|
|
65
|
-
if (typeof extraOrMessage === "string") {
|
|
66
|
-
if (message !== void 0 && typeof message === "object") {
|
|
67
|
-
if (process.env.NODE_ENV !== "production") {
|
|
68
|
-
console.warn(
|
|
69
|
-
`[autotel] Legacy logger pattern detected: logger.${level}('message', metadata). Autotel recommends Pino signature: logger.${level}({ ...metadata }, 'message'). Auto-swapping arguments for compatibility.`
|
|
70
|
-
);
|
|
71
|
-
}
|
|
72
|
-
log(level, extraOrMessage, message);
|
|
73
|
-
} else {
|
|
74
|
-
log(level, extraOrMessage);
|
|
75
|
-
}
|
|
76
|
-
} else {
|
|
77
|
-
log(level, message || "", extraOrMessage);
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
|
-
};
|
|
81
|
-
return {
|
|
82
|
-
info: createLogMethod("info"),
|
|
83
|
-
warn: createLogMethod("warn"),
|
|
84
|
-
debug: createLogMethod("debug"),
|
|
85
|
-
error: (extraOrMessage, message) => {
|
|
86
|
-
if (typeof extraOrMessage === "string") {
|
|
87
|
-
if (message instanceof Error) {
|
|
88
|
-
if (process.env.NODE_ENV !== "production") {
|
|
89
|
-
console.warn(
|
|
90
|
-
`[autotel] Legacy logger pattern detected: logger.error('message', error). Autotel recommends Pino signature: logger.error({ err: error }, 'message'). Auto-swapping arguments for compatibility.`
|
|
91
|
-
);
|
|
92
|
-
}
|
|
93
|
-
log("error", extraOrMessage, {
|
|
94
|
-
error: message.message,
|
|
95
|
-
stack: message.stack,
|
|
96
|
-
name: message.name
|
|
97
|
-
});
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
if (message !== void 0 && typeof message === "object") {
|
|
101
|
-
if (process.env.NODE_ENV !== "production") {
|
|
102
|
-
console.warn(
|
|
103
|
-
`[autotel] Legacy logger pattern detected: logger.error('message', metadata). Autotel recommends Pino signature: logger.error({ ...metadata }, 'message'). Auto-swapping arguments for compatibility.`
|
|
104
|
-
);
|
|
105
|
-
}
|
|
106
|
-
const extra = message;
|
|
107
|
-
const { err: err2, ...rest2 } = extra;
|
|
108
|
-
let errorAttrs2 = rest2;
|
|
109
|
-
if (err2 instanceof Error) {
|
|
110
|
-
errorAttrs2 = {
|
|
111
|
-
error: err2.message,
|
|
112
|
-
stack: err2.stack,
|
|
113
|
-
name: err2.name,
|
|
114
|
-
...rest2
|
|
115
|
-
};
|
|
116
|
-
} else if (err2 !== void 0) {
|
|
117
|
-
errorAttrs2 = { err: err2, ...rest2 };
|
|
118
|
-
}
|
|
119
|
-
log("error", extraOrMessage, errorAttrs2);
|
|
120
|
-
return;
|
|
121
|
-
}
|
|
122
|
-
log("error", extraOrMessage);
|
|
123
|
-
return;
|
|
124
|
-
}
|
|
125
|
-
const { err, ...rest } = extraOrMessage;
|
|
126
|
-
let errorAttrs = rest;
|
|
127
|
-
if (err instanceof Error) {
|
|
128
|
-
errorAttrs = {
|
|
129
|
-
error: err.message,
|
|
130
|
-
stack: err.stack,
|
|
131
|
-
name: err.name,
|
|
132
|
-
...rest
|
|
133
|
-
};
|
|
134
|
-
} else if (err !== void 0) {
|
|
135
|
-
errorAttrs = {
|
|
136
|
-
err,
|
|
137
|
-
...rest
|
|
138
|
-
};
|
|
139
|
-
}
|
|
140
|
-
log("error", message || "", errorAttrs);
|
|
141
|
-
}
|
|
142
|
-
};
|
|
143
|
-
}
|
|
144
|
-
function autotelLogger(options) {
|
|
145
|
-
return createBuiltinLogger(options?.service || "app", {
|
|
146
|
-
level: options?.level,
|
|
147
|
-
pretty: options?.pretty
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
// src/logger.ts
|
|
152
|
-
var LOG_LEVEL = {
|
|
153
|
-
DEBUG: "debug",
|
|
154
|
-
INFO: "info",
|
|
155
|
-
WARN: "warn",
|
|
156
|
-
ERROR: "error"
|
|
157
|
-
};
|
|
158
|
-
function LoggedOperation(operationNameOrOptions) {
|
|
159
|
-
const operationName = typeof operationNameOrOptions === "string" ? operationNameOrOptions : operationNameOrOptions.operationName;
|
|
160
|
-
return function(originalMethod, context) {
|
|
161
|
-
const methodName = String(context.name);
|
|
162
|
-
return async function(...args) {
|
|
163
|
-
const log = this.deps?.log;
|
|
164
|
-
const startTime = performance.now();
|
|
165
|
-
const config = getConfig();
|
|
166
|
-
const tracer = config.tracer;
|
|
167
|
-
return tracer.startActiveSpan(operationName, async (span) => {
|
|
168
|
-
try {
|
|
169
|
-
log?.info(
|
|
170
|
-
{
|
|
171
|
-
operation: operationName,
|
|
172
|
-
method: methodName,
|
|
173
|
-
args
|
|
174
|
-
},
|
|
175
|
-
"Operation started"
|
|
176
|
-
);
|
|
177
|
-
const result = await originalMethod.apply(this, args);
|
|
178
|
-
const duration = performance.now() - startTime;
|
|
179
|
-
log?.info(
|
|
180
|
-
{
|
|
181
|
-
operation: operationName,
|
|
182
|
-
method: methodName,
|
|
183
|
-
duration
|
|
184
|
-
},
|
|
185
|
-
"Operation completed"
|
|
186
|
-
);
|
|
187
|
-
span.setStatus({ code: SpanStatusCode.OK });
|
|
188
|
-
span.setAttributes({
|
|
189
|
-
"operation.name": operationName,
|
|
190
|
-
"operation.method": methodName,
|
|
191
|
-
"operation.duration": duration,
|
|
192
|
-
"operation.success": true
|
|
193
|
-
});
|
|
194
|
-
return result;
|
|
195
|
-
} catch (error) {
|
|
196
|
-
const duration = performance.now() - startTime;
|
|
197
|
-
log?.error(
|
|
198
|
-
{
|
|
199
|
-
err: error instanceof Error ? error : void 0,
|
|
200
|
-
operation: operationName,
|
|
201
|
-
method: methodName,
|
|
202
|
-
duration
|
|
203
|
-
},
|
|
204
|
-
"Operation failed"
|
|
205
|
-
);
|
|
206
|
-
span.setStatus({
|
|
207
|
-
code: SpanStatusCode.ERROR,
|
|
208
|
-
message: error instanceof Error ? error.message : "Unknown error"
|
|
209
|
-
});
|
|
210
|
-
span.setAttributes({
|
|
211
|
-
"operation.name": operationName,
|
|
212
|
-
"operation.method": methodName,
|
|
213
|
-
"operation.duration": duration,
|
|
214
|
-
"operation.success": false,
|
|
215
|
-
"error.type": error instanceof Error ? error.constructor.name : "Unknown"
|
|
216
|
-
});
|
|
217
|
-
throw error;
|
|
218
|
-
} finally {
|
|
219
|
-
span.end();
|
|
220
|
-
}
|
|
221
|
-
});
|
|
222
|
-
};
|
|
223
|
-
};
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
export { LOG_LEVEL, LoggedOperation, autotelLogger, createBuiltinLogger, getActiveLogLevel, getTraceContext, runWithLogLevel };
|
|
227
|
-
//# sourceMappingURL=chunk-55ER2KD5.js.map
|
|
228
|
-
//# sourceMappingURL=chunk-55ER2KD5.js.map
|