@walkeros/collector 4.1.1 → 4.1.3-next-1779963694449

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/CHANGELOG.md CHANGED
@@ -1,5 +1,30 @@
1
1
  # @walkeros/collector
2
2
 
3
+ ## 4.1.3-next-1779963694449
4
+
5
+ ### Patch Changes
6
+
7
+ - 908d6f0: Promote chain, route shape, and reference scanner helpers to the
8
+ public surface so app and tooling can resolve transformer chains, probe route
9
+ shapes, and discover `$flow.` references without reaching into internal
10
+ modules:
11
+ - collector: re-export `walkChain` (resolve a transformer chain start into the
12
+ ordered step IDs) and `extractTransformerNextMap` (read static next-links
13
+ from a `Transformer.Transformers` map).
14
+ - core: re-export `isRouteArray` and `isRouteConfigEntry` (the canonical shape
15
+ probes for `Transformer.Route`) and add `scanFlowRefs(value, into?)`, which
16
+ walks any value (string, object, array) and returns every `$flow.<name>`
17
+ reference found, including refs nested inside `$code:` snippets.
18
+
19
+ - Updated dependencies [908d6f0]
20
+ - @walkeros/core@4.1.3-next-1779963694449
21
+
22
+ ## 4.1.2
23
+
24
+ ### Patch Changes
25
+
26
+ - @walkeros/core@4.1.2
27
+
3
28
  ## 4.1.1
4
29
 
5
30
  ### Patch Changes
