@walkeros/web-source-session 4.1.1-next-1779822275564 → 4.1.1

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,6 +1,6 @@
1
1
  # @walkeros/web-source-session
2
2
 
3
- ## 4.1.1-next-1779822275564
3
+ ## 4.1.1
4
4
 
5
5
  ### Patch Changes
6
6
 
@@ -8,8 +8,8 @@
8
8
  - Updated dependencies [b0279ee]
9
9
  - Updated dependencies [0b7f494]
10
10
  - Updated dependencies [edd3836]
11
- - @walkeros/core@4.1.1-next-1779822275564
12
- - @walkeros/web-core@4.1.1-next-1779822275564
11
+ - @walkeros/core@4.1.1
12
+ - @walkeros/web-core@4.1.1
13
13
 
14
14
  ## 4.1.0
15
15
 
package/dist/dev.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})},i={};r(i,{examples:()=>p,schemas:()=>a}),module.exports=(e=i,((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 a={};r(a,{SettingsSchema:()=>u,settings:()=>d});var c=require("@walkeros/core/dev"),l=require("@walkeros/core/dev"),u=l.z.object({storage:l.z.boolean().default(!1).describe("Enable persistent storage for session/device IDs").optional(),consent:l.z.union([l.z.string(),l.z.array(l.z.string())]).describe("Consent key(s) required to enable storage mode").optional(),length:l.z.number().default(30).describe("Session timeout in minutes").optional(),pulse:l.z.boolean().default(!1).describe("Keep session alive on each event").optional(),sessionKey:l.z.string().default("elbSessionId").describe("Storage key for session ID").optional(),sessionStorage:l.z.enum(["local","session"]).default("local").describe("Storage type for session").optional(),deviceKey:l.z.string().default("elbDeviceId").describe("Storage key for device ID").optional(),deviceStorage:l.z.enum(["local","session"]).default("local").describe("Storage type for device").optional(),deviceAge:l.z.number().default(30).describe("Device ID age in days").optional(),cb:l.z.any().describe("Custom session callback function or false to disable").optional(),clickIds:l.z.array(l.ClickIdEntrySchema).describe("Custom click-ID registry. Entries with a `param` matching a default override the platform name in place; new params append to the end of the priority list.").optional()}),d=(0,c.zodToSchema)(u),p={};r(p,{createTrigger:()=>ye,step:()=>f,trigger:()=>we});var f={};r(f,{newMarketingSession:()=>g,returningVisitor:()=>h});var g={title:"New marketing session",description:"A visit with UTM parameters starts a new session and emits walker user, session, and session start calls.",trigger:{type:"load",options:{url:"https://example.com/?utm_source=google&utm_medium=cpc&utm_campaign=winter-sale"}},in:{storage:!0},out:[["elb","user",{session:"s3ss10n-id",device:"d3v1c3-id"}],["elb","session",{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}],["elb",{name:"session start",data:{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}}]]},h={title:"Returning visitor",description:"A returning visit with a google referrer reuses the stored device id and increments the session count.",trigger:{type:"load",options:{referrer:"https://google.com"}},in:{storage:!0},out:[["elb","user",{session:"n3w-s3ss10n",device:"d3v1c3-id"}],["elb","session",{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}],["elb",{name:"session start",data:{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}}]]},m=require("@walkeros/core"),v=require("@walkeros/core"),y=require("@walkeros/core"),w=(require("@walkeros/core"),require("@walkeros/core")),b=require("@walkeros/core"),k=require("@walkeros/core"),I=require("@walkeros/core"),S=require("@walkeros/core"),C=require("@walkeros/core"),q=require("@walkeros/core"),x=require("@walkeros/core"),O=require("@walkeros/core"),j=require("@walkeros/core"),D={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"};function A(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}}function E(e,t){return e.storeId&&t.stores[e.storeId]?t.stores[e.storeId]:t.stores.__cache}function $(e){var t;const n={};for(const[o,s]of Object.entries(e)){const e=null==(t=s.config)?void 0:t.next;"string"==typeof e||Array.isArray(e)&&e.every(e=>"string"==typeof e)?n[o]={next:e}:n[o]={}}return n}function M(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 _(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 T(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,I.createIngest)(n),config:t.config,env:H(t.config.env)};s.debug("init");const i=await(0,I.useHooks)(t.init,"TransformerInit",e.hooks,e.logger)(r);if(!1===i)return!1;t.config={...i||t.config,env:(null==i?void 0:i.env)||t.config.env,init:!0},s.debug("init done")}return!0}async function P(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:{...H(t.config.env),...r?{respond:r}:{}}};a.debug("push",{event:o.name});const l="string"==typeof o.id?o.id:"",u=Date.now(),d=A(e,{stepId:(0,I.stepId)("transformer",n),stepType:"transformer",phase:"in",eventId:l,now:u});(0,I.emitStep)(e,d);try{const s=await(0,I.useHooks)(t.push,"TransformerPush",e.hooks,e.logger)(o,c),r=Date.now(),i=A(e,{stepId:(0,I.stepId)("transformer",n),stepType:"transformer",phase:"out",eventId:l,now:r});return i.durationMs=r-u,i.outEvent=s,(0,I.emitStep)(e,i),a.debug("push done"),s}catch(t){const o=Date.now(),s=A(e,{stepId:(0,I.stepId)("transformer",n),stepType:"transformer",phase:"error",eventId:l,now:o});throw s.durationMs=o-u,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,I.emitStep)(e,s),t}}function z(e,t){return e?{...e,_meta:{...e._meta,path:[...e._meta.path]}}:(0,I.createIngest)(t)}async function K(e,t,n,o,s,r,i){var a,c,l,u,d,p,f,g;s||(s=(0,I.createIngest)(null!=(a=n[0])?a:"chain")),i&&s._meta&&(s._meta.chainPath=i);let h=o,m=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:m};if(s&&s._meta&&(s._meta.hops++,s._meta.path.push(o)),!await(0,I.tryCatchAsync)(T,t=>{if(t instanceof I.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:m};if(i&&void 0!==(null==(l=null==(c=r.config)?void 0:c.chainMocks)?void 0:l[i])){const t=r.config.chainMocks[i];e.logger.scope(`transformer:${r.type||"unknown"}`).debug("chainMock",{chain:i}),h=t;continue}if(void 0!==(null==(u=r.config)?void 0:u.mock)){e.logger.scope(`transformer:${r.type||"unknown"}`).debug("mock"),h=r.config.mock;continue}if(null==(d=r.config)?void 0:d.disabled)continue;const a=null==(p=r.config)?void 0:p.cache,v=a?(0,I.compileCache)(a):void 0,y=v?E(v,e):void 0;let w;if(v&&y){const e=(0,I.buildCacheContext)(s,h),t=await(0,I.checkCache)(v,y,e);if("HIT"===(null==t?void 0:t.status)&&t.value){if(h=t.value,v.stop)return{event:h,respond:m,stopped:!0};continue}"MISS"===(null==t?void 0:t.status)&&(w={key:t.key,ttl:t.rule.ttl})}const b=r.config.before;if(b){const n=(0,I.getNextSteps)(b,(0,I.buildCacheContext)(s,h));if(1===n.length){const o=_(n[0],$(t));if(o.length>0){const n=await K(e,t,o,h,s,m,i);if(null===n.event)return{event:null,respond:null!=(f=n.respond)?f:m};if(n.stopped)return{event:Array.isArray(n.event)?n.event[0]:n.event,respond:null!=(g=n.respond)?g:m,stopped:!0};n.respond&&(m=n.respond),h=Array.isArray(n.event)?n.event[0]:n.event}}else n.length>1&&await Promise.all(n.map(n=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(n,$(t)),h,z(s,n),void 0,i)))}const k=await(0,I.tryCatchAsync)(P,t=>(e.logger.scope(`transformer:${r.type||"unknown"}`).error("Push failed",{error:t}),!1))(e,r,o,h,s,m);if(!1===k)return{event:null,respond:m};if(Array.isArray(k)){const r=n.slice(n.indexOf(o)+1),a=await Promise.all(k.map(async n=>{const o=n.event||h,a=z(s,"unknown");if(n.next){const s=(0,I.getNextSteps)(n.next,(0,I.buildCacheContext)(a,o));if(0===s.length)return{event:o,respond:m};if(1===s.length){const n=_(s[0],$(t));return n.length>0?K(e,t,n,o,a,m,i):{event:o,respond:m}}return(await Promise.all(s.map(n=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(n,$(t)),o,z(a,n),void 0,i)))).map(e=>({event:e.event,respond:void 0}))}return r.length>0?K(e,t,r,o,a,m,i):{event:o,respond:m}}));let c=m;const l=[];for(const e of a.flat())if(null!==e)if(e&&"object"==typeof e&&"event"in e){const t=e;if(t.respond&&(c=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:c}:1===l.length?{event:l[0],respond:c}:{event:l,respond:c}}if(k&&"object"==typeof k){const{event:n,respond:o,next:r}=k;if(o&&(m=o),void 0!==r){const o=(0,I.getNextSteps)(r,(0,I.buildCacheContext)(s,h));if(0===o.length){n&&(h=n);continue}if(1===o.length){const a=_(o[0],$(t));return a.length>0?K(e,t,a,n||h,s,m,i):(e.logger.warn(`Branch target not found: ${JSON.stringify(r)}`),{event:null,respond:m})}return await Promise.all(o.map(o=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${o} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(o,$(t)),n||h,z(s,o),void 0,i))),{event:null,respond:void 0}}n&&(h=n)}w&&y&&(0,I.storeCache)(y,w.key,h,w.ttl);const S=r.config.next,C="string"==typeof S||Array.isArray(S)&&S.every(e=>"string"==typeof e),q=void 0!==S&&!C;if((!k||"object"==typeof k&&!k.next)&&q){const n=(0,I.getNextSteps)(r.config.next,(0,I.buildCacheContext)(s,h));if(1===n.length){const o=_(n[0],$(t));return o.length>0?K(e,t,o,h,s,m,i):{event:h,respond:m}}return n.length>1?(await Promise.all(n.map(n=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(n,$(t)),h,z(s,n),void 0,i))),{event:null,respond:void 0}):{event:h,respond:m}}}return{event:h,respond:m}}function H(e){return e&&(0,I.isObject)(e)?e:{}}function N(e){return"string"==typeof e||!(!Array.isArray(e)||!e.every(e=>"string"==typeof e))}async function R(e,t,n){var o,s;if(!t.on||!(null==(o=t.queueOn)?void 0:o.length))return;const r=t.queueOn;t.queueOn=[];const i=n||(null==(s=t.config)?void 0:s.id)||"unknown";for(const{type:n,data:o}of r)await(0,k.tryCatchAsync)(t.on,t=>{if(t instanceof k.FatalError)throw t;e.status.failed++,e.logger.scope("source").error("source on flush failed",{sourceId:i,type:n,error:t})})(n,o)}function F(e){var t;return Boolean(e.config.init)&&!(null==(t=e.config.require)?void 0:t.length)}async function B(e,t,n){var o;const{code:s,config:r={},env:i={},primary:a,next:c,before:l,cache:u}=n,d=u,p=d?(0,k.compileCache)({...d,stop:null==(o=d.stop)||o}):void 0,f=N(c)?_(c,$(e.transformers)):void 0,g=N(l)?_(l,$(e.transformers)):void 0,h=i.push,m=null!=h?h:e.push,v=Boolean(h),y=async(n,o,s)=>{var i;let a;const u=null!=g?g:void 0!==l?(()=>{const t=(0,k.getNextSteps)(l,(0,k.buildCacheContext)(s.ingest));return 0===t.length?[]:_(1===t.length?t[0]:t,$(e.transformers))})():[];let d=[n];if(u.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const o=await K(e,e.transformers,u,n,s.ingest,s.respond,`source.${t}.before`);if(null===o.event)return{ok:!0};if(o.stopped)return o.respond&&(s.respond=o.respond),{ok:!0};o.respond&&(s.respond=o.respond),d=Array.isArray(o.event)?o.event:[o.event]}if(p){const t=E(p,e);if(t){const n=(0,k.buildCacheContext)(s.ingest),o=await(0,k.checkCache)(p,t,n);if(o){if("HIT"===o.status&&void 0!==o.value&&p.stop){let t=o.value;return o.rule.update&&(t=await(0,k.applyUpdate)(t,o.rule.update,{...n,cache:{status:"HIT"}},e)),null==(i=s.respond)||i.call(s,t),{ok:!0}}if("MISS"===o.status&&p.stop&&s.respond){const r=s.respond,i=o.rule.update,c={...n,cache:{status:"MISS"}},l=o.key,u=o.rule.ttl,d=n=>{(0,k.storeCache)(t,l,n,u),i?a=(async()=>{const t=await(0,k.applyUpdate)(n,i,c,e);r(t)})():r(n)};s.respond=d}"MISS"!==o.status||p.stop||(0,k.storeCache)(t,o.key,!0,o.rule.ttl)}}}const h=f?{kind:"single",preChain:f}:void 0!==c?(()=>{const t=(0,k.getNextSteps)(c,(0,k.buildCacheContext)(s.ingest));return 0===t.length?{kind:"single",preChain:[]}:1===t.length?{kind:"single",preChain:_(t[0],$(e.transformers))}:{kind:"many",branches:t.map(t=>_(t,$(e.transformers)))}})():{kind:"single",preChain:[]};let y={ok:!0};for(const n of d)"many"===h.kind?(await Promise.all(h.branches.map((i,a)=>(0,k.tryCatchAsync)(async()=>v?m(n):m(n,{...o,id:t,ingest:z(s.ingest,`${t}.${a}`),respond:void 0,mapping:r,preChain:i}),t=>(e.logger.scope("source:many").error(`many branch ${a} failed`,{error:t}),{ok:!0}))())),y={ok:!0}):y=v?await m(n):await m(n,{...o,id:t,ingest:s.ingest,respond:s.respond,mapping:r,preChain:h.preChain});return a&&await a,y},w=async n=>{const o=(0,k.createIngest)(t);if(!r.ingest||void 0===n)return o;const s=await(0,k.getMappingValue)(n,r.ingest,{collector:e});return{...o,...s,_meta:o._meta}},b=e.logger.scope("source").scope(t),I={command:e.command,sources:e.sources,elb:e.sources.elb.push,logger:b,...i,push:async(e,n={})=>{const o={ingest:(0,k.createIngest)(t),respond:void 0};return y(e,n,o)}},S={collector:e,logger:b,id:t,config:r,env:I,withScope:async(e,t,n)=>{const o={ingest:await w(e),respond:t};return n({...I,push:(e,t={})=>y(e,t,o),ingest:o.ingest,respond:o.respond})}},C=await(0,k.tryCatchAsync)(s,n=>{if(n instanceof k.FatalError)throw n;e.status.failed++,e.logger.scope("source").error("source factory failed",{sourceId:t,error:n})})(S);if(!C)return;const q=C.type||"unknown",x=e.logger.scope(q).scope(t);return I.logger=x,a&&(C.config={...C.config,primary:a}),C}function G(e,t,n,o){if(n instanceof w.FatalError)throw n;e.logger.scope("on").error("on callback failed",{kind:t,...o,error:n})}function U(e,t){return{collector:e,logger:e.logger.scope("on").scope(String(t))}}function W(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:le(t.env,t.config.env)};(0,b.tryCatch)(t.on,t=>G(e,"destination",t,{destId:n,type:o}))(o,a)}function L(e,t,n,o){let s;switch(t){case D.Consent:s=o||e.consent;break;case D.Session:s=e.session;break;case D.User:s=o||e.user;break;case D.Custom:s=o||e.custom;break;case D.Globals:s=o||e.globals;break;case D.Config:s=o||e.config;break;case D.Ready:case D.Run:default:s=void 0}if(n.length)switch(t){case D.Consent:!function(e,t,n){const o=n||e.consent,s=U(e,D.Consent);t.forEach(t=>{Object.keys(o).filter(e=>e in t).forEach(n=>{(0,b.tryCatch)(t[n],t=>G(e,"consent",t,{key:n}))(o,s)})})}(e,n,o);break;case D.Ready:!function(e,t){if(!e.allowed)return;const n=U(e,D.Ready);t.forEach(t=>{(0,b.tryCatch)(t,t=>G(e,"ready",t))(void 0,n)})}(e,n);break;case D.Run:!function(e,t){if(!e.allowed)return;const n=U(e,D.Run);t.forEach(t=>{(0,b.tryCatch)(t,t=>G(e,"run",t))(void 0,n)})}(e,n);break;case D.Session:!function(e,t){if(!e.session)return;const n=U(e,D.Session);t.forEach(t=>{(0,b.tryCatch)(t,t=>G(e,"session",t))(e.session,n)})}(e,n);break;default:{const o=U(e,t);n.forEach(n=>{"function"==typeof n&&(0,b.tryCatch)(n,n=>G(e,"generic",n,{type:t}))(s,o)});break}}}function J(e,t,n,o){var s;if(!Number.isFinite(n.max)||n.max<=0)throw new Error(`pushBounded: max must be > 0 (got ${n.max})`);if("dropNewest"===(null!=(s=n.onOverflow)?s:"dropOldest"))return e.length>=n.max?(o&&o([t]),{appended:!1,dropped:1}):(e.push(t),{appended:!0,dropped:0});const r=[];for(;e.length>=n.max;)r.push(e.shift());return e.push(t),r.length>0&&o&&o(r),{appended:!0,dropped:r.length}}var V=new WeakMap;function Y(e,t,n,o){V.get(e)||(V.set(e,!0),t.warn(n,o))}function Q(e){V.delete(e)}var X=Object.freeze({batched:!0});function Z(e){return e===X}function ee(e){return void 0===e?{}:"number"==typeof e?{wait:e}:{wait:e.wait,size:e.size,age:e.age}}function te(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 ne(e,t,n,o){var s;e.dropped[t]||(e.dropped[t]={});const r=e.dropped[t];return r[n]=(null!=(s=r[n])?s:0)+o,r[n]}function oe(e,t,n){if(!e)return[];if(Array.isArray(e)&&e.every(e=>"string"==typeof e))return _(e,t);if("string"==typeof e)return _(e,t);const o=(0,y.getNextSteps)(e,(0,y.buildCacheContext)(n));return 0===o.length?[]:1===o.length?_(o[0],t):_(o,t)}async function se(e,t,n={},o){var s,r,i,a,c,l;const{allowed:u,consent:d,globals:p,user:f}=e;if(!u)return ae({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=J(e.queue,t,{max:n});if(o.dropped>0){const t=ne(e.status,(0,y.stepId)("collector"),"queue",o.dropped);Y(e.queue,e.logger,"collector.queue overflow; oldest events dropped",{buffer:"queue",cap:n,droppedCount:t})}else e.queue.length<n&&Q(e.queue);e.status.in++}o||(o=e.destinations);const g=e.transformers?$(e.transformers):{},h=await Promise.all(Object.entries(o||{}).map(async([o,s])=>{var r,i,a,c;if(s.config.disabled)return{id:o,destination:s,skipped:!0};let l=(s.queuePush||[]).map(e=>({...e,consent:d}));s.queuePush=[],t&&l.push((0,y.clone)(t));const u=n.ingest?{...n.ingest,_meta:{...n.ingest._meta,path:[...n.ingest._meta.path]}}:(0,y.createIngest)("unknown");if(!l.length&&!(null==(r=s.queueOn)?void 0:r.length))return{id:o,destination:s,skipped:!0};if(!l.length&&(null==(i=s.queueOn)?void 0:i.length)){let t=!1;try{t=await re(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 h=[],m=l.filter(t=>{const n=(0,y.getGrantedConsent)(s.config.consent,d,t.consent);if(n)return t.consent=n,h.push(t),!1;const r=A(e,{stepId:(0,y.stepId)("destination",o),stepType:"destination",phase:"skip",eventId:"string"==typeof t.id?t.id:"",now:Date.now()});return r.skipReason="consent",d&&(r.consent={...d}),s.config.consent&&(r.meta={required:{...s.config.consent}}),(0,y.emitStep)(e,r),!0});if(m.length>0){const t=s.queuePush,n=s.config.id||o,r={max:null!=(a=s.config.queueMax)?a:1e3};let i=0;for(const e of m)i+=J(t,e,r).dropped;if(i>0){te(e,n);const o=ne(e.status,(0,y.stepId)("destination",n),"queue",i);Y(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&&Q(t)}if(!h.length)return{id:o,destination:s,queue:l};let v,w,b=!1;try{b=await re(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(!b)return{id:o,destination:s,queue:l};s.dlq||(s.dlq=[]);const k=oe(s.config.before,g,u),I=s.config.next,S=null==(c=s.config)?void 0:c.cache,C=S?(0,y.compileCache)(S):void 0,q=C?E(C,e):void 0;let x=0,O=0;return await Promise.all(h.map(async t=>{let r;if(t.globals=(0,y.assign)(p,t.globals),t.user=(0,y.assign)(f,t.user),(null==C?void 0:C.stop)&&q){const e=(0,y.buildCacheContext)(u,t),n=await(0,y.checkCache)(C,q,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}let i=t,a=n.respond;if(k.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const s=await K(e,e.transformers,k,t,u,n.respond,`destination.${o}.before`);if(null===s.event)return t;s.respond&&(a=s.respond),i=Array.isArray(s.event)?s.event[0]:s.event}if(C&&!C.stop&&q){const e=(0,y.buildCacheContext)(u,i),n=await(0,y.checkCache)(C,q,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}const c=Date.now();let l=!1;const d=await(0,y.tryCatchAsync)(ie,t=>{var n;const r=s.type||"unknown";e.logger.scope(r).error("Push failed",{error:t,event:i.name}),v=t,l=!0;const a=s.dlq,c=s.config.id||o,u={max:null!=(n=s.config.dlqMax)?n:100},d=J(a,[i,t],u);if(d.dropped>0){te(e,c);const t=ne(e.status,(0,y.stepId)("destination",c),"dlq",d.dropped);Y(a,e.logger.scope(s.type||"unknown"),"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:u.max,droppedCount:t})}else a.length<u.max&&Q(a)})(e,s,o,i,u,a);if(x+=Date.now()-c,r&&q&&void 0===s.config.mock&&(0,y.storeCache)(q,r.key,null==d||d,r.ttl),void 0===d||Z(d)||(w=d),Z(d)&&O++,!l&&I){void 0!==d&&(u._response=d);const t=oe(I,g,u);if(t.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const n=await K(e,e.transformers,t,i,u,a,`destination.${o}.next`);n.respond&&(a=n.respond)}}return t})),{id:o,destination:s,error:v,response:w,totalDuration:x,batchedCount:O,allowedCount:h.length}})),m={},v={},w={};for(const t of h){if(t.skipped)continue;const n=t.destination,o={type:n.type||"unknown",data:t.response};te(e,t.id);const u=e.status.destinations[t.id],d=Date.now();if(u.queuePushSize=null!=(r=null==(s=n.queuePush)?void 0:s.length)?r:0,u.dlqSize=null!=(a=null==(i=n.dlq)?void 0:i.length)?a:0,t.error)o.error=t.error,w[t.id]=o,u.failed++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.failed++;else if(t.queue&&t.queue.length)v[t.id]=o;else{const n=null!=(c=t.batchedCount)?c:0,s=null!=(l=t.allowedCount)?l:0;(Math.max(0,s-n)>0||0===s)&&(m[t.id]=o,u.count++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.out++)}}return ae({event:t,...Object.keys(m).length&&{done:m},...Object.keys(v).length&&{queued:v},...Object.keys(w).length&&{failed:w}})}async function re(e,t,n){var o;if(t.init&&!t.config.init){const s=t.type||"unknown",r=e.logger.scope(s),i={collector:e,logger:r,id:n,config:t.config,env:le(t.env,t.config.env)};r.debug("init");const a=Date.now();let c;(0,y.emitStep)(e,A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"init",eventId:"",now:a}));try{c=await(0,y.useHooks)(t.init,"DestinationInit",e.hooks,e.logger)(i)}catch(t){const o=Date.now(),s=A(e,{stepId:(0,y.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,y.emitStep)(e,s),t}if(!1===c)return c;if(t.config={...c||t.config,init:!0},null==(o=t.queueOn)?void 0:o.length){const o=t.queueOn;t.queueOn=[];for(const{type:s,data:r}of o)W(e,t,n,s,r)}r.debug("init done")}return!0}async function ie(e,t,n,o,s,r){var i,a,c,l,u,d,p;const{config:f}=t,g=await(0,y.processEventMapping)(o,f,e);if(g.ignore)return!1;const h=t.type||"unknown",m=e.logger.scope(h),v={collector:e,logger:m,id:n,config:f,data:g.data,rule:g.mapping,ingest:s,env:{...le(t.env,f.env),...r?{respond:r}:{}}};if(void 0!==f.mock)return m.debug("mock",{event:g.event.name}),f.mock;const w=g.mapping,b=g.mappingKey||"* *";if((null==w?void 0:w.batch)&&t.pushBatch&&void 0===f.mock){if(t.batches=t.batches||{},!t.batches[b]){const o={key:b,entries:[],events:[],data:[]},s=ee(w.batch),r=ee(f.batch),p=null!=(a=null!=(i=s.wait)?i:r.wait)?a:3e4,g=null!=(l=null!=(c=s.size)?c:r.size)?l:1e3,h=null!=(d=null!=(u=s.age)?u:r.age)?d:3e4,v=le(t.env,f.env),k=(0,y.debounce)(async()=>{var o;const s=t.batches[b].batched;if(0===s.entries.length)return;const r={key:s.key,entries:s.entries,events:s.events,data:s.data};s.entries=[],s.events=[],s.data=[];const i=r.entries[0],a={collector:e,logger:m,id:n,config:f,data:void 0,rule:i.rule,ingest:i.ingest,env:{...v,...i.respond?{respond:i.respond}:{}}};m.debug("push batch",{events:r.entries.length});const c=t.config.id||n,l=te(e,c),u=Date.now(),d=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"flush",eventId:"",now:u});d.batch={size:r.entries.length,index:0},(0,y.emitStep)(e,d);let p=!0;await(0,y.tryCatchAsync)((0,y.useHooks)(t.pushBatch,"DestinationPushBatch",e.hooks,e.logger),o=>{var s;p=!1;const i=Date.now(),a=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"error",eventId:"",now:i});a.durationMs=i-u,a.error=o instanceof Error?{name:o.name,message:o.message}:{message:String(o)},a.batch={size:r.entries.length,index:0},(0,y.emitStep)(e,a);const d=t.dlq=t.dlq||[],f={max:null!=(s=t.config.dlqMax)?s:100};let g=0;for(const e of r.entries)g+=J(d,[e.event,o],f).dropped;if(g>0){const t=ne(e.status,(0,y.stepId)("destination",c),"dlq",g);Y(d,m,"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:f.max,droppedCount:t})}else d.length<f.max&&Q(d);l.failed+=r.entries.length,l.dlqSize=d.length,e.status.failed+=r.entries.length,m.error("Push batch failed",{error:o instanceof Error?o.message:String(o),entries:r.entries.length})})(r,a),m.debug("push batch done"),l.inFlightBatch=Math.max(0,(null!=(o=l.inFlightBatch)?o:0)-r.entries.length),p&&(l.count+=r.entries.length,l.lastAt=Date.now(),e.status.out+=r.entries.length)},{wait:p,size:g,age:h});t.batches[b]={batched:o,batchFn:()=>{k()},flush:async()=>{await k.flush()}}}const o=t.batches[b];o.batched.entries.push({event:g.event,ingest:s,respond:r,rule:w,data:g.data}),o.batched.events.push(g.event),(0,y.isDefined)(g.data)&&o.batched.data.push(g.data);const h=t.config.id||n,v=te(e,h);return v.inFlightBatch=(null!=(p=v.inFlightBatch)?p:0)+1,o.batchFn(),X}{m.debug("push",{event:g.event.name});const o="string"==typeof g.event.id?g.event.id:"",s=Date.now(),r=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"in",eventId:o,now:s});g.mappingKey&&(r.mappingKey=g.mappingKey),g.event.consent&&(r.consent={...g.event.consent}),(0,y.emitStep)(e,r);try{const r=await(0,y.useHooks)(t.push,"DestinationPush",e.hooks,e.logger)(g.event,v),i=Date.now(),a=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"out",eventId:o,now:i});return a.durationMs=i-s,a.outEvent=r,g.mappingKey&&(a.mappingKey=g.mappingKey),(0,y.emitStep)(e,a),m.debug("push done"),r}catch(t){const r=Date.now(),i=A(e,{stepId:(0,y.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)},g.mappingKey&&(i.mappingKey=g.mappingKey),(0,y.emitStep)(e,i),t}}}function ae(e){return{ok:!(null==e?void 0:e.failed),...e}}function ce(e){const{code:t,config:n={},env:o={},cache:s}=e,{config:r}=M(e,"before"),{config:i}=M({...e,config:r},"next"),a={...t.config,...n,...i};s&&(a.cache=s);const c=le(t.env,o);return{...t,config:a,env:c}}function le(e,t){return e||t?t?e&&(0,y.isObject)(e)&&(0,y.isObject)(t)?{...e,...t}:t:e:{}}async function ue(e,t,n){const o=Object.entries(e).map(async([e,o])=>{var s;const r=o.destroy;if(!r)return;const i=o.type||"unknown",a=n.scope(i),c={id:e,config:o.config,env:null!=(s=o.env)?s:{},logger:a};try{await Promise.race([r(c),new Promise((n,o)=>setTimeout(()=>o(new Error(`${t} '${e}' destroy timed out`)),5e3))])}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 D.Config:(0,C.isObject)(n)&&((0,S.assign)(e.config,n,{shallow:!1}),s=n,r=!0);break;case D.Consent:if((0,C.isObject)(n)){const{update:t}=function(e,t){const n={};return Object.entries(t).forEach(([e,t])=>{n[e]=!!t}),e.consent=(0,m.assign)(e.consent,n),{update:n}}(e,n);s=t,r=!0}break;case D.Custom:(0,C.isObject)(n)&&(e.custom=(0,S.assign)(e.custom,n),s=n,r=!0);break;case D.Destination:(0,C.isObject)(n)&&"code"in n&&(0,C.isObject)(n.code)&&(o=await async function(e,t){const{code:n,config:o={},env:s={},before:r,next:i,cache:a}=t;if(!(0,y.isFunction)(n.push))return ae({ok:!1,failed:{invalid:{type:"invalid",error:"Destination code must have a push method"}}});const c=o||{init:!1};let l=r?{...c,before:r}:{...c};i&&(l={...l,next:i}),a&&(l={...l,cache:a});const u={...n,config:l,env:le(n.env,s)};let d=u.config.id;if(!d)do{d=(0,y.getId)(5,"abcdefghijklmnopqrstuvwxyz")}while(e.destinations[d]);return e.destinations[d]=u,!1!==u.config.queue&&(u.queuePush=[...e.queue]),se(e,void 0,{},{[d]:u})}(e,n));break;case D.Globals:(0,C.isObject)(n)&&(e.globals=(0,S.assign)(e.globals,n),s=n,r=!0);break;case D.Hook:if((0,C.isObject)(n)&&(0,S.isString)(n.name)&&(0,S.isFunction)(n.fn)){const{name:t,fn:o}=n;e.hooks[t]=o,s=n,r=!0}break;case D.On:if((0,C.isObject)(n)&&(0,S.isString)(n.type)){const{type:t,rules:o}=n;await async function(e,t,n){const o=e.on,s=o[t]||[],r=(0,w.isArray)(n)?n:[n];r.forEach(e=>{s.push(e)}),o[t]=s,L(e,t,r)}(e,t,o)}break;case D.Ready:r=!0;break;case D.Run:o=await async function(e,t){return e.allowed=!0,e.timing=Date.now(),t&&(t.consent&&(e.consent=(0,S.assign)(e.consent,t.consent)),t.user&&(e.user=(0,S.assign)(e.user,t.user)),t.globals&&(e.globals=(0,S.assign)(e.config.globalsStatic||{},t.globals)),t.custom&&(e.custom=(0,S.assign)(e.custom,t.custom))),Object.values(e.destinations).forEach(e=>{e.queuePush=[]}),e.queue=[],e.round++,await se(e)}(e,n),r=!0;break;case D.Session:r=!0;break;case D.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 D.User:(0,C.isObject)(n)&&((0,S.assign)(e.user,n,{shallow:!1}),s=n,r=!0)}return r&&(await async function(e,t,n,o){var s,r;let i,a=n||[];switch(n||(a=e.on[t]||[]),t){case D.Consent:i=o||e.consent;break;case D.Session:i=e.session;break;case D.User:i=o||e.user;break;case D.Custom:i=o||e.custom;break;case D.Globals:i=o||e.globals;break;case D.Config:i=o||e.config;break;case D.Ready:case D.Run:default:i=void 0}let c=!1;for(const[n,o]of Object.entries(e.sources)){if(null==(s=o.config.require)?void 0:s.length){const e=o.config.require.indexOf(t);-1!==e&&o.config.require.splice(e,1)}o.on&&(F(o)?!1===await(0,b.tryCatchAsync)(o.on,o=>G(e,"source",o,{sourceId:n,type:t}))(t,i)&&(c=!0):(o.queueOn=o.queueOn||[],o.queueOn.push({type:t,data:i})))}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:i});W(e,o,n,t,i)}});for(const[t,n]of Object.entries(e.sources))F(n)&&(null==(r=n.queueOn)?void 0:r.length)&&await R(e,n,t);return Object.keys(e.pending.destinations).length>0&&await async function(e,t){var n;for(const[o,s]of Object.entries(e.pending.destinations)){if(!e.pending.destinations[o]||e.destinations[o])continue;const r=null==(n=s.config)?void 0:n.require;if(!r)continue;const i=r.indexOf(t);if(-1===i)continue;if(r.splice(i,1),r.length>0)continue;delete e.pending.destinations[o];const a=ce(s);!1!==a.config.queue&&(a.queuePush=[...e.queue]),e.destinations[o]=a}}(e,t),L(e,t,a,o),!c}(e,t,void 0,s),o=await se(e)),o||ae({ok:!0})}function pe(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:l={},user:u=e.user,nested:d=[],consent:p=e.consent,id:f=(0,S.getSpanId)(),trigger:g="",entity:h=n,action:m=o,timing:v=0,source:y={type:"collector",schema:"4"}}=t;return{name:r,data:i,context:a,globals:c,custom:l,user:u,nested:d,consent:p,id:f,trigger:g,entity:h,action:m,timestamp:s,timing:v,source:y}}function fe(e={}){var t,n,o;const s=null!=(t=e.maxEntries)?t:1e4,r=null!=(n=e.lowWaterMark)?n:.8,i=null!=(o=e.sweepIntervalMs)?o:6e4,a=Math.floor(s*r),c=new Map,l={hits:0,misses:0,populates:0,writes:0,deletes:0,evictions_entries:0,evictions_ttl:0};let u;return i>0&&(u=setInterval(function(){const e=Date.now();let t=0;for(const[n,o]of c)void 0!==o.expires&&o.expires<=e&&(c.delete(n),t++);l.evictions_ttl+=t},i),u&&"function"==typeof u.unref&&u.unref()),{type:"memory",config:{},get(e){const t=c.get(e);if(t)return void 0!==t.expires&&t.expires<=Date.now()?(c.delete(e),l.evictions_ttl++,void l.misses++):(c.delete(e),c.set(e,t),l.hits++,t.value);l.misses++},set(e,t,n){const o=!c.has(e);o||c.delete(e),c.set(e,{value:t,expires:void 0!==n?Date.now()+n:void 0}),l.writes++,o&&l.populates++,c.size>s&&function(){if(c.size<=s)return;const e=c.size-a;let t=0;for(const n of c.keys()){if(t>=e)break;c.delete(n),t++}l.evictions_entries+=t}()},delete(e){c.delete(e)&&l.deletes++},get counters(){return{...l}},destroy(){void 0!==u&&(clearInterval(u),u=void 0),c.clear()}}}function ge(e,t){const{cacheConfig:n,cacheStore:o,namespace:s,logger:r,storeId:i,collector:a}=t,c=(e,t)=>{if(!a)return;const n=A(a,{stepId:`store.${i}`,stepType:"store",phase:"in",eventId:"",now:Date.now()});n.meta={op:"cache",cached:"hit"===t,status:t,key:e},(0,j.emitStep)(a,n)},l={hits:0,misses:0,populates:0,writes:0,deletes:0,inflight_dedups:0},u=n.rules.map(e=>({match:e.match?(0,j.compileMatcher)(e.match):()=>!0,ttl:e.ttl})),d=e=>`${s}:${e}`;function p(e,t){const n=void 0===t?{key:e}:{key:e,value:t};return u.find(e=>e.match(n))}const f=new Map;return{type:e.type,config:e.config,setup:e.setup,get counters(){return{...l}},async get(t){const n=d(t),s=await o.get(n);if(void 0!==s)return l.hits++,c(t,"hit"),s;const r=f.get(n);if(r)return l.inflight_dedups++,c(t,"hit"),r;l.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),l.populates++}catch(e){g("set",t,e)}return s}finally{f.delete(n)}})();return f.set(n,i),i},async set(t,n,s){l.writes++,await e.set(t,n,s);const r=p(t,n);if(r)try{await o.set(d(t),n,1e3*r.ttl)}catch(e){g("set",t,e)}},async delete(t){l.deletes++,await e.delete(t);try{await o.delete(d(t))}catch(e){g("delete",t,e)}}};function g(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 he(e,t,n){const o=`store.${n}`,s=(0,O.useHooks)(t.get,"StoreGet",e.hooks,e.logger),r=(0,O.useHooks)(t.set,"StoreSet",e.hooks,e.logger),i=(0,O.useHooks)(t.delete,"StoreDelete",e.hooks,e.logger);t.get=async t=>{const n=Date.now(),r=A(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});r.meta={op:"get",key:t},(0,O.emitStep)(e,r);try{const r=await s(t),i=Date.now(),a=A(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:i});return a.durationMs=i-n,a.meta={op:"get",key:t},(0,O.emitStep)(e,a),r}catch(s){const r=Date.now(),i=A(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,O.emitStep)(e,i),s}},t.set=async(t,n,s)=>{const i=Date.now(),a=A(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:i});a.meta={op:"set",key:t,value:n},(0,O.emitStep)(e,a);try{await r(t,n,s);const a=Date.now(),c=A(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:a});c.durationMs=a-i,c.meta={op:"set",key:t,value:n},(0,O.emitStep)(e,c)}catch(s){const r=Date.now(),a=A(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:r});throw a.durationMs=r-i,a.meta={op:"set",key:t,value:n},a.error=s instanceof Error?{name:s.name,message:s.message}:{message:String(s)},(0,O.emitStep)(e,a),s}},t.delete=async t=>{const n=Date.now(),s=A(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});s.meta={op:"delete",key:t},(0,O.emitStep)(e,s);try{await i(t);const s=Date.now(),r=A(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:s});r.durationMs=s-n,r.meta={op:"delete",key:t},(0,O.emitStep)(e,r)}catch(s){const r=Date.now(),i=A(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,O.emitStep)(e,i),s}}}async function me(e){var t,n;const o=(0,v.assign)({globalsStatic:{},sessionStatic:{},run:!0,queueMax:1e3},e,{merge:!1,extend:!1}),s={level:null==(t=e.logger)?void 0:t.level,handler:null==(n=e.logger)?void 0:n.handler},r=(0,v.createLogger)(s),i={...o.globalsStatic,...e.globals},a={allowed:!1,config:o,consent:e.consent||{},custom:e.custom||{},destinations:{},transformers:{},stores:{},globals:i,hooks:e.hooks||{},observers:new Set,logger:r,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};var c,l;a.push=function(e,t){const n=(0,q.useHooks)(async(n,o={})=>await(0,q.tryCatchAsync)(async()=>{var s;const r=Date.now(),{id:i,ingest:a,respond:c,mapping:l,preChain:u,include:d,exclude:p}=o;let f=c,g=n;const h=d||p?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,p):void 0,m=null!=a?a:(0,q.createIngest)(i||"unknown");if(l){const t=await(0,q.processEventMapping)(g,l,e);if(t.ignore)return ae({ok:!0});if(l.consent&&!(0,q.getGrantedConsent)(l.consent,e.consent,t.event.consent))return ae({ok:!0});g=t.event}if((null==u?void 0:u.length)&&e.transformers&&Object.keys(e.transformers).length>0){const n=await K(e,e.transformers,u,g,m,f,i?`source.${i}.next`:void 0);if(null===n.event)return ae({ok:!0});if(n.stopped)return n.respond&&(f=n.respond),ae({ok:!0});if(n.respond&&(f=n.respond),Array.isArray(n.event)){const o=await Promise.all(n.event.map(async n=>{const o=t(n),s=pe(e,o);return se(e,s,{id:i,ingest:m,respond:f},h)}));if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count+=n.event.length,t.lastAt=Date.now(),t.duration+=Date.now()-r}return null!=(s=o[0])?s:ae({ok:!0})}g=n.event}const v=t(g),y=pe(e,v),w=await se(e,y,{id:i,ingest:m,respond:f},h);if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count++,t.lastAt=Date.now(),t.duration+=Date.now()-r}return w},t=>{if(t instanceof q.FatalError)throw t;return e.status.failed++,e.logger.error("push failed",{event:n,ingest:o.ingest,error:t}),ae({ok:!1})})(),"Push",e.hooks,e.logger);return async(t,o)=>{const s="string"==typeof t.id?t.id:"",r=Date.now();(0,q.emitStep)(e,A(e,{stepId:"collector.push",stepType:"collector",phase:"in",eventId:s,now:r}));try{const i=await n(t,o),a=Date.now(),c=A(e,{stepId:"collector.push",stepType:"collector",phase:"out",eventId:s,now:a});return c.durationMs=a-r,c.outEvent=i,(0,q.emitStep)(e,c),i}catch(t){const n=Date.now(),o=A(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,q.emitStep)(e,o),t}}}(a,e=>({timing:Math.round((Date.now()-a.timing)/10)/100,source:{type:"collector",schema:"4",version:"4.1.1-next-1779822275564"},...e})),a.command=(c=a,l=de,(0,x.useHooks)(async(e,t,n)=>await(0,x.tryCatchAsync)(async()=>await l(c,e,t,n),n=>{if(n instanceof x.FatalError)throw n;return c.status.failed++,c.logger.error("command failed",{command:e,data:t,error:n}),ae({ok:!1})})(),"Command",c.hooks,c.logger));const u=e.stores||{};return a.stores=await async function(e,t={}){var n;const o={};for(const[n,s]of Object.entries(t)){const{code:t,config:r={},env:i={}}=s,a=e.logger.scope("store").scope(n),c={collector:e,logger:a,id:n,config:r,env:i},l=await t(c);o[n]=l}const s=t,r=function(e){const t={};for(const n of Object.keys(e))t[n]="WHITE";const n=[],o=[];function s(r){var i;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 c=null==(i=e[r].cache)?void 0:i.store;if(void 0!==c){if(!(c in e))throw new Error(`Store "${r}" cache.store references "${c}", which is not declared in flow.stores`);s(c)}o.pop(),t[r]="BLACK",n.push(r)}for(const n of Object.keys(e))"WHITE"===t[n]&&s(n);return n}(s);for(const t of r){const r=s[t].cache;if(!r)continue;let i,a;void 0!==r.store?(i=o[r.store],a=r.store):(o.__cache||(o.__cache=fe()),i=o.__cache,a="__cache");const c=null!=(n=r.namespace)?n:t;e.logger.scope("store-cache").scope(t).info(`store "${t}" caches with namespace "${c}:" via ${a}`),o[t]=ge(o[t],{storeId:t,cacheConfig:r,cacheStore:i,namespace:c,logger:e.logger.scope("store-cache").scope(t),collector:e})}for(const[t,n]of Object.entries(o))"__cache"!==t&&he(e,n,t);return o}(a,u),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)}}}(u,a.stores,e),a.stores.__cache||(a.stores.__cache=fe()),a.destinations=await async function(e,t={}){var n,o;const s={};for(const[r,i]of Object.entries(t))(null==(o=null==(n=i.config)?void 0:n.require)?void 0:o.length)?e.pending.destinations[r]=i:s[r]=ce(i);return s}(a,e.destinations||{}),a.transformers=await async function(e,t={}){var n,o,s,r;const i={};for(const[a,c]of Object.entries(t)){const{code:t,env:l={}}=c,u=(0,I.validateStepEntry)(c,"Transformer");if(!u.ok){e.logger.warn(`Transformer ${a} invalid (${u.code}): ${u.reason}. Skipping.`);continue}const{config:d}=M(c,"before"),{config:p}=M({...c,config:d},"next"),f=Object.keys(l).length>0?{...p,env:l}:p,{cache:g}=c,h=g?{...f,cache:g}:f,m=e.logger.scope("transformer").scope(a),v={collector:e,logger:m,id:a,ingest:(0,I.createIngest)(a),config:h,env:l},y=null!=t?t:e=>{const t=c.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 ${a}: \`${n.join(", ")}\` ignored at transformer position (only event-mutating fields apply).`),{type:"pass",config:e.config,push:async n=>{const o=await(0,I.processEventMapping)(n,t,e.collector);return!o.ignore&&{event:o.event}}}}return{type:"pass",config:e.config,push:e=>({event:e})}},w=await y(v);void 0!==c.before&&void 0===(null==(n=w.config)?void 0:n.before)&&(w.config={...null!=(o=w.config)?o:{},before:c.before}),void 0!==c.next&&void 0===(null==(s=w.config)?void 0:s.next)&&(w.config={...null!=(r=w.config)?r:{},next:c.next}),i[a]=w}return i}(a,e.transformers||{}),a}async function ve(e){e=e||{};const t=await me(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 ae({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 async function(e,t={}){var n;const o={};for(const[s,r]of Object.entries(t)){const t=await B(e,s,r);if(!t)continue;const i=null==(n=r.config)?void 0:n.require;t.config={...t.config,init:!1,...i?{require:[...i]}:{}},o[s]=t}Object.assign(e.sources,o);for(const t of Object.keys(o)){const n=e.sources[t];let o=!1;n.init&&await(0,k.tryCatchAsync)(n.init.bind(n),n=>{if(n instanceof k.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,F(n)&&await R(e,n,t))}return o}(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 l=Object.values(t.sources).filter(e=>"elb"!==e.type),u=l.find(e=>e.config.primary);return u?c=u.push:l.length>0&&(c=l[0].push),{collector:t,elb:c}}var ye=async e=>{let t;return{get flow(){return t},trigger:(n,o)=>async n=>{var s,r,i,a,c,l,u,d,p;const f=o||{};if(f.url){const e=new URL(f.url);window.history.replaceState({},"",e.pathname+e.search)}if(f.referrer&&Object.defineProperty(document,"referrer",{value:f.referrer,configurable:!0}),f.sessionData){const e=f.sessionKey||"elbSessionId";localStorage.setItem(e,JSON.stringify(f.sessionData))}if(f.deviceId){const e=f.deviceKey||"elbDeviceId";localStorage.setItem(e,f.deviceId)}if(!t){const n=await ve({...e,run:null==(s=e.run)||s});t={collector:n.collector,elb:n.elb};const o=f.sessionKey||(null==(c=null==(a=null==(i=null==(r=e.sources)?void 0:r.session)?void 0:i.config)?void 0:a.settings)?void 0:c.sessionKey)||"elbSessionId",g=f.deviceKey||(null==(p=null==(d=null==(u=null==(l=e.sources)?void 0:l.session)?void 0:u.config)?void 0:d.settings)?void 0:p.deviceKey)||"elbDeviceId";localStorage.removeItem(o),localStorage.removeItem(g),f.sessionData&&localStorage.setItem(o,JSON.stringify(f.sessionData)),f.deviceId&&localStorage.setItem(g,f.deviceId),e.consent&&await t.collector.command("consent",e.consent)}}}},we=(e,t)=>{if(!e||"object"!=typeof e)return;const n=e,o=t.localStorage;if(n.sessionData&&"object"==typeof n.sessionData){const e="string"==typeof n.sessionKey?n.sessionKey:"elbSessionId";o.setItem(e,JSON.stringify(n.sessionData))}if("string"==typeof n.deviceId){const e="string"==typeof n.deviceKey?n.deviceKey:"elbDeviceId";o.setItem(e,n.deviceId)}};//# sourceMappingURL=dev.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})},i={};r(i,{examples:()=>p,schemas:()=>a}),module.exports=(e=i,((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 a={};r(a,{SettingsSchema:()=>u,settings:()=>d});var c=require("@walkeros/core/dev"),l=require("@walkeros/core/dev"),u=l.z.object({storage:l.z.boolean().default(!1).describe("Enable persistent storage for session/device IDs").optional(),consent:l.z.union([l.z.string(),l.z.array(l.z.string())]).describe("Consent key(s) required to enable storage mode").optional(),length:l.z.number().default(30).describe("Session timeout in minutes").optional(),pulse:l.z.boolean().default(!1).describe("Keep session alive on each event").optional(),sessionKey:l.z.string().default("elbSessionId").describe("Storage key for session ID").optional(),sessionStorage:l.z.enum(["local","session"]).default("local").describe("Storage type for session").optional(),deviceKey:l.z.string().default("elbDeviceId").describe("Storage key for device ID").optional(),deviceStorage:l.z.enum(["local","session"]).default("local").describe("Storage type for device").optional(),deviceAge:l.z.number().default(30).describe("Device ID age in days").optional(),cb:l.z.any().describe("Custom session callback function or false to disable").optional(),clickIds:l.z.array(l.ClickIdEntrySchema).describe("Custom click-ID registry. Entries with a `param` matching a default override the platform name in place; new params append to the end of the priority list.").optional()}),d=(0,c.zodToSchema)(u),p={};r(p,{createTrigger:()=>ye,step:()=>f,trigger:()=>we});var f={};r(f,{newMarketingSession:()=>g,returningVisitor:()=>h});var g={title:"New marketing session",description:"A visit with UTM parameters starts a new session and emits walker user, session, and session start calls.",trigger:{type:"load",options:{url:"https://example.com/?utm_source=google&utm_medium=cpc&utm_campaign=winter-sale"}},in:{storage:!0},out:[["elb","user",{session:"s3ss10n-id",device:"d3v1c3-id"}],["elb","session",{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}],["elb",{name:"session start",data:{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}}]]},h={title:"Returning visitor",description:"A returning visit with a google referrer reuses the stored device id and increments the session count.",trigger:{type:"load",options:{referrer:"https://google.com"}},in:{storage:!0},out:[["elb","user",{session:"n3w-s3ss10n",device:"d3v1c3-id"}],["elb","session",{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}],["elb",{name:"session start",data:{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}}]]},m=require("@walkeros/core"),v=require("@walkeros/core"),y=require("@walkeros/core"),w=(require("@walkeros/core"),require("@walkeros/core")),b=require("@walkeros/core"),k=require("@walkeros/core"),I=require("@walkeros/core"),S=require("@walkeros/core"),C=require("@walkeros/core"),q=require("@walkeros/core"),x=require("@walkeros/core"),O=require("@walkeros/core"),j=require("@walkeros/core"),D={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"};function A(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}}function E(e,t){return e.storeId&&t.stores[e.storeId]?t.stores[e.storeId]:t.stores.__cache}function $(e){var t;const n={};for(const[o,s]of Object.entries(e)){const e=null==(t=s.config)?void 0:t.next;"string"==typeof e||Array.isArray(e)&&e.every(e=>"string"==typeof e)?n[o]={next:e}:n[o]={}}return n}function M(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 _(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 T(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,I.createIngest)(n),config:t.config,env:H(t.config.env)};s.debug("init");const i=await(0,I.useHooks)(t.init,"TransformerInit",e.hooks,e.logger)(r);if(!1===i)return!1;t.config={...i||t.config,env:(null==i?void 0:i.env)||t.config.env,init:!0},s.debug("init done")}return!0}async function P(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:{...H(t.config.env),...r?{respond:r}:{}}};a.debug("push",{event:o.name});const l="string"==typeof o.id?o.id:"",u=Date.now(),d=A(e,{stepId:(0,I.stepId)("transformer",n),stepType:"transformer",phase:"in",eventId:l,now:u});(0,I.emitStep)(e,d);try{const s=await(0,I.useHooks)(t.push,"TransformerPush",e.hooks,e.logger)(o,c),r=Date.now(),i=A(e,{stepId:(0,I.stepId)("transformer",n),stepType:"transformer",phase:"out",eventId:l,now:r});return i.durationMs=r-u,i.outEvent=s,(0,I.emitStep)(e,i),a.debug("push done"),s}catch(t){const o=Date.now(),s=A(e,{stepId:(0,I.stepId)("transformer",n),stepType:"transformer",phase:"error",eventId:l,now:o});throw s.durationMs=o-u,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},(0,I.emitStep)(e,s),t}}function z(e,t){return e?{...e,_meta:{...e._meta,path:[...e._meta.path]}}:(0,I.createIngest)(t)}async function K(e,t,n,o,s,r,i){var a,c,l,u,d,p,f,g;s||(s=(0,I.createIngest)(null!=(a=n[0])?a:"chain")),i&&s._meta&&(s._meta.chainPath=i);let h=o,m=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:m};if(s&&s._meta&&(s._meta.hops++,s._meta.path.push(o)),!await(0,I.tryCatchAsync)(T,t=>{if(t instanceof I.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:m};if(i&&void 0!==(null==(l=null==(c=r.config)?void 0:c.chainMocks)?void 0:l[i])){const t=r.config.chainMocks[i];e.logger.scope(`transformer:${r.type||"unknown"}`).debug("chainMock",{chain:i}),h=t;continue}if(void 0!==(null==(u=r.config)?void 0:u.mock)){e.logger.scope(`transformer:${r.type||"unknown"}`).debug("mock"),h=r.config.mock;continue}if(null==(d=r.config)?void 0:d.disabled)continue;const a=null==(p=r.config)?void 0:p.cache,v=a?(0,I.compileCache)(a):void 0,y=v?E(v,e):void 0;let w;if(v&&y){const e=(0,I.buildCacheContext)(s,h),t=await(0,I.checkCache)(v,y,e);if("HIT"===(null==t?void 0:t.status)&&t.value){if(h=t.value,v.stop)return{event:h,respond:m,stopped:!0};continue}"MISS"===(null==t?void 0:t.status)&&(w={key:t.key,ttl:t.rule.ttl})}const b=r.config.before;if(b){const n=(0,I.getNextSteps)(b,(0,I.buildCacheContext)(s,h));if(1===n.length){const o=_(n[0],$(t));if(o.length>0){const n=await K(e,t,o,h,s,m,i);if(null===n.event)return{event:null,respond:null!=(f=n.respond)?f:m};if(n.stopped)return{event:Array.isArray(n.event)?n.event[0]:n.event,respond:null!=(g=n.respond)?g:m,stopped:!0};n.respond&&(m=n.respond),h=Array.isArray(n.event)?n.event[0]:n.event}}else n.length>1&&await Promise.all(n.map(n=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(n,$(t)),h,z(s,n),void 0,i)))}const k=await(0,I.tryCatchAsync)(P,t=>(e.logger.scope(`transformer:${r.type||"unknown"}`).error("Push failed",{error:t}),!1))(e,r,o,h,s,m);if(!1===k)return{event:null,respond:m};if(Array.isArray(k)){const r=n.slice(n.indexOf(o)+1),a=await Promise.all(k.map(async n=>{const o=n.event||h,a=z(s,"unknown");if(n.next){const s=(0,I.getNextSteps)(n.next,(0,I.buildCacheContext)(a,o));if(0===s.length)return{event:o,respond:m};if(1===s.length){const n=_(s[0],$(t));return n.length>0?K(e,t,n,o,a,m,i):{event:o,respond:m}}return(await Promise.all(s.map(n=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(n,$(t)),o,z(a,n),void 0,i)))).map(e=>({event:e.event,respond:void 0}))}return r.length>0?K(e,t,r,o,a,m,i):{event:o,respond:m}}));let c=m;const l=[];for(const e of a.flat())if(null!==e)if(e&&"object"==typeof e&&"event"in e){const t=e;if(t.respond&&(c=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:c}:1===l.length?{event:l[0],respond:c}:{event:l,respond:c}}if(k&&"object"==typeof k){const{event:n,respond:o,next:r}=k;if(o&&(m=o),void 0!==r){const o=(0,I.getNextSteps)(r,(0,I.buildCacheContext)(s,h));if(0===o.length){n&&(h=n);continue}if(1===o.length){const a=_(o[0],$(t));return a.length>0?K(e,t,a,n||h,s,m,i):(e.logger.warn(`Branch target not found: ${JSON.stringify(r)}`),{event:null,respond:m})}return await Promise.all(o.map(o=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${o} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(o,$(t)),n||h,z(s,o),void 0,i))),{event:null,respond:void 0}}n&&(h=n)}w&&y&&(0,I.storeCache)(y,w.key,h,w.ttl);const S=r.config.next,C="string"==typeof S||Array.isArray(S)&&S.every(e=>"string"==typeof e),q=void 0!==S&&!C;if((!k||"object"==typeof k&&!k.next)&&q){const n=(0,I.getNextSteps)(r.config.next,(0,I.buildCacheContext)(s,h));if(1===n.length){const o=_(n[0],$(t));return o.length>0?K(e,t,o,h,s,m,i):{event:h,respond:m}}return n.length>1?(await Promise.all(n.map(n=>(0,I.tryCatchAsync)(K,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,_(n,$(t)),h,z(s,n),void 0,i))),{event:null,respond:void 0}):{event:h,respond:m}}}return{event:h,respond:m}}function H(e){return e&&(0,I.isObject)(e)?e:{}}function N(e){return"string"==typeof e||!(!Array.isArray(e)||!e.every(e=>"string"==typeof e))}async function R(e,t,n){var o,s;if(!t.on||!(null==(o=t.queueOn)?void 0:o.length))return;const r=t.queueOn;t.queueOn=[];const i=n||(null==(s=t.config)?void 0:s.id)||"unknown";for(const{type:n,data:o}of r)await(0,k.tryCatchAsync)(t.on,t=>{if(t instanceof k.FatalError)throw t;e.status.failed++,e.logger.scope("source").error("source on flush failed",{sourceId:i,type:n,error:t})})(n,o)}function F(e){var t;return Boolean(e.config.init)&&!(null==(t=e.config.require)?void 0:t.length)}async function B(e,t,n){var o;const{code:s,config:r={},env:i={},primary:a,next:c,before:l,cache:u}=n,d=u,p=d?(0,k.compileCache)({...d,stop:null==(o=d.stop)||o}):void 0,f=N(c)?_(c,$(e.transformers)):void 0,g=N(l)?_(l,$(e.transformers)):void 0,h=i.push,m=null!=h?h:e.push,v=Boolean(h),y=async(n,o,s)=>{var i;let a;const u=null!=g?g:void 0!==l?(()=>{const t=(0,k.getNextSteps)(l,(0,k.buildCacheContext)(s.ingest));return 0===t.length?[]:_(1===t.length?t[0]:t,$(e.transformers))})():[];let d=[n];if(u.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const o=await K(e,e.transformers,u,n,s.ingest,s.respond,`source.${t}.before`);if(null===o.event)return{ok:!0};if(o.stopped)return o.respond&&(s.respond=o.respond),{ok:!0};o.respond&&(s.respond=o.respond),d=Array.isArray(o.event)?o.event:[o.event]}if(p){const t=E(p,e);if(t){const n=(0,k.buildCacheContext)(s.ingest),o=await(0,k.checkCache)(p,t,n);if(o){if("HIT"===o.status&&void 0!==o.value&&p.stop){let t=o.value;return o.rule.update&&(t=await(0,k.applyUpdate)(t,o.rule.update,{...n,cache:{status:"HIT"}},e)),null==(i=s.respond)||i.call(s,t),{ok:!0}}if("MISS"===o.status&&p.stop&&s.respond){const r=s.respond,i=o.rule.update,c={...n,cache:{status:"MISS"}},l=o.key,u=o.rule.ttl,d=n=>{(0,k.storeCache)(t,l,n,u),i?a=(async()=>{const t=await(0,k.applyUpdate)(n,i,c,e);r(t)})():r(n)};s.respond=d}"MISS"!==o.status||p.stop||(0,k.storeCache)(t,o.key,!0,o.rule.ttl)}}}const h=f?{kind:"single",preChain:f}:void 0!==c?(()=>{const t=(0,k.getNextSteps)(c,(0,k.buildCacheContext)(s.ingest));return 0===t.length?{kind:"single",preChain:[]}:1===t.length?{kind:"single",preChain:_(t[0],$(e.transformers))}:{kind:"many",branches:t.map(t=>_(t,$(e.transformers)))}})():{kind:"single",preChain:[]};let y={ok:!0};for(const n of d)"many"===h.kind?(await Promise.all(h.branches.map((i,a)=>(0,k.tryCatchAsync)(async()=>v?m(n):m(n,{...o,id:t,ingest:z(s.ingest,`${t}.${a}`),respond:void 0,mapping:r,preChain:i}),t=>(e.logger.scope("source:many").error(`many branch ${a} failed`,{error:t}),{ok:!0}))())),y={ok:!0}):y=v?await m(n):await m(n,{...o,id:t,ingest:s.ingest,respond:s.respond,mapping:r,preChain:h.preChain});return a&&await a,y},w=async n=>{const o=(0,k.createIngest)(t);if(!r.ingest||void 0===n)return o;const s=await(0,k.getMappingValue)(n,r.ingest,{collector:e});return{...o,...s,_meta:o._meta}},b=e.logger.scope("source").scope(t),I={command:e.command,sources:e.sources,elb:e.sources.elb.push,logger:b,...i,push:async(e,n={})=>{const o={ingest:(0,k.createIngest)(t),respond:void 0};return y(e,n,o)}},S={collector:e,logger:b,id:t,config:r,env:I,withScope:async(e,t,n)=>{const o={ingest:await w(e),respond:t};return n({...I,push:(e,t={})=>y(e,t,o),ingest:o.ingest,respond:o.respond})}},C=await(0,k.tryCatchAsync)(s,n=>{if(n instanceof k.FatalError)throw n;e.status.failed++,e.logger.scope("source").error("source factory failed",{sourceId:t,error:n})})(S);if(!C)return;const q=C.type||"unknown",x=e.logger.scope(q).scope(t);return I.logger=x,a&&(C.config={...C.config,primary:a}),C}function G(e,t,n,o){if(n instanceof w.FatalError)throw n;e.logger.scope("on").error("on callback failed",{kind:t,...o,error:n})}function U(e,t){return{collector:e,logger:e.logger.scope("on").scope(String(t))}}function W(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:le(t.env,t.config.env)};(0,b.tryCatch)(t.on,t=>G(e,"destination",t,{destId:n,type:o}))(o,a)}function L(e,t,n,o){let s;switch(t){case D.Consent:s=o||e.consent;break;case D.Session:s=e.session;break;case D.User:s=o||e.user;break;case D.Custom:s=o||e.custom;break;case D.Globals:s=o||e.globals;break;case D.Config:s=o||e.config;break;case D.Ready:case D.Run:default:s=void 0}if(n.length)switch(t){case D.Consent:!function(e,t,n){const o=n||e.consent,s=U(e,D.Consent);t.forEach(t=>{Object.keys(o).filter(e=>e in t).forEach(n=>{(0,b.tryCatch)(t[n],t=>G(e,"consent",t,{key:n}))(o,s)})})}(e,n,o);break;case D.Ready:!function(e,t){if(!e.allowed)return;const n=U(e,D.Ready);t.forEach(t=>{(0,b.tryCatch)(t,t=>G(e,"ready",t))(void 0,n)})}(e,n);break;case D.Run:!function(e,t){if(!e.allowed)return;const n=U(e,D.Run);t.forEach(t=>{(0,b.tryCatch)(t,t=>G(e,"run",t))(void 0,n)})}(e,n);break;case D.Session:!function(e,t){if(!e.session)return;const n=U(e,D.Session);t.forEach(t=>{(0,b.tryCatch)(t,t=>G(e,"session",t))(e.session,n)})}(e,n);break;default:{const o=U(e,t);n.forEach(n=>{"function"==typeof n&&(0,b.tryCatch)(n,n=>G(e,"generic",n,{type:t}))(s,o)});break}}}function J(e,t,n,o){var s;if(!Number.isFinite(n.max)||n.max<=0)throw new Error(`pushBounded: max must be > 0 (got ${n.max})`);if("dropNewest"===(null!=(s=n.onOverflow)?s:"dropOldest"))return e.length>=n.max?(o&&o([t]),{appended:!1,dropped:1}):(e.push(t),{appended:!0,dropped:0});const r=[];for(;e.length>=n.max;)r.push(e.shift());return e.push(t),r.length>0&&o&&o(r),{appended:!0,dropped:r.length}}var V=new WeakMap;function Y(e,t,n,o){V.get(e)||(V.set(e,!0),t.warn(n,o))}function Q(e){V.delete(e)}var X=Object.freeze({batched:!0});function Z(e){return e===X}function ee(e){return void 0===e?{}:"number"==typeof e?{wait:e}:{wait:e.wait,size:e.size,age:e.age}}function te(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 ne(e,t,n,o){var s;e.dropped[t]||(e.dropped[t]={});const r=e.dropped[t];return r[n]=(null!=(s=r[n])?s:0)+o,r[n]}function oe(e,t,n){if(!e)return[];if(Array.isArray(e)&&e.every(e=>"string"==typeof e))return _(e,t);if("string"==typeof e)return _(e,t);const o=(0,y.getNextSteps)(e,(0,y.buildCacheContext)(n));return 0===o.length?[]:1===o.length?_(o[0],t):_(o,t)}async function se(e,t,n={},o){var s,r,i,a,c,l;const{allowed:u,consent:d,globals:p,user:f}=e;if(!u)return ae({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=J(e.queue,t,{max:n});if(o.dropped>0){const t=ne(e.status,(0,y.stepId)("collector"),"queue",o.dropped);Y(e.queue,e.logger,"collector.queue overflow; oldest events dropped",{buffer:"queue",cap:n,droppedCount:t})}else e.queue.length<n&&Q(e.queue);e.status.in++}o||(o=e.destinations);const g=e.transformers?$(e.transformers):{},h=await Promise.all(Object.entries(o||{}).map(async([o,s])=>{var r,i,a,c;if(s.config.disabled)return{id:o,destination:s,skipped:!0};let l=(s.queuePush||[]).map(e=>({...e,consent:d}));s.queuePush=[],t&&l.push((0,y.clone)(t));const u=n.ingest?{...n.ingest,_meta:{...n.ingest._meta,path:[...n.ingest._meta.path]}}:(0,y.createIngest)("unknown");if(!l.length&&!(null==(r=s.queueOn)?void 0:r.length))return{id:o,destination:s,skipped:!0};if(!l.length&&(null==(i=s.queueOn)?void 0:i.length)){let t=!1;try{t=await re(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 h=[],m=l.filter(t=>{const n=(0,y.getGrantedConsent)(s.config.consent,d,t.consent);if(n)return t.consent=n,h.push(t),!1;const r=A(e,{stepId:(0,y.stepId)("destination",o),stepType:"destination",phase:"skip",eventId:"string"==typeof t.id?t.id:"",now:Date.now()});return r.skipReason="consent",d&&(r.consent={...d}),s.config.consent&&(r.meta={required:{...s.config.consent}}),(0,y.emitStep)(e,r),!0});if(m.length>0){const t=s.queuePush,n=s.config.id||o,r={max:null!=(a=s.config.queueMax)?a:1e3};let i=0;for(const e of m)i+=J(t,e,r).dropped;if(i>0){te(e,n);const o=ne(e.status,(0,y.stepId)("destination",n),"queue",i);Y(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&&Q(t)}if(!h.length)return{id:o,destination:s,queue:l};let v,w,b=!1;try{b=await re(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(!b)return{id:o,destination:s,queue:l};s.dlq||(s.dlq=[]);const k=oe(s.config.before,g,u),I=s.config.next,S=null==(c=s.config)?void 0:c.cache,C=S?(0,y.compileCache)(S):void 0,q=C?E(C,e):void 0;let x=0,O=0;return await Promise.all(h.map(async t=>{let r;if(t.globals=(0,y.assign)(p,t.globals),t.user=(0,y.assign)(f,t.user),(null==C?void 0:C.stop)&&q){const e=(0,y.buildCacheContext)(u,t),n=await(0,y.checkCache)(C,q,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}let i=t,a=n.respond;if(k.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const s=await K(e,e.transformers,k,t,u,n.respond,`destination.${o}.before`);if(null===s.event)return t;s.respond&&(a=s.respond),i=Array.isArray(s.event)?s.event[0]:s.event}if(C&&!C.stop&&q){const e=(0,y.buildCacheContext)(u,i),n=await(0,y.checkCache)(C,q,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}const c=Date.now();let l=!1;const d=await(0,y.tryCatchAsync)(ie,t=>{var n;const r=s.type||"unknown";e.logger.scope(r).error("Push failed",{error:t,event:i.name}),v=t,l=!0;const a=s.dlq,c=s.config.id||o,u={max:null!=(n=s.config.dlqMax)?n:100},d=J(a,[i,t],u);if(d.dropped>0){te(e,c);const t=ne(e.status,(0,y.stepId)("destination",c),"dlq",d.dropped);Y(a,e.logger.scope(s.type||"unknown"),"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:u.max,droppedCount:t})}else a.length<u.max&&Q(a)})(e,s,o,i,u,a);if(x+=Date.now()-c,r&&q&&void 0===s.config.mock&&(0,y.storeCache)(q,r.key,null==d||d,r.ttl),void 0===d||Z(d)||(w=d),Z(d)&&O++,!l&&I){void 0!==d&&(u._response=d);const t=oe(I,g,u);if(t.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const n=await K(e,e.transformers,t,i,u,a,`destination.${o}.next`);n.respond&&(a=n.respond)}}return t})),{id:o,destination:s,error:v,response:w,totalDuration:x,batchedCount:O,allowedCount:h.length}})),m={},v={},w={};for(const t of h){if(t.skipped)continue;const n=t.destination,o={type:n.type||"unknown",data:t.response};te(e,t.id);const u=e.status.destinations[t.id],d=Date.now();if(u.queuePushSize=null!=(r=null==(s=n.queuePush)?void 0:s.length)?r:0,u.dlqSize=null!=(a=null==(i=n.dlq)?void 0:i.length)?a:0,t.error)o.error=t.error,w[t.id]=o,u.failed++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.failed++;else if(t.queue&&t.queue.length)v[t.id]=o;else{const n=null!=(c=t.batchedCount)?c:0,s=null!=(l=t.allowedCount)?l:0;(Math.max(0,s-n)>0||0===s)&&(m[t.id]=o,u.count++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.out++)}}return ae({event:t,...Object.keys(m).length&&{done:m},...Object.keys(v).length&&{queued:v},...Object.keys(w).length&&{failed:w}})}async function re(e,t,n){var o;if(t.init&&!t.config.init){const s=t.type||"unknown",r=e.logger.scope(s),i={collector:e,logger:r,id:n,config:t.config,env:le(t.env,t.config.env)};r.debug("init");const a=Date.now();let c;(0,y.emitStep)(e,A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"init",eventId:"",now:a}));try{c=await(0,y.useHooks)(t.init,"DestinationInit",e.hooks,e.logger)(i)}catch(t){const o=Date.now(),s=A(e,{stepId:(0,y.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,y.emitStep)(e,s),t}if(!1===c)return c;if(t.config={...c||t.config,init:!0},null==(o=t.queueOn)?void 0:o.length){const o=t.queueOn;t.queueOn=[];for(const{type:s,data:r}of o)W(e,t,n,s,r)}r.debug("init done")}return!0}async function ie(e,t,n,o,s,r){var i,a,c,l,u,d,p;const{config:f}=t,g=await(0,y.processEventMapping)(o,f,e);if(g.ignore)return!1;const h=t.type||"unknown",m=e.logger.scope(h),v={collector:e,logger:m,id:n,config:f,data:g.data,rule:g.mapping,ingest:s,env:{...le(t.env,f.env),...r?{respond:r}:{}}};if(void 0!==f.mock)return m.debug("mock",{event:g.event.name}),f.mock;const w=g.mapping,b=g.mappingKey||"* *";if((null==w?void 0:w.batch)&&t.pushBatch&&void 0===f.mock){if(t.batches=t.batches||{},!t.batches[b]){const o={key:b,entries:[],events:[],data:[]},s=ee(w.batch),r=ee(f.batch),p=null!=(a=null!=(i=s.wait)?i:r.wait)?a:3e4,g=null!=(l=null!=(c=s.size)?c:r.size)?l:1e3,h=null!=(d=null!=(u=s.age)?u:r.age)?d:3e4,v=le(t.env,f.env),k=(0,y.debounce)(async()=>{var o;const s=t.batches[b].batched;if(0===s.entries.length)return;const r={key:s.key,entries:s.entries,events:s.events,data:s.data};s.entries=[],s.events=[],s.data=[];const i=r.entries[0],a={collector:e,logger:m,id:n,config:f,data:void 0,rule:i.rule,ingest:i.ingest,env:{...v,...i.respond?{respond:i.respond}:{}}};m.debug("push batch",{events:r.entries.length});const c=t.config.id||n,l=te(e,c),u=Date.now(),d=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"flush",eventId:"",now:u});d.batch={size:r.entries.length,index:0},(0,y.emitStep)(e,d);let p=!0;await(0,y.tryCatchAsync)((0,y.useHooks)(t.pushBatch,"DestinationPushBatch",e.hooks,e.logger),o=>{var s;p=!1;const i=Date.now(),a=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"error",eventId:"",now:i});a.durationMs=i-u,a.error=o instanceof Error?{name:o.name,message:o.message}:{message:String(o)},a.batch={size:r.entries.length,index:0},(0,y.emitStep)(e,a);const d=t.dlq=t.dlq||[],f={max:null!=(s=t.config.dlqMax)?s:100};let g=0;for(const e of r.entries)g+=J(d,[e.event,o],f).dropped;if(g>0){const t=ne(e.status,(0,y.stepId)("destination",c),"dlq",g);Y(d,m,"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:f.max,droppedCount:t})}else d.length<f.max&&Q(d);l.failed+=r.entries.length,l.dlqSize=d.length,e.status.failed+=r.entries.length,m.error("Push batch failed",{error:o instanceof Error?o.message:String(o),entries:r.entries.length})})(r,a),m.debug("push batch done"),l.inFlightBatch=Math.max(0,(null!=(o=l.inFlightBatch)?o:0)-r.entries.length),p&&(l.count+=r.entries.length,l.lastAt=Date.now(),e.status.out+=r.entries.length)},{wait:p,size:g,age:h});t.batches[b]={batched:o,batchFn:()=>{k()},flush:async()=>{await k.flush()}}}const o=t.batches[b];o.batched.entries.push({event:g.event,ingest:s,respond:r,rule:w,data:g.data}),o.batched.events.push(g.event),(0,y.isDefined)(g.data)&&o.batched.data.push(g.data);const h=t.config.id||n,v=te(e,h);return v.inFlightBatch=(null!=(p=v.inFlightBatch)?p:0)+1,o.batchFn(),X}{m.debug("push",{event:g.event.name});const o="string"==typeof g.event.id?g.event.id:"",s=Date.now(),r=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"in",eventId:o,now:s});g.mappingKey&&(r.mappingKey=g.mappingKey),g.event.consent&&(r.consent={...g.event.consent}),(0,y.emitStep)(e,r);try{const r=await(0,y.useHooks)(t.push,"DestinationPush",e.hooks,e.logger)(g.event,v),i=Date.now(),a=A(e,{stepId:(0,y.stepId)("destination",n),stepType:"destination",phase:"out",eventId:o,now:i});return a.durationMs=i-s,a.outEvent=r,g.mappingKey&&(a.mappingKey=g.mappingKey),(0,y.emitStep)(e,a),m.debug("push done"),r}catch(t){const r=Date.now(),i=A(e,{stepId:(0,y.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)},g.mappingKey&&(i.mappingKey=g.mappingKey),(0,y.emitStep)(e,i),t}}}function ae(e){return{ok:!(null==e?void 0:e.failed),...e}}function ce(e){const{code:t,config:n={},env:o={},cache:s}=e,{config:r}=M(e,"before"),{config:i}=M({...e,config:r},"next"),a={...t.config,...n,...i};s&&(a.cache=s);const c=le(t.env,o);return{...t,config:a,env:c}}function le(e,t){return e||t?t?e&&(0,y.isObject)(e)&&(0,y.isObject)(t)?{...e,...t}:t:e:{}}async function ue(e,t,n){const o=Object.entries(e).map(async([e,o])=>{var s;const r=o.destroy;if(!r)return;const i=o.type||"unknown",a=n.scope(i),c={id:e,config:o.config,env:null!=(s=o.env)?s:{},logger:a};try{await Promise.race([r(c),new Promise((n,o)=>setTimeout(()=>o(new Error(`${t} '${e}' destroy timed out`)),5e3))])}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 D.Config:(0,C.isObject)(n)&&((0,S.assign)(e.config,n,{shallow:!1}),s=n,r=!0);break;case D.Consent:if((0,C.isObject)(n)){const{update:t}=function(e,t){const n={};return Object.entries(t).forEach(([e,t])=>{n[e]=!!t}),e.consent=(0,m.assign)(e.consent,n),{update:n}}(e,n);s=t,r=!0}break;case D.Custom:(0,C.isObject)(n)&&(e.custom=(0,S.assign)(e.custom,n),s=n,r=!0);break;case D.Destination:(0,C.isObject)(n)&&"code"in n&&(0,C.isObject)(n.code)&&(o=await async function(e,t){const{code:n,config:o={},env:s={},before:r,next:i,cache:a}=t;if(!(0,y.isFunction)(n.push))return ae({ok:!1,failed:{invalid:{type:"invalid",error:"Destination code must have a push method"}}});const c=o||{init:!1};let l=r?{...c,before:r}:{...c};i&&(l={...l,next:i}),a&&(l={...l,cache:a});const u={...n,config:l,env:le(n.env,s)};let d=u.config.id;if(!d)do{d=(0,y.getId)(5,"abcdefghijklmnopqrstuvwxyz")}while(e.destinations[d]);return e.destinations[d]=u,!1!==u.config.queue&&(u.queuePush=[...e.queue]),se(e,void 0,{},{[d]:u})}(e,n));break;case D.Globals:(0,C.isObject)(n)&&(e.globals=(0,S.assign)(e.globals,n),s=n,r=!0);break;case D.Hook:if((0,C.isObject)(n)&&(0,S.isString)(n.name)&&(0,S.isFunction)(n.fn)){const{name:t,fn:o}=n;e.hooks[t]=o,s=n,r=!0}break;case D.On:if((0,C.isObject)(n)&&(0,S.isString)(n.type)){const{type:t,rules:o}=n;await async function(e,t,n){const o=e.on,s=o[t]||[],r=(0,w.isArray)(n)?n:[n];r.forEach(e=>{s.push(e)}),o[t]=s,L(e,t,r)}(e,t,o)}break;case D.Ready:r=!0;break;case D.Run:o=await async function(e,t){return e.allowed=!0,e.timing=Date.now(),t&&(t.consent&&(e.consent=(0,S.assign)(e.consent,t.consent)),t.user&&(e.user=(0,S.assign)(e.user,t.user)),t.globals&&(e.globals=(0,S.assign)(e.config.globalsStatic||{},t.globals)),t.custom&&(e.custom=(0,S.assign)(e.custom,t.custom))),Object.values(e.destinations).forEach(e=>{e.queuePush=[]}),e.queue=[],e.round++,await se(e)}(e,n),r=!0;break;case D.Session:r=!0;break;case D.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 D.User:(0,C.isObject)(n)&&((0,S.assign)(e.user,n,{shallow:!1}),s=n,r=!0)}return r&&(await async function(e,t,n,o){var s,r;let i,a=n||[];switch(n||(a=e.on[t]||[]),t){case D.Consent:i=o||e.consent;break;case D.Session:i=e.session;break;case D.User:i=o||e.user;break;case D.Custom:i=o||e.custom;break;case D.Globals:i=o||e.globals;break;case D.Config:i=o||e.config;break;case D.Ready:case D.Run:default:i=void 0}let c=!1;for(const[n,o]of Object.entries(e.sources)){if(null==(s=o.config.require)?void 0:s.length){const e=o.config.require.indexOf(t);-1!==e&&o.config.require.splice(e,1)}o.on&&(F(o)?!1===await(0,b.tryCatchAsync)(o.on,o=>G(e,"source",o,{sourceId:n,type:t}))(t,i)&&(c=!0):(o.queueOn=o.queueOn||[],o.queueOn.push({type:t,data:i})))}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:i});W(e,o,n,t,i)}});for(const[t,n]of Object.entries(e.sources))F(n)&&(null==(r=n.queueOn)?void 0:r.length)&&await R(e,n,t);return Object.keys(e.pending.destinations).length>0&&await async function(e,t){var n;for(const[o,s]of Object.entries(e.pending.destinations)){if(!e.pending.destinations[o]||e.destinations[o])continue;const r=null==(n=s.config)?void 0:n.require;if(!r)continue;const i=r.indexOf(t);if(-1===i)continue;if(r.splice(i,1),r.length>0)continue;delete e.pending.destinations[o];const a=ce(s);!1!==a.config.queue&&(a.queuePush=[...e.queue]),e.destinations[o]=a}}(e,t),L(e,t,a,o),!c}(e,t,void 0,s),o=await se(e)),o||ae({ok:!0})}function pe(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:l={},user:u=e.user,nested:d=[],consent:p=e.consent,id:f=(0,S.getSpanId)(),trigger:g="",entity:h=n,action:m=o,timing:v=0,source:y={type:"collector",schema:"4"}}=t;return{name:r,data:i,context:a,globals:c,custom:l,user:u,nested:d,consent:p,id:f,trigger:g,entity:h,action:m,timestamp:s,timing:v,source:y}}function fe(e={}){var t,n,o;const s=null!=(t=e.maxEntries)?t:1e4,r=null!=(n=e.lowWaterMark)?n:.8,i=null!=(o=e.sweepIntervalMs)?o:6e4,a=Math.floor(s*r),c=new Map,l={hits:0,misses:0,populates:0,writes:0,deletes:0,evictions_entries:0,evictions_ttl:0};let u;return i>0&&(u=setInterval(function(){const e=Date.now();let t=0;for(const[n,o]of c)void 0!==o.expires&&o.expires<=e&&(c.delete(n),t++);l.evictions_ttl+=t},i),u&&"function"==typeof u.unref&&u.unref()),{type:"memory",config:{},get(e){const t=c.get(e);if(t)return void 0!==t.expires&&t.expires<=Date.now()?(c.delete(e),l.evictions_ttl++,void l.misses++):(c.delete(e),c.set(e,t),l.hits++,t.value);l.misses++},set(e,t,n){const o=!c.has(e);o||c.delete(e),c.set(e,{value:t,expires:void 0!==n?Date.now()+n:void 0}),l.writes++,o&&l.populates++,c.size>s&&function(){if(c.size<=s)return;const e=c.size-a;let t=0;for(const n of c.keys()){if(t>=e)break;c.delete(n),t++}l.evictions_entries+=t}()},delete(e){c.delete(e)&&l.deletes++},get counters(){return{...l}},destroy(){void 0!==u&&(clearInterval(u),u=void 0),c.clear()}}}function ge(e,t){const{cacheConfig:n,cacheStore:o,namespace:s,logger:r,storeId:i,collector:a}=t,c=(e,t)=>{if(!a)return;const n=A(a,{stepId:`store.${i}`,stepType:"store",phase:"in",eventId:"",now:Date.now()});n.meta={op:"cache",cached:"hit"===t,status:t,key:e},(0,j.emitStep)(a,n)},l={hits:0,misses:0,populates:0,writes:0,deletes:0,inflight_dedups:0},u=n.rules.map(e=>({match:e.match?(0,j.compileMatcher)(e.match):()=>!0,ttl:e.ttl})),d=e=>`${s}:${e}`;function p(e,t){const n=void 0===t?{key:e}:{key:e,value:t};return u.find(e=>e.match(n))}const f=new Map;return{type:e.type,config:e.config,setup:e.setup,get counters(){return{...l}},async get(t){const n=d(t),s=await o.get(n);if(void 0!==s)return l.hits++,c(t,"hit"),s;const r=f.get(n);if(r)return l.inflight_dedups++,c(t,"hit"),r;l.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),l.populates++}catch(e){g("set",t,e)}return s}finally{f.delete(n)}})();return f.set(n,i),i},async set(t,n,s){l.writes++,await e.set(t,n,s);const r=p(t,n);if(r)try{await o.set(d(t),n,1e3*r.ttl)}catch(e){g("set",t,e)}},async delete(t){l.deletes++,await e.delete(t);try{await o.delete(d(t))}catch(e){g("delete",t,e)}}};function g(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 he(e,t,n){const o=`store.${n}`,s=(0,O.useHooks)(t.get,"StoreGet",e.hooks,e.logger),r=(0,O.useHooks)(t.set,"StoreSet",e.hooks,e.logger),i=(0,O.useHooks)(t.delete,"StoreDelete",e.hooks,e.logger);t.get=async t=>{const n=Date.now(),r=A(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});r.meta={op:"get",key:t},(0,O.emitStep)(e,r);try{const r=await s(t),i=Date.now(),a=A(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:i});return a.durationMs=i-n,a.meta={op:"get",key:t},(0,O.emitStep)(e,a),r}catch(s){const r=Date.now(),i=A(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,O.emitStep)(e,i),s}},t.set=async(t,n,s)=>{const i=Date.now(),a=A(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:i});a.meta={op:"set",key:t},(0,O.emitStep)(e,a);try{await r(t,n,s);const a=Date.now(),c=A(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:a});c.durationMs=a-i,c.meta={op:"set",key:t},(0,O.emitStep)(e,c)}catch(n){const s=Date.now(),r=A(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,O.emitStep)(e,r),n}},t.delete=async t=>{const n=Date.now(),s=A(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});s.meta={op:"delete",key:t},(0,O.emitStep)(e,s);try{await i(t);const s=Date.now(),r=A(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:s});r.durationMs=s-n,r.meta={op:"delete",key:t},(0,O.emitStep)(e,r)}catch(s){const r=Date.now(),i=A(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,O.emitStep)(e,i),s}}}async function me(e){var t,n;const o=(0,v.assign)({globalsStatic:{},sessionStatic:{},run:!0,queueMax:1e3},e,{merge:!1,extend:!1}),s={level:null==(t=e.logger)?void 0:t.level,handler:null==(n=e.logger)?void 0:n.handler},r=(0,v.createLogger)(s),i={...o.globalsStatic,...e.globals},a={allowed:!1,config:o,consent:e.consent||{},custom:e.custom||{},destinations:{},transformers:{},stores:{},globals:i,hooks:e.hooks||{},observers:new Set,logger:r,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};var c,l;a.push=function(e,t){const n=(0,q.useHooks)(async(n,o={})=>await(0,q.tryCatchAsync)(async()=>{var s;const r=Date.now(),{id:i,ingest:a,respond:c,mapping:l,preChain:u,include:d,exclude:p}=o;let f=c,g=n;const h=d||p?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,p):void 0,m=null!=a?a:(0,q.createIngest)(i||"unknown");if(l){const t=await(0,q.processEventMapping)(g,l,e);if(t.ignore)return ae({ok:!0});if(l.consent&&!(0,q.getGrantedConsent)(l.consent,e.consent,t.event.consent))return ae({ok:!0});g=t.event}if((null==u?void 0:u.length)&&e.transformers&&Object.keys(e.transformers).length>0){const n=await K(e,e.transformers,u,g,m,f,i?`source.${i}.next`:void 0);if(null===n.event)return ae({ok:!0});if(n.stopped)return n.respond&&(f=n.respond),ae({ok:!0});if(n.respond&&(f=n.respond),Array.isArray(n.event)){const o=await Promise.all(n.event.map(async n=>{const o=t(n),s=pe(e,o);return se(e,s,{id:i,ingest:m,respond:f},h)}));if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count+=n.event.length,t.lastAt=Date.now(),t.duration+=Date.now()-r}return null!=(s=o[0])?s:ae({ok:!0})}g=n.event}const v=t(g),y=pe(e,v),w=await se(e,y,{id:i,ingest:m,respond:f},h);if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count++,t.lastAt=Date.now(),t.duration+=Date.now()-r}return w},t=>{if(t instanceof q.FatalError)throw t;return e.status.failed++,e.logger.error("push failed",{event:n,ingest:o.ingest,error:t}),ae({ok:!1})})(),"Push",e.hooks,e.logger);return async(t,o)=>{const s="string"==typeof t.id?t.id:"",r=Date.now();(0,q.emitStep)(e,A(e,{stepId:"collector.push",stepType:"collector",phase:"in",eventId:s,now:r}));try{const i=await n(t,o),a=Date.now(),c=A(e,{stepId:"collector.push",stepType:"collector",phase:"out",eventId:s,now:a});return c.durationMs=a-r,c.outEvent=i,(0,q.emitStep)(e,c),i}catch(t){const n=Date.now(),o=A(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,q.emitStep)(e,o),t}}}(a,e=>({timing:Math.round((Date.now()-a.timing)/10)/100,source:{type:"collector",schema:"4",version:"4.1.1"},...e})),a.command=(c=a,l=de,(0,x.useHooks)(async(e,t,n)=>await(0,x.tryCatchAsync)(async()=>await l(c,e,t,n),n=>{if(n instanceof x.FatalError)throw n;return c.status.failed++,c.logger.error("command failed",{command:e,data:t,error:n}),ae({ok:!1})})(),"Command",c.hooks,c.logger));const u=e.stores||{};return a.stores=await async function(e,t={}){var n;const o={};for(const[n,s]of Object.entries(t)){const{code:t,config:r={},env:i={}}=s,a=e.logger.scope("store").scope(n),c={collector:e,logger:a,id:n,config:r,env:i},l=await t(c);o[n]=l}const s=t,r=function(e){const t={};for(const n of Object.keys(e))t[n]="WHITE";const n=[],o=[];function s(r){var i;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 c=null==(i=e[r].cache)?void 0:i.store;if(void 0!==c){if(!(c in e))throw new Error(`Store "${r}" cache.store references "${c}", which is not declared in flow.stores`);s(c)}o.pop(),t[r]="BLACK",n.push(r)}for(const n of Object.keys(e))"WHITE"===t[n]&&s(n);return n}(s);for(const t of r){const r=s[t].cache;if(!r)continue;let i,a;void 0!==r.store?(i=o[r.store],a=r.store):(o.__cache||(o.__cache=fe()),i=o.__cache,a="__cache");const c=null!=(n=r.namespace)?n:t;e.logger.scope("store-cache").scope(t).info(`store "${t}" caches with namespace "${c}:" via ${a}`),o[t]=ge(o[t],{storeId:t,cacheConfig:r,cacheStore:i,namespace:c,logger:e.logger.scope("store-cache").scope(t),collector:e})}for(const[t,n]of Object.entries(o))"__cache"!==t&&he(e,n,t);return o}(a,u),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)}}}(u,a.stores,e),a.stores.__cache||(a.stores.__cache=fe()),a.destinations=await async function(e,t={}){var n,o;const s={};for(const[r,i]of Object.entries(t))(null==(o=null==(n=i.config)?void 0:n.require)?void 0:o.length)?e.pending.destinations[r]=i:s[r]=ce(i);return s}(a,e.destinations||{}),a.transformers=await async function(e,t={}){var n,o,s,r;const i={};for(const[a,c]of Object.entries(t)){const{code:t,env:l={}}=c,u=(0,I.validateStepEntry)(c,"Transformer");if(!u.ok){e.logger.warn(`Transformer ${a} invalid (${u.code}): ${u.reason}. Skipping.`);continue}const{config:d}=M(c,"before"),{config:p}=M({...c,config:d},"next"),f=Object.keys(l).length>0?{...p,env:l}:p,{cache:g}=c,h=g?{...f,cache:g}:f,m=e.logger.scope("transformer").scope(a),v={collector:e,logger:m,id:a,ingest:(0,I.createIngest)(a),config:h,env:l},y=null!=t?t:e=>{const t=c.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 ${a}: \`${n.join(", ")}\` ignored at transformer position (only event-mutating fields apply).`),{type:"pass",config:e.config,push:async n=>{const o=await(0,I.processEventMapping)(n,t,e.collector);return!o.ignore&&{event:o.event}}}}return{type:"pass",config:e.config,push:e=>({event:e})}},w=await y(v);void 0!==c.before&&void 0===(null==(n=w.config)?void 0:n.before)&&(w.config={...null!=(o=w.config)?o:{},before:c.before}),void 0!==c.next&&void 0===(null==(s=w.config)?void 0:s.next)&&(w.config={...null!=(r=w.config)?r:{},next:c.next}),i[a]=w}return i}(a,e.transformers||{}),a}async function ve(e){e=e||{};const t=await me(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 ae({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 async function(e,t={}){var n;const o={};for(const[s,r]of Object.entries(t)){const t=await B(e,s,r);if(!t)continue;const i=null==(n=r.config)?void 0:n.require;t.config={...t.config,init:!1,...i?{require:[...i]}:{}},o[s]=t}Object.assign(e.sources,o);for(const t of Object.keys(o)){const n=e.sources[t];let o=!1;n.init&&await(0,k.tryCatchAsync)(n.init.bind(n),n=>{if(n instanceof k.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,F(n)&&await R(e,n,t))}return o}(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 l=Object.values(t.sources).filter(e=>"elb"!==e.type),u=l.find(e=>e.config.primary);return u?c=u.push:l.length>0&&(c=l[0].push),{collector:t,elb:c}}var ye=async e=>{let t;return{get flow(){return t},trigger:(n,o)=>async n=>{var s,r,i,a,c,l,u,d,p;const f=o||{};if(f.url){const e=new URL(f.url);window.history.replaceState({},"",e.pathname+e.search)}if(f.referrer&&Object.defineProperty(document,"referrer",{value:f.referrer,configurable:!0}),f.sessionData){const e=f.sessionKey||"elbSessionId";localStorage.setItem(e,JSON.stringify(f.sessionData))}if(f.deviceId){const e=f.deviceKey||"elbDeviceId";localStorage.setItem(e,f.deviceId)}if(!t){const n=await ve({...e,run:null==(s=e.run)||s});t={collector:n.collector,elb:n.elb};const o=f.sessionKey||(null==(c=null==(a=null==(i=null==(r=e.sources)?void 0:r.session)?void 0:i.config)?void 0:a.settings)?void 0:c.sessionKey)||"elbSessionId",g=f.deviceKey||(null==(p=null==(d=null==(u=null==(l=e.sources)?void 0:l.session)?void 0:u.config)?void 0:d.settings)?void 0:p.deviceKey)||"elbDeviceId";localStorage.removeItem(o),localStorage.removeItem(g),f.sessionData&&localStorage.setItem(o,JSON.stringify(f.sessionData)),f.deviceId&&localStorage.setItem(g,f.deviceId),e.consent&&await t.collector.command("consent",e.consent)}}}},we=(e,t)=>{if(!e||"object"!=typeof e)return;const n=e,o=t.localStorage;if(n.sessionData&&"object"==typeof n.sessionData){const e="string"==typeof n.sessionKey?n.sessionKey:"elbSessionId";o.setItem(e,JSON.stringify(n.sessionData))}if("string"==typeof n.deviceId){const e="string"==typeof n.deviceKey?n.deviceKey:"elbDeviceId";o.setItem(e,n.deviceId)}};//# sourceMappingURL=dev.js.map
package/dist/dev.mjs CHANGED
@@ -1 +1 @@
1
- var e=Object.defineProperty,t=(t,n)=>{for(var o in n)e(t,o,{get:n[o],enumerable:!0})},n={};t(n,{SettingsSchema:()=>i,settings:()=>a});import{zodToSchema as o}from"@walkeros/core/dev";import{z as s,ClickIdEntrySchema as r}from"@walkeros/core/dev";var i=s.object({storage:s.boolean().default(!1).describe("Enable persistent storage for session/device IDs").optional(),consent:s.union([s.string(),s.array(s.string())]).describe("Consent key(s) required to enable storage mode").optional(),length:s.number().default(30).describe("Session timeout in minutes").optional(),pulse:s.boolean().default(!1).describe("Keep session alive on each event").optional(),sessionKey:s.string().default("elbSessionId").describe("Storage key for session ID").optional(),sessionStorage:s.enum(["local","session"]).default("local").describe("Storage type for session").optional(),deviceKey:s.string().default("elbDeviceId").describe("Storage key for device ID").optional(),deviceStorage:s.enum(["local","session"]).default("local").describe("Storage type for device").optional(),deviceAge:s.number().default(30).describe("Device ID age in days").optional(),cb:s.any().describe("Custom session callback function or false to disable").optional(),clickIds:s.array(r).describe("Custom click-ID registry. Entries with a `param` matching a default override the platform name in place; new params append to the end of the priority list.").optional()}),a=o(i),c={};t(c,{createTrigger:()=>vt,step:()=>l,trigger:()=>yt});var l={};t(l,{newMarketingSession:()=>u,returningVisitor:()=>d});var u={title:"New marketing session",description:"A visit with UTM parameters starts a new session and emits walker user, session, and session start calls.",trigger:{type:"load",options:{url:"https://example.com/?utm_source=google&utm_medium=cpc&utm_campaign=winter-sale"}},in:{storage:!0},out:[["elb","user",{session:"s3ss10n-id",device:"d3v1c3-id"}],["elb","session",{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}],["elb",{name:"session start",data:{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}}]]},d={title:"Returning visitor",description:"A returning visit with a google referrer reuses the stored device id and increments the session count.",trigger:{type:"load",options:{referrer:"https://google.com"}},in:{storage:!0},out:[["elb","user",{session:"n3w-s3ss10n",device:"d3v1c3-id"}],["elb","session",{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}],["elb",{name:"session start",data:{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}}]]};import{assign as f}from"@walkeros/core";import{assign as p,createLogger as g}from"@walkeros/core";import{assign as h,buildCacheContext as m,clone as v,compileCache as y,checkCache as w,storeCache as b,createIngest as k,debounce as I,emitStep as S,getId as q,getGrantedConsent as x,getNextSteps as O,isDefined as D,isFunction as C,isObject as j,processEventMapping as A,stepId as E,tryCatchAsync as $,useHooks as M}from"@walkeros/core";import{emitStep as T}from"@walkeros/core";import{isArray as _,FatalError as P}from"@walkeros/core";import{tryCatch as K,tryCatchAsync as z}from"@walkeros/core";import{createIngest as R,FatalError as F,getMappingValue as H,tryCatchAsync as N,getNextSteps as B,compileCache as G,checkCache as U,storeCache as W,applyUpdate as L,buildCacheContext as J}from"@walkeros/core";import{createIngest as V,emitStep as Y,FatalError as Q,isObject as X,stepId as Z,tryCatchAsync as ee,useHooks as te,getNextSteps as ne,compileCache as oe,checkCache as se,storeCache as re,buildCacheContext as ie,validateStepEntry as ae,processEventMapping as ce}from"@walkeros/core";import{assign as le,getSpanId as ue,isFunction as de,isString as fe}from"@walkeros/core";import{isObject as pe}from"@walkeros/core";import{createIngest as ge,emitStep as he,FatalError as me,getGrantedConsent as ve,processEventMapping as ye,tryCatchAsync as we,useHooks as be}from"@walkeros/core";import{FatalError as ke,useHooks as Ie,tryCatchAsync as Se}from"@walkeros/core";import{emitStep as qe,useHooks as xe}from"@walkeros/core";import{compileMatcher as Oe,emitStep as De}from"@walkeros/core";var Ce={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"};function je(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}}function Ae(e,t){return e.storeId&&t.stores[e.storeId]?t.stores[e.storeId]:t.stores.__cache}function Ee(e){var t;const n={};for(const[o,s]of Object.entries(e)){const e=null==(t=s.config)?void 0:t.next;"string"==typeof e||Array.isArray(e)&&e.every(e=>"string"==typeof e)?n[o]={next:e}:n[o]={}}return n}function $e(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 Me(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 Te(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:V(n),config:t.config,env:ze(t.config.env)};s.debug("init");const i=await te(t.init,"TransformerInit",e.hooks,e.logger)(r);if(!1===i)return!1;t.config={...i||t.config,env:(null==i?void 0:i.env)||t.config.env,init:!0},s.debug("init done")}return!0}async function _e(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:{...ze(t.config.env),...r?{respond:r}:{}}};a.debug("push",{event:o.name});const l="string"==typeof o.id?o.id:"",u=Date.now(),d=je(e,{stepId:Z("transformer",n),stepType:"transformer",phase:"in",eventId:l,now:u});Y(e,d);try{const s=await te(t.push,"TransformerPush",e.hooks,e.logger)(o,c),r=Date.now(),i=je(e,{stepId:Z("transformer",n),stepType:"transformer",phase:"out",eventId:l,now:r});return i.durationMs=r-u,i.outEvent=s,Y(e,i),a.debug("push done"),s}catch(t){const o=Date.now(),s=je(e,{stepId:Z("transformer",n),stepType:"transformer",phase:"error",eventId:l,now:o});throw s.durationMs=o-u,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},Y(e,s),t}}function Pe(e,t){return e?{...e,_meta:{...e._meta,path:[...e._meta.path]}}:V(t)}async function Ke(e,t,n,o,s,r,i){var a,c,l,u,d,f,p,g;s||(s=V(null!=(a=n[0])?a:"chain")),i&&s._meta&&(s._meta.chainPath=i);let h=o,m=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:m};if(s&&s._meta&&(s._meta.hops++,s._meta.path.push(o)),!await ee(Te,t=>{if(t instanceof Q)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:m};if(i&&void 0!==(null==(l=null==(c=r.config)?void 0:c.chainMocks)?void 0:l[i])){const t=r.config.chainMocks[i];e.logger.scope(`transformer:${r.type||"unknown"}`).debug("chainMock",{chain:i}),h=t;continue}if(void 0!==(null==(u=r.config)?void 0:u.mock)){e.logger.scope(`transformer:${r.type||"unknown"}`).debug("mock"),h=r.config.mock;continue}if(null==(d=r.config)?void 0:d.disabled)continue;const a=null==(f=r.config)?void 0:f.cache,v=a?oe(a):void 0,y=v?Ae(v,e):void 0;let w;if(v&&y){const e=ie(s,h),t=await se(v,y,e);if("HIT"===(null==t?void 0:t.status)&&t.value){if(h=t.value,v.stop)return{event:h,respond:m,stopped:!0};continue}"MISS"===(null==t?void 0:t.status)&&(w={key:t.key,ttl:t.rule.ttl})}const b=r.config.before;if(b){const n=ne(b,ie(s,h));if(1===n.length){const o=Me(n[0],Ee(t));if(o.length>0){const n=await Ke(e,t,o,h,s,m,i);if(null===n.event)return{event:null,respond:null!=(p=n.respond)?p:m};if(n.stopped)return{event:Array.isArray(n.event)?n.event[0]:n.event,respond:null!=(g=n.respond)?g:m,stopped:!0};n.respond&&(m=n.respond),h=Array.isArray(n.event)?n.event[0]:n.event}}else n.length>1&&await Promise.all(n.map(n=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(n,Ee(t)),h,Pe(s,n),void 0,i)))}const k=await ee(_e,t=>(e.logger.scope(`transformer:${r.type||"unknown"}`).error("Push failed",{error:t}),!1))(e,r,o,h,s,m);if(!1===k)return{event:null,respond:m};if(Array.isArray(k)){const r=n.slice(n.indexOf(o)+1),a=await Promise.all(k.map(async n=>{const o=n.event||h,a=Pe(s,"unknown");if(n.next){const s=ne(n.next,ie(a,o));if(0===s.length)return{event:o,respond:m};if(1===s.length){const n=Me(s[0],Ee(t));return n.length>0?Ke(e,t,n,o,a,m,i):{event:o,respond:m}}return(await Promise.all(s.map(n=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(n,Ee(t)),o,Pe(a,n),void 0,i)))).map(e=>({event:e.event,respond:void 0}))}return r.length>0?Ke(e,t,r,o,a,m,i):{event:o,respond:m}}));let c=m;const l=[];for(const e of a.flat())if(null!==e)if(e&&"object"==typeof e&&"event"in e){const t=e;if(t.respond&&(c=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:c}:1===l.length?{event:l[0],respond:c}:{event:l,respond:c}}if(k&&"object"==typeof k){const{event:n,respond:o,next:r}=k;if(o&&(m=o),void 0!==r){const o=ne(r,ie(s,h));if(0===o.length){n&&(h=n);continue}if(1===o.length){const a=Me(o[0],Ee(t));return a.length>0?Ke(e,t,a,n||h,s,m,i):(e.logger.warn(`Branch target not found: ${JSON.stringify(r)}`),{event:null,respond:m})}return await Promise.all(o.map(o=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${o} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(o,Ee(t)),n||h,Pe(s,o),void 0,i))),{event:null,respond:void 0}}n&&(h=n)}w&&y&&re(y,w.key,h,w.ttl);const I=r.config.next,S="string"==typeof I||Array.isArray(I)&&I.every(e=>"string"==typeof e),q=void 0!==I&&!S;if((!k||"object"==typeof k&&!k.next)&&q){const n=ne(r.config.next,ie(s,h));if(1===n.length){const o=Me(n[0],Ee(t));return o.length>0?Ke(e,t,o,h,s,m,i):{event:h,respond:m}}return n.length>1?(await Promise.all(n.map(n=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(n,Ee(t)),h,Pe(s,n),void 0,i))),{event:null,respond:void 0}):{event:h,respond:m}}}return{event:h,respond:m}}function ze(e){return e&&X(e)?e:{}}function Re(e){return"string"==typeof e||!(!Array.isArray(e)||!e.every(e=>"string"==typeof e))}async function Fe(e,t,n){var o,s;if(!t.on||!(null==(o=t.queueOn)?void 0:o.length))return;const r=t.queueOn;t.queueOn=[];const i=n||(null==(s=t.config)?void 0:s.id)||"unknown";for(const{type:n,data:o}of r)await N(t.on,t=>{if(t instanceof F)throw t;e.status.failed++,e.logger.scope("source").error("source on flush failed",{sourceId:i,type:n,error:t})})(n,o)}function He(e){var t;return Boolean(e.config.init)&&!(null==(t=e.config.require)?void 0:t.length)}async function Ne(e,t,n){var o;const{code:s,config:r={},env:i={},primary:a,next:c,before:l,cache:u}=n,d=u,f=d?G({...d,stop:null==(o=d.stop)||o}):void 0,p=Re(c)?Me(c,Ee(e.transformers)):void 0,g=Re(l)?Me(l,Ee(e.transformers)):void 0,h=i.push,m=null!=h?h:e.push,v=Boolean(h),y=async(n,o,s)=>{var i;let a;const u=null!=g?g:void 0!==l?(()=>{const t=B(l,J(s.ingest));return 0===t.length?[]:Me(1===t.length?t[0]:t,Ee(e.transformers))})():[];let d=[n];if(u.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const o=await Ke(e,e.transformers,u,n,s.ingest,s.respond,`source.${t}.before`);if(null===o.event)return{ok:!0};if(o.stopped)return o.respond&&(s.respond=o.respond),{ok:!0};o.respond&&(s.respond=o.respond),d=Array.isArray(o.event)?o.event:[o.event]}if(f){const t=Ae(f,e);if(t){const n=J(s.ingest),o=await U(f,t,n);if(o){if("HIT"===o.status&&void 0!==o.value&&f.stop){let t=o.value;return o.rule.update&&(t=await L(t,o.rule.update,{...n,cache:{status:"HIT"}},e)),null==(i=s.respond)||i.call(s,t),{ok:!0}}if("MISS"===o.status&&f.stop&&s.respond){const r=s.respond,i=o.rule.update,c={...n,cache:{status:"MISS"}},l=o.key,u=o.rule.ttl,d=n=>{W(t,l,n,u),i?a=(async()=>{const t=await L(n,i,c,e);r(t)})():r(n)};s.respond=d}"MISS"!==o.status||f.stop||W(t,o.key,!0,o.rule.ttl)}}}const h=p?{kind:"single",preChain:p}:void 0!==c?(()=>{const t=B(c,J(s.ingest));return 0===t.length?{kind:"single",preChain:[]}:1===t.length?{kind:"single",preChain:Me(t[0],Ee(e.transformers))}:{kind:"many",branches:t.map(t=>Me(t,Ee(e.transformers)))}})():{kind:"single",preChain:[]};let y={ok:!0};for(const n of d)"many"===h.kind?(await Promise.all(h.branches.map((i,a)=>N(async()=>v?m(n):m(n,{...o,id:t,ingest:Pe(s.ingest,`${t}.${a}`),respond:void 0,mapping:r,preChain:i}),t=>(e.logger.scope("source:many").error(`many branch ${a} failed`,{error:t}),{ok:!0}))())),y={ok:!0}):y=v?await m(n):await m(n,{...o,id:t,ingest:s.ingest,respond:s.respond,mapping:r,preChain:h.preChain});return a&&await a,y},w=async n=>{const o=R(t);if(!r.ingest||void 0===n)return o;const s=await H(n,r.ingest,{collector:e});return{...o,...s,_meta:o._meta}},b=e.logger.scope("source").scope(t),k={command:e.command,sources:e.sources,elb:e.sources.elb.push,logger:b,...i,push:async(e,n={})=>{const o={ingest:R(t),respond:void 0};return y(e,n,o)}},I={collector:e,logger:b,id:t,config:r,env:k,withScope:async(e,t,n)=>{const o={ingest:await w(e),respond:t};return n({...k,push:(e,t={})=>y(e,t,o),ingest:o.ingest,respond:o.respond})}},S=await N(s,n=>{if(n instanceof F)throw n;e.status.failed++,e.logger.scope("source").error("source factory failed",{sourceId:t,error:n})})(I);if(!S)return;const q=S.type||"unknown",x=e.logger.scope(q).scope(t);return k.logger=x,a&&(S.config={...S.config,primary:a}),S}function Be(e,t,n,o){if(n instanceof P)throw n;e.logger.scope("on").error("on callback failed",{kind:t,...o,error:n})}function Ge(e,t){return{collector:e,logger:e.logger.scope("on").scope(String(t))}}function Ue(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:ct(t.env,t.config.env)};K(t.on,t=>Be(e,"destination",t,{destId:n,type:o}))(o,a)}function We(e,t,n,o){let s;switch(t){case Ce.Consent:s=o||e.consent;break;case Ce.Session:s=e.session;break;case Ce.User:s=o||e.user;break;case Ce.Custom:s=o||e.custom;break;case Ce.Globals:s=o||e.globals;break;case Ce.Config:s=o||e.config;break;case Ce.Ready:case Ce.Run:default:s=void 0}if(n.length)switch(t){case Ce.Consent:!function(e,t,n){const o=n||e.consent,s=Ge(e,Ce.Consent);t.forEach(t=>{Object.keys(o).filter(e=>e in t).forEach(n=>{K(t[n],t=>Be(e,"consent",t,{key:n}))(o,s)})})}(e,n,o);break;case Ce.Ready:!function(e,t){if(!e.allowed)return;const n=Ge(e,Ce.Ready);t.forEach(t=>{K(t,t=>Be(e,"ready",t))(void 0,n)})}(e,n);break;case Ce.Run:!function(e,t){if(!e.allowed)return;const n=Ge(e,Ce.Run);t.forEach(t=>{K(t,t=>Be(e,"run",t))(void 0,n)})}(e,n);break;case Ce.Session:!function(e,t){if(!e.session)return;const n=Ge(e,Ce.Session);t.forEach(t=>{K(t,t=>Be(e,"session",t))(e.session,n)})}(e,n);break;default:{const o=Ge(e,t);n.forEach(n=>{"function"==typeof n&&K(n,n=>Be(e,"generic",n,{type:t}))(s,o)});break}}}function Le(e,t,n,o){var s;if(!Number.isFinite(n.max)||n.max<=0)throw new Error(`pushBounded: max must be > 0 (got ${n.max})`);if("dropNewest"===(null!=(s=n.onOverflow)?s:"dropOldest"))return e.length>=n.max?(o&&o([t]),{appended:!1,dropped:1}):(e.push(t),{appended:!0,dropped:0});const r=[];for(;e.length>=n.max;)r.push(e.shift());return e.push(t),r.length>0&&o&&o(r),{appended:!0,dropped:r.length}}var Je=new WeakMap;function Ve(e,t,n,o){Je.get(e)||(Je.set(e,!0),t.warn(n,o))}function Ye(e){Je.delete(e)}var Qe=Object.freeze({batched:!0});function Xe(e){return e===Qe}function Ze(e){return void 0===e?{}:"number"==typeof e?{wait:e}:{wait:e.wait,size:e.size,age:e.age}}function et(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 tt(e,t,n,o){var s;e.dropped[t]||(e.dropped[t]={});const r=e.dropped[t];return r[n]=(null!=(s=r[n])?s:0)+o,r[n]}function nt(e,t,n){if(!e)return[];if(Array.isArray(e)&&e.every(e=>"string"==typeof e))return Me(e,t);if("string"==typeof e)return Me(e,t);const o=O(e,m(n));return 0===o.length?[]:1===o.length?Me(o[0],t):Me(o,t)}async function ot(e,t,n={},o){var s,r,i,a,c,l;const{allowed:u,consent:d,globals:f,user:p}=e;if(!u)return it({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=Le(e.queue,t,{max:n});if(o.dropped>0){const t=tt(e.status,E("collector"),"queue",o.dropped);Ve(e.queue,e.logger,"collector.queue overflow; oldest events dropped",{buffer:"queue",cap:n,droppedCount:t})}else e.queue.length<n&&Ye(e.queue);e.status.in++}o||(o=e.destinations);const g=e.transformers?Ee(e.transformers):{},I=await Promise.all(Object.entries(o||{}).map(async([o,s])=>{var r,i,a,c;if(s.config.disabled)return{id:o,destination:s,skipped:!0};let l=(s.queuePush||[]).map(e=>({...e,consent:d}));s.queuePush=[],t&&l.push(v(t));const u=n.ingest?{...n.ingest,_meta:{...n.ingest._meta,path:[...n.ingest._meta.path]}}:k("unknown");if(!l.length&&!(null==(r=s.queueOn)?void 0:r.length))return{id:o,destination:s,skipped:!0};if(!l.length&&(null==(i=s.queueOn)?void 0:i.length)){let t=!1;try{t=await st(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 I=[],q=l.filter(t=>{const n=x(s.config.consent,d,t.consent);if(n)return t.consent=n,I.push(t),!1;const r=je(e,{stepId:E("destination",o),stepType:"destination",phase:"skip",eventId:"string"==typeof t.id?t.id:"",now:Date.now()});return r.skipReason="consent",d&&(r.consent={...d}),s.config.consent&&(r.meta={required:{...s.config.consent}}),S(e,r),!0});if(q.length>0){const t=s.queuePush,n=s.config.id||o,r={max:null!=(a=s.config.queueMax)?a:1e3};let i=0;for(const e of q)i+=Le(t,e,r).dropped;if(i>0){et(e,n);const o=tt(e.status,E("destination",n),"queue",i);Ve(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&&Ye(t)}if(!I.length)return{id:o,destination:s,queue:l};let O,D,C=!1;try{C=await st(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(!C)return{id:o,destination:s,queue:l};s.dlq||(s.dlq=[]);const j=nt(s.config.before,g,u),A=s.config.next,M=null==(c=s.config)?void 0:c.cache,T=M?y(M):void 0,_=T?Ae(T,e):void 0;let P=0,K=0;return await Promise.all(I.map(async t=>{let r;if(t.globals=h(f,t.globals),t.user=h(p,t.user),(null==T?void 0:T.stop)&&_){const e=m(u,t),n=await w(T,_,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}let i=t,a=n.respond;if(j.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const s=await Ke(e,e.transformers,j,t,u,n.respond,`destination.${o}.before`);if(null===s.event)return t;s.respond&&(a=s.respond),i=Array.isArray(s.event)?s.event[0]:s.event}if(T&&!T.stop&&_){const e=m(u,i),n=await w(T,_,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}const c=Date.now();let l=!1;const d=await $(rt,t=>{var n;const r=s.type||"unknown";e.logger.scope(r).error("Push failed",{error:t,event:i.name}),O=t,l=!0;const a=s.dlq,c=s.config.id||o,u={max:null!=(n=s.config.dlqMax)?n:100},d=Le(a,[i,t],u);if(d.dropped>0){et(e,c);const t=tt(e.status,E("destination",c),"dlq",d.dropped);Ve(a,e.logger.scope(s.type||"unknown"),"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:u.max,droppedCount:t})}else a.length<u.max&&Ye(a)})(e,s,o,i,u,a);if(P+=Date.now()-c,r&&_&&void 0===s.config.mock&&b(_,r.key,null==d||d,r.ttl),void 0===d||Xe(d)||(D=d),Xe(d)&&K++,!l&&A){void 0!==d&&(u._response=d);const t=nt(A,g,u);if(t.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const n=await Ke(e,e.transformers,t,i,u,a,`destination.${o}.next`);n.respond&&(a=n.respond)}}return t})),{id:o,destination:s,error:O,response:D,totalDuration:P,batchedCount:K,allowedCount:I.length}})),q={},O={},D={};for(const t of I){if(t.skipped)continue;const n=t.destination,o={type:n.type||"unknown",data:t.response};et(e,t.id);const u=e.status.destinations[t.id],d=Date.now();if(u.queuePushSize=null!=(r=null==(s=n.queuePush)?void 0:s.length)?r:0,u.dlqSize=null!=(a=null==(i=n.dlq)?void 0:i.length)?a:0,t.error)o.error=t.error,D[t.id]=o,u.failed++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.failed++;else if(t.queue&&t.queue.length)O[t.id]=o;else{const n=null!=(c=t.batchedCount)?c:0,s=null!=(l=t.allowedCount)?l:0;(Math.max(0,s-n)>0||0===s)&&(q[t.id]=o,u.count++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.out++)}}return it({event:t,...Object.keys(q).length&&{done:q},...Object.keys(O).length&&{queued:O},...Object.keys(D).length&&{failed:D}})}async function st(e,t,n){var o;if(t.init&&!t.config.init){const s=t.type||"unknown",r=e.logger.scope(s),i={collector:e,logger:r,id:n,config:t.config,env:ct(t.env,t.config.env)};r.debug("init");const a=Date.now();let c;S(e,je(e,{stepId:E("destination",n),stepType:"destination",phase:"init",eventId:"",now:a}));try{c=await M(t.init,"DestinationInit",e.hooks,e.logger)(i)}catch(t){const o=Date.now(),s=je(e,{stepId:E("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)},S(e,s),t}if(!1===c)return c;if(t.config={...c||t.config,init:!0},null==(o=t.queueOn)?void 0:o.length){const o=t.queueOn;t.queueOn=[];for(const{type:s,data:r}of o)Ue(e,t,n,s,r)}r.debug("init done")}return!0}async function rt(e,t,n,o,s,r){var i,a,c,l,u,d,f;const{config:p}=t,g=await A(o,p,e);if(g.ignore)return!1;const h=t.type||"unknown",m=e.logger.scope(h),v={collector:e,logger:m,id:n,config:p,data:g.data,rule:g.mapping,ingest:s,env:{...ct(t.env,p.env),...r?{respond:r}:{}}};if(void 0!==p.mock)return m.debug("mock",{event:g.event.name}),p.mock;const y=g.mapping,w=g.mappingKey||"* *";if((null==y?void 0:y.batch)&&t.pushBatch&&void 0===p.mock){if(t.batches=t.batches||{},!t.batches[w]){const o={key:w,entries:[],events:[],data:[]},s=Ze(y.batch),r=Ze(p.batch),f=null!=(a=null!=(i=s.wait)?i:r.wait)?a:3e4,g=null!=(l=null!=(c=s.size)?c:r.size)?l:1e3,h=null!=(d=null!=(u=s.age)?u:r.age)?d:3e4,v=ct(t.env,p.env),b=I(async()=>{var o;const s=t.batches[w].batched;if(0===s.entries.length)return;const r={key:s.key,entries:s.entries,events:s.events,data:s.data};s.entries=[],s.events=[],s.data=[];const i=r.entries[0],a={collector:e,logger:m,id:n,config:p,data:void 0,rule:i.rule,ingest:i.ingest,env:{...v,...i.respond?{respond:i.respond}:{}}};m.debug("push batch",{events:r.entries.length});const c=t.config.id||n,l=et(e,c),u=Date.now(),d=je(e,{stepId:E("destination",n),stepType:"destination",phase:"flush",eventId:"",now:u});d.batch={size:r.entries.length,index:0},S(e,d);let f=!0;await $(M(t.pushBatch,"DestinationPushBatch",e.hooks,e.logger),o=>{var s;f=!1;const i=Date.now(),a=je(e,{stepId:E("destination",n),stepType:"destination",phase:"error",eventId:"",now:i});a.durationMs=i-u,a.error=o instanceof Error?{name:o.name,message:o.message}:{message:String(o)},a.batch={size:r.entries.length,index:0},S(e,a);const d=t.dlq=t.dlq||[],p={max:null!=(s=t.config.dlqMax)?s:100};let g=0;for(const e of r.entries)g+=Le(d,[e.event,o],p).dropped;if(g>0){const t=tt(e.status,E("destination",c),"dlq",g);Ve(d,m,"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:p.max,droppedCount:t})}else d.length<p.max&&Ye(d);l.failed+=r.entries.length,l.dlqSize=d.length,e.status.failed+=r.entries.length,m.error("Push batch failed",{error:o instanceof Error?o.message:String(o),entries:r.entries.length})})(r,a),m.debug("push batch done"),l.inFlightBatch=Math.max(0,(null!=(o=l.inFlightBatch)?o:0)-r.entries.length),f&&(l.count+=r.entries.length,l.lastAt=Date.now(),e.status.out+=r.entries.length)},{wait:f,size:g,age:h});t.batches[w]={batched:o,batchFn:()=>{b()},flush:async()=>{await b.flush()}}}const o=t.batches[w];o.batched.entries.push({event:g.event,ingest:s,respond:r,rule:y,data:g.data}),o.batched.events.push(g.event),D(g.data)&&o.batched.data.push(g.data);const h=t.config.id||n,v=et(e,h);return v.inFlightBatch=(null!=(f=v.inFlightBatch)?f:0)+1,o.batchFn(),Qe}{m.debug("push",{event:g.event.name});const o="string"==typeof g.event.id?g.event.id:"",s=Date.now(),r=je(e,{stepId:E("destination",n),stepType:"destination",phase:"in",eventId:o,now:s});g.mappingKey&&(r.mappingKey=g.mappingKey),g.event.consent&&(r.consent={...g.event.consent}),S(e,r);try{const r=await M(t.push,"DestinationPush",e.hooks,e.logger)(g.event,v),i=Date.now(),a=je(e,{stepId:E("destination",n),stepType:"destination",phase:"out",eventId:o,now:i});return a.durationMs=i-s,a.outEvent=r,g.mappingKey&&(a.mappingKey=g.mappingKey),S(e,a),m.debug("push done"),r}catch(t){const r=Date.now(),i=je(e,{stepId:E("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)},g.mappingKey&&(i.mappingKey=g.mappingKey),S(e,i),t}}}function it(e){return{ok:!(null==e?void 0:e.failed),...e}}function at(e){const{code:t,config:n={},env:o={},cache:s}=e,{config:r}=$e(e,"before"),{config:i}=$e({...e,config:r},"next"),a={...t.config,...n,...i};s&&(a.cache=s);const c=ct(t.env,o);return{...t,config:a,env:c}}function ct(e,t){return e||t?t?e&&j(e)&&j(t)?{...e,...t}:t:e:{}}async function lt(e,t,n){const o=Object.entries(e).map(async([e,o])=>{var s;const r=o.destroy;if(!r)return;const i=o.type||"unknown",a=n.scope(i),c={id:e,config:o.config,env:null!=(s=o.env)?s:{},logger:a};try{await Promise.race([r(c),new Promise((n,o)=>setTimeout(()=>o(new Error(`${t} '${e}' destroy timed out`)),5e3))])}catch(n){a.error(`${t} '${e}' destroy failed: ${n}`)}});await Promise.allSettled(o)}async function ut(e,t,n){let o,s,r=!1;switch(t){case Ce.Config:pe(n)&&(le(e.config,n,{shallow:!1}),s=n,r=!0);break;case Ce.Consent:if(pe(n)){const{update:t}=function(e,t){const n={};return Object.entries(t).forEach(([e,t])=>{n[e]=!!t}),e.consent=f(e.consent,n),{update:n}}(e,n);s=t,r=!0}break;case Ce.Custom:pe(n)&&(e.custom=le(e.custom,n),s=n,r=!0);break;case Ce.Destination:pe(n)&&"code"in n&&pe(n.code)&&(o=await async function(e,t){const{code:n,config:o={},env:s={},before:r,next:i,cache:a}=t;if(!C(n.push))return it({ok:!1,failed:{invalid:{type:"invalid",error:"Destination code must have a push method"}}});const c=o||{init:!1};let l=r?{...c,before:r}:{...c};i&&(l={...l,next:i}),a&&(l={...l,cache:a});const u={...n,config:l,env:ct(n.env,s)};let d=u.config.id;if(!d)do{d=q(5,"abcdefghijklmnopqrstuvwxyz")}while(e.destinations[d]);return e.destinations[d]=u,!1!==u.config.queue&&(u.queuePush=[...e.queue]),ot(e,void 0,{},{[d]:u})}(e,n));break;case Ce.Globals:pe(n)&&(e.globals=le(e.globals,n),s=n,r=!0);break;case Ce.Hook:if(pe(n)&&fe(n.name)&&de(n.fn)){const{name:t,fn:o}=n;e.hooks[t]=o,s=n,r=!0}break;case Ce.On:if(pe(n)&&fe(n.type)){const{type:t,rules:o}=n;await async function(e,t,n){const o=e.on,s=o[t]||[],r=_(n)?n:[n];r.forEach(e=>{s.push(e)}),o[t]=s,We(e,t,r)}(e,t,o)}break;case Ce.Ready:r=!0;break;case Ce.Run:o=await async function(e,t){return e.allowed=!0,e.timing=Date.now(),t&&(t.consent&&(e.consent=le(e.consent,t.consent)),t.user&&(e.user=le(e.user,t.user)),t.globals&&(e.globals=le(e.config.globalsStatic||{},t.globals)),t.custom&&(e.custom=le(e.custom,t.custom))),Object.values(e.destinations).forEach(e=>{e.queuePush=[]}),e.queue=[],e.round++,await ot(e)}(e,n),r=!0;break;case Ce.Session:r=!0;break;case Ce.Shutdown:await async function(e){const t=e.logger;await lt(e.sources,"source",t),await lt(e.destinations,"destination",t),await lt(e.transformers,"transformer",t),await lt(e.stores,"store",t)}(e);break;case Ce.User:pe(n)&&(le(e.user,n,{shallow:!1}),s=n,r=!0)}return r&&(await async function(e,t,n,o){var s,r;let i,a=n||[];switch(n||(a=e.on[t]||[]),t){case Ce.Consent:i=o||e.consent;break;case Ce.Session:i=e.session;break;case Ce.User:i=o||e.user;break;case Ce.Custom:i=o||e.custom;break;case Ce.Globals:i=o||e.globals;break;case Ce.Config:i=o||e.config;break;case Ce.Ready:case Ce.Run:default:i=void 0}let c=!1;for(const[n,o]of Object.entries(e.sources)){if(null==(s=o.config.require)?void 0:s.length){const e=o.config.require.indexOf(t);-1!==e&&o.config.require.splice(e,1)}o.on&&(He(o)?!1===await z(o.on,o=>Be(e,"source",o,{sourceId:n,type:t}))(t,i)&&(c=!0):(o.queueOn=o.queueOn||[],o.queueOn.push({type:t,data:i})))}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:i});Ue(e,o,n,t,i)}});for(const[t,n]of Object.entries(e.sources))He(n)&&(null==(r=n.queueOn)?void 0:r.length)&&await Fe(e,n,t);return Object.keys(e.pending.destinations).length>0&&await async function(e,t){var n;for(const[o,s]of Object.entries(e.pending.destinations)){if(!e.pending.destinations[o]||e.destinations[o])continue;const r=null==(n=s.config)?void 0:n.require;if(!r)continue;const i=r.indexOf(t);if(-1===i)continue;if(r.splice(i,1),r.length>0)continue;delete e.pending.destinations[o];const a=at(s);!1!==a.config.queue&&(a.queuePush=[...e.queue]),e.destinations[o]=a}}(e,t),We(e,t,a,o),!c}(e,t,void 0,s),o=await ot(e)),o||it({ok:!0})}function dt(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:l={},user:u=e.user,nested:d=[],consent:f=e.consent,id:p=ue(),trigger:g="",entity:h=n,action:m=o,timing:v=0,source:y={type:"collector",schema:"4"}}=t;return{name:r,data:i,context:a,globals:c,custom:l,user:u,nested:d,consent:f,id:p,trigger:g,entity:h,action:m,timestamp:s,timing:v,source:y}}function ft(e={}){var t,n,o;const s=null!=(t=e.maxEntries)?t:1e4,r=null!=(n=e.lowWaterMark)?n:.8,i=null!=(o=e.sweepIntervalMs)?o:6e4,a=Math.floor(s*r),c=new Map,l={hits:0,misses:0,populates:0,writes:0,deletes:0,evictions_entries:0,evictions_ttl:0};let u;return i>0&&(u=setInterval(function(){const e=Date.now();let t=0;for(const[n,o]of c)void 0!==o.expires&&o.expires<=e&&(c.delete(n),t++);l.evictions_ttl+=t},i),u&&"function"==typeof u.unref&&u.unref()),{type:"memory",config:{},get(e){const t=c.get(e);if(t)return void 0!==t.expires&&t.expires<=Date.now()?(c.delete(e),l.evictions_ttl++,void l.misses++):(c.delete(e),c.set(e,t),l.hits++,t.value);l.misses++},set(e,t,n){const o=!c.has(e);o||c.delete(e),c.set(e,{value:t,expires:void 0!==n?Date.now()+n:void 0}),l.writes++,o&&l.populates++,c.size>s&&function(){if(c.size<=s)return;const e=c.size-a;let t=0;for(const n of c.keys()){if(t>=e)break;c.delete(n),t++}l.evictions_entries+=t}()},delete(e){c.delete(e)&&l.deletes++},get counters(){return{...l}},destroy(){void 0!==u&&(clearInterval(u),u=void 0),c.clear()}}}function pt(e,t){const{cacheConfig:n,cacheStore:o,namespace:s,logger:r,storeId:i,collector:a}=t,c=(e,t)=>{if(!a)return;const n=je(a,{stepId:`store.${i}`,stepType:"store",phase:"in",eventId:"",now:Date.now()});n.meta={op:"cache",cached:"hit"===t,status:t,key:e},De(a,n)},l={hits:0,misses:0,populates:0,writes:0,deletes:0,inflight_dedups:0},u=n.rules.map(e=>({match:e.match?Oe(e.match):()=>!0,ttl:e.ttl})),d=e=>`${s}:${e}`;function f(e,t){const n=void 0===t?{key:e}:{key:e,value:t};return u.find(e=>e.match(n))}const p=new Map;return{type:e.type,config:e.config,setup:e.setup,get counters(){return{...l}},async get(t){const n=d(t),s=await o.get(n);if(void 0!==s)return l.hits++,c(t,"hit"),s;const r=p.get(n);if(r)return l.inflight_dedups++,c(t,"hit"),r;l.misses++,c(t,"miss");const i=(async()=>{try{const s=await e.get(t);if(void 0===s)return;const r=f(t,s);if(r)try{await o.set(n,s,1e3*r.ttl),l.populates++}catch(e){g("set",t,e)}return s}finally{p.delete(n)}})();return p.set(n,i),i},async set(t,n,s){l.writes++,await e.set(t,n,s);const r=f(t,n);if(r)try{await o.set(d(t),n,1e3*r.ttl)}catch(e){g("set",t,e)}},async delete(t){l.deletes++,await e.delete(t);try{await o.delete(d(t))}catch(e){g("delete",t,e)}}};function g(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 gt(e,t,n){const o=`store.${n}`,s=xe(t.get,"StoreGet",e.hooks,e.logger),r=xe(t.set,"StoreSet",e.hooks,e.logger),i=xe(t.delete,"StoreDelete",e.hooks,e.logger);t.get=async t=>{const n=Date.now(),r=je(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});r.meta={op:"get",key:t},qe(e,r);try{const r=await s(t),i=Date.now(),a=je(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:i});return a.durationMs=i-n,a.meta={op:"get",key:t},qe(e,a),r}catch(s){const r=Date.now(),i=je(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)},qe(e,i),s}},t.set=async(t,n,s)=>{const i=Date.now(),a=je(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:i});a.meta={op:"set",key:t,value:n},qe(e,a);try{await r(t,n,s);const a=Date.now(),c=je(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:a});c.durationMs=a-i,c.meta={op:"set",key:t,value:n},qe(e,c)}catch(s){const r=Date.now(),a=je(e,{stepId:o,stepType:"store",phase:"error",eventId:"",now:r});throw a.durationMs=r-i,a.meta={op:"set",key:t,value:n},a.error=s instanceof Error?{name:s.name,message:s.message}:{message:String(s)},qe(e,a),s}},t.delete=async t=>{const n=Date.now(),s=je(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});s.meta={op:"delete",key:t},qe(e,s);try{await i(t);const s=Date.now(),r=je(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:s});r.durationMs=s-n,r.meta={op:"delete",key:t},qe(e,r)}catch(s){const r=Date.now(),i=je(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)},qe(e,i),s}}}async function ht(e){var t,n;const o=p({globalsStatic:{},sessionStatic:{},run:!0,queueMax:1e3},e,{merge:!1,extend:!1}),s={level:null==(t=e.logger)?void 0:t.level,handler:null==(n=e.logger)?void 0:n.handler},r=g(s),i={...o.globalsStatic,...e.globals},a={allowed:!1,config:o,consent:e.consent||{},custom:e.custom||{},destinations:{},transformers:{},stores:{},globals:i,hooks:e.hooks||{},observers:new Set,logger:r,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};var c,l;a.push=function(e,t){const n=be(async(n,o={})=>await we(async()=>{var s;const r=Date.now(),{id:i,ingest:a,respond:c,mapping:l,preChain:u,include:d,exclude:f}=o;let p=c,g=n;const h=d||f?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,f):void 0,m=null!=a?a:ge(i||"unknown");if(l){const t=await ye(g,l,e);if(t.ignore)return it({ok:!0});if(l.consent&&!ve(l.consent,e.consent,t.event.consent))return it({ok:!0});g=t.event}if((null==u?void 0:u.length)&&e.transformers&&Object.keys(e.transformers).length>0){const n=await Ke(e,e.transformers,u,g,m,p,i?`source.${i}.next`:void 0);if(null===n.event)return it({ok:!0});if(n.stopped)return n.respond&&(p=n.respond),it({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=dt(e,o);return ot(e,s,{id:i,ingest:m,respond:p},h)}));if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count+=n.event.length,t.lastAt=Date.now(),t.duration+=Date.now()-r}return null!=(s=o[0])?s:it({ok:!0})}g=n.event}const v=t(g),y=dt(e,v),w=await ot(e,y,{id:i,ingest:m,respond:p},h);if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count++,t.lastAt=Date.now(),t.duration+=Date.now()-r}return w},t=>{if(t instanceof me)throw t;return e.status.failed++,e.logger.error("push failed",{event:n,ingest:o.ingest,error:t}),it({ok:!1})})(),"Push",e.hooks,e.logger);return async(t,o)=>{const s="string"==typeof t.id?t.id:"",r=Date.now();he(e,je(e,{stepId:"collector.push",stepType:"collector",phase:"in",eventId:s,now:r}));try{const i=await n(t,o),a=Date.now(),c=je(e,{stepId:"collector.push",stepType:"collector",phase:"out",eventId:s,now:a});return c.durationMs=a-r,c.outEvent=i,he(e,c),i}catch(t){const n=Date.now(),o=je(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)},he(e,o),t}}}(a,e=>({timing:Math.round((Date.now()-a.timing)/10)/100,source:{type:"collector",schema:"4",version:"4.1.1-next-1779822275564"},...e})),a.command=(l=ut,Ie(async(e,t,n)=>await Se(async()=>await l(c,e,t,n),n=>{if(n instanceof ke)throw n;return c.status.failed++,c.logger.error("command failed",{command:e,data:t,error:n}),it({ok:!1})})(),"Command",(c=a).hooks,c.logger));const u=e.stores||{};return a.stores=await async function(e,t={}){var n;const o={};for(const[n,s]of Object.entries(t)){const{code:t,config:r={},env:i={}}=s,a=e.logger.scope("store").scope(n),c={collector:e,logger:a,id:n,config:r,env:i},l=await t(c);o[n]=l}const s=t,r=function(e){const t={};for(const n of Object.keys(e))t[n]="WHITE";const n=[],o=[];function s(r){var i;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 c=null==(i=e[r].cache)?void 0:i.store;if(void 0!==c){if(!(c in e))throw new Error(`Store "${r}" cache.store references "${c}", which is not declared in flow.stores`);s(c)}o.pop(),t[r]="BLACK",n.push(r)}for(const n of Object.keys(e))"WHITE"===t[n]&&s(n);return n}(s);for(const t of r){const r=s[t].cache;if(!r)continue;let i,a;void 0!==r.store?(i=o[r.store],a=r.store):(o.__cache||(o.__cache=ft()),i=o.__cache,a="__cache");const c=null!=(n=r.namespace)?n:t;e.logger.scope("store-cache").scope(t).info(`store "${t}" caches with namespace "${c}:" via ${a}`),o[t]=pt(o[t],{storeId:t,cacheConfig:r,cacheStore:i,namespace:c,logger:e.logger.scope("store-cache").scope(t),collector:e})}for(const[t,n]of Object.entries(o))"__cache"!==t&&gt(e,n,t);return o}(a,u),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)}}}(u,a.stores,e),a.stores.__cache||(a.stores.__cache=ft()),a.destinations=await async function(e,t={}){var n,o;const s={};for(const[r,i]of Object.entries(t))(null==(o=null==(n=i.config)?void 0:n.require)?void 0:o.length)?e.pending.destinations[r]=i:s[r]=at(i);return s}(a,e.destinations||{}),a.transformers=await async function(e,t={}){var n,o,s,r;const i={};for(const[a,c]of Object.entries(t)){const{code:t,env:l={}}=c,u=ae(c,"Transformer");if(!u.ok){e.logger.warn(`Transformer ${a} invalid (${u.code}): ${u.reason}. Skipping.`);continue}const{config:d}=$e(c,"before"),{config:f}=$e({...c,config:d},"next"),p=Object.keys(l).length>0?{...f,env:l}:f,{cache:g}=c,h=g?{...p,cache:g}:p,m=e.logger.scope("transformer").scope(a),v={collector:e,logger:m,id:a,ingest:V(a),config:h,env:l},y=null!=t?t:e=>{const t=c.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 ${a}: \`${n.join(", ")}\` ignored at transformer position (only event-mutating fields apply).`),{type:"pass",config:e.config,push:async n=>{const o=await ce(n,t,e.collector);return!o.ignore&&{event:o.event}}}}return{type:"pass",config:e.config,push:e=>({event:e})}},w=await y(v);void 0!==c.before&&void 0===(null==(n=w.config)?void 0:n.before)&&(w.config={...null!=(o=w.config)?o:{},before:c.before}),void 0!==c.next&&void 0===(null==(s=w.config)?void 0:s.next)&&(w.config={...null!=(r=w.config)?r:{},next:c.next}),i[a]=w}return i}(a,e.transformers||{}),a}async function mt(e){e=e||{};const t=await ht(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 it({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 async function(e,t={}){var n;const o={};for(const[s,r]of Object.entries(t)){const t=await Ne(e,s,r);if(!t)continue;const i=null==(n=r.config)?void 0:n.require;t.config={...t.config,init:!1,...i?{require:[...i]}:{}},o[s]=t}Object.assign(e.sources,o);for(const t of Object.keys(o)){const n=e.sources[t];let o=!1;n.init&&await N(n.init.bind(n),n=>{if(n instanceof F)throw n;o=!0,e.status.failed++,e.logger.scope("source").error("source init failed",{sourceId:t,error:n})})(),o||(n.config.init=!0,He(n)&&await Fe(e,n,t))}return o}(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 l=Object.values(t.sources).filter(e=>"elb"!==e.type),u=l.find(e=>e.config.primary);return u?c=u.push:l.length>0&&(c=l[0].push),{collector:t,elb:c}}var vt=async e=>{let t;return{get flow(){return t},trigger:(n,o)=>async n=>{var s,r,i,a,c,l,u,d,f;const p=o||{};if(p.url){const e=new URL(p.url);window.history.replaceState({},"",e.pathname+e.search)}if(p.referrer&&Object.defineProperty(document,"referrer",{value:p.referrer,configurable:!0}),p.sessionData){const e=p.sessionKey||"elbSessionId";localStorage.setItem(e,JSON.stringify(p.sessionData))}if(p.deviceId){const e=p.deviceKey||"elbDeviceId";localStorage.setItem(e,p.deviceId)}if(!t){const n=await mt({...e,run:null==(s=e.run)||s});t={collector:n.collector,elb:n.elb};const o=p.sessionKey||(null==(c=null==(a=null==(i=null==(r=e.sources)?void 0:r.session)?void 0:i.config)?void 0:a.settings)?void 0:c.sessionKey)||"elbSessionId",g=p.deviceKey||(null==(f=null==(d=null==(u=null==(l=e.sources)?void 0:l.session)?void 0:u.config)?void 0:d.settings)?void 0:f.deviceKey)||"elbDeviceId";localStorage.removeItem(o),localStorage.removeItem(g),p.sessionData&&localStorage.setItem(o,JSON.stringify(p.sessionData)),p.deviceId&&localStorage.setItem(g,p.deviceId),e.consent&&await t.collector.command("consent",e.consent)}}}},yt=(e,t)=>{if(!e||"object"!=typeof e)return;const n=e,o=t.localStorage;if(n.sessionData&&"object"==typeof n.sessionData){const e="string"==typeof n.sessionKey?n.sessionKey:"elbSessionId";o.setItem(e,JSON.stringify(n.sessionData))}if("string"==typeof n.deviceId){const e="string"==typeof n.deviceKey?n.deviceKey:"elbDeviceId";o.setItem(e,n.deviceId)}};export{c as examples,n as schemas};//# sourceMappingURL=dev.mjs.map
1
+ var e=Object.defineProperty,t=(t,n)=>{for(var o in n)e(t,o,{get:n[o],enumerable:!0})},n={};t(n,{SettingsSchema:()=>i,settings:()=>a});import{zodToSchema as o}from"@walkeros/core/dev";import{z as s,ClickIdEntrySchema as r}from"@walkeros/core/dev";var i=s.object({storage:s.boolean().default(!1).describe("Enable persistent storage for session/device IDs").optional(),consent:s.union([s.string(),s.array(s.string())]).describe("Consent key(s) required to enable storage mode").optional(),length:s.number().default(30).describe("Session timeout in minutes").optional(),pulse:s.boolean().default(!1).describe("Keep session alive on each event").optional(),sessionKey:s.string().default("elbSessionId").describe("Storage key for session ID").optional(),sessionStorage:s.enum(["local","session"]).default("local").describe("Storage type for session").optional(),deviceKey:s.string().default("elbDeviceId").describe("Storage key for device ID").optional(),deviceStorage:s.enum(["local","session"]).default("local").describe("Storage type for device").optional(),deviceAge:s.number().default(30).describe("Device ID age in days").optional(),cb:s.any().describe("Custom session callback function or false to disable").optional(),clickIds:s.array(r).describe("Custom click-ID registry. Entries with a `param` matching a default override the platform name in place; new params append to the end of the priority list.").optional()}),a=o(i),c={};t(c,{createTrigger:()=>vt,step:()=>l,trigger:()=>yt});var l={};t(l,{newMarketingSession:()=>u,returningVisitor:()=>d});var u={title:"New marketing session",description:"A visit with UTM parameters starts a new session and emits walker user, session, and session start calls.",trigger:{type:"load",options:{url:"https://example.com/?utm_source=google&utm_medium=cpc&utm_campaign=winter-sale"}},in:{storage:!0},out:[["elb","user",{session:"s3ss10n-id",device:"d3v1c3-id"}],["elb","session",{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}],["elb",{name:"session start",data:{id:"s3ss10n-id",start:17e11,isNew:!0,count:1,runs:1,marketing:!0,source:"google",medium:"cpc",campaign:"winter-sale",referrer:"",device:"d3v1c3-id",isStart:!0,storage:!0,updated:17e11}}]]},d={title:"Returning visitor",description:"A returning visit with a google referrer reuses the stored device id and increments the session count.",trigger:{type:"load",options:{referrer:"https://google.com"}},in:{storage:!0},out:[["elb","user",{session:"n3w-s3ss10n",device:"d3v1c3-id"}],["elb","session",{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}],["elb",{name:"session start",data:{id:"n3w-s3ss10n",start:1700001e6,isNew:!1,count:3,runs:1,referrer:"google.com",device:"d3v1c3-id",isStart:!0,storage:!0,updated:1700001e6}}]]};import{assign as f}from"@walkeros/core";import{assign as p,createLogger as g}from"@walkeros/core";import{assign as h,buildCacheContext as m,clone as v,compileCache as y,checkCache as w,storeCache as b,createIngest as k,debounce as I,emitStep as S,getId as q,getGrantedConsent as x,getNextSteps as O,isDefined as D,isFunction as C,isObject as j,processEventMapping as A,stepId as E,tryCatchAsync as $,useHooks as M}from"@walkeros/core";import{emitStep as T}from"@walkeros/core";import{isArray as _,FatalError as P}from"@walkeros/core";import{tryCatch as K,tryCatchAsync as z}from"@walkeros/core";import{createIngest as R,FatalError as F,getMappingValue as H,tryCatchAsync as N,getNextSteps as B,compileCache as G,checkCache as U,storeCache as W,applyUpdate as L,buildCacheContext as J}from"@walkeros/core";import{createIngest as V,emitStep as Y,FatalError as Q,isObject as X,stepId as Z,tryCatchAsync as ee,useHooks as te,getNextSteps as ne,compileCache as oe,checkCache as se,storeCache as re,buildCacheContext as ie,validateStepEntry as ae,processEventMapping as ce}from"@walkeros/core";import{assign as le,getSpanId as ue,isFunction as de,isString as fe}from"@walkeros/core";import{isObject as pe}from"@walkeros/core";import{createIngest as ge,emitStep as he,FatalError as me,getGrantedConsent as ve,processEventMapping as ye,tryCatchAsync as we,useHooks as be}from"@walkeros/core";import{FatalError as ke,useHooks as Ie,tryCatchAsync as Se}from"@walkeros/core";import{emitStep as qe,useHooks as xe}from"@walkeros/core";import{compileMatcher as Oe,emitStep as De}from"@walkeros/core";var Ce={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"};function je(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}}function Ae(e,t){return e.storeId&&t.stores[e.storeId]?t.stores[e.storeId]:t.stores.__cache}function Ee(e){var t;const n={};for(const[o,s]of Object.entries(e)){const e=null==(t=s.config)?void 0:t.next;"string"==typeof e||Array.isArray(e)&&e.every(e=>"string"==typeof e)?n[o]={next:e}:n[o]={}}return n}function $e(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 Me(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 Te(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:V(n),config:t.config,env:ze(t.config.env)};s.debug("init");const i=await te(t.init,"TransformerInit",e.hooks,e.logger)(r);if(!1===i)return!1;t.config={...i||t.config,env:(null==i?void 0:i.env)||t.config.env,init:!0},s.debug("init done")}return!0}async function _e(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:{...ze(t.config.env),...r?{respond:r}:{}}};a.debug("push",{event:o.name});const l="string"==typeof o.id?o.id:"",u=Date.now(),d=je(e,{stepId:Z("transformer",n),stepType:"transformer",phase:"in",eventId:l,now:u});Y(e,d);try{const s=await te(t.push,"TransformerPush",e.hooks,e.logger)(o,c),r=Date.now(),i=je(e,{stepId:Z("transformer",n),stepType:"transformer",phase:"out",eventId:l,now:r});return i.durationMs=r-u,i.outEvent=s,Y(e,i),a.debug("push done"),s}catch(t){const o=Date.now(),s=je(e,{stepId:Z("transformer",n),stepType:"transformer",phase:"error",eventId:l,now:o});throw s.durationMs=o-u,s.error=t instanceof Error?{name:t.name,message:t.message}:{message:String(t)},Y(e,s),t}}function Pe(e,t){return e?{...e,_meta:{...e._meta,path:[...e._meta.path]}}:V(t)}async function Ke(e,t,n,o,s,r,i){var a,c,l,u,d,f,p,g;s||(s=V(null!=(a=n[0])?a:"chain")),i&&s._meta&&(s._meta.chainPath=i);let h=o,m=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:m};if(s&&s._meta&&(s._meta.hops++,s._meta.path.push(o)),!await ee(Te,t=>{if(t instanceof Q)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:m};if(i&&void 0!==(null==(l=null==(c=r.config)?void 0:c.chainMocks)?void 0:l[i])){const t=r.config.chainMocks[i];e.logger.scope(`transformer:${r.type||"unknown"}`).debug("chainMock",{chain:i}),h=t;continue}if(void 0!==(null==(u=r.config)?void 0:u.mock)){e.logger.scope(`transformer:${r.type||"unknown"}`).debug("mock"),h=r.config.mock;continue}if(null==(d=r.config)?void 0:d.disabled)continue;const a=null==(f=r.config)?void 0:f.cache,v=a?oe(a):void 0,y=v?Ae(v,e):void 0;let w;if(v&&y){const e=ie(s,h),t=await se(v,y,e);if("HIT"===(null==t?void 0:t.status)&&t.value){if(h=t.value,v.stop)return{event:h,respond:m,stopped:!0};continue}"MISS"===(null==t?void 0:t.status)&&(w={key:t.key,ttl:t.rule.ttl})}const b=r.config.before;if(b){const n=ne(b,ie(s,h));if(1===n.length){const o=Me(n[0],Ee(t));if(o.length>0){const n=await Ke(e,t,o,h,s,m,i);if(null===n.event)return{event:null,respond:null!=(p=n.respond)?p:m};if(n.stopped)return{event:Array.isArray(n.event)?n.event[0]:n.event,respond:null!=(g=n.respond)?g:m,stopped:!0};n.respond&&(m=n.respond),h=Array.isArray(n.event)?n.event[0]:n.event}}else n.length>1&&await Promise.all(n.map(n=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(n,Ee(t)),h,Pe(s,n),void 0,i)))}const k=await ee(_e,t=>(e.logger.scope(`transformer:${r.type||"unknown"}`).error("Push failed",{error:t}),!1))(e,r,o,h,s,m);if(!1===k)return{event:null,respond:m};if(Array.isArray(k)){const r=n.slice(n.indexOf(o)+1),a=await Promise.all(k.map(async n=>{const o=n.event||h,a=Pe(s,"unknown");if(n.next){const s=ne(n.next,ie(a,o));if(0===s.length)return{event:o,respond:m};if(1===s.length){const n=Me(s[0],Ee(t));return n.length>0?Ke(e,t,n,o,a,m,i):{event:o,respond:m}}return(await Promise.all(s.map(n=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(n,Ee(t)),o,Pe(a,n),void 0,i)))).map(e=>({event:e.event,respond:void 0}))}return r.length>0?Ke(e,t,r,o,a,m,i):{event:o,respond:m}}));let c=m;const l=[];for(const e of a.flat())if(null!==e)if(e&&"object"==typeof e&&"event"in e){const t=e;if(t.respond&&(c=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:c}:1===l.length?{event:l[0],respond:c}:{event:l,respond:c}}if(k&&"object"==typeof k){const{event:n,respond:o,next:r}=k;if(o&&(m=o),void 0!==r){const o=ne(r,ie(s,h));if(0===o.length){n&&(h=n);continue}if(1===o.length){const a=Me(o[0],Ee(t));return a.length>0?Ke(e,t,a,n||h,s,m,i):(e.logger.warn(`Branch target not found: ${JSON.stringify(r)}`),{event:null,respond:m})}return await Promise.all(o.map(o=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${o} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(o,Ee(t)),n||h,Pe(s,o),void 0,i))),{event:null,respond:void 0}}n&&(h=n)}w&&y&&re(y,w.key,h,w.ttl);const I=r.config.next,S="string"==typeof I||Array.isArray(I)&&I.every(e=>"string"==typeof e),q=void 0!==I&&!S;if((!k||"object"==typeof k&&!k.next)&&q){const n=ne(r.config.next,ie(s,h));if(1===n.length){const o=Me(n[0],Ee(t));return o.length>0?Ke(e,t,o,h,s,m,i):{event:h,respond:m}}return n.length>1?(await Promise.all(n.map(n=>ee(Ke,t=>(e.logger.scope("transformer:many").error(`many branch ${n} failed`,{error:t}),{event:null,respond:void 0}))(e,t,Me(n,Ee(t)),h,Pe(s,n),void 0,i))),{event:null,respond:void 0}):{event:h,respond:m}}}return{event:h,respond:m}}function ze(e){return e&&X(e)?e:{}}function Re(e){return"string"==typeof e||!(!Array.isArray(e)||!e.every(e=>"string"==typeof e))}async function Fe(e,t,n){var o,s;if(!t.on||!(null==(o=t.queueOn)?void 0:o.length))return;const r=t.queueOn;t.queueOn=[];const i=n||(null==(s=t.config)?void 0:s.id)||"unknown";for(const{type:n,data:o}of r)await N(t.on,t=>{if(t instanceof F)throw t;e.status.failed++,e.logger.scope("source").error("source on flush failed",{sourceId:i,type:n,error:t})})(n,o)}function He(e){var t;return Boolean(e.config.init)&&!(null==(t=e.config.require)?void 0:t.length)}async function Ne(e,t,n){var o;const{code:s,config:r={},env:i={},primary:a,next:c,before:l,cache:u}=n,d=u,f=d?G({...d,stop:null==(o=d.stop)||o}):void 0,p=Re(c)?Me(c,Ee(e.transformers)):void 0,g=Re(l)?Me(l,Ee(e.transformers)):void 0,h=i.push,m=null!=h?h:e.push,v=Boolean(h),y=async(n,o,s)=>{var i;let a;const u=null!=g?g:void 0!==l?(()=>{const t=B(l,J(s.ingest));return 0===t.length?[]:Me(1===t.length?t[0]:t,Ee(e.transformers))})():[];let d=[n];if(u.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const o=await Ke(e,e.transformers,u,n,s.ingest,s.respond,`source.${t}.before`);if(null===o.event)return{ok:!0};if(o.stopped)return o.respond&&(s.respond=o.respond),{ok:!0};o.respond&&(s.respond=o.respond),d=Array.isArray(o.event)?o.event:[o.event]}if(f){const t=Ae(f,e);if(t){const n=J(s.ingest),o=await U(f,t,n);if(o){if("HIT"===o.status&&void 0!==o.value&&f.stop){let t=o.value;return o.rule.update&&(t=await L(t,o.rule.update,{...n,cache:{status:"HIT"}},e)),null==(i=s.respond)||i.call(s,t),{ok:!0}}if("MISS"===o.status&&f.stop&&s.respond){const r=s.respond,i=o.rule.update,c={...n,cache:{status:"MISS"}},l=o.key,u=o.rule.ttl,d=n=>{W(t,l,n,u),i?a=(async()=>{const t=await L(n,i,c,e);r(t)})():r(n)};s.respond=d}"MISS"!==o.status||f.stop||W(t,o.key,!0,o.rule.ttl)}}}const h=p?{kind:"single",preChain:p}:void 0!==c?(()=>{const t=B(c,J(s.ingest));return 0===t.length?{kind:"single",preChain:[]}:1===t.length?{kind:"single",preChain:Me(t[0],Ee(e.transformers))}:{kind:"many",branches:t.map(t=>Me(t,Ee(e.transformers)))}})():{kind:"single",preChain:[]};let y={ok:!0};for(const n of d)"many"===h.kind?(await Promise.all(h.branches.map((i,a)=>N(async()=>v?m(n):m(n,{...o,id:t,ingest:Pe(s.ingest,`${t}.${a}`),respond:void 0,mapping:r,preChain:i}),t=>(e.logger.scope("source:many").error(`many branch ${a} failed`,{error:t}),{ok:!0}))())),y={ok:!0}):y=v?await m(n):await m(n,{...o,id:t,ingest:s.ingest,respond:s.respond,mapping:r,preChain:h.preChain});return a&&await a,y},w=async n=>{const o=R(t);if(!r.ingest||void 0===n)return o;const s=await H(n,r.ingest,{collector:e});return{...o,...s,_meta:o._meta}},b=e.logger.scope("source").scope(t),k={command:e.command,sources:e.sources,elb:e.sources.elb.push,logger:b,...i,push:async(e,n={})=>{const o={ingest:R(t),respond:void 0};return y(e,n,o)}},I={collector:e,logger:b,id:t,config:r,env:k,withScope:async(e,t,n)=>{const o={ingest:await w(e),respond:t};return n({...k,push:(e,t={})=>y(e,t,o),ingest:o.ingest,respond:o.respond})}},S=await N(s,n=>{if(n instanceof F)throw n;e.status.failed++,e.logger.scope("source").error("source factory failed",{sourceId:t,error:n})})(I);if(!S)return;const q=S.type||"unknown",x=e.logger.scope(q).scope(t);return k.logger=x,a&&(S.config={...S.config,primary:a}),S}function Be(e,t,n,o){if(n instanceof P)throw n;e.logger.scope("on").error("on callback failed",{kind:t,...o,error:n})}function Ge(e,t){return{collector:e,logger:e.logger.scope("on").scope(String(t))}}function Ue(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:ct(t.env,t.config.env)};K(t.on,t=>Be(e,"destination",t,{destId:n,type:o}))(o,a)}function We(e,t,n,o){let s;switch(t){case Ce.Consent:s=o||e.consent;break;case Ce.Session:s=e.session;break;case Ce.User:s=o||e.user;break;case Ce.Custom:s=o||e.custom;break;case Ce.Globals:s=o||e.globals;break;case Ce.Config:s=o||e.config;break;case Ce.Ready:case Ce.Run:default:s=void 0}if(n.length)switch(t){case Ce.Consent:!function(e,t,n){const o=n||e.consent,s=Ge(e,Ce.Consent);t.forEach(t=>{Object.keys(o).filter(e=>e in t).forEach(n=>{K(t[n],t=>Be(e,"consent",t,{key:n}))(o,s)})})}(e,n,o);break;case Ce.Ready:!function(e,t){if(!e.allowed)return;const n=Ge(e,Ce.Ready);t.forEach(t=>{K(t,t=>Be(e,"ready",t))(void 0,n)})}(e,n);break;case Ce.Run:!function(e,t){if(!e.allowed)return;const n=Ge(e,Ce.Run);t.forEach(t=>{K(t,t=>Be(e,"run",t))(void 0,n)})}(e,n);break;case Ce.Session:!function(e,t){if(!e.session)return;const n=Ge(e,Ce.Session);t.forEach(t=>{K(t,t=>Be(e,"session",t))(e.session,n)})}(e,n);break;default:{const o=Ge(e,t);n.forEach(n=>{"function"==typeof n&&K(n,n=>Be(e,"generic",n,{type:t}))(s,o)});break}}}function Le(e,t,n,o){var s;if(!Number.isFinite(n.max)||n.max<=0)throw new Error(`pushBounded: max must be > 0 (got ${n.max})`);if("dropNewest"===(null!=(s=n.onOverflow)?s:"dropOldest"))return e.length>=n.max?(o&&o([t]),{appended:!1,dropped:1}):(e.push(t),{appended:!0,dropped:0});const r=[];for(;e.length>=n.max;)r.push(e.shift());return e.push(t),r.length>0&&o&&o(r),{appended:!0,dropped:r.length}}var Je=new WeakMap;function Ve(e,t,n,o){Je.get(e)||(Je.set(e,!0),t.warn(n,o))}function Ye(e){Je.delete(e)}var Qe=Object.freeze({batched:!0});function Xe(e){return e===Qe}function Ze(e){return void 0===e?{}:"number"==typeof e?{wait:e}:{wait:e.wait,size:e.size,age:e.age}}function et(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 tt(e,t,n,o){var s;e.dropped[t]||(e.dropped[t]={});const r=e.dropped[t];return r[n]=(null!=(s=r[n])?s:0)+o,r[n]}function nt(e,t,n){if(!e)return[];if(Array.isArray(e)&&e.every(e=>"string"==typeof e))return Me(e,t);if("string"==typeof e)return Me(e,t);const o=O(e,m(n));return 0===o.length?[]:1===o.length?Me(o[0],t):Me(o,t)}async function ot(e,t,n={},o){var s,r,i,a,c,l;const{allowed:u,consent:d,globals:f,user:p}=e;if(!u)return it({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=Le(e.queue,t,{max:n});if(o.dropped>0){const t=tt(e.status,E("collector"),"queue",o.dropped);Ve(e.queue,e.logger,"collector.queue overflow; oldest events dropped",{buffer:"queue",cap:n,droppedCount:t})}else e.queue.length<n&&Ye(e.queue);e.status.in++}o||(o=e.destinations);const g=e.transformers?Ee(e.transformers):{},I=await Promise.all(Object.entries(o||{}).map(async([o,s])=>{var r,i,a,c;if(s.config.disabled)return{id:o,destination:s,skipped:!0};let l=(s.queuePush||[]).map(e=>({...e,consent:d}));s.queuePush=[],t&&l.push(v(t));const u=n.ingest?{...n.ingest,_meta:{...n.ingest._meta,path:[...n.ingest._meta.path]}}:k("unknown");if(!l.length&&!(null==(r=s.queueOn)?void 0:r.length))return{id:o,destination:s,skipped:!0};if(!l.length&&(null==(i=s.queueOn)?void 0:i.length)){let t=!1;try{t=await st(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 I=[],q=l.filter(t=>{const n=x(s.config.consent,d,t.consent);if(n)return t.consent=n,I.push(t),!1;const r=je(e,{stepId:E("destination",o),stepType:"destination",phase:"skip",eventId:"string"==typeof t.id?t.id:"",now:Date.now()});return r.skipReason="consent",d&&(r.consent={...d}),s.config.consent&&(r.meta={required:{...s.config.consent}}),S(e,r),!0});if(q.length>0){const t=s.queuePush,n=s.config.id||o,r={max:null!=(a=s.config.queueMax)?a:1e3};let i=0;for(const e of q)i+=Le(t,e,r).dropped;if(i>0){et(e,n);const o=tt(e.status,E("destination",n),"queue",i);Ve(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&&Ye(t)}if(!I.length)return{id:o,destination:s,queue:l};let O,D,C=!1;try{C=await st(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(!C)return{id:o,destination:s,queue:l};s.dlq||(s.dlq=[]);const j=nt(s.config.before,g,u),A=s.config.next,M=null==(c=s.config)?void 0:c.cache,T=M?y(M):void 0,_=T?Ae(T,e):void 0;let P=0,K=0;return await Promise.all(I.map(async t=>{let r;if(t.globals=h(f,t.globals),t.user=h(p,t.user),(null==T?void 0:T.stop)&&_){const e=m(u,t),n=await w(T,_,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}let i=t,a=n.respond;if(j.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const s=await Ke(e,e.transformers,j,t,u,n.respond,`destination.${o}.before`);if(null===s.event)return t;s.respond&&(a=s.respond),i=Array.isArray(s.event)?s.event[0]:s.event}if(T&&!T.stop&&_){const e=m(u,i),n=await w(T,_,e);if("HIT"===(null==n?void 0:n.status))return t;"MISS"===(null==n?void 0:n.status)&&(r={key:n.key,ttl:n.rule.ttl})}const c=Date.now();let l=!1;const d=await $(rt,t=>{var n;const r=s.type||"unknown";e.logger.scope(r).error("Push failed",{error:t,event:i.name}),O=t,l=!0;const a=s.dlq,c=s.config.id||o,u={max:null!=(n=s.config.dlqMax)?n:100},d=Le(a,[i,t],u);if(d.dropped>0){et(e,c);const t=tt(e.status,E("destination",c),"dlq",d.dropped);Ve(a,e.logger.scope(s.type||"unknown"),"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:u.max,droppedCount:t})}else a.length<u.max&&Ye(a)})(e,s,o,i,u,a);if(P+=Date.now()-c,r&&_&&void 0===s.config.mock&&b(_,r.key,null==d||d,r.ttl),void 0===d||Xe(d)||(D=d),Xe(d)&&K++,!l&&A){void 0!==d&&(u._response=d);const t=nt(A,g,u);if(t.length>0&&e.transformers&&Object.keys(e.transformers).length>0){const n=await Ke(e,e.transformers,t,i,u,a,`destination.${o}.next`);n.respond&&(a=n.respond)}}return t})),{id:o,destination:s,error:O,response:D,totalDuration:P,batchedCount:K,allowedCount:I.length}})),q={},O={},D={};for(const t of I){if(t.skipped)continue;const n=t.destination,o={type:n.type||"unknown",data:t.response};et(e,t.id);const u=e.status.destinations[t.id],d=Date.now();if(u.queuePushSize=null!=(r=null==(s=n.queuePush)?void 0:s.length)?r:0,u.dlqSize=null!=(a=null==(i=n.dlq)?void 0:i.length)?a:0,t.error)o.error=t.error,D[t.id]=o,u.failed++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.failed++;else if(t.queue&&t.queue.length)O[t.id]=o;else{const n=null!=(c=t.batchedCount)?c:0,s=null!=(l=t.allowedCount)?l:0;(Math.max(0,s-n)>0||0===s)&&(q[t.id]=o,u.count++,u.lastAt=d,u.duration+=t.totalDuration||0,e.status.out++)}}return it({event:t,...Object.keys(q).length&&{done:q},...Object.keys(O).length&&{queued:O},...Object.keys(D).length&&{failed:D}})}async function st(e,t,n){var o;if(t.init&&!t.config.init){const s=t.type||"unknown",r=e.logger.scope(s),i={collector:e,logger:r,id:n,config:t.config,env:ct(t.env,t.config.env)};r.debug("init");const a=Date.now();let c;S(e,je(e,{stepId:E("destination",n),stepType:"destination",phase:"init",eventId:"",now:a}));try{c=await M(t.init,"DestinationInit",e.hooks,e.logger)(i)}catch(t){const o=Date.now(),s=je(e,{stepId:E("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)},S(e,s),t}if(!1===c)return c;if(t.config={...c||t.config,init:!0},null==(o=t.queueOn)?void 0:o.length){const o=t.queueOn;t.queueOn=[];for(const{type:s,data:r}of o)Ue(e,t,n,s,r)}r.debug("init done")}return!0}async function rt(e,t,n,o,s,r){var i,a,c,l,u,d,f;const{config:p}=t,g=await A(o,p,e);if(g.ignore)return!1;const h=t.type||"unknown",m=e.logger.scope(h),v={collector:e,logger:m,id:n,config:p,data:g.data,rule:g.mapping,ingest:s,env:{...ct(t.env,p.env),...r?{respond:r}:{}}};if(void 0!==p.mock)return m.debug("mock",{event:g.event.name}),p.mock;const y=g.mapping,w=g.mappingKey||"* *";if((null==y?void 0:y.batch)&&t.pushBatch&&void 0===p.mock){if(t.batches=t.batches||{},!t.batches[w]){const o={key:w,entries:[],events:[],data:[]},s=Ze(y.batch),r=Ze(p.batch),f=null!=(a=null!=(i=s.wait)?i:r.wait)?a:3e4,g=null!=(l=null!=(c=s.size)?c:r.size)?l:1e3,h=null!=(d=null!=(u=s.age)?u:r.age)?d:3e4,v=ct(t.env,p.env),b=I(async()=>{var o;const s=t.batches[w].batched;if(0===s.entries.length)return;const r={key:s.key,entries:s.entries,events:s.events,data:s.data};s.entries=[],s.events=[],s.data=[];const i=r.entries[0],a={collector:e,logger:m,id:n,config:p,data:void 0,rule:i.rule,ingest:i.ingest,env:{...v,...i.respond?{respond:i.respond}:{}}};m.debug("push batch",{events:r.entries.length});const c=t.config.id||n,l=et(e,c),u=Date.now(),d=je(e,{stepId:E("destination",n),stepType:"destination",phase:"flush",eventId:"",now:u});d.batch={size:r.entries.length,index:0},S(e,d);let f=!0;await $(M(t.pushBatch,"DestinationPushBatch",e.hooks,e.logger),o=>{var s;f=!1;const i=Date.now(),a=je(e,{stepId:E("destination",n),stepType:"destination",phase:"error",eventId:"",now:i});a.durationMs=i-u,a.error=o instanceof Error?{name:o.name,message:o.message}:{message:String(o)},a.batch={size:r.entries.length,index:0},S(e,a);const d=t.dlq=t.dlq||[],p={max:null!=(s=t.config.dlqMax)?s:100};let g=0;for(const e of r.entries)g+=Le(d,[e.event,o],p).dropped;if(g>0){const t=tt(e.status,E("destination",c),"dlq",g);Ve(d,m,"destination.dlq overflow; oldest entries dropped",{buffer:"dlq",destination:c,cap:p.max,droppedCount:t})}else d.length<p.max&&Ye(d);l.failed+=r.entries.length,l.dlqSize=d.length,e.status.failed+=r.entries.length,m.error("Push batch failed",{error:o instanceof Error?o.message:String(o),entries:r.entries.length})})(r,a),m.debug("push batch done"),l.inFlightBatch=Math.max(0,(null!=(o=l.inFlightBatch)?o:0)-r.entries.length),f&&(l.count+=r.entries.length,l.lastAt=Date.now(),e.status.out+=r.entries.length)},{wait:f,size:g,age:h});t.batches[w]={batched:o,batchFn:()=>{b()},flush:async()=>{await b.flush()}}}const o=t.batches[w];o.batched.entries.push({event:g.event,ingest:s,respond:r,rule:y,data:g.data}),o.batched.events.push(g.event),D(g.data)&&o.batched.data.push(g.data);const h=t.config.id||n,v=et(e,h);return v.inFlightBatch=(null!=(f=v.inFlightBatch)?f:0)+1,o.batchFn(),Qe}{m.debug("push",{event:g.event.name});const o="string"==typeof g.event.id?g.event.id:"",s=Date.now(),r=je(e,{stepId:E("destination",n),stepType:"destination",phase:"in",eventId:o,now:s});g.mappingKey&&(r.mappingKey=g.mappingKey),g.event.consent&&(r.consent={...g.event.consent}),S(e,r);try{const r=await M(t.push,"DestinationPush",e.hooks,e.logger)(g.event,v),i=Date.now(),a=je(e,{stepId:E("destination",n),stepType:"destination",phase:"out",eventId:o,now:i});return a.durationMs=i-s,a.outEvent=r,g.mappingKey&&(a.mappingKey=g.mappingKey),S(e,a),m.debug("push done"),r}catch(t){const r=Date.now(),i=je(e,{stepId:E("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)},g.mappingKey&&(i.mappingKey=g.mappingKey),S(e,i),t}}}function it(e){return{ok:!(null==e?void 0:e.failed),...e}}function at(e){const{code:t,config:n={},env:o={},cache:s}=e,{config:r}=$e(e,"before"),{config:i}=$e({...e,config:r},"next"),a={...t.config,...n,...i};s&&(a.cache=s);const c=ct(t.env,o);return{...t,config:a,env:c}}function ct(e,t){return e||t?t?e&&j(e)&&j(t)?{...e,...t}:t:e:{}}async function lt(e,t,n){const o=Object.entries(e).map(async([e,o])=>{var s;const r=o.destroy;if(!r)return;const i=o.type||"unknown",a=n.scope(i),c={id:e,config:o.config,env:null!=(s=o.env)?s:{},logger:a};try{await Promise.race([r(c),new Promise((n,o)=>setTimeout(()=>o(new Error(`${t} '${e}' destroy timed out`)),5e3))])}catch(n){a.error(`${t} '${e}' destroy failed: ${n}`)}});await Promise.allSettled(o)}async function ut(e,t,n){let o,s,r=!1;switch(t){case Ce.Config:pe(n)&&(le(e.config,n,{shallow:!1}),s=n,r=!0);break;case Ce.Consent:if(pe(n)){const{update:t}=function(e,t){const n={};return Object.entries(t).forEach(([e,t])=>{n[e]=!!t}),e.consent=f(e.consent,n),{update:n}}(e,n);s=t,r=!0}break;case Ce.Custom:pe(n)&&(e.custom=le(e.custom,n),s=n,r=!0);break;case Ce.Destination:pe(n)&&"code"in n&&pe(n.code)&&(o=await async function(e,t){const{code:n,config:o={},env:s={},before:r,next:i,cache:a}=t;if(!C(n.push))return it({ok:!1,failed:{invalid:{type:"invalid",error:"Destination code must have a push method"}}});const c=o||{init:!1};let l=r?{...c,before:r}:{...c};i&&(l={...l,next:i}),a&&(l={...l,cache:a});const u={...n,config:l,env:ct(n.env,s)};let d=u.config.id;if(!d)do{d=q(5,"abcdefghijklmnopqrstuvwxyz")}while(e.destinations[d]);return e.destinations[d]=u,!1!==u.config.queue&&(u.queuePush=[...e.queue]),ot(e,void 0,{},{[d]:u})}(e,n));break;case Ce.Globals:pe(n)&&(e.globals=le(e.globals,n),s=n,r=!0);break;case Ce.Hook:if(pe(n)&&fe(n.name)&&de(n.fn)){const{name:t,fn:o}=n;e.hooks[t]=o,s=n,r=!0}break;case Ce.On:if(pe(n)&&fe(n.type)){const{type:t,rules:o}=n;await async function(e,t,n){const o=e.on,s=o[t]||[],r=_(n)?n:[n];r.forEach(e=>{s.push(e)}),o[t]=s,We(e,t,r)}(e,t,o)}break;case Ce.Ready:r=!0;break;case Ce.Run:o=await async function(e,t){return e.allowed=!0,e.timing=Date.now(),t&&(t.consent&&(e.consent=le(e.consent,t.consent)),t.user&&(e.user=le(e.user,t.user)),t.globals&&(e.globals=le(e.config.globalsStatic||{},t.globals)),t.custom&&(e.custom=le(e.custom,t.custom))),Object.values(e.destinations).forEach(e=>{e.queuePush=[]}),e.queue=[],e.round++,await ot(e)}(e,n),r=!0;break;case Ce.Session:r=!0;break;case Ce.Shutdown:await async function(e){const t=e.logger;await lt(e.sources,"source",t),await lt(e.destinations,"destination",t),await lt(e.transformers,"transformer",t),await lt(e.stores,"store",t)}(e);break;case Ce.User:pe(n)&&(le(e.user,n,{shallow:!1}),s=n,r=!0)}return r&&(await async function(e,t,n,o){var s,r;let i,a=n||[];switch(n||(a=e.on[t]||[]),t){case Ce.Consent:i=o||e.consent;break;case Ce.Session:i=e.session;break;case Ce.User:i=o||e.user;break;case Ce.Custom:i=o||e.custom;break;case Ce.Globals:i=o||e.globals;break;case Ce.Config:i=o||e.config;break;case Ce.Ready:case Ce.Run:default:i=void 0}let c=!1;for(const[n,o]of Object.entries(e.sources)){if(null==(s=o.config.require)?void 0:s.length){const e=o.config.require.indexOf(t);-1!==e&&o.config.require.splice(e,1)}o.on&&(He(o)?!1===await z(o.on,o=>Be(e,"source",o,{sourceId:n,type:t}))(t,i)&&(c=!0):(o.queueOn=o.queueOn||[],o.queueOn.push({type:t,data:i})))}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:i});Ue(e,o,n,t,i)}});for(const[t,n]of Object.entries(e.sources))He(n)&&(null==(r=n.queueOn)?void 0:r.length)&&await Fe(e,n,t);return Object.keys(e.pending.destinations).length>0&&await async function(e,t){var n;for(const[o,s]of Object.entries(e.pending.destinations)){if(!e.pending.destinations[o]||e.destinations[o])continue;const r=null==(n=s.config)?void 0:n.require;if(!r)continue;const i=r.indexOf(t);if(-1===i)continue;if(r.splice(i,1),r.length>0)continue;delete e.pending.destinations[o];const a=at(s);!1!==a.config.queue&&(a.queuePush=[...e.queue]),e.destinations[o]=a}}(e,t),We(e,t,a,o),!c}(e,t,void 0,s),o=await ot(e)),o||it({ok:!0})}function dt(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:l={},user:u=e.user,nested:d=[],consent:f=e.consent,id:p=ue(),trigger:g="",entity:h=n,action:m=o,timing:v=0,source:y={type:"collector",schema:"4"}}=t;return{name:r,data:i,context:a,globals:c,custom:l,user:u,nested:d,consent:f,id:p,trigger:g,entity:h,action:m,timestamp:s,timing:v,source:y}}function ft(e={}){var t,n,o;const s=null!=(t=e.maxEntries)?t:1e4,r=null!=(n=e.lowWaterMark)?n:.8,i=null!=(o=e.sweepIntervalMs)?o:6e4,a=Math.floor(s*r),c=new Map,l={hits:0,misses:0,populates:0,writes:0,deletes:0,evictions_entries:0,evictions_ttl:0};let u;return i>0&&(u=setInterval(function(){const e=Date.now();let t=0;for(const[n,o]of c)void 0!==o.expires&&o.expires<=e&&(c.delete(n),t++);l.evictions_ttl+=t},i),u&&"function"==typeof u.unref&&u.unref()),{type:"memory",config:{},get(e){const t=c.get(e);if(t)return void 0!==t.expires&&t.expires<=Date.now()?(c.delete(e),l.evictions_ttl++,void l.misses++):(c.delete(e),c.set(e,t),l.hits++,t.value);l.misses++},set(e,t,n){const o=!c.has(e);o||c.delete(e),c.set(e,{value:t,expires:void 0!==n?Date.now()+n:void 0}),l.writes++,o&&l.populates++,c.size>s&&function(){if(c.size<=s)return;const e=c.size-a;let t=0;for(const n of c.keys()){if(t>=e)break;c.delete(n),t++}l.evictions_entries+=t}()},delete(e){c.delete(e)&&l.deletes++},get counters(){return{...l}},destroy(){void 0!==u&&(clearInterval(u),u=void 0),c.clear()}}}function pt(e,t){const{cacheConfig:n,cacheStore:o,namespace:s,logger:r,storeId:i,collector:a}=t,c=(e,t)=>{if(!a)return;const n=je(a,{stepId:`store.${i}`,stepType:"store",phase:"in",eventId:"",now:Date.now()});n.meta={op:"cache",cached:"hit"===t,status:t,key:e},De(a,n)},l={hits:0,misses:0,populates:0,writes:0,deletes:0,inflight_dedups:0},u=n.rules.map(e=>({match:e.match?Oe(e.match):()=>!0,ttl:e.ttl})),d=e=>`${s}:${e}`;function f(e,t){const n=void 0===t?{key:e}:{key:e,value:t};return u.find(e=>e.match(n))}const p=new Map;return{type:e.type,config:e.config,setup:e.setup,get counters(){return{...l}},async get(t){const n=d(t),s=await o.get(n);if(void 0!==s)return l.hits++,c(t,"hit"),s;const r=p.get(n);if(r)return l.inflight_dedups++,c(t,"hit"),r;l.misses++,c(t,"miss");const i=(async()=>{try{const s=await e.get(t);if(void 0===s)return;const r=f(t,s);if(r)try{await o.set(n,s,1e3*r.ttl),l.populates++}catch(e){g("set",t,e)}return s}finally{p.delete(n)}})();return p.set(n,i),i},async set(t,n,s){l.writes++,await e.set(t,n,s);const r=f(t,n);if(r)try{await o.set(d(t),n,1e3*r.ttl)}catch(e){g("set",t,e)}},async delete(t){l.deletes++,await e.delete(t);try{await o.delete(d(t))}catch(e){g("delete",t,e)}}};function g(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 gt(e,t,n){const o=`store.${n}`,s=xe(t.get,"StoreGet",e.hooks,e.logger),r=xe(t.set,"StoreSet",e.hooks,e.logger),i=xe(t.delete,"StoreDelete",e.hooks,e.logger);t.get=async t=>{const n=Date.now(),r=je(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});r.meta={op:"get",key:t},qe(e,r);try{const r=await s(t),i=Date.now(),a=je(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:i});return a.durationMs=i-n,a.meta={op:"get",key:t},qe(e,a),r}catch(s){const r=Date.now(),i=je(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)},qe(e,i),s}},t.set=async(t,n,s)=>{const i=Date.now(),a=je(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:i});a.meta={op:"set",key:t},qe(e,a);try{await r(t,n,s);const a=Date.now(),c=je(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:a});c.durationMs=a-i,c.meta={op:"set",key:t},qe(e,c)}catch(n){const s=Date.now(),r=je(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)},qe(e,r),n}},t.delete=async t=>{const n=Date.now(),s=je(e,{stepId:o,stepType:"store",phase:"in",eventId:"",now:n});s.meta={op:"delete",key:t},qe(e,s);try{await i(t);const s=Date.now(),r=je(e,{stepId:o,stepType:"store",phase:"out",eventId:"",now:s});r.durationMs=s-n,r.meta={op:"delete",key:t},qe(e,r)}catch(s){const r=Date.now(),i=je(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)},qe(e,i),s}}}async function ht(e){var t,n;const o=p({globalsStatic:{},sessionStatic:{},run:!0,queueMax:1e3},e,{merge:!1,extend:!1}),s={level:null==(t=e.logger)?void 0:t.level,handler:null==(n=e.logger)?void 0:n.handler},r=g(s),i={...o.globalsStatic,...e.globals},a={allowed:!1,config:o,consent:e.consent||{},custom:e.custom||{},destinations:{},transformers:{},stores:{},globals:i,hooks:e.hooks||{},observers:new Set,logger:r,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};var c,l;a.push=function(e,t){const n=be(async(n,o={})=>await we(async()=>{var s;const r=Date.now(),{id:i,ingest:a,respond:c,mapping:l,preChain:u,include:d,exclude:f}=o;let p=c,g=n;const h=d||f?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,f):void 0,m=null!=a?a:ge(i||"unknown");if(l){const t=await ye(g,l,e);if(t.ignore)return it({ok:!0});if(l.consent&&!ve(l.consent,e.consent,t.event.consent))return it({ok:!0});g=t.event}if((null==u?void 0:u.length)&&e.transformers&&Object.keys(e.transformers).length>0){const n=await Ke(e,e.transformers,u,g,m,p,i?`source.${i}.next`:void 0);if(null===n.event)return it({ok:!0});if(n.stopped)return n.respond&&(p=n.respond),it({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=dt(e,o);return ot(e,s,{id:i,ingest:m,respond:p},h)}));if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count+=n.event.length,t.lastAt=Date.now(),t.duration+=Date.now()-r}return null!=(s=o[0])?s:it({ok:!0})}g=n.event}const v=t(g),y=dt(e,v),w=await ot(e,y,{id:i,ingest:m,respond:p},h);if(i){e.status.sources[i]||(e.status.sources[i]={count:0,duration:0});const t=e.status.sources[i];t.count++,t.lastAt=Date.now(),t.duration+=Date.now()-r}return w},t=>{if(t instanceof me)throw t;return e.status.failed++,e.logger.error("push failed",{event:n,ingest:o.ingest,error:t}),it({ok:!1})})(),"Push",e.hooks,e.logger);return async(t,o)=>{const s="string"==typeof t.id?t.id:"",r=Date.now();he(e,je(e,{stepId:"collector.push",stepType:"collector",phase:"in",eventId:s,now:r}));try{const i=await n(t,o),a=Date.now(),c=je(e,{stepId:"collector.push",stepType:"collector",phase:"out",eventId:s,now:a});return c.durationMs=a-r,c.outEvent=i,he(e,c),i}catch(t){const n=Date.now(),o=je(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)},he(e,o),t}}}(a,e=>({timing:Math.round((Date.now()-a.timing)/10)/100,source:{type:"collector",schema:"4",version:"4.1.1"},...e})),a.command=(l=ut,Ie(async(e,t,n)=>await Se(async()=>await l(c,e,t,n),n=>{if(n instanceof ke)throw n;return c.status.failed++,c.logger.error("command failed",{command:e,data:t,error:n}),it({ok:!1})})(),"Command",(c=a).hooks,c.logger));const u=e.stores||{};return a.stores=await async function(e,t={}){var n;const o={};for(const[n,s]of Object.entries(t)){const{code:t,config:r={},env:i={}}=s,a=e.logger.scope("store").scope(n),c={collector:e,logger:a,id:n,config:r,env:i},l=await t(c);o[n]=l}const s=t,r=function(e){const t={};for(const n of Object.keys(e))t[n]="WHITE";const n=[],o=[];function s(r){var i;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 c=null==(i=e[r].cache)?void 0:i.store;if(void 0!==c){if(!(c in e))throw new Error(`Store "${r}" cache.store references "${c}", which is not declared in flow.stores`);s(c)}o.pop(),t[r]="BLACK",n.push(r)}for(const n of Object.keys(e))"WHITE"===t[n]&&s(n);return n}(s);for(const t of r){const r=s[t].cache;if(!r)continue;let i,a;void 0!==r.store?(i=o[r.store],a=r.store):(o.__cache||(o.__cache=ft()),i=o.__cache,a="__cache");const c=null!=(n=r.namespace)?n:t;e.logger.scope("store-cache").scope(t).info(`store "${t}" caches with namespace "${c}:" via ${a}`),o[t]=pt(o[t],{storeId:t,cacheConfig:r,cacheStore:i,namespace:c,logger:e.logger.scope("store-cache").scope(t),collector:e})}for(const[t,n]of Object.entries(o))"__cache"!==t&&gt(e,n,t);return o}(a,u),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)}}}(u,a.stores,e),a.stores.__cache||(a.stores.__cache=ft()),a.destinations=await async function(e,t={}){var n,o;const s={};for(const[r,i]of Object.entries(t))(null==(o=null==(n=i.config)?void 0:n.require)?void 0:o.length)?e.pending.destinations[r]=i:s[r]=at(i);return s}(a,e.destinations||{}),a.transformers=await async function(e,t={}){var n,o,s,r;const i={};for(const[a,c]of Object.entries(t)){const{code:t,env:l={}}=c,u=ae(c,"Transformer");if(!u.ok){e.logger.warn(`Transformer ${a} invalid (${u.code}): ${u.reason}. Skipping.`);continue}const{config:d}=$e(c,"before"),{config:f}=$e({...c,config:d},"next"),p=Object.keys(l).length>0?{...f,env:l}:f,{cache:g}=c,h=g?{...p,cache:g}:p,m=e.logger.scope("transformer").scope(a),v={collector:e,logger:m,id:a,ingest:V(a),config:h,env:l},y=null!=t?t:e=>{const t=c.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 ${a}: \`${n.join(", ")}\` ignored at transformer position (only event-mutating fields apply).`),{type:"pass",config:e.config,push:async n=>{const o=await ce(n,t,e.collector);return!o.ignore&&{event:o.event}}}}return{type:"pass",config:e.config,push:e=>({event:e})}},w=await y(v);void 0!==c.before&&void 0===(null==(n=w.config)?void 0:n.before)&&(w.config={...null!=(o=w.config)?o:{},before:c.before}),void 0!==c.next&&void 0===(null==(s=w.config)?void 0:s.next)&&(w.config={...null!=(r=w.config)?r:{},next:c.next}),i[a]=w}return i}(a,e.transformers||{}),a}async function mt(e){e=e||{};const t=await ht(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 it({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 async function(e,t={}){var n;const o={};for(const[s,r]of Object.entries(t)){const t=await Ne(e,s,r);if(!t)continue;const i=null==(n=r.config)?void 0:n.require;t.config={...t.config,init:!1,...i?{require:[...i]}:{}},o[s]=t}Object.assign(e.sources,o);for(const t of Object.keys(o)){const n=e.sources[t];let o=!1;n.init&&await N(n.init.bind(n),n=>{if(n instanceof F)throw n;o=!0,e.status.failed++,e.logger.scope("source").error("source init failed",{sourceId:t,error:n})})(),o||(n.config.init=!0,He(n)&&await Fe(e,n,t))}return o}(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 l=Object.values(t.sources).filter(e=>"elb"!==e.type),u=l.find(e=>e.config.primary);return u?c=u.push:l.length>0&&(c=l[0].push),{collector:t,elb:c}}var vt=async e=>{let t;return{get flow(){return t},trigger:(n,o)=>async n=>{var s,r,i,a,c,l,u,d,f;const p=o||{};if(p.url){const e=new URL(p.url);window.history.replaceState({},"",e.pathname+e.search)}if(p.referrer&&Object.defineProperty(document,"referrer",{value:p.referrer,configurable:!0}),p.sessionData){const e=p.sessionKey||"elbSessionId";localStorage.setItem(e,JSON.stringify(p.sessionData))}if(p.deviceId){const e=p.deviceKey||"elbDeviceId";localStorage.setItem(e,p.deviceId)}if(!t){const n=await mt({...e,run:null==(s=e.run)||s});t={collector:n.collector,elb:n.elb};const o=p.sessionKey||(null==(c=null==(a=null==(i=null==(r=e.sources)?void 0:r.session)?void 0:i.config)?void 0:a.settings)?void 0:c.sessionKey)||"elbSessionId",g=p.deviceKey||(null==(f=null==(d=null==(u=null==(l=e.sources)?void 0:l.session)?void 0:u.config)?void 0:d.settings)?void 0:f.deviceKey)||"elbDeviceId";localStorage.removeItem(o),localStorage.removeItem(g),p.sessionData&&localStorage.setItem(o,JSON.stringify(p.sessionData)),p.deviceId&&localStorage.setItem(g,p.deviceId),e.consent&&await t.collector.command("consent",e.consent)}}}},yt=(e,t)=>{if(!e||"object"!=typeof e)return;const n=e,o=t.localStorage;if(n.sessionData&&"object"==typeof n.sessionData){const e="string"==typeof n.sessionKey?n.sessionKey:"elbSessionId";o.setItem(e,JSON.stringify(n.sessionData))}if("string"==typeof n.deviceId){const e="string"==typeof n.deviceKey?n.deviceKey:"elbDeviceId";o.setItem(e,n.deviceId)}};export{c as examples,n as schemas};//# sourceMappingURL=dev.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "$meta": {
3
3
  "package": "@walkeros/web-source-session",
4
- "version": "4.1.1-next-1779822275564",
4
+ "version": "4.1.1",
5
5
  "type": "source",
6
6
  "platform": [
7
7
  "web"
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@walkeros/web-source-session",
3
3
  "description": "Session source for walkerOS",
4
- "version": "4.1.1-next-1779822275564",
4
+ "version": "4.1.1",
5
5
  "license": "MIT",
6
6
  "main": "./dist/index.js",
7
7
  "module": "./dist/index.mjs",
@@ -33,11 +33,11 @@
33
33
  "update": "npx npm-check-updates -u && npm update"
34
34
  },
35
35
  "dependencies": {
36
- "@walkeros/core": "4.1.1-next-1779822275564",
37
- "@walkeros/web-core": "4.1.1-next-1779822275564"
36
+ "@walkeros/core": "4.1.1",
37
+ "@walkeros/web-core": "4.1.1"
38
38
  },
39
39
  "devDependencies": {
40
- "@walkeros/collector": "4.1.1-next-1779822275564"
40
+ "@walkeros/collector": "4.1.1"
41
41
  },
42
42
  "repository": {
43
43
  "url": "git+https://github.com/elbwalker/walkerOS.git",