package/dist/index.d.mts CHANGED
@@ -234,6 +234,46 @@ declare function initSource(collector: Collector.Instance, sourceId: string, sou
234
234
  */
235
235
  declare function initSources(collector: Collector.Instance, sources?: Source.InitSources): Promise<Collector.Sources>;
236
236
 
237
+ /**
238
+ * Extracts transformer next configuration for chain walking.
239
+ * Maps transformer instances to their config.next values.
240
+ *
241
+ * This is the single source of truth for extracting chain links.
242
+ * Used by both source.ts (pre-collector chains) and destination.ts (post-collector chains).
243
+ *
244
+ * @param transformers - Map of transformer instances
245
+ * @returns Map of transformer IDs to their next configuration
246
+ */
247
+ declare function extractTransformerNextMap(transformers: Transformer.Transformers): Record<string, {
248
+ next?: string | string[];
249
+ }>;
250
+ /**
251
+ * Walks a transformer chain starting from a given transformer ID.
252
+ * Returns ordered array of transformer IDs in the chain.
253
+ *
254
+ * Used for on-demand chain resolution:
255
+ * - Called from destination.ts with destination.config.before
256
+ * - Called from source.ts with source.config.next
257
+ *
258
+ * @param startId - First transformer in chain, or explicit array of transformer IDs
259
+ * @param transformers - Available transformer configs with optional `next` field
260
+ * @returns Ordered array of transformer IDs to execute
261
+ *
262
+ * @example
263
+ * // Single transformer
264
+ * walkChain('redact', { redact: {} }) // ['redact']
265
+ *
266
+ * @example
267
+ * // Chain via next
268
+ * walkChain('a', { a: { next: 'b' }, b: { next: 'c' }, c: {} }) // ['a', 'b', 'c']
269
+ *
270
+ * @example
271
+ * // Explicit array
272
+ * walkChain(['x', 'y'], {}) // ['x', 'y']
273
+ */
274
+ declare function walkChain(startId: string | string[] | undefined, transformers?: Record<string, {
275
+ next?: string | string[];
276
+ }>): string[];
237
277
  /**
238
278
  * Initializes a transformer if it hasn't been initialized yet.
239
279
  * Called lazily before first push.
@@ -291,4 +331,4 @@ declare function wrapEnv(env: Record<string, unknown> & {
291
331
  */
292
332
  declare function getCacheStore(compiled: CompiledCache, collector: Collector.Instance): Store.Instance | undefined;
293
333
 
294
- export { code as Code, type CommandTypes, Commands, Const, type CreateCollector, type HandleCommandFn, type RunState, type StartFlow, type StorageType, addDestination, callDestinationOn, commonHandleCommand, createEvent, createPush, createPushResult, destinationInit, destinationPush, flushSourceQueueOn, getCacheStore, initDestinations, initSource, initSources, isSourceStarted, mergeEnvironments, on, onApply, processConsent, pushToDestinations, registerDestination, runCollector, runTransformerChain, startFlow, transformerInit, transformerPush, wrapEnv };
334
+ export { code as Code, type CommandTypes, Commands, Const, type CreateCollector, type HandleCommandFn, type RunState, type StartFlow, type StorageType, addDestination, callDestinationOn, commonHandleCommand, createEvent, createPush, createPushResult, destinationInit, destinationPush, extractTransformerNextMap, flushSourceQueueOn, getCacheStore, initDestinations, initSource, initSources, isSourceStarted, mergeEnvironments, on, onApply, processConsent, pushToDestinations, registerDestination, runCollector, runTransformerChain, startFlow, transformerInit, transformerPush, walkChain, wrapEnv };
package/dist/index.d.ts CHANGED
@@ -234,6 +234,46 @@ declare function initSource(collector: Collector.Instance, sourceId: string, sou
234
234
  */
235
235
  declare function initSources(collector: Collector.Instance, sources?: Source.InitSources): Promise<Collector.Sources>;
236
236
 
237
+ /**
238
+ * Extracts transformer next configuration for chain walking.
239
+ * Maps transformer instances to their config.next values.
240
+ *
241
+ * This is the single source of truth for extracting chain links.
242
+ * Used by both source.ts (pre-collector chains) and destination.ts (post-collector chains).
243
+ *
244
+ * @param transformers - Map of transformer instances
245
+ * @returns Map of transformer IDs to their next configuration
246
+ */
247
+ declare function extractTransformerNextMap(transformers: Transformer.Transformers): Record<string, {
248
+ next?: string | string[];
249
+ }>;
250
+ /**
251
+ * Walks a transformer chain starting from a given transformer ID.
252
+ * Returns ordered array of transformer IDs in the chain.
253
+ *
254
+ * Used for on-demand chain resolution:
255
+ * - Called from destination.ts with destination.config.before
256
+ * - Called from source.ts with source.config.next
257
+ *
258
+ * @param startId - First transformer in chain, or explicit array of transformer IDs
259
+ * @param transformers - Available transformer configs with optional `next` field
260
+ * @returns Ordered array of transformer IDs to execute
261
+ *
262
+ * @example
263
+ * // Single transformer
264
+ * walkChain('redact', { redact: {} }) // ['redact']
265
+ *
266
+ * @example
267
+ * // Chain via next
268
+ * walkChain('a', { a: { next: 'b' }, b: { next: 'c' }, c: {} }) // ['a', 'b', 'c']
269
+ *
270
+ * @example
271
+ * // Explicit array
272
+ * walkChain(['x', 'y'], {}) // ['x', 'y']
273
+ */
274
+ declare function walkChain(startId: string | string[] | undefined, transformers?: Record<string, {
275
+ next?: string | string[];
276
+ }>): string[];
237
277
  /**
238
278
  * Initializes a transformer if it hasn't been initialized yet.
239
279
  * Called lazily before first push.
@@ -291,4 +331,4 @@ declare function wrapEnv(env: Record<string, unknown> & {
291
331
  */
292
332
  declare function getCacheStore(compiled: CompiledCache, collector: Collector.Instance): Store.Instance | undefined;
293
333
 
294
- export { code as Code, type CommandTypes, Commands, Const, type CreateCollector, type HandleCommandFn, type RunState, type StartFlow, type StorageType, addDestination, callDestinationOn, commonHandleCommand, createEvent, createPush, createPushResult, destinationInit, destinationPush, flushSourceQueueOn, getCacheStore, initDestinations, initSource, initSources, isSourceStarted, mergeEnvironments, on, onApply, processConsent, pushToDestinations, registerDestination, runCollector, runTransformerChain, startFlow, transformerInit, transformerPush, wrapEnv };
334
+ export { code as Code, type CommandTypes, Commands, Const, type CreateCollector, type HandleCommandFn, type RunState, type StartFlow, type StorageType, addDestination, callDestinationOn, commonHandleCommand, createEvent, createPush, createPushResult, destinationInit, destinationPush, extractTransformerNextMap, flushSourceQueueOn, getCacheStore, initDestinations, initSource, initSources, isSourceStarted, mergeEnvironments, on, onApply, processConsent, pushToDestinations, registerDestination, runCollector, runTransformerChain, startFlow, transformerInit, transformerPush, walkChain, wrapEnv };
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- "use strict";var e,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,r={};((e,n)=>{for(var o in n)t(e,o,{get:n[o],enumerable:!0})})(r,{Code:()=>i,Commands:()=>a,Const:()=>c,addDestination:()=>X,callDestinationOn:()=>_,commonHandleCommand:()=>de,createEvent:()=>le,createPush:()=>ge,createPushResult:()=>ne,destinationInit:()=>ee,destinationPush:()=>te,flushSourceQueueOn:()=>j,getCacheStore:()=>w,initDestinations:()=>se,initSource:()=>D,initSources:()=>E,isSourceStarted:()=>A,mergeEnvironments:()=>re,on:()=>T,onApply:()=>H,processConsent:()=>d,pushToDestinations:()=>Z,registerDestination:()=>oe,runCollector:()=>pe,runTransformerChain:()=>q,startFlow:()=>Oe,transformerInit:()=>C,transformerPush:()=>I,wrapEnv:()=>je}),module.exports=(e=r,((e,r,i,a)=>{if(r&&"object"==typeof r||"function"==typeof r)for(let c of o(r))s.call(e,c)||c===i||t(e,c,{get:()=>r[c],enumerable:!(a=n(r,c))||a.enumerable});return e})(t({},"__esModule",{value:!0}),e));var i={},a={Action:"action",Actions:"actions",Config:"config",Consent:"consent",Context:"context",Custom:"custom",Destination:"destination",Elb:"elb",Globals:"globals",Hook:"hook",Init:"init",Link:"link",On:"on",Prefix:"data-elb",Ready:"ready",Run:"run",Session:"session",Shutdown:"shutdown",User:"user",Walker:"walker"},c={Commands:a,Utils:{Storage:{Cookie:"cookie",Local:"local",Session:"session"}}},u=require("@walkeros/core");function d(e,t){const n={};return Object.entries(t).forEach(([e,t])=>{n[e]=!!t}),e.consent=(0,u.assign)(e.consent,n),{update:n}}var l=require("@walkeros/core"),p=require("@walkeros/core");require("@walkeros/core");function f(e,t){const n=e.status.startedAt;return{flowId:"default",stepId:t.stepId,stepType:t.stepType,phase:t.phase,eventId:t.eventId,timestamp:new Date(t.now).toISOString(),elapsedMs:t.now-n}}var g=require("@walkeros/core"),h=require("@walkeros/core");var m=require("@walkeros/core"),y=require("@walkeros/core");function w(e,t){return e.storeId&&t.stores[e.storeId]?t.stores[e.storeId]:t.stores.__cache}function v(e){const t={};for(const[n,o]of Object.entries(e)){const e=o.config?.next;"string"==typeof e||Array.isArray(e)&&e.every(e=>"string"==typeof e)?t[n]={next:e}:t[n]={}}return t}function b(e,t){const n=e.config||{},o=e[t];return void 0!==o?{config:{...n,[t]:o},chainValue:o}:{config:n,chainValue:void 0}}function k(e,t={}){if(!e)return[];if(Array.isArray(e))return e;const n=[],o=new Set;let s=e;for(;s&&t[s]&&!o.has(s);){o.add(s),n.push(s);const e=t[s].next;if(Array.isArray(e)){n.push(...e);break}s=e}return n}async function C(e,t,n){if(t.init&&!t.config.init){const o=t.type||"unknown",s=e.logger.scope(`transformer:${o}`),r={collector:e,logger:s,id:n,ingest:(0,y.createIngest)(n),config:t.config,env:O(t.config.env)};s.debug("init");const i=await(0,y.useHooks)(t.init,"TransformerInit",e.hooks,e.logger)(r);if(!1===i)return!1;t.config={...i||t.config,env:i?.env||t.config.env,init:!0},s.debug("init done")}return!0}async function I(e,t,n,o,s,r){const i=t.type||"unknown",a=e.logger.scope(`transformer:${i}`),c={collector:e,logger:a,id:n,ingest:s,config:t.config,env:{...O(t.config.env),...r?{respond:r}:{}}};a.debug("push",{event:o.name});const u="string"==typeof o.id?o.id:"",d=Date.now(),l=f(e,{stepId:(0,y.stepId)("transformer",n),stepType:"transformer",phase:"in",eventId:u,now:d});(0,y.emitStep)(e,l);try{const s=await(0,y.useHooks)(t.push,"TransformerPush",e.hooks,e.logger)(o,c),r=Date.now(),i=f(e,{stepId:(0,y.stepId)("transformer",n),stepType:"transformer",phase:"out",eventId:u,now:r});return i.durationMs=r-d,i.outEvent=s,(0,y.emitStep)(e,i),a.debug("push done"),s}catch(t){const o=Date.now(),s=f(e,{stepId:(0,y.stepId)("transformer",n),stepType:"transformer",phase:"error",eventId:u,now:o});throw s.durationMs=o-d,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,y.emitStep)(e,s),t}}function S(e,t){return e?{...e,_meta:{...e._meta,path:[...e._meta.path]}}:(0,y.createIngest)(t)}async function q(e,t,n,o,s,r,i){s||(s=(0,y.createIngest)(n[0]??"chain")),i&&s._meta&&(s._meta.chainPath=i);let a=o,c=r;for(const o of n){const r=t[o];if(!r){e.logger.warn(`Transformer not found: ${o}`);continue}if(s&&s._meta&&s._meta.path.length>256)return e.logger.error(`Max path length exceeded at ${o}`),{event:null,respond:c};s&&s._meta&&(s._meta.hops++,s._meta.path.push(o));if(!await(0,y.tryCatchAsync)(C,t=>{if(t instanceof y.FatalError)throw t;return e.status.failed++,e.logger.scope(`transformer:${r.type||"unknown"}`).error("transformer init failed",{transformer:o,error:t}),!1})(e,r,o))return{event:null,respond:c};if(i&&void 0!==r.config?.chainMocks?.[i]){const t=r.config.chainMocks[i];e.logger.scope(`transformer:${r.type||"unknown"}`).debug("chainMock",{chain:i}),a=t;continue}if(void 0!==r.config?.mock){e.logger.scope(`transformer:${r.type||"unknown"}`).debug("mock"),a=r.config.mock;continue}if(r.config?.disabled)continue;const u=r.config?.cache,d=u?(0,y.compileCache)(u):void 0,l=d?w(d,e):void 0;let p;if(d&&l){const e=(0,y.buildCacheContext)(s,a),t=await(0,y.checkCache)(d,l,e);if("HIT"===t?.status&&t.value){if(a=t.value,d.stop)return{event:a,respond:c,stopped:!0};continue}"MISS"===t?.status&&(p={key:t.key,ttl:t.rule.ttl})}const f=r.config.before;if(f){const n=(0,y.getNextSteps)(f,(0,y.buildCacheContext)(s,a));if(1===n.length){const o=k(n[0],v(t));if(o.length>0){const n=await q(e,t,o,a,s,c,i);if(null===n.event)return{event:null,respond:n.respond??c};if(n.stopped)return{event:Array.isArray(n.event)?n.event[0]:n.event,respond:n.respond??c,stopped:!0};n.respond&&(c=n.respond),a=Array.isArray(n.event)?n.event[0]:n.event}}else n.length>1&&await Promise.all(n.map(n=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(n,v(t)),a,S(s,n),void 0,i)))}const g=await(0,y.tryCatchAsync)(I,t=>(e.logger.scope(`transformer:${r.type||"unknown"}`).error("Push failed",{error:t}),!1))(e,r,o,a,s,c);if(!1===g)return{event:null,respond:c};if(Array.isArray(g)){const r=n.slice(n.indexOf(o)+1),u=await Promise.all(g.map(async n=>{const o=n.event||a,u=S(s,"unknown");if(n.next){const s=(0,y.getNextSteps)(n.next,(0,y.buildCacheContext)(u,o));if(0===s.length)return{event:o,respond:c};if(1===s.length){const n=k(s[0],v(t));return n.length>0?q(e,t,n,o,u,c,i):{event:o,respond:c}}return(await Promise.all(s.map(n=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(n,v(t)),o,S(u,n),void 0,i)))).map(e=>({event:e.event,respond:void 0}))}return r.length>0?q(e,t,r,o,u,c,i):{event:o,respond:c}}));let d=c;const l=[];for(const e of u.flat())if(null!==e)if(e&&"object"==typeof e&&"event"in e){const t=e;if(t.respond&&(d=t.respond),null===t.event)continue;Array.isArray(t.event)?l.push(...t.event):l.push(t.event)}else l.push(e);return 0===l.length?{event:null,respond:d}:1===l.length?{event:l[0],respond:d}:{event:l,respond:d}}if(g&&"object"==typeof g){const{event:n,respond:o,next:r}=g;if(o&&(c=o),void 0!==r){const o=(0,y.getNextSteps)(r,(0,y.buildCacheContext)(s,a));if(0===o.length){n&&(a=n);continue}if(1===o.length){const u=k(o[0],v(t));return u.length>0?q(e,t,u,n||a,s,c,i):(e.logger.warn(`Branch target not found: ${JSON.stringify(r)}`),{event:null,respond:c})}return await Promise.all(o.map(o=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${o} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(o,v(t)),n||a,S(s,o),void 0,i))),{event:null,respond:void 0}}n&&(a=n)}p&&l&&(0,y.storeCache)(l,p.key,a,p.ttl);const h=r.config.next,m="string"==typeof h||Array.isArray(h)&&h.every(e=>"string"==typeof e),b=void 0!==h&&!m;if((!g||"object"==typeof g&&!g.next)&&b){const n=(0,y.getNextSteps)(r.config.next,(0,y.buildCacheContext)(s,a));if(1===n.length){const o=k(n[0],v(t));return o.length>0?q(e,t,o,a,s,c,i):{event:a,respond:c}}return n.length>1?(await Promise.all(n.map(n=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(n,v(t)),a,S(s,n),void 0,i))),{event:null,respond:void 0}):{event:a,respond:c}}}return{event:a,respond:c}}function O(e){return e&&(0,y.isObject)(e)?e:{}}function x(e){return"string"==typeof e||!(!Array.isArray(e)||!e.every(e=>"string"==typeof e))}async function j(e,t,n){if(!t.on||!t.queueOn?.length)return;const o=t.queueOn;t.queueOn=[];const s=n||t.config?.id||"unknown";for(const{type:n,data:r}of o)await(0,m.tryCatchAsync)(t.on,t=>{if(t instanceof m.FatalError)throw t;e.status.failed++,e.logger.scope("source").error("source on flush failed",{sourceId:s,type:n,error:t})})(n,r)}function A(e){return Boolean(e.config.init)&&!e.config.require?.length}async function D(e,t,n){const{code:o,config:s={},env:r={},primary:i,next:a,before:c,cache:u}=n,d=u,l=d?(0,m.compileCache)({...d,stop:d.stop??!0}):void 0,p=x(a)?k(a,v(e.transformers)):void 0,f=x(c)?k(c,v(e.transformers)):void 0,g=r.push,h=g??e.push,y=Boolean(g),b=async(n,o,r)=>{let i;const u=f??(void 0!==c?(()=>{const t=(0,m.getNextSteps)(c,(0,m.buildCacheContext)(r.ingest));if(0===t.length)return[];return k(1===t.length?t[0]:t,v(e.transformers))})():[]);let d=[n];if(u.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const o=await q(e,e.transformers,u,n,r.ingest,r.respond,`source.${t}.before`);if(null===o.event)return{ok:!0};if(o.stopped)return o.respond&&(r.respond=o.respond),{ok:!0};o.respond&&(r.respond=o.respond),d=Array.isArray(o.event)?o.event:[o.event]}if(l){const t=w(l,e);if(t){const n=(0,m.buildCacheContext)(r.ingest),o=await(0,m.checkCache)(l,t,n);if(o){if("HIT"===o.status&&void 0!==o.value&&l.stop){let t=o.value;return o.rule.update&&(t=await(0,m.applyUpdate)(t,o.rule.update,{...n,cache:{status:"HIT"}},e)),r.respond?.(t),{ok:!0}}if("MISS"===o.status&&l.stop&&r.respond){const s=r.respond,a=o.rule.update,c={...n,cache:{status:"MISS"}},u=o.key,d=o.rule.ttl,l=n=>{(0,m.storeCache)(t,u,n,d),a?i=(async()=>{const t=await(0,m.applyUpdate)(n,a,c,e);s(t)})():s(n)};r.respond=l}"MISS"!==o.status||l.stop||(0,m.storeCache)(t,o.key,!0,o.rule.ttl)}}}const g=p?{kind:"single",preChain:p}:void 0!==a?(()=>{const t=(0,m.getNextSteps)(a,(0,m.buildCacheContext)(r.ingest));return 0===t.length?{kind:"single",preChain:[]}:1===t.length?{kind:"single",preChain:k(t[0],v(e.transformers))}:{kind:"many",branches:t.map(t=>k(t,v(e.transformers)))}})():{kind:"single",preChain:[]};let b={ok:!0};for(const n of d)"many"===g.kind?(await Promise.all(g.branches.map((i,a)=>(0,m.tryCatchAsync)(async()=>y?h(n):h(n,{...o,id:t,ingest:S(r.ingest,`${t}.${a}`),respond:void 0,mapping:s,preChain:i}),t=>(e.logger.scope("source:many").error(`many branch ${a} failed`,{error:t}),{ok:!0}))())),b={ok:!0}):b=y?await h(n):await h(n,{...o,id:t,ingest:r.ingest,respond:r.respond,mapping:s,preChain:g.preChain});return i&&await i,b},C=async n=>{const o=(0,m.createIngest)(t);if(!s.ingest||void 0===n)return o;const r=await(0,m.getMappingValue)(n,s.ingest,{collector:e});return{...o,...r,_meta:o._meta}},I=e.logger.scope("source").scope(t),O={command:e.command,sources:e.sources,elb:e.sources.elb.push,logger:I,...r,push:async(e,n={})=>{const o={ingest:(0,m.createIngest)(t),respond:void 0};return b(e,n,o)}},j={collector:e,logger:I,id:t,config:s,env:O,withScope:async(e,t,n)=>{const o={ingest:await C(e),respond:t};return n({...O,push:(e,t={})=>b(e,t,o),ingest:o.ingest,respond:o.respond})}},A=await(0,m.tryCatchAsync)(o,n=>{if(n instanceof m.FatalError)throw n;e.status.failed++,e.logger.scope("source").error("source factory failed",{sourceId:t,error:n})})(j);if(!A)return;const D=A.type||"unknown",E=e.logger.scope(D).scope(t);return O.logger=E,i&&(A.config={...A.config,primary:i}),A}async function E(e,t={}){const n={};for(const[o,s]of Object.entries(t)){const t=await D(e,o,s);if(!t)continue;const r=s.config?.require;t.config={...t.config,init:!1,...r?{require:[...r]}:{}},n[o]=t}Object.assign(e.sources,n);for(const t of Object.keys(n)){const n=e.sources[t];let o=!1;n.init&&await(0,m.tryCatchAsync)(n.init.bind(n),n=>{if(n instanceof m.FatalError)throw n;o=!0,e.status.failed++,e.logger.scope("source").error("source init failed",{sourceId:t,error:n})})(),o||(n.config.init=!0,A(n)&&await j(e,n,t))}return n}function $(e,t,n,o){if(n instanceof g.FatalError)throw n;e.logger.scope("on").error("on callback failed",{kind:t,...o,error:n})}function M(e,t){return{collector:e,logger:e.logger.scope("on").scope(String(t))}}async function T(e,t,n){const o=e.on,s=o[t]||[],r=(0,g.isArray)(n)?n:[n];r.forEach(e=>{s.push(e)}),o[t]=s,P(e,t,r)}function _(e,t,n,o,s){if(!t.on)return;const r=t.type||"unknown",i=e.logger.scope(r).scope("on").scope(o),a={collector:e,logger:i,id:n,config:t.config,data:s,env:re(t.env,t.config.env)};(0,h.tryCatch)(t.on,t=>$(e,"destination",t,{destId:n,type:o}))(o,a)}function P(e,t,n,o){let s;switch(t){case c.Commands.Consent:s=o||e.consent;break;case c.Commands.Session:s=e.session;break;case c.Commands.User:s=o||e.user;break;case c.Commands.Custom:s=o||e.custom;break;case c.Commands.Globals:s=o||e.globals;break;case c.Commands.Config:s=o||e.config;break;case c.Commands.Ready:case c.Commands.Run:default:s=void 0}if(n.length)switch(t){case c.Commands.Consent:!function(e,t,n){const o=n||e.consent,s=M(e,c.Commands.Consent);t.forEach(t=>{Object.keys(o).filter(e=>e in t).forEach(n=>{(0,h.tryCatch)(t[n],t=>$(e,"consent",t,{key:n}))(o,s)})})}(e,n,o);break;case c.Commands.Ready:!function(e,t){if(!e.allowed)return;const n=M(e,c.Commands.Ready);t.forEach(t=>{(0,h.tryCatch)(t,t=>$(e,"ready",t))(void 0,n)})}(e,n);break;case c.Commands.Run:!function(e,t){if(!e.allowed)return;const n=M(e,c.Commands.Run);t.forEach(t=>{(0,h.tryCatch)(t,t=>$(e,"run",t))(void 0,n)})}(e,n);break;case c.Commands.Session:!function(e,t){if(!e.session)return;const n=M(e,c.Commands.Session);t.forEach(t=>{(0,h.tryCatch)(t,t=>$(e,"session",t))(e.session,n)})}(e,n);break;default:{const o=M(e,t);n.forEach(n=>{"function"==typeof n&&(0,h.tryCatch)(n,n=>$(e,"generic",n,{type:t}))(s,o)});break}}}async function H(e,t,n,o){let s,r=n||[];switch(n||(r=e.on[t]||[]),t){case c.Commands.Consent:s=o||e.consent;break;case c.Commands.Session:s=e.session;break;case c.Commands.User:s=o||e.user;break;case c.Commands.Custom:s=o||e.custom;break;case c.Commands.Globals:s=o||e.globals;break;case c.Commands.Config:s=o||e.config;break;case c.Commands.Ready:case c.Commands.Run:default:s=void 0}let i=!1;for(const[n,o]of Object.entries(e.sources)){if(o.config.require?.length){const e=o.config.require.indexOf(t);-1!==e&&o.config.require.splice(e,1)}if(o.on)if(A(o)){!1===await(0,h.tryCatchAsync)(o.on,o=>$(e,"source",o,{sourceId:n,type:t}))(t,s)&&(i=!0)}else o.queueOn=o.queueOn||[],o.queueOn.push({type:t,data:s})}Object.entries(e.destinations).forEach(([n,o])=>{if(o.on){if(!o.config.init)return o.queueOn=o.queueOn||[],void o.queueOn.push({type:t,data:s});_(e,o,n,t,s)}});for(const[t,n]of Object.entries(e.sources))A(n)&&n.queueOn?.length&&await j(e,n,t);return Object.keys(e.pending.destinations).length>0&&await async function(e,t){for(const[n,o]of Object.entries(e.pending.destinations)){if(!e.pending.destinations[n]||e.destinations[n])continue;const s=o.config?.require;if(!s)continue;const r=s.indexOf(t);if(-1===r)continue;if(s.splice(r,1),s.length>0)continue;delete e.pending.destinations[n];const i=oe(o);!1!==i.config.queue&&(i.queuePush=[...e.queue]),e.destinations[n]=i}}(e,t),P(e,t,r,o),!i}function z(e,t,n,o){if(!Number.isFinite(n.max)||n.max<=0)throw new Error(`pushBounded: max must be > 0 (got ${n.max})`);if("dropNewest"===(n.onOverflow??"dropOldest"))return e.length>=n.max?(o&&o([t]),{appended:!1,dropped:1}):(e.push(t),{appended:!0,dropped:0});const s=[];for(;e.length>=n.max;)s.push(e.shift());return e.push(t),s.length>0&&o&&o(s),{appended:!0,dropped:s.length}}var F=new WeakMap;function R(e,t,n,o){F.get(e)||(F.set(e,!0),t.warn(n,o))}function B(e){F.delete(e)}var K=1e3,N=100,G=1e3,U=3e4,W=Object.freeze({batched:!0});function L(e){return e===W}function V(e){return void 0===e?{}:"number"==typeof e?{wait:e}:{wait:e.wait,size:e.size,age:e.age}}function Y(e,t){return e.status.destinations[t]||(e.status.destinations[t]={count:0,failed:0,duration:0,queuePushSize:0,dlqSize:0}),e.status.destinations[t]}function J(e,t,n,o){e.dropped[t]||(e.dropped[t]={});const s=e.dropped[t];return s[n]=(s[n]??0)+o,s[n]}function Q(e,t,n){if(!e)return[];if(Array.isArray(e)&&e.every(e=>"string"==typeof e))return k(e,t);if("string"==typeof e)return k(e,t);const o=(0,p.getNextSteps)(e,(0,p.buildCacheContext)(n));return 0===o.length?[]:1===o.length?k(o[0],t):k(o,t)}async function X(e,t){const{code:n,config:o={},env:s={},before:r,next:i,cache:a}=t;if(!(0,p.isFunction)(n.push))return ne({ok:!1,failed:{invalid:{type:"invalid",error:"Destination code must have a push method"}}});const c=o||{init:!1};let u=r?{...c,before:r}:{...c};i&&(u={...u,next:i}),a&&(u={...u,cache:a});const d={...n,config:u,env:re(n.env,s)};let l=d.config.id;if(!l)do{l=(0,p.getId)(5,"abcdefghijklmnopqrstuvwxyz")}while(e.destinations[l]);return e.destinations[l]=d,!1!==d.config.queue&&(d.queuePush=[...e.queue]),Z(e,void 0,{},{[l]:d})}async function Z(e,t,n={},o){const{allowed:s,consent:r,globals:i,user:a}=e;if(!s)return ne({ok:!1});if(t){const n=e.config.queueMax;if(void 0===n)throw new Error("Collector.Config.queueMax is undefined; defaults must be seeded by collector()");const o=z(e.queue,t,{max:n});if(o.dropped>0){const t=J(e.status,(0,p.stepId)("collector"),"queue",o.dropped);R(e.queue,e.logger,"collector.queue overflow; oldest events dropped",{buffer:"queue",cap:n,droppedCount:t})}else e.queue.length<n&&B(e.queue);e.status.in++}o||(o=e.destinations);const c=e.transformers?v(e.transformers):{},u=await Promise.all(Object.entries(o||{}).map(async([o,s])=>{if(s.config.disabled)return{id:o,destination:s,skipped:!0};let u=(s.queuePush||[]).map(e=>({...e,consent:r}));s.queuePush=[],t&&u.push((0,p.clone)(t));const d=n.ingest?{...n.ingest,_meta:{...n.ingest._meta,path:[...n.ingest._meta.path]}}:(0,p.createIngest)("unknown");if(!u.length&&!s.queueOn?.length)return{id:o,destination:s,skipped:!0};if(!u.length&&s.queueOn?.length){let t=!1;try{t=await ee(e,s,o)}catch(t){e.status.failed++;const n=s.type||"unknown";e.logger.scope(n).error("destination init failed",{error:t instanceof Error?t.message:String(t)})}return{id:o,destination:s,skipped:!t}}const l=[],g=u.filter(t=>{const n=(0,p.getGrantedConsent)(s.config.consent,r,t.consent);if(n)return t.consent=n,l.push(t),!1;const i=f(e,{stepId:(0,p.stepId)("destination",o),stepType:"destination",phase:"skip",eventId:"string"==typeof t.id?t.id:"",now:Date.now()});return i.skipReason="consent",r&&(i.consent={...r}),s.config.consent&&(i.meta={required:{...s.config.consent}}),(0,p.emitStep)(e,i),!0});if(g.length>0){const t=s.queuePush,n=s.config.id||o,r={max:s.config.queueMax??K};let i=0;for(const e of g){i+=z(t,e,r).dropped}if(i>0){Y(e,n);const o=J(e.status,(0,p.stepId)("destination",n),"queue",i);R(t,e.logger.scope(s.type||"unknown"),"destination.queuePush overflow; oldest events dropped",{buffer:"queuePush",destination:n,cap:r.max,droppedCount:o})}else t.length<r.max&&B(t)}if(!l.length)return{id:o,destination:s,queue:u};let h,m,y=!1;try{y=await ee(e,s,o)}catch(t){e.status.failed++;const n=s.type||"unknown";e.logger.scope(n).error("destination init failed",{error:t instanceof Error?t.message:String(t)})}if(!y)return{id:o,destination:s,queue:u};s.dlq||(s.dlq=[]);const v=Q(s.config.before,c,d),b=s.config.next,k=s.config?.cache,C=k?(0,p.compileCache)(k):void 0,I=C?w(C,e):void 0;let S=0,O=0;return await Promise.all(l.map(async t=>{let r;if(t.globals=(0,p.assign)(i,t.globals),t.user=(0,p.assign)(a,t.user),C?.stop&&I){const e=(0,p.buildCacheContext)(d,t),n=await(0,p.checkCache)(C,I,e);if("HIT"===n?.status)return t;"MISS"===n?.status&&(r={key:n.key,ttl:n.rule.ttl})}let u=t,l=n.respond;if(v.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const s=await q(e,e.transformers,v,t,d,n.respond,`destination.${o}.before`);if(null===s.event)return t;s.respond&&(l=s.respond),u=Array.isArray(s.event)?s.event[0]:s.event}if(C&&!C.stop&&I){const e=(0,p.buildCacheContext)(d,u),n=await(0,p.checkCache)(C,I,e);if("HIT"===n?.status)return t;"MISS"===n?.status&&(r={key:n.key,ttl:n.rule.ttl})}const f=Date.now();let g=!1;const y=await(0,p.tryCatchAsync)(te,t=>{const n=s.type||"unknown";e.logger.scope(n).error("Push failed",{error:t,event:u.name}),h=t,g=!0;const r=s.dlq,i=s.config.id||o,a={max:s.config.dlqMax??N},c=z(r,[u,t],a);if(c.dropped>0){Y(e,i);const t=J(e.status,(0,p.stepId)("destination",i),"dlq",c.dropped);R(r,e.logger.scope(s.type||"unknown"),"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:i,cap:a.max,droppedCount:t})}else r.length<a.max&&B(r)})(e,s,o,u,d,l);if(S+=Date.now()-f,r&&I&&void 0===s.config.mock&&(0,p.storeCache)(I,r.key,y??!0,r.ttl),void 0===y||L(y)||(m=y),L(y)&&O++,!g&&b){void 0!==y&&(d._response=y);const t=Q(b,c,d);if(t.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const n=await q(e,e.transformers,t,u,d,l,`destination.${o}.next`);n.respond&&(l=n.respond)}}return t})),{id:o,destination:s,error:h,response:m,totalDuration:S,batchedCount:O,allowedCount:l.length}})),d={},l={},g={};for(const t of u){if(t.skipped)continue;const n=t.destination,o={type:n.type||"unknown",data:t.response};Y(e,t.id);const s=e.status.destinations[t.id],r=Date.now();if(s.queuePushSize=n.queuePush?.length??0,s.dlqSize=n.dlq?.length??0,t.error)o.error=t.error,g[t.id]=o,s.failed++,s.lastAt=r,s.duration+=t.totalDuration||0,e.status.failed++;else if(t.queue&&t.queue.length)l[t.id]=o;else{const n=t.batchedCount??0,i=t.allowedCount??0;(Math.max(0,i-n)>0||0===i)&&(d[t.id]=o,s.count++,s.lastAt=r,s.duration+=t.totalDuration||0,e.status.out++)}}return ne({event:t,...Object.keys(d).length&&{done:d},...Object.keys(l).length&&{queued:l},...Object.keys(g).length&&{failed:g}})}async function ee(e,t,n){if(t.init&&!t.config.init){const o=t.type||"unknown",s=e.logger.scope(o),r={collector:e,logger:s,id:n,config:t.config,env:re(t.env,t.config.env)};s.debug("init");const i=Date.now();let a;(0,p.emitStep)(e,f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"init",eventId:"",now:i}));try{a=await(0,p.useHooks)(t.init,"DestinationInit",e.hooks,e.logger)(r)}catch(t){const o=Date.now(),s=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"error",eventId:"",now:o});throw s.durationMs=o-i,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,p.emitStep)(e,s),t}if(!1===a)return a;if(t.config={...a||t.config,init:!0},t.queueOn?.length){const o=t.queueOn;t.queueOn=[];for(const{type:s,data:r}of o)_(e,t,n,s,r)}s.debug("init done")}return!0}async function te(e,t,n,o,s,r){const{config:i}=t,a=await(0,p.processEventMapping)(o,i,e);if(a.ignore)return!1;const c=t.type||"unknown",u=e.logger.scope(c),d={collector:e,logger:u,id:n,config:i,data:a.data,rule:a.mapping,ingest:s,env:{...re(t.env,i.env),...r?{respond:r}:{}}};if(void 0!==i.mock)return u.debug("mock",{event:a.event.name}),i.mock;const l=a.mapping,g=a.mappingKey||"* *";if(l?.batch&&t.pushBatch&&void 0===i.mock){if(t.batches=t.batches||{},!t.batches[g]){const o={key:g,entries:[],events:[],data:[]},s=V(l.batch),r=V(i.batch),a=s.wait??r.wait??U,c=s.size??r.size??G,d=s.age??r.age??U,h=re(t.env,i.env),m=async()=>{const o=t.batches[g].batched;if(0===o.entries.length)return;const s={key:o.key,entries:o.entries,events:o.events,data:o.data};o.entries=[],o.events=[],o.data=[];const r=s.entries[0],a={collector:e,logger:u,id:n,config:i,data:void 0,rule:r.rule,ingest:r.ingest,env:{...h,...r.respond?{respond:r.respond}:{}}};u.debug("push batch",{events:s.entries.length});const c=t.config.id||n,d=Y(e,c),l=Date.now(),m=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"flush",eventId:"",now:l});m.batch={size:s.entries.length,index:0},(0,p.emitStep)(e,m);let y=!0;await(0,p.tryCatchAsync)((0,p.useHooks)(t.pushBatch,"DestinationPushBatch",e.hooks,e.logger),o=>{y=!1;const r=Date.now(),i=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"error",eventId:"",now:r});i.durationMs=r-l,i.error=o instanceof Error?{name:o.name,message:o.message}:{message:String(o)},i.batch={size:s.entries.length,index:0},(0,p.emitStep)(e,i);const a=t.dlq=t.dlq||[],g={max:t.config.dlqMax??N};let h=0;for(const e of s.entries){h+=z(a,[e.event,o],g).dropped}if(h>0){const t=J(e.status,(0,p.stepId)("destination",c),"dlq",h);R(a,u,"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:g.max,droppedCount:t})}else a.length<g.max&&B(a);d.failed+=s.entries.length,d.dlqSize=a.length,e.status.failed+=s.entries.length,u.error("Push batch failed",{error:o instanceof Error?o.message:String(o),entries:s.entries.length})})(s,a),u.debug("push batch done"),d.inFlightBatch=Math.max(0,(d.inFlightBatch??0)-s.entries.length),y&&(d.count+=s.entries.length,d.lastAt=Date.now(),e.status.out+=s.entries.length)},y=(0,p.debounce)(m,{wait:a,size:c,age:d});t.batches[g]={batched:o,batchFn:()=>{y()},flush:async()=>{await y.flush()}}}const o=t.batches[g];o.batched.entries.push({event:a.event,ingest:s,respond:r,rule:l,data:a.data}),o.batched.events.push(a.event),(0,p.isDefined)(a.data)&&o.batched.data.push(a.data);const c=t.config.id||n,d=Y(e,c);return d.inFlightBatch=(d.inFlightBatch??0)+1,o.batchFn(),W}{u.debug("push",{event:a.event.name});const o="string"==typeof a.event.id?a.event.id:"",s=Date.now(),r=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"in",eventId:o,now:s});a.mappingKey&&(r.mappingKey=a.mappingKey),a.event.consent&&(r.consent={...a.event.consent}),(0,p.emitStep)(e,r);try{const r=await(0,p.useHooks)(t.push,"DestinationPush",e.hooks,e.logger)(a.event,d),i=Date.now(),c=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"out",eventId:o,now:i});return c.durationMs=i-s,c.outEvent=r,a.mappingKey&&(c.mappingKey=a.mappingKey),(0,p.emitStep)(e,c),u.debug("push done"),r}catch(t){const r=Date.now(),i=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"error",eventId:o,now:r});throw i.durationMs=r-s,i.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},a.mappingKey&&(i.mappingKey=a.mappingKey),(0,p.emitStep)(e,i),t}}}function ne(e){return{ok:!e?.failed,...e}}function oe(e){const{code:t,config:n={},env:o={},cache:s}=e,{config:r}=b(e,"before"),{config:i}=b({...e,config:r},"next"),a={...t.config,...n,...i};s&&(a.cache=s);const c=re(t.env,o);return{...t,config:a,env:c}}async function se(e,t={}){const n={};for(const[o,s]of Object.entries(t))s.config?.require?.length?e.pending.destinations[o]=s:n[o]=oe(s);return n}function re(e,t){return e||t?t?e&&(0,p.isObject)(e)&&(0,p.isObject)(t)?{...e,...t}:t:e:{}}var ie=require("@walkeros/core"),ae=require("@walkeros/core"),ce=5e3;async function ue(e,t,n){const o=Object.entries(e).map(async([e,o])=>{const s=o.destroy;if(!s)return;const r=o.type||"unknown",i=n.scope(r),a={id:e,config:o.config,env:o.env??{},logger:i};try{await Promise.race([s(a),new Promise((n,o)=>setTimeout(()=>o(new Error(`${t} '${e}' destroy timed out`)),ce))])}catch(n){i.error(`${t} '${e}' destroy failed: ${n}`)}});await Promise.allSettled(o)}async function de(e,t,n){let o,s,r=!1;switch(t){case c.Commands.Config:(0,ae.isObject)(n)&&((0,ie.assign)(e.config,n,{shallow:!1}),s=n,r=!0);break;case c.Commands.Consent:if((0,ae.isObject)(n)){const{update:t}=d(e,n);s=t,r=!0}break;case c.Commands.Custom:(0,ae.isObject)(n)&&(e.custom=(0,ie.assign)(e.custom,n),s=n,r=!0);break;case c.Commands.Destination:(0,ae.isObject)(n)&&"code"in n&&(0,ae.isObject)(n.code)&&(o=await X(e,n));break;case c.Commands.Globals:(0,ae.isObject)(n)&&(e.globals=(0,ie.assign)(e.globals,n),s=n,r=!0);break;case c.Commands.Hook:if((0,ae.isObject)(n)&&(0,ie.isString)(n.name)&&(0,ie.isFunction)(n.fn)){const{name:t,fn:o}=n;e.hooks[t]=o,s=n,r=!0}break;case c.Commands.On:if((0,ae.isObject)(n)&&(0,ie.isString)(n.type)){const{type:t,rules:o}=n;await T(e,t,o)}break;case c.Commands.Ready:r=!0;break;case c.Commands.Run:o=await pe(e,n),r=!0;break;case c.Commands.Session:r=!0;break;case c.Commands.Shutdown:await async function(e){const t=e.logger;await ue(e.sources,"source",t),await ue(e.destinations,"destination",t),await ue(e.transformers,"transformer",t),await ue(e.stores,"store",t)}(e);break;case c.Commands.User:(0,ae.isObject)(n)&&((0,ie.assign)(e.user,n,{shallow:!1}),s=n,r=!0)}return r&&(await H(e,t,void 0,s),o=await Z(e)),o||ne({ok:!0})}function le(e,t){if(!t.name)throw new Error("Event name is required");const[n,o]=t.name.split(" ");if(!n||!o)throw new Error("Event name is invalid");const{timestamp:s=Date.now(),name:r=`${n} ${o}`,data:i={},context:a={},globals:c=e.globals,custom:u={},user:d=e.user,nested:l=[],consent:p=e.consent,id:f=(0,ie.getSpanId)(),trigger:g="",entity:h=n,action:m=o,timing:y=0,source:w={type:"collector",schema:"4"}}=t;return{name:r,data:i,context:a,globals:c,custom:u,user:d,nested:l,consent:p,id:f,trigger:g,entity:h,action:m,timestamp:s,timing:y,source:w}}async function pe(e,t){e.allowed=!0,e.timing=Date.now(),t&&(t.consent&&(e.consent=(0,ie.assign)(e.consent,t.consent)),t.user&&(e.user=(0,ie.assign)(e.user,t.user)),t.globals&&(e.globals=(0,ie.assign)(e.config.globalsStatic||{},t.globals)),t.custom&&(e.custom=(0,ie.assign)(e.custom,t.custom))),Object.values(e.destinations).forEach(e=>{e.queuePush=[]}),e.queue=[],e.round++;return await Z(e)}var fe=require("@walkeros/core");function ge(e,t){const n=(0,fe.useHooks)(async(n,o={})=>await(0,fe.tryCatchAsync)(async()=>{const s=Date.now(),{id:r,ingest:i,respond:a,mapping:c,preChain:u,include:d,exclude:l}=o;let p=a,f=n;const g=d||l?function(e,t,n){let o=e;return t&&(o=Object.fromEntries(Object.entries(o).filter(([e])=>t.includes(e)))),n&&(o=Object.fromEntries(Object.entries(o).filter(([e])=>!n.includes(e)))),o}(e.destinations,d,l):void 0,h=i??(0,fe.createIngest)(r||"unknown");if(c){const t=await(0,fe.processEventMapping)(f,c,e);if(t.ignore)return ne({ok:!0});if(c.consent){if(!(0,fe.getGrantedConsent)(c.consent,e.consent,t.event.consent))return ne({ok:!0})}f=t.event}if(u?.length&&e.transformers&&Object.keys(e.transformers).length>0){const n=await q(e,e.transformers,u,f,h,p,r?`source.${r}.next`:void 0);if(null===n.event)return ne({ok:!0});if(n.stopped)return n.respond&&(p=n.respond),ne({ok:!0});if(n.respond&&(p=n.respond),Array.isArray(n.event)){const o=await Promise.all(n.event.map(async n=>{const o=t(n),s=le(e,o);return Z(e,s,{id:r,ingest:h,respond:p},g)}));if(r){e.status.sources[r]||(e.status.sources[r]={count:0,duration:0});const t=e.status.sources[r];t.count+=n.event.length,t.lastAt=Date.now(),t.duration+=Date.now()-s}return o[0]??ne({ok:!0})}f=n.event}const m=t(f),y=le(e,m),w=await Z(e,y,{id:r,ingest:h,respond:p},g);if(r){e.status.sources[r]||(e.status.sources[r]={count:0,duration:0});const t=e.status.sources[r];t.count++,t.lastAt=Date.now(),t.duration+=Date.now()-s}return w},t=>{if(t instanceof fe.FatalError)throw t;return e.status.failed++,e.logger.error("push failed",{event:n,ingest:o.ingest,error:t}),ne({ok:!1})})(),"Push",e.hooks,e.logger);return async(t,o)=>{const s="string"==typeof t.id?t.id:"",r=Date.now();(0,fe.emitStep)(e,f(e,{stepId:"collector.push",stepType:"collector",phase:"in",eventId:s,now:r}));try{const i=await n(t,o),a=Date.now(),c=f(e,{stepId:"collector.push",stepType:"collector",phase:"out",eventId:s,now:a});return c.durationMs=a-r,c.outEvent=i,(0,fe.emitStep)(e,c),i}catch(t){const n=Date.now(),o=f(e,{stepId:"collector.push",stepType:"collector",phase:"error",eventId:s,now:n});throw o.durationMs=n-r,o.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,fe.emitStep)(e,o),t}}}var he=require("@walkeros/core");var me=require("@walkeros/core"),ye=1e4,we=6e4,ve=.8;function be(e={}){const t=e.maxEntries??ye,n=e.lowWaterMark??ve,o=e.sweepIntervalMs??we,s=Math.floor(t*n),r=new Map,i={hits:0,misses:0,populates:0,writes:0,deletes:0,evictions_entries:0,evictions_ttl:0};let a;o>0&&(a=setInterval(function(){const e=Date.now();let t=0;for(const[n,o]of r)void 0!==o.expires&&o.expires<=e&&(r.delete(n),t++);i.evictions_ttl+=t},o),a&&"function"==typeof a.unref&&a.unref());return{type:"memory",config:{},get(e){const t=r.get(e);if(t)return void 0!==t.expires&&t.expires<=Date.now()?(r.delete(e),i.evictions_ttl++,void i.misses++):(r.delete(e),r.set(e,t),i.hits++,t.value);i.misses++},set(e,n,o){const a=!r.has(e);a||r.delete(e),r.set(e,{value:n,expires:void 0!==o?Date.now()+o:void 0}),i.writes++,a&&i.populates++,r.size>t&&function(){if(r.size<=t)return;const e=r.size-s;let n=0;for(const t of r.keys()){if(n>=e)break;r.delete(t),n++}i.evictions_entries+=n}()},delete(e){r.delete(e)&&i.deletes++},get counters(){return{...i}},destroy(){void 0!==a&&(clearInterval(a),a=void 0),r.clear()}}}var ke=require("@walkeros/core");function Ce(e,t){const{cacheConfig:n,cacheStore:o,namespace:s,logger:r,storeId:i,collector:a}=t,c=(e,t)=>{if(!a)return;const n=f(a,{stepId:`store.${i}`,stepType:"store",phase:"in",eventId:"",now:Date.now()});n.meta={op:"cache",cached:"hit"===t,status:t,key:e},(0,ke.emitStep)(a,n)},u={hits:0,misses:0,populates:0,writes:0,deletes:0,inflight_dedups:0},d=n.rules.map(e=>({match:e.match?(0,ke.compileMatcher)(e.match):()=>!0,ttl:e.ttl})),l=e=>`${s}:${e}`;function p(e,t){const n=void 0===t?{key:e}:{key:e,value:t};return d.find(e=>e.match(n))}const g=new Map;return{type:e.type,config:e.config,setup:e.setup,get counters(){return{...u}},async get(t){const n=l(t),s=await o.get(n);if(void 0!==s)return u.hits++,c(t,"hit"),s;const r=g.get(n);if(r)return u.inflight_dedups++,c(t,"hit"),r;u.misses++,c(t,"miss");const i=(async()=>{try{const s=await e.get(t);if(void 0===s)return;const r=p(t,s);if(r)try{await o.set(n,s,1e3*r.ttl),u.populates++}catch(e){h("set",t,e)}return s}finally{g.delete(n)}})();return g.set(n,i),i},async set(t,n,s){u.writes++,await e.set(t,n,s);const r=p(t,n);if(r)try{await o.set(l(t),n,1e3*r.ttl)}catch(e){h("set",t,e)}},async delete(t){u.deletes++,await e.delete(t);try{await o.delete(l(t))}catch(e){h("delete",t,e)}}};function h(e,t,n){const o=`store-cache(${i}): cache ${e} failed for "${t}"; backing succeeded, continuing`;r?r.warn(o,{error:n}):console.warn(o,n)}}function Ie(e,t,n){const o=`store.${n}`,s=(0,me.useHooks)(t.get,"StoreGet",e.hooks,e.logger),r=(0,me.useHooks)(t.set,"StoreSet",e.hooks,e.logger),i=(0,me.useHooks)(t.delete,"StoreDelete",e.hooks,e.logger);t.get=async t=>{const n=Date.now(),r=f(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});r.meta={op:"get",key:t},(0,me.emitStep)(e,r);try{const r=await s(t),i=Date.now(),a=f(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:i});return a.durationMs=i-n,a.meta={op:"get",key:t},(0,me.emitStep)(e,a),r}catch(s){const r=Date.now(),i=f(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:r});throw i.durationMs=r-n,i.meta={op:"get",key:t},i.error=s instanceof Error?{name:s.name,message:s.message}:{message:String(s)},(0,me.emitStep)(e,i),s}},t.set=async(t,n,s)=>{const i=Date.now(),a=f(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:i});a.meta={op:"set",key:t},(0,me.emitStep)(e,a);try{await r(t,n,s);const a=Date.now(),c=f(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:a});c.durationMs=a-i,c.meta={op:"set",key:t},(0,me.emitStep)(e,c)}catch(n){const s=Date.now(),r=f(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:s});throw r.durationMs=s-i,r.meta={op:"set",key:t},r.error=n instanceof Error?{name:n.name,message:n.message}:{message:String(n)},(0,me.emitStep)(e,r),n}},t.delete=async t=>{const n=Date.now(),s=f(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});s.meta={op:"delete",key:t},(0,me.emitStep)(e,s);try{await i(t);const s=Date.now(),r=f(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:s});r.durationMs=s-n,r.meta={op:"delete",key:t},(0,me.emitStep)(e,r)}catch(s){const r=Date.now(),i=f(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:r});throw i.durationMs=r-n,i.meta={op:"delete",key:t},i.error=s instanceof Error?{name:s.name,message:s.message}:{message:String(s)},(0,me.emitStep)(e,i),s}}}async function Se(e,t={}){const n={};for(const[o,s]of Object.entries(t)){const{code:t,config:r={},env:i={}}=s,a=e.logger.scope("store").scope(o),c={collector:e,logger:a,id:o,config:r,env:i},u=await t(c);n[o]=u}const o=t,s=function(e){const t={};for(const n of Object.keys(e))t[n]="WHITE";const n=[],o=[];function s(r){const i=t[r];if("BLACK"===i)return;if("GRAY"===i){const e=o.indexOf(r),t=o.slice(-1===e?0:e).concat(r).join(" -> ");throw new Error(`Cycle in cache.store chain: ${t}`)}t[r]="GRAY",o.push(r);const a=e[r].cache?.store;if(void 0!==a){if(!(a in e))throw new Error(`Store "${r}" cache.store references "${a}", which is not declared in flow.stores`);s(a)}o.pop(),t[r]="BLACK",n.push(r)}for(const n of Object.keys(e))"WHITE"===t[n]&&s(n);return n}(o);for(const t of s){const s=o[t].cache;if(!s)continue;let r,i;void 0!==s.store?(r=n[s.store],i=s.store):(n.__cache||(n.__cache=be()),r=n.__cache,i="__cache");const a=s.namespace??t;e.logger.scope("store-cache").scope(t).info(`store "${t}" caches with namespace "${a}:" via ${i}`),n[t]=Ce(n[t],{storeId:t,cacheConfig:s,cacheStore:r,namespace:a,logger:e.logger.scope("store-cache").scope(t),collector:e})}for(const[t,o]of Object.entries(n))"__cache"!==t&&Ie(e,o,t);return n}async function qe(e){const t=(0,l.assign)({globalsStatic:{},sessionStatic:{},run:!0,queueMax:1e3},e,{merge:!1,extend:!1}),n={level:e.logger?.level,handler:e.logger?.handler},o=(0,l.createLogger)(n),s={...t.globalsStatic,...e.globals},r={allowed:!1,config:t,consent:e.consent||{},custom:e.custom||{},destinations:{},transformers:{},stores:{},globals:s,hooks:e.hooks||{},observers:new Set,logger:o,on:{},queue:[],round:0,session:void 0,status:{startedAt:Date.now(),in:0,out:0,failed:0,sources:{},destinations:{},dropped:{}},timing:Date.now(),user:e.user||{},sources:{},pending:{destinations:{}},push:void 0,command:void 0};r.push=ge(r,e=>({timing:Math.round((Date.now()-r.timing)/10)/100,source:{type:"collector",schema:"4",version:"4.1.1"},...e})),r.command=function(e,t){return(0,he.useHooks)(async(n,o,s)=>await(0,he.tryCatchAsync)(async()=>await t(e,n,o,s),t=>{if(t instanceof he.FatalError)throw t;return e.status.failed++,e.logger.error("command failed",{command:n,data:o,error:t}),ne({ok:!1})})(),"Command",e.hooks,e.logger)}(r,de);const i=e.stores||{};return r.stores=await Se(r,i),function(e,t,n){const o=new Map;for(const[n,s]of Object.entries(e))t[n]&&o.set(s,t[n]);if(0!==o.size)for(const e of[n.transformers,n.destinations,n.sources])if(e)for(const t of Object.values(e))s(t.env);function s(e){if(e)for(const[t,n]of Object.entries(e))if("object"==typeof n&&null!==n){const s=o.get(n);s&&(e[t]=s)}}}(i,r.stores,e),r.stores.__cache||(r.stores.__cache=be()),r.destinations=await se(r,e.destinations||{}),r.transformers=await async function(e,t={}){const n={};for(const[o,s]of Object.entries(t)){const{code:t,env:r={}}=s,i=(0,y.validateStepEntry)(s,"Transformer");if(!i.ok){e.logger.warn(`Transformer ${o} invalid (${i.code}): ${i.reason}. Skipping.`);continue}const{config:a}=b(s,"before"),{config:c}=b({...s,config:a},"next"),u=Object.keys(r).length>0?{...c,env:r}:c,{cache:d}=s,l=d?{...u,cache:d}:u,p=e.logger.scope("transformer").scope(o),f={collector:e,logger:p,id:o,ingest:(0,y.createIngest)(o),config:l,env:r},g=t??(e=>{const t=s.mapping;if(t){const n=[];if(void 0!==t.data&&n.push("data"),t.mapping)for(const[e,o]of Object.entries(t.mapping))if("object"==typeof o&&null!==o)for(const[t,s]of Object.entries(o)){if("object"!=typeof s||null===s)continue;const o=s;void 0!==o.data&&n.push(`mapping[${e}][${t}].data`),void 0!==o.silent&&n.push(`mapping[${e}][${t}].silent`)}return n.length>0&&e.collector.logger.warn(`Transformer ${o}: \`${n.join(", ")}\` ignored at transformer position (only event-mutating fields apply).`),{type:"pass",config:e.config,push:async n=>{const o=await(0,y.processEventMapping)(n,t,e.collector);return!o.ignore&&{event:o.event}}}}return{type:"pass",config:e.config,push:e=>({event:e})}}),h=await g(f);void 0!==s.before&&void 0===h.config?.before&&(h.config={...h.config??{},before:s.before}),void 0!==s.next&&void 0===h.config?.next&&(h.config={...h.config??{},next:s.next}),n[o]=h}return n}(r,e.transformers||{}),r}async function Oe(e){e=e||{};const t=await qe(e),n=(o=t,{type:"elb",config:{},push:async(e,t,n,s,r)=>{if("string"==typeof e&&e.startsWith("walker ")){const n=e.replace("walker ","");return o.command(n,t)}let i;if("string"==typeof e)i={name:e},t&&"object"==typeof t&&!Array.isArray(t)&&(i.data=t);else{if(!e||"object"!=typeof e)return ne({ok:!1});i=e,t&&"object"==typeof t&&!Array.isArray(t)&&(i.data={...i.data||{},...t})}return n&&"object"==typeof n&&(i.context=n),s&&Array.isArray(s)&&(i.nested=s),r&&"object"==typeof r&&(i.custom=r),o.push(i)}});var o;t.sources.elb=n,await E(t,e.sources||{});const{consent:s,user:r,globals:i,custom:a}=e;s&&await t.command("consent",s),r&&await t.command("user",r),i&&Object.assign(t.globals,i),a&&Object.assign(t.custom,a),t.config.run&&await t.command("run");let c=n.push;const u=Object.values(t.sources).filter(e=>"elb"!==e.type),d=u.find(e=>e.config.primary);return d?c=d.push:u.length>0&&(c=u[0].push),{collector:t,elb:c}}function xe(e){if(null===e||"object"!=typeof e)return e;if(Array.isArray(e))return e.map(xe);const t={};for(const[n,o]of Object.entries(e))t[n]="function"==typeof o?o:xe(o);return t}function je(e){const t=[],{simulation:n,...o}=e,s=xe(o);for(const e of n){const n=e.startsWith("call:")?e.slice(5):e,o=n.split(".");let r=s;for(let e=0;e<o.length-1&&null!=r[o[e]];e++)r=r[o[e]];const i=o[o.length-1];if(null==r||!(i in r))continue;const a=r[i];"function"==typeof a&&(r[i]=function(...e){return t.push({fn:n,args:e,ts:Date.now()}),a.apply(this,e)})}return{wrappedEnv:s,calls:t}}//# sourceMappingURL=index.js.map
1
+ "use strict";var e,t=Object.defineProperty,n=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,r={};((e,n)=>{for(var o in n)t(e,o,{get:n[o],enumerable:!0})})(r,{Code:()=>a,Commands:()=>i,Const:()=>c,addDestination:()=>X,callDestinationOn:()=>_,commonHandleCommand:()=>de,createEvent:()=>le,createPush:()=>ge,createPushResult:()=>ne,destinationInit:()=>ee,destinationPush:()=>te,extractTransformerNextMap:()=>v,flushSourceQueueOn:()=>j,getCacheStore:()=>w,initDestinations:()=>se,initSource:()=>D,initSources:()=>E,isSourceStarted:()=>A,mergeEnvironments:()=>re,on:()=>T,onApply:()=>H,processConsent:()=>d,pushToDestinations:()=>Z,registerDestination:()=>oe,runCollector:()=>pe,runTransformerChain:()=>q,startFlow:()=>xe,transformerInit:()=>C,transformerPush:()=>I,walkChain:()=>k,wrapEnv:()=>je}),module.exports=(e=r,((e,r,a,i)=>{if(r&&"object"==typeof r||"function"==typeof r)for(let c of o(r))s.call(e,c)||c===a||t(e,c,{get:()=>r[c],enumerable:!(i=n(r,c))||i.enumerable});return e})(t({},"__esModule",{value:!0}),e));var a={},i={Action:"action",Actions:"actions",Config:"config",Consent:"consent",Context:"context",Custom:"custom",Destination:"destination",Elb:"elb",Globals:"globals",Hook:"hook",Init:"init",Link:"link",On:"on",Prefix:"data-elb",Ready:"ready",Run:"run",Session:"session",Shutdown:"shutdown",User:"user",Walker:"walker"},c={Commands:i,Utils:{Storage:{Cookie:"cookie",Local:"local",Session:"session"}}},u=require("@walkeros/core");function d(e,t){const n={};return Object.entries(t).forEach(([e,t])=>{n[e]=!!t}),e.consent=(0,u.assign)(e.consent,n),{update:n}}var l=require("@walkeros/core"),p=require("@walkeros/core");require("@walkeros/core");function f(e,t){const n=e.status.startedAt;return{flowId:"default",stepId:t.stepId,stepType:t.stepType,phase:t.phase,eventId:t.eventId,timestamp:new Date(t.now).toISOString(),elapsedMs:t.now-n}}var g=require("@walkeros/core"),h=require("@walkeros/core");var m=require("@walkeros/core"),y=require("@walkeros/core");function w(e,t){return e.storeId&&t.stores[e.storeId]?t.stores[e.storeId]:t.stores.__cache}function v(e){const t={};for(const[n,o]of Object.entries(e)){const e=o.config?.next;"string"==typeof e||Array.isArray(e)&&e.every(e=>"string"==typeof e)?t[n]={next:e}:t[n]={}}return t}function b(e,t){const n=e.config||{},o=e[t];return void 0!==o?{config:{...n,[t]:o},chainValue:o}:{config:n,chainValue:void 0}}function k(e,t={}){if(!e)return[];if(Array.isArray(e))return e;const n=[],o=new Set;let s=e;for(;s&&t[s]&&!o.has(s);){o.add(s),n.push(s);const e=t[s].next;if(Array.isArray(e)){n.push(...e);break}s=e}return n}async function C(e,t,n){if(t.init&&!t.config.init){const o=t.type||"unknown",s=e.logger.scope(`transformer:${o}`),r={collector:e,logger:s,id:n,ingest:(0,y.createIngest)(n),config:t.config,env:x(t.config.env)};s.debug("init");const a=await(0,y.useHooks)(t.init,"TransformerInit",e.hooks,e.logger)(r);if(!1===a)return!1;t.config={...a||t.config,env:a?.env||t.config.env,init:!0},s.debug("init done")}return!0}async function I(e,t,n,o,s,r){const a=t.type||"unknown",i=e.logger.scope(`transformer:${a}`),c={collector:e,logger:i,id:n,ingest:s,config:t.config,env:{...x(t.config.env),...r?{respond:r}:{}}};i.debug("push",{event:o.name});const u="string"==typeof o.id?o.id:"",d=Date.now(),l=f(e,{stepId:(0,y.stepId)("transformer",n),stepType:"transformer",phase:"in",eventId:u,now:d});(0,y.emitStep)(e,l);try{const s=await(0,y.useHooks)(t.push,"TransformerPush",e.hooks,e.logger)(o,c),r=Date.now(),a=f(e,{stepId:(0,y.stepId)("transformer",n),stepType:"transformer",phase:"out",eventId:u,now:r});return a.durationMs=r-d,a.outEvent=s,(0,y.emitStep)(e,a),i.debug("push done"),s}catch(t){const o=Date.now(),s=f(e,{stepId:(0,y.stepId)("transformer",n),stepType:"transformer",phase:"error",eventId:u,now:o});throw s.durationMs=o-d,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,y.emitStep)(e,s),t}}function S(e,t){return e?{...e,_meta:{...e._meta,path:[...e._meta.path]}}:(0,y.createIngest)(t)}async function q(e,t,n,o,s,r,a){s||(s=(0,y.createIngest)(n[0]??"chain")),a&&s._meta&&(s._meta.chainPath=a);let i=o,c=r;for(const o of n){const r=t[o];if(!r){e.logger.warn(`Transformer not found: ${o}`);continue}if(s&&s._meta&&s._meta.path.length>256)return e.logger.error(`Max path length exceeded at ${o}`),{event:null,respond:c};s&&s._meta&&(s._meta.hops++,s._meta.path.push(o));if(!await(0,y.tryCatchAsync)(C,t=>{if(t instanceof y.FatalError)throw t;return e.status.failed++,e.logger.scope(`transformer:${r.type||"unknown"}`).error("transformer init failed",{transformer:o,error:t}),!1})(e,r,o))return{event:null,respond:c};if(a&&void 0!==r.config?.chainMocks?.[a]){const t=r.config.chainMocks[a];e.logger.scope(`transformer:${r.type||"unknown"}`).debug("chainMock",{chain:a}),i=t;continue}if(void 0!==r.config?.mock){e.logger.scope(`transformer:${r.type||"unknown"}`).debug("mock"),i=r.config.mock;continue}if(r.config?.disabled)continue;const u=r.config?.cache,d=u?(0,y.compileCache)(u):void 0,l=d?w(d,e):void 0;let p;if(d&&l){const e=(0,y.buildCacheContext)(s,i),t=await(0,y.checkCache)(d,l,e);if("HIT"===t?.status&&t.value){if(i=t.value,d.stop)return{event:i,respond:c,stopped:!0};continue}"MISS"===t?.status&&(p={key:t.key,ttl:t.rule.ttl})}const f=r.config.before;if(f){const n=(0,y.getNextSteps)(f,(0,y.buildCacheContext)(s,i));if(1===n.length){const o=k(n[0],v(t));if(o.length>0){const n=await q(e,t,o,i,s,c,a);if(null===n.event)return{event:null,respond:n.respond??c};if(n.stopped)return{event:Array.isArray(n.event)?n.event[0]:n.event,respond:n.respond??c,stopped:!0};n.respond&&(c=n.respond),i=Array.isArray(n.event)?n.event[0]:n.event}}else n.length>1&&await Promise.all(n.map(n=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(n,v(t)),i,S(s,n),void 0,a)))}const g=await(0,y.tryCatchAsync)(I,t=>(e.logger.scope(`transformer:${r.type||"unknown"}`).error("Push failed",{error:t}),!1))(e,r,o,i,s,c);if(!1===g)return{event:null,respond:c};if(Array.isArray(g)){const r=n.slice(n.indexOf(o)+1),u=await Promise.all(g.map(async n=>{const o=n.event||i,u=S(s,"unknown");if(n.next){const s=(0,y.getNextSteps)(n.next,(0,y.buildCacheContext)(u,o));if(0===s.length)return{event:o,respond:c};if(1===s.length){const n=k(s[0],v(t));return n.length>0?q(e,t,n,o,u,c,a):{event:o,respond:c}}return(await Promise.all(s.map(n=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(n,v(t)),o,S(u,n),void 0,a)))).map(e=>({event:e.event,respond:void 0}))}return r.length>0?q(e,t,r,o,u,c,a):{event:o,respond:c}}));let d=c;const l=[];for(const e of u.flat())if(null!==e)if(e&&"object"==typeof e&&"event"in e){const t=e;if(t.respond&&(d=t.respond),null===t.event)continue;Array.isArray(t.event)?l.push(...t.event):l.push(t.event)}else l.push(e);return 0===l.length?{event:null,respond:d}:1===l.length?{event:l[0],respond:d}:{event:l,respond:d}}if(g&&"object"==typeof g){const{event:n,respond:o,next:r}=g;if(o&&(c=o),void 0!==r){const o=(0,y.getNextSteps)(r,(0,y.buildCacheContext)(s,i));if(0===o.length){n&&(i=n);continue}if(1===o.length){const u=k(o[0],v(t));return u.length>0?q(e,t,u,n||i,s,c,a):(e.logger.warn(`Branch target not found: ${JSON.stringify(r)}`),{event:null,respond:c})}return await Promise.all(o.map(o=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${o} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(o,v(t)),n||i,S(s,o),void 0,a))),{event:null,respond:void 0}}n&&(i=n)}p&&l&&(0,y.storeCache)(l,p.key,i,p.ttl);const h=r.config.next,m="string"==typeof h||Array.isArray(h)&&h.every(e=>"string"==typeof e),b=void 0!==h&&!m;if((!g||"object"==typeof g&&!g.next)&&b){const n=(0,y.getNextSteps)(r.config.next,(0,y.buildCacheContext)(s,i));if(1===n.length){const o=k(n[0],v(t));return o.length>0?q(e,t,o,i,s,c,a):{event:i,respond:c}}return n.length>1?(await Promise.all(n.map(n=>(0,y.tryCatchAsync)(q,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,k(n,v(t)),i,S(s,n),void 0,a))),{event:null,respond:void 0}):{event:i,respond:c}}}return{event:i,respond:c}}function x(e){return e&&(0,y.isObject)(e)?e:{}}function O(e){return"string"==typeof e||!(!Array.isArray(e)||!e.every(e=>"string"==typeof e))}async function j(e,t,n){if(!t.on||!t.queueOn?.length)return;const o=t.queueOn;t.queueOn=[];const s=n||t.config?.id||"unknown";for(const{type:n,data:r}of o)await(0,m.tryCatchAsync)(t.on,t=>{if(t instanceof m.FatalError)throw t;e.status.failed++,e.logger.scope("source").error("source on flush failed",{sourceId:s,type:n,error:t})})(n,r)}function A(e){return Boolean(e.config.init)&&!e.config.require?.length}async function D(e,t,n){const{code:o,config:s={},env:r={},primary:a,next:i,before:c,cache:u}=n,d=u,l=d?(0,m.compileCache)({...d,stop:d.stop??!0}):void 0,p=O(i)?k(i,v(e.transformers)):void 0,f=O(c)?k(c,v(e.transformers)):void 0,g=r.push,h=g??e.push,y=Boolean(g),b=async(n,o,r)=>{let a;const u=f??(void 0!==c?(()=>{const t=(0,m.getNextSteps)(c,(0,m.buildCacheContext)(r.ingest));if(0===t.length)return[];return k(1===t.length?t[0]:t,v(e.transformers))})():[]);let d=[n];if(u.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const o=await q(e,e.transformers,u,n,r.ingest,r.respond,`source.${t}.before`);if(null===o.event)return{ok:!0};if(o.stopped)return o.respond&&(r.respond=o.respond),{ok:!0};o.respond&&(r.respond=o.respond),d=Array.isArray(o.event)?o.event:[o.event]}if(l){const t=w(l,e);if(t){const n=(0,m.buildCacheContext)(r.ingest),o=await(0,m.checkCache)(l,t,n);if(o){if("HIT"===o.status&&void 0!==o.value&&l.stop){let t=o.value;return o.rule.update&&(t=await(0,m.applyUpdate)(t,o.rule.update,{...n,cache:{status:"HIT"}},e)),r.respond?.(t),{ok:!0}}if("MISS"===o.status&&l.stop&&r.respond){const s=r.respond,i=o.rule.update,c={...n,cache:{status:"MISS"}},u=o.key,d=o.rule.ttl,l=n=>{(0,m.storeCache)(t,u,n,d),i?a=(async()=>{const t=await(0,m.applyUpdate)(n,i,c,e);s(t)})():s(n)};r.respond=l}"MISS"!==o.status||l.stop||(0,m.storeCache)(t,o.key,!0,o.rule.ttl)}}}const g=p?{kind:"single",preChain:p}:void 0!==i?(()=>{const t=(0,m.getNextSteps)(i,(0,m.buildCacheContext)(r.ingest));return 0===t.length?{kind:"single",preChain:[]}:1===t.length?{kind:"single",preChain:k(t[0],v(e.transformers))}:{kind:"many",branches:t.map(t=>k(t,v(e.transformers)))}})():{kind:"single",preChain:[]};let b={ok:!0};for(const n of d)"many"===g.kind?(await Promise.all(g.branches.map((a,i)=>(0,m.tryCatchAsync)(async()=>y?h(n):h(n,{...o,id:t,ingest:S(r.ingest,`${t}.${i}`),respond:void 0,mapping:s,preChain:a}),t=>(e.logger.scope("source:many").error(`many branch ${i} failed`,{error:t}),{ok:!0}))())),b={ok:!0}):b=y?await h(n):await h(n,{...o,id:t,ingest:r.ingest,respond:r.respond,mapping:s,preChain:g.preChain});return a&&await a,b},C=async n=>{const o=(0,m.createIngest)(t);if(!s.ingest||void 0===n)return o;const r=await(0,m.getMappingValue)(n,s.ingest,{collector:e});return{...o,...r,_meta:o._meta}},I=e.logger.scope("source").scope(t),x={command:e.command,sources:e.sources,elb:e.sources.elb.push,logger:I,...r,push:async(e,n={})=>{const o={ingest:(0,m.createIngest)(t),respond:void 0};return b(e,n,o)}},j={collector:e,logger:I,id:t,config:s,env:x,withScope:async(e,t,n)=>{const o={ingest:await C(e),respond:t};return n({...x,push:(e,t={})=>b(e,t,o),ingest:o.ingest,respond:o.respond})}},A=await(0,m.tryCatchAsync)(o,n=>{if(n instanceof m.FatalError)throw n;e.status.failed++,e.logger.scope("source").error("source factory failed",{sourceId:t,error:n})})(j);if(!A)return;const D=A.type||"unknown",E=e.logger.scope(D).scope(t);return x.logger=E,a&&(A.config={...A.config,primary:a}),A}async function E(e,t={}){const n={};for(const[o,s]of Object.entries(t)){const t=await D(e,o,s);if(!t)continue;const r=s.config?.require;t.config={...t.config,init:!1,...r?{require:[...r]}:{}},n[o]=t}Object.assign(e.sources,n);for(const t of Object.keys(n)){const n=e.sources[t];let o=!1;n.init&&await(0,m.tryCatchAsync)(n.init.bind(n),n=>{if(n instanceof m.FatalError)throw n;o=!0,e.status.failed++,e.logger.scope("source").error("source init failed",{sourceId:t,error:n})})(),o||(n.config.init=!0,A(n)&&await j(e,n,t))}return n}function $(e,t,n,o){if(n instanceof g.FatalError)throw n;e.logger.scope("on").error("on callback failed",{kind:t,...o,error:n})}function M(e,t){return{collector:e,logger:e.logger.scope("on").scope(String(t))}}async function T(e,t,n){const o=e.on,s=o[t]||[],r=(0,g.isArray)(n)?n:[n];r.forEach(e=>{s.push(e)}),o[t]=s,P(e,t,r)}function _(e,t,n,o,s){if(!t.on)return;const r=t.type||"unknown",a=e.logger.scope(r).scope("on").scope(o),i={collector:e,logger:a,id:n,config:t.config,data:s,env:re(t.env,t.config.env)};(0,h.tryCatch)(t.on,t=>$(e,"destination",t,{destId:n,type:o}))(o,i)}function P(e,t,n,o){let s;switch(t){case c.Commands.Consent:s=o||e.consent;break;case c.Commands.Session:s=e.session;break;case c.Commands.User:s=o||e.user;break;case c.Commands.Custom:s=o||e.custom;break;case c.Commands.Globals:s=o||e.globals;break;case c.Commands.Config:s=o||e.config;break;case c.Commands.Ready:case c.Commands.Run:default:s=void 0}if(n.length)switch(t){case c.Commands.Consent:!function(e,t,n){const o=n||e.consent,s=M(e,c.Commands.Consent);t.forEach(t=>{Object.keys(o).filter(e=>e in t).forEach(n=>{(0,h.tryCatch)(t[n],t=>$(e,"consent",t,{key:n}))(o,s)})})}(e,n,o);break;case c.Commands.Ready:!function(e,t){if(!e.allowed)return;const n=M(e,c.Commands.Ready);t.forEach(t=>{(0,h.tryCatch)(t,t=>$(e,"ready",t))(void 0,n)})}(e,n);break;case c.Commands.Run:!function(e,t){if(!e.allowed)return;const n=M(e,c.Commands.Run);t.forEach(t=>{(0,h.tryCatch)(t,t=>$(e,"run",t))(void 0,n)})}(e,n);break;case c.Commands.Session:!function(e,t){if(!e.session)return;const n=M(e,c.Commands.Session);t.forEach(t=>{(0,h.tryCatch)(t,t=>$(e,"session",t))(e.session,n)})}(e,n);break;default:{const o=M(e,t);n.forEach(n=>{"function"==typeof n&&(0,h.tryCatch)(n,n=>$(e,"generic",n,{type:t}))(s,o)});break}}}async function H(e,t,n,o){let s,r=n||[];switch(n||(r=e.on[t]||[]),t){case c.Commands.Consent:s=o||e.consent;break;case c.Commands.Session:s=e.session;break;case c.Commands.User:s=o||e.user;break;case c.Commands.Custom:s=o||e.custom;break;case c.Commands.Globals:s=o||e.globals;break;case c.Commands.Config:s=o||e.config;break;case c.Commands.Ready:case c.Commands.Run:default:s=void 0}let a=!1;for(const[n,o]of Object.entries(e.sources)){if(o.config.require?.length){const e=o.config.require.indexOf(t);-1!==e&&o.config.require.splice(e,1)}if(o.on)if(A(o)){!1===await(0,h.tryCatchAsync)(o.on,o=>$(e,"source",o,{sourceId:n,type:t}))(t,s)&&(a=!0)}else o.queueOn=o.queueOn||[],o.queueOn.push({type:t,data:s})}Object.entries(e.destinations).forEach(([n,o])=>{if(o.on){if(!o.config.init)return o.queueOn=o.queueOn||[],void o.queueOn.push({type:t,data:s});_(e,o,n,t,s)}});for(const[t,n]of Object.entries(e.sources))A(n)&&n.queueOn?.length&&await j(e,n,t);return Object.keys(e.pending.destinations).length>0&&await async function(e,t){for(const[n,o]of Object.entries(e.pending.destinations)){if(!e.pending.destinations[n]||e.destinations[n])continue;const s=o.config?.require;if(!s)continue;const r=s.indexOf(t);if(-1===r)continue;if(s.splice(r,1),s.length>0)continue;delete e.pending.destinations[n];const a=oe(o);!1!==a.config.queue&&(a.queuePush=[...e.queue]),e.destinations[n]=a}}(e,t),P(e,t,r,o),!a}function z(e,t,n,o){if(!Number.isFinite(n.max)||n.max<=0)throw new Error(`pushBounded: max must be > 0 (got ${n.max})`);if("dropNewest"===(n.onOverflow??"dropOldest"))return e.length>=n.max?(o&&o([t]),{appended:!1,dropped:1}):(e.push(t),{appended:!0,dropped:0});const s=[];for(;e.length>=n.max;)s.push(e.shift());return e.push(t),s.length>0&&o&&o(s),{appended:!0,dropped:s.length}}var F=new WeakMap;function R(e,t,n,o){F.get(e)||(F.set(e,!0),t.warn(n,o))}function B(e){F.delete(e)}var K=1e3,N=100,G=1e3,U=3e4,W=Object.freeze({batched:!0});function L(e){return e===W}function V(e){return void 0===e?{}:"number"==typeof e?{wait:e}:{wait:e.wait,size:e.size,age:e.age}}function Y(e,t){return e.status.destinations[t]||(e.status.destinations[t]={count:0,failed:0,duration:0,queuePushSize:0,dlqSize:0}),e.status.destinations[t]}function J(e,t,n,o){e.dropped[t]||(e.dropped[t]={});const s=e.dropped[t];return s[n]=(s[n]??0)+o,s[n]}function Q(e,t,n){if(!e)return[];if(Array.isArray(e)&&e.every(e=>"string"==typeof e))return k(e,t);if("string"==typeof e)return k(e,t);const o=(0,p.getNextSteps)(e,(0,p.buildCacheContext)(n));return 0===o.length?[]:1===o.length?k(o[0],t):k(o,t)}async function X(e,t){const{code:n,config:o={},env:s={},before:r,next:a,cache:i}=t;if(!(0,p.isFunction)(n.push))return ne({ok:!1,failed:{invalid:{type:"invalid",error:"Destination code must have a push method"}}});const c=o||{init:!1};let u=r?{...c,before:r}:{...c};a&&(u={...u,next:a}),i&&(u={...u,cache:i});const d={...n,config:u,env:re(n.env,s)};let l=d.config.id;if(!l)do{l=(0,p.getId)(5,"abcdefghijklmnopqrstuvwxyz")}while(e.destinations[l]);return e.destinations[l]=d,!1!==d.config.queue&&(d.queuePush=[...e.queue]),Z(e,void 0,{},{[l]:d})}async function Z(e,t,n={},o){const{allowed:s,consent:r,globals:a,user:i}=e;if(!s)return ne({ok:!1});if(t){const n=e.config.queueMax;if(void 0===n)throw new Error("Collector.Config.queueMax is undefined; defaults must be seeded by collector()");const o=z(e.queue,t,{max:n});if(o.dropped>0){const t=J(e.status,(0,p.stepId)("collector"),"queue",o.dropped);R(e.queue,e.logger,"collector.queue overflow; oldest events dropped",{buffer:"queue",cap:n,droppedCount:t})}else e.queue.length<n&&B(e.queue);e.status.in++}o||(o=e.destinations);const c=e.transformers?v(e.transformers):{},u=await Promise.all(Object.entries(o||{}).map(async([o,s])=>{if(s.config.disabled)return{id:o,destination:s,skipped:!0};let u=(s.queuePush||[]).map(e=>({...e,consent:r}));s.queuePush=[],t&&u.push((0,p.clone)(t));const d=n.ingest?{...n.ingest,_meta:{...n.ingest._meta,path:[...n.ingest._meta.path]}}:(0,p.createIngest)("unknown");if(!u.length&&!s.queueOn?.length)return{id:o,destination:s,skipped:!0};if(!u.length&&s.queueOn?.length){let t=!1;try{t=await ee(e,s,o)}catch(t){e.status.failed++;const n=s.type||"unknown";e.logger.scope(n).error("destination init failed",{error:t instanceof Error?t.message:String(t)})}return{id:o,destination:s,skipped:!t}}const l=[],g=u.filter(t=>{const n=(0,p.getGrantedConsent)(s.config.consent,r,t.consent);if(n)return t.consent=n,l.push(t),!1;const a=f(e,{stepId:(0,p.stepId)("destination",o),stepType:"destination",phase:"skip",eventId:"string"==typeof t.id?t.id:"",now:Date.now()});return a.skipReason="consent",r&&(a.consent={...r}),s.config.consent&&(a.meta={required:{...s.config.consent}}),(0,p.emitStep)(e,a),!0});if(g.length>0){const t=s.queuePush,n=s.config.id||o,r={max:s.config.queueMax??K};let a=0;for(const e of g){a+=z(t,e,r).dropped}if(a>0){Y(e,n);const o=J(e.status,(0,p.stepId)("destination",n),"queue",a);R(t,e.logger.scope(s.type||"unknown"),"destination.queuePush overflow; oldest events dropped",{buffer:"queuePush",destination:n,cap:r.max,droppedCount:o})}else t.length<r.max&&B(t)}if(!l.length)return{id:o,destination:s,queue:u};let h,m,y=!1;try{y=await ee(e,s,o)}catch(t){e.status.failed++;const n=s.type||"unknown";e.logger.scope(n).error("destination init failed",{error:t instanceof Error?t.message:String(t)})}if(!y)return{id:o,destination:s,queue:u};s.dlq||(s.dlq=[]);const v=Q(s.config.before,c,d),b=s.config.next,k=s.config?.cache,C=k?(0,p.compileCache)(k):void 0,I=C?w(C,e):void 0;let S=0,x=0;return await Promise.all(l.map(async t=>{let r;if(t.globals=(0,p.assign)(a,t.globals),t.user=(0,p.assign)(i,t.user),C?.stop&&I){const e=(0,p.buildCacheContext)(d,t),n=await(0,p.checkCache)(C,I,e);if("HIT"===n?.status)return t;"MISS"===n?.status&&(r={key:n.key,ttl:n.rule.ttl})}let u=t,l=n.respond;if(v.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const s=await q(e,e.transformers,v,t,d,n.respond,`destination.${o}.before`);if(null===s.event)return t;s.respond&&(l=s.respond),u=Array.isArray(s.event)?s.event[0]:s.event}if(C&&!C.stop&&I){const e=(0,p.buildCacheContext)(d,u),n=await(0,p.checkCache)(C,I,e);if("HIT"===n?.status)return t;"MISS"===n?.status&&(r={key:n.key,ttl:n.rule.ttl})}const f=Date.now();let g=!1;const y=await(0,p.tryCatchAsync)(te,t=>{const n=s.type||"unknown";e.logger.scope(n).error("Push failed",{error:t,event:u.name}),h=t,g=!0;const r=s.dlq,a=s.config.id||o,i={max:s.config.dlqMax??N},c=z(r,[u,t],i);if(c.dropped>0){Y(e,a);const t=J(e.status,(0,p.stepId)("destination",a),"dlq",c.dropped);R(r,e.logger.scope(s.type||"unknown"),"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:a,cap:i.max,droppedCount:t})}else r.length<i.max&&B(r)})(e,s,o,u,d,l);if(S+=Date.now()-f,r&&I&&void 0===s.config.mock&&(0,p.storeCache)(I,r.key,y??!0,r.ttl),void 0===y||L(y)||(m=y),L(y)&&x++,!g&&b){void 0!==y&&(d._response=y);const t=Q(b,c,d);if(t.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const n=await q(e,e.transformers,t,u,d,l,`destination.${o}.next`);n.respond&&(l=n.respond)}}return t})),{id:o,destination:s,error:h,response:m,totalDuration:S,batchedCount:x,allowedCount:l.length}})),d={},l={},g={};for(const t of u){if(t.skipped)continue;const n=t.destination,o={type:n.type||"unknown",data:t.response};Y(e,t.id);const s=e.status.destinations[t.id],r=Date.now();if(s.queuePushSize=n.queuePush?.length??0,s.dlqSize=n.dlq?.length??0,t.error)o.error=t.error,g[t.id]=o,s.failed++,s.lastAt=r,s.duration+=t.totalDuration||0,e.status.failed++;else if(t.queue&&t.queue.length)l[t.id]=o;else{const n=t.batchedCount??0,a=t.allowedCount??0;(Math.max(0,a-n)>0||0===a)&&(d[t.id]=o,s.count++,s.lastAt=r,s.duration+=t.totalDuration||0,e.status.out++)}}return ne({event:t,...Object.keys(d).length&&{done:d},...Object.keys(l).length&&{queued:l},...Object.keys(g).length&&{failed:g}})}async function ee(e,t,n){if(t.init&&!t.config.init){const o=t.type||"unknown",s=e.logger.scope(o),r={collector:e,logger:s,id:n,config:t.config,env:re(t.env,t.config.env)};s.debug("init");const a=Date.now();let i;(0,p.emitStep)(e,f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"init",eventId:"",now:a}));try{i=await(0,p.useHooks)(t.init,"DestinationInit",e.hooks,e.logger)(r)}catch(t){const o=Date.now(),s=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"error",eventId:"",now:o});throw s.durationMs=o-a,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,p.emitStep)(e,s),t}if(!1===i)return i;if(t.config={...i||t.config,init:!0},t.queueOn?.length){const o=t.queueOn;t.queueOn=[];for(const{type:s,data:r}of o)_(e,t,n,s,r)}s.debug("init done")}return!0}async function te(e,t,n,o,s,r){const{config:a}=t,i=await(0,p.processEventMapping)(o,a,e);if(i.ignore)return!1;const c=t.type||"unknown",u=e.logger.scope(c),d={collector:e,logger:u,id:n,config:a,data:i.data,rule:i.mapping,ingest:s,env:{...re(t.env,a.env),...r?{respond:r}:{}}};if(void 0!==a.mock)return u.debug("mock",{event:i.event.name}),a.mock;const l=i.mapping,g=i.mappingKey||"* *";if(l?.batch&&t.pushBatch&&void 0===a.mock){if(t.batches=t.batches||{},!t.batches[g]){const o={key:g,entries:[],events:[],data:[]},s=V(l.batch),r=V(a.batch),i=s.wait??r.wait??U,c=s.size??r.size??G,d=s.age??r.age??U,h=re(t.env,a.env),m=async()=>{const o=t.batches[g].batched;if(0===o.entries.length)return;const s={key:o.key,entries:o.entries,events:o.events,data:o.data};o.entries=[],o.events=[],o.data=[];const r=s.entries[0],i={collector:e,logger:u,id:n,config:a,data:void 0,rule:r.rule,ingest:r.ingest,env:{...h,...r.respond?{respond:r.respond}:{}}};u.debug("push batch",{events:s.entries.length});const c=t.config.id||n,d=Y(e,c),l=Date.now(),m=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"flush",eventId:"",now:l});m.batch={size:s.entries.length,index:0},(0,p.emitStep)(e,m);let y=!0;await(0,p.tryCatchAsync)((0,p.useHooks)(t.pushBatch,"DestinationPushBatch",e.hooks,e.logger),o=>{y=!1;const r=Date.now(),a=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"error",eventId:"",now:r});a.durationMs=r-l,a.error=o instanceof Error?{name:o.name,message:o.message}:{message:String(o)},a.batch={size:s.entries.length,index:0},(0,p.emitStep)(e,a);const i=t.dlq=t.dlq||[],g={max:t.config.dlqMax??N};let h=0;for(const e of s.entries){h+=z(i,[e.event,o],g).dropped}if(h>0){const t=J(e.status,(0,p.stepId)("destination",c),"dlq",h);R(i,u,"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:g.max,droppedCount:t})}else i.length<g.max&&B(i);d.failed+=s.entries.length,d.dlqSize=i.length,e.status.failed+=s.entries.length,u.error("Push batch failed",{error:o instanceof Error?o.message:String(o),entries:s.entries.length})})(s,i),u.debug("push batch done"),d.inFlightBatch=Math.max(0,(d.inFlightBatch??0)-s.entries.length),y&&(d.count+=s.entries.length,d.lastAt=Date.now(),e.status.out+=s.entries.length)},y=(0,p.debounce)(m,{wait:i,size:c,age:d});t.batches[g]={batched:o,batchFn:()=>{y()},flush:async()=>{await y.flush()}}}const o=t.batches[g];o.batched.entries.push({event:i.event,ingest:s,respond:r,rule:l,data:i.data}),o.batched.events.push(i.event),(0,p.isDefined)(i.data)&&o.batched.data.push(i.data);const c=t.config.id||n,d=Y(e,c);return d.inFlightBatch=(d.inFlightBatch??0)+1,o.batchFn(),W}{u.debug("push",{event:i.event.name});const o="string"==typeof i.event.id?i.event.id:"",s=Date.now(),r=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"in",eventId:o,now:s});i.mappingKey&&(r.mappingKey=i.mappingKey),i.event.consent&&(r.consent={...i.event.consent}),(0,p.emitStep)(e,r);try{const r=await(0,p.useHooks)(t.push,"DestinationPush",e.hooks,e.logger)(i.event,d),a=Date.now(),c=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"out",eventId:o,now:a});return c.durationMs=a-s,c.outEvent=r,i.mappingKey&&(c.mappingKey=i.mappingKey),(0,p.emitStep)(e,c),u.debug("push done"),r}catch(t){const r=Date.now(),a=f(e,{stepId:(0,p.stepId)("destination",n),stepType:"destination",phase:"error",eventId:o,now:r});throw a.durationMs=r-s,a.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},i.mappingKey&&(a.mappingKey=i.mappingKey),(0,p.emitStep)(e,a),t}}}function ne(e){return{ok:!e?.failed,...e}}function oe(e){const{code:t,config:n={},env:o={},cache:s}=e,{config:r}=b(e,"before"),{config:a}=b({...e,config:r},"next"),i={...t.config,...n,...a};s&&(i.cache=s);const c=re(t.env,o);return{...t,config:i,env:c}}async function se(e,t={}){const n={};for(const[o,s]of Object.entries(t))s.config?.require?.length?e.pending.destinations[o]=s:n[o]=oe(s);return n}function re(e,t){return e||t?t?e&&(0,p.isObject)(e)&&(0,p.isObject)(t)?{...e,...t}:t:e:{}}var ae=require("@walkeros/core"),ie=require("@walkeros/core"),ce=5e3;async function ue(e,t,n){const o=Object.entries(e).map(async([e,o])=>{const s=o.destroy;if(!s)return;const r=o.type||"unknown",a=n.scope(r),i={id:e,config:o.config,env:o.env??{},logger:a};try{await Promise.race([s(i),new Promise((n,o)=>setTimeout(()=>o(new Error(`${t} '${e}' destroy timed out`)),ce))])}catch(n){a.error(`${t} '${e}' destroy failed: ${n}`)}});await Promise.allSettled(o)}async function de(e,t,n){let o,s,r=!1;switch(t){case c.Commands.Config:(0,ie.isObject)(n)&&((0,ae.assign)(e.config,n,{shallow:!1}),s=n,r=!0);break;case c.Commands.Consent:if((0,ie.isObject)(n)){const{update:t}=d(e,n);s=t,r=!0}break;case c.Commands.Custom:(0,ie.isObject)(n)&&(e.custom=(0,ae.assign)(e.custom,n),s=n,r=!0);break;case c.Commands.Destination:(0,ie.isObject)(n)&&"code"in n&&(0,ie.isObject)(n.code)&&(o=await X(e,n));break;case c.Commands.Globals:(0,ie.isObject)(n)&&(e.globals=(0,ae.assign)(e.globals,n),s=n,r=!0);break;case c.Commands.Hook:if((0,ie.isObject)(n)&&(0,ae.isString)(n.name)&&(0,ae.isFunction)(n.fn)){const{name:t,fn:o}=n;e.hooks[t]=o,s=n,r=!0}break;case c.Commands.On:if((0,ie.isObject)(n)&&(0,ae.isString)(n.type)){const{type:t,rules:o}=n;await T(e,t,o)}break;case c.Commands.Ready:r=!0;break;case c.Commands.Run:o=await pe(e,n),r=!0;break;case c.Commands.Session:r=!0;break;case c.Commands.Shutdown:await async function(e){const t=e.logger;await ue(e.sources,"source",t),await ue(e.destinations,"destination",t),await ue(e.transformers,"transformer",t),await ue(e.stores,"store",t)}(e);break;case c.Commands.User:(0,ie.isObject)(n)&&((0,ae.assign)(e.user,n,{shallow:!1}),s=n,r=!0)}return r&&(await H(e,t,void 0,s),o=await Z(e)),o||ne({ok:!0})}function le(e,t){if(!t.name)throw new Error("Event name is required");const[n,o]=t.name.split(" ");if(!n||!o)throw new Error("Event name is invalid");const{timestamp:s=Date.now(),name:r=`${n} ${o}`,data:a={},context:i={},globals:c=e.globals,custom:u={},user:d=e.user,nested:l=[],consent:p=e.consent,id:f=(0,ae.getSpanId)(),trigger:g="",entity:h=n,action:m=o,timing:y=0,source:w={type:"collector",schema:"4"}}=t;return{name:r,data:a,context:i,globals:c,custom:u,user:d,nested:l,consent:p,id:f,trigger:g,entity:h,action:m,timestamp:s,timing:y,source:w}}async function pe(e,t){e.allowed=!0,e.timing=Date.now(),t&&(t.consent&&(e.consent=(0,ae.assign)(e.consent,t.consent)),t.user&&(e.user=(0,ae.assign)(e.user,t.user)),t.globals&&(e.globals=(0,ae.assign)(e.config.globalsStatic||{},t.globals)),t.custom&&(e.custom=(0,ae.assign)(e.custom,t.custom))),Object.values(e.destinations).forEach(e=>{e.queuePush=[]}),e.queue=[],e.round++;return await Z(e)}var fe=require("@walkeros/core");function ge(e,t){const n=(0,fe.useHooks)(async(n,o={})=>await(0,fe.tryCatchAsync)(async()=>{const s=Date.now(),{id:r,ingest:a,respond:i,mapping:c,preChain:u,include:d,exclude:l}=o;let p=i,f=n;const g=d||l?function(e,t,n){let o=e;return t&&(o=Object.fromEntries(Object.entries(o).filter(([e])=>t.includes(e)))),n&&(o=Object.fromEntries(Object.entries(o).filter(([e])=>!n.includes(e)))),o}(e.destinations,d,l):void 0,h=a??(0,fe.createIngest)(r||"unknown");if(c){const t=await(0,fe.processEventMapping)(f,c,e);if(t.ignore)return ne({ok:!0});if(c.consent){if(!(0,fe.getGrantedConsent)(c.consent,e.consent,t.event.consent))return ne({ok:!0})}f=t.event}if(u?.length&&e.transformers&&Object.keys(e.transformers).length>0){const n=await q(e,e.transformers,u,f,h,p,r?`source.${r}.next`:void 0);if(null===n.event)return ne({ok:!0});if(n.stopped)return n.respond&&(p=n.respond),ne({ok:!0});if(n.respond&&(p=n.respond),Array.isArray(n.event)){const o=await Promise.all(n.event.map(async n=>{const o=t(n),s=le(e,o);return Z(e,s,{id:r,ingest:h,respond:p},g)}));if(r){e.status.sources[r]||(e.status.sources[r]={count:0,duration:0});const t=e.status.sources[r];t.count+=n.event.length,t.lastAt=Date.now(),t.duration+=Date.now()-s}return o[0]??ne({ok:!0})}f=n.event}const m=t(f),y=le(e,m),w=await Z(e,y,{id:r,ingest:h,respond:p},g);if(r){e.status.sources[r]||(e.status.sources[r]={count:0,duration:0});const t=e.status.sources[r];t.count++,t.lastAt=Date.now(),t.duration+=Date.now()-s}return w},t=>{if(t instanceof fe.FatalError)throw t;return e.status.failed++,e.logger.error("push failed",{event:n,ingest:o.ingest,error:t}),ne({ok:!1})})(),"Push",e.hooks,e.logger);return async(t,o)=>{const s="string"==typeof t.id?t.id:"",r=Date.now();(0,fe.emitStep)(e,f(e,{stepId:"collector.push",stepType:"collector",phase:"in",eventId:s,now:r}));try{const a=await n(t,o),i=Date.now(),c=f(e,{stepId:"collector.push",stepType:"collector",phase:"out",eventId:s,now:i});return c.durationMs=i-r,c.outEvent=a,(0,fe.emitStep)(e,c),a}catch(t){const n=Date.now(),o=f(e,{stepId:"collector.push",stepType:"collector",phase:"error",eventId:s,now:n});throw o.durationMs=n-r,o.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,fe.emitStep)(e,o),t}}}var he=require("@walkeros/core");var me=require("@walkeros/core"),ye=1e4,we=6e4,ve=.8;function be(e={}){const t=e.maxEntries??ye,n=e.lowWaterMark??ve,o=e.sweepIntervalMs??we,s=Math.floor(t*n),r=new Map,a={hits:0,misses:0,populates:0,writes:0,deletes:0,evictions_entries:0,evictions_ttl:0};let i;o>0&&(i=setInterval(function(){const e=Date.now();let t=0;for(const[n,o]of r)void 0!==o.expires&&o.expires<=e&&(r.delete(n),t++);a.evictions_ttl+=t},o),i&&"function"==typeof i.unref&&i.unref());return{type:"memory",config:{},get(e){const t=r.get(e);if(t)return void 0!==t.expires&&t.expires<=Date.now()?(r.delete(e),a.evictions_ttl++,void a.misses++):(r.delete(e),r.set(e,t),a.hits++,t.value);a.misses++},set(e,n,o){const i=!r.has(e);i||r.delete(e),r.set(e,{value:n,expires:void 0!==o?Date.now()+o:void 0}),a.writes++,i&&a.populates++,r.size>t&&function(){if(r.size<=t)return;const e=r.size-s;let n=0;for(const t of r.keys()){if(n>=e)break;r.delete(t),n++}a.evictions_entries+=n}()},delete(e){r.delete(e)&&a.deletes++},get counters(){return{...a}},destroy(){void 0!==i&&(clearInterval(i),i=void 0),r.clear()}}}var ke=require("@walkeros/core");function Ce(e,t){const{cacheConfig:n,cacheStore:o,namespace:s,logger:r,storeId:a,collector:i}=t,c=(e,t)=>{if(!i)return;const n=f(i,{stepId:`store.${a}`,stepType:"store",phase:"in",eventId:"",now:Date.now()});n.meta={op:"cache",cached:"hit"===t,status:t,key:e},(0,ke.emitStep)(i,n)},u={hits:0,misses:0,populates:0,writes:0,deletes:0,inflight_dedups:0},d=n.rules.map(e=>({match:e.match?(0,ke.compileMatcher)(e.match):()=>!0,ttl:e.ttl})),l=e=>`${s}:${e}`;function p(e,t){const n=void 0===t?{key:e}:{key:e,value:t};return d.find(e=>e.match(n))}const g=new Map;return{type:e.type,config:e.config,setup:e.setup,get counters(){return{...u}},async get(t){const n=l(t),s=await o.get(n);if(void 0!==s)return u.hits++,c(t,"hit"),s;const r=g.get(n);if(r)return u.inflight_dedups++,c(t,"hit"),r;u.misses++,c(t,"miss");const a=(async()=>{try{const s=await e.get(t);if(void 0===s)return;const r=p(t,s);if(r)try{await o.set(n,s,1e3*r.ttl),u.populates++}catch(e){h("set",t,e)}return s}finally{g.delete(n)}})();return g.set(n,a),a},async set(t,n,s){u.writes++,await e.set(t,n,s);const r=p(t,n);if(r)try{await o.set(l(t),n,1e3*r.ttl)}catch(e){h("set",t,e)}},async delete(t){u.deletes++,await e.delete(t);try{await o.delete(l(t))}catch(e){h("delete",t,e)}}};function h(e,t,n){const o=`store-cache(${a}): cache ${e} failed for "${t}"; backing succeeded, continuing`;r?r.warn(o,{error:n}):console.warn(o,n)}}function Ie(e,t,n){const o=`store.${n}`,s=(0,me.useHooks)(t.get,"StoreGet",e.hooks,e.logger),r=(0,me.useHooks)(t.set,"StoreSet",e.hooks,e.logger),a=(0,me.useHooks)(t.delete,"StoreDelete",e.hooks,e.logger);t.get=async t=>{const n=Date.now(),r=f(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});r.meta={op:"get",key:t},(0,me.emitStep)(e,r);try{const r=await s(t),a=Date.now(),i=f(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:a});return i.durationMs=a-n,i.meta={op:"get",key:t},(0,me.emitStep)(e,i),r}catch(s){const r=Date.now(),a=f(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:r});throw a.durationMs=r-n,a.meta={op:"get",key:t},a.error=s instanceof Error?{name:s.name,message:s.message}:{message:String(s)},(0,me.emitStep)(e,a),s}},t.set=async(t,n,s)=>{const a=Date.now(),i=f(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:a});i.meta={op:"set",key:t},(0,me.emitStep)(e,i);try{await r(t,n,s);const i=Date.now(),c=f(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:i});c.durationMs=i-a,c.meta={op:"set",key:t},(0,me.emitStep)(e,c)}catch(n){const s=Date.now(),r=f(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:s});throw r.durationMs=s-a,r.meta={op:"set",key:t},r.error=n instanceof Error?{name:n.name,message:n.message}:{message:String(n)},(0,me.emitStep)(e,r),n}},t.delete=async t=>{const n=Date.now(),s=f(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});s.meta={op:"delete",key:t},(0,me.emitStep)(e,s);try{await a(t);const s=Date.now(),r=f(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:s});r.durationMs=s-n,r.meta={op:"delete",key:t},(0,me.emitStep)(e,r)}catch(s){const r=Date.now(),a=f(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:r});throw a.durationMs=r-n,a.meta={op:"delete",key:t},a.error=s instanceof Error?{name:s.name,message:s.message}:{message:String(s)},(0,me.emitStep)(e,a),s}}}async function Se(e,t={}){const n={};for(const[o,s]of Object.entries(t)){const{code:t,config:r={},env:a={}}=s,i=e.logger.scope("store").scope(o),c={collector:e,logger:i,id:o,config:r,env:a},u=await t(c);n[o]=u}const o=t,s=function(e){const t={};for(const n of Object.keys(e))t[n]="WHITE";const n=[],o=[];function s(r){const a=t[r];if("BLACK"===a)return;if("GRAY"===a){const e=o.indexOf(r),t=o.slice(-1===e?0:e).concat(r).join(" -> ");throw new Error(`Cycle in cache.store chain: ${t}`)}t[r]="GRAY",o.push(r);const i=e[r].cache?.store;if(void 0!==i){if(!(i in e))throw new Error(`Store "${r}" cache.store references "${i}", which is not declared in flow.stores`);s(i)}o.pop(),t[r]="BLACK",n.push(r)}for(const n of Object.keys(e))"WHITE"===t[n]&&s(n);return n}(o);for(const t of s){const s=o[t].cache;if(!s)continue;let r,a;void 0!==s.store?(r=n[s.store],a=s.store):(n.__cache||(n.__cache=be()),r=n.__cache,a="__cache");const i=s.namespace??t;e.logger.scope("store-cache").scope(t).info(`store "${t}" caches with namespace "${i}:" via ${a}`),n[t]=Ce(n[t],{storeId:t,cacheConfig:s,cacheStore:r,namespace:i,logger:e.logger.scope("store-cache").scope(t),collector:e})}for(const[t,o]of Object.entries(n))"__cache"!==t&&Ie(e,o,t);return n}async function qe(e){const t=(0,l.assign)({globalsStatic:{},sessionStatic:{},run:!0,queueMax:1e3},e,{merge:!1,extend:!1}),n={level:e.logger?.level,handler:e.logger?.handler},o=(0,l.createLogger)(n),s={...t.globalsStatic,...e.globals},r={allowed:!1,config:t,consent:e.consent||{},custom:e.custom||{},destinations:{},transformers:{},stores:{},globals:s,hooks:e.hooks||{},observers:new Set,logger:o,on:{},queue:[],round:0,session:void 0,status:{startedAt:Date.now(),in:0,out:0,failed:0,sources:{},destinations:{},dropped:{}},timing:Date.now(),user:e.user||{},sources:{},pending:{destinations:{}},push:void 0,command:void 0};r.push=ge(r,e=>({timing:Math.round((Date.now()-r.timing)/10)/100,source:{type:"collector",schema:"4",version:"4.1.3-next-1779963694449"},...e})),r.command=function(e,t){return(0,he.useHooks)(async(n,o,s)=>await(0,he.tryCatchAsync)(async()=>await t(e,n,o,s),t=>{if(t instanceof he.FatalError)throw t;return e.status.failed++,e.logger.error("command failed",{command:n,data:o,error:t}),ne({ok:!1})})(),"Command",e.hooks,e.logger)}(r,de);const a=e.stores||{};return r.stores=await Se(r,a),function(e,t,n){const o=new Map;for(const[n,s]of Object.entries(e))t[n]&&o.set(s,t[n]);if(0!==o.size)for(const e of[n.transformers,n.destinations,n.sources])if(e)for(const t of Object.values(e))s(t.env);function s(e){if(e)for(const[t,n]of Object.entries(e))if("object"==typeof n&&null!==n){const s=o.get(n);s&&(e[t]=s)}}}(a,r.stores,e),r.stores.__cache||(r.stores.__cache=be()),r.destinations=await se(r,e.destinations||{}),r.transformers=await async function(e,t={}){const n={};for(const[o,s]of Object.entries(t)){const{code:t,env:r={}}=s,a=(0,y.validateStepEntry)(s,"Transformer");if(!a.ok){e.logger.warn(`Transformer ${o} invalid (${a.code}): ${a.reason}. Skipping.`);continue}const{config:i}=b(s,"before"),{config:c}=b({...s,config:i},"next"),u=Object.keys(r).length>0?{...c,env:r}:c,{cache:d}=s,l=d?{...u,cache:d}:u,p=e.logger.scope("transformer").scope(o),f={collector:e,logger:p,id:o,ingest:(0,y.createIngest)(o),config:l,env:r},g=t??(e=>{const t=s.mapping;if(t){const n=[];if(void 0!==t.data&&n.push("data"),t.mapping)for(const[e,o]of Object.entries(t.mapping))if("object"==typeof o&&null!==o)for(const[t,s]of Object.entries(o)){if("object"!=typeof s||null===s)continue;const o=s;void 0!==o.data&&n.push(`mapping[${e}][${t}].data`),void 0!==o.silent&&n.push(`mapping[${e}][${t}].silent`)}return n.length>0&&e.collector.logger.warn(`Transformer ${o}: \`${n.join(", ")}\` ignored at transformer position (only event-mutating fields apply).`),{type:"pass",config:e.config,push:async n=>{const o=await(0,y.processEventMapping)(n,t,e.collector);return!o.ignore&&{event:o.event}}}}return{type:"pass",config:e.config,push:e=>({event:e})}}),h=await g(f);void 0!==s.before&&void 0===h.config?.before&&(h.config={...h.config??{},before:s.before}),void 0!==s.next&&void 0===h.config?.next&&(h.config={...h.config??{},next:s.next}),n[o]=h}return n}(r,e.transformers||{}),r}async function xe(e){e=e||{};const t=await qe(e),n=(o=t,{type:"elb",config:{},push:async(e,t,n,s,r)=>{if("string"==typeof e&&e.startsWith("walker ")){const n=e.replace("walker ","");return o.command(n,t)}let a;if("string"==typeof e)a={name:e},t&&"object"==typeof t&&!Array.isArray(t)&&(a.data=t);else{if(!e||"object"!=typeof e)return ne({ok:!1});a=e,t&&"object"==typeof t&&!Array.isArray(t)&&(a.data={...a.data||{},...t})}return n&&"object"==typeof n&&(a.context=n),s&&Array.isArray(s)&&(a.nested=s),r&&"object"==typeof r&&(a.custom=r),o.push(a)}});var o;t.sources.elb=n,await E(t,e.sources||{});const{consent:s,user:r,globals:a,custom:i}=e;s&&await t.command("consent",s),r&&await t.command("user",r),a&&Object.assign(t.globals,a),i&&Object.assign(t.custom,i),t.config.run&&await t.command("run");let c=n.push;const u=Object.values(t.sources).filter(e=>"elb"!==e.type),d=u.find(e=>e.config.primary);return d?c=d.push:u.length>0&&(c=u[0].push),{collector:t,elb:c}}function Oe(e){if(null===e||"object"!=typeof e)return e;if(Array.isArray(e))return e.map(Oe);const t={};for(const[n,o]of Object.entries(e))t[n]="function"==typeof o?o:Oe(o);return t}function je(e){const t=[],{simulation:n,...o}=e,s=Oe(o);for(const e of n){const n=e.startsWith("call:")?e.slice(5):e,o=n.split(".");let r=s;for(let e=0;e<o.length-1&&null!=r[o[e]];e++)r=r[o[e]];const a=o[o.length-1];if(null==r||!(a in r))continue;const i=r[a];"function"==typeof i&&(r[a]=function(...e){return t.push({fn:n,args:e,ts:Date.now()}),i.apply(this,e)})}return{wrappedEnv:s,calls:t}}//# sourceMappingURL=index.js.map