stroid 0.1.2 → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/CHANGELOG.md +27 -2
  2. package/dist/async.js +22 -22
  3. package/dist/async.js.map +1 -1
  4. package/dist/computed.d.ts +7 -1
  5. package/dist/computed.js +11 -11
  6. package/dist/computed.js.map +1 -1
  7. package/dist/core.js +14 -14
  8. package/dist/core.js.map +1 -1
  9. package/dist/devtools.js +1 -1
  10. package/dist/devtools.js.map +1 -1
  11. package/dist/feature.js.map +1 -1
  12. package/dist/helpers.js +14 -14
  13. package/dist/helpers.js.map +1 -1
  14. package/dist/index.d.cts +1 -0
  15. package/dist/index.d.ts +1 -0
  16. package/dist/index.js +24 -24
  17. package/dist/index.js.map +1 -1
  18. package/dist/install.js +1 -1
  19. package/dist/install.js.map +1 -1
  20. package/dist/persist.js +1 -1
  21. package/dist/persist.js.map +1 -1
  22. package/dist/react/index.js +25 -25
  23. package/dist/react/index.js.map +1 -1
  24. package/dist/runtime-admin.js +1 -1
  25. package/dist/runtime-admin.js.map +1 -1
  26. package/dist/runtime-tools.js +2 -2
  27. package/dist/runtime-tools.js.map +1 -1
  28. package/dist/selectors.js +1 -1
  29. package/dist/selectors.js.map +1 -1
  30. package/dist/server.js +11 -11
  31. package/dist/server.js.map +1 -1
  32. package/dist/store-registry.d.ts +0 -1
  33. package/dist/sync.js +1 -1
  34. package/dist/sync.js.map +1 -1
  35. package/dist/testing.js +14 -14
  36. package/dist/testing.js.map +1 -1
  37. package/package.json +4 -1
  38. package/dist/types/adapters/options.d.ts +0 -335
  39. package/dist/types/async/cache.d.ts +0 -39
  40. package/dist/types/async/clone.d.ts +0 -10
  41. package/dist/types/async/errors.d.ts +0 -3
  42. package/dist/types/async/fetch.d.ts +0 -37
  43. package/dist/types/async/inflight.d.ts +0 -13
  44. package/dist/types/async/rate.d.ts +0 -5
  45. package/dist/types/async/registry.d.ts +0 -116
  46. package/dist/types/async/request.d.ts +0 -11
  47. package/dist/types/async/retry.d.ts +0 -10
  48. package/dist/types/async.d.ts +0 -10
  49. package/dist/types/computed/computed-graph.d.ts +0 -29
  50. package/dist/types/computed/index.d.ts +0 -16
  51. package/dist/types/config.d.ts +0 -10
  52. package/dist/types/core/index.d.ts +0 -11
  53. package/dist/types/core/lifecycle-hooks.d.ts +0 -16
  54. package/dist/types/core/store-admin-impl.d.ts +0 -9
  55. package/dist/types/core/store-admin.d.ts +0 -9
  56. package/dist/types/core/store-core.d.ts +0 -13
  57. package/dist/types/core/store-create.d.ts +0 -16
  58. package/dist/types/core/store-hydrate-impl.d.ts +0 -35
  59. package/dist/types/core/store-hydrate.d.ts +0 -9
  60. package/dist/types/core/store-lifecycle/hooks.d.ts +0 -19
  61. package/dist/types/core/store-lifecycle/identity.d.ts +0 -23
  62. package/dist/types/core/store-lifecycle/registry.d.ts +0 -53
  63. package/dist/types/core/store-lifecycle/types.d.ts +0 -67
  64. package/dist/types/core/store-lifecycle/validation.d.ts +0 -53
  65. package/dist/types/core/store-name.d.ts +0 -28
  66. package/dist/types/core/store-notify.d.ts +0 -12
  67. package/dist/types/core/store-read.d.ts +0 -18
  68. package/dist/types/core/store-registry.d.ts +0 -108
  69. package/dist/types/core/store-replace-impl.d.ts +0 -11
  70. package/dist/types/core/store-replace.d.ts +0 -9
  71. package/dist/types/core/store-set-impl.d.ts +0 -13
  72. package/dist/types/core/store-set.d.ts +0 -9
  73. package/dist/types/core/store-shared/core.d.ts +0 -13
  74. package/dist/types/core/store-shared/notify.d.ts +0 -12
  75. package/dist/types/core/store-transaction.d.ts +0 -26
  76. package/dist/types/core/store-write-shared.d.ts +0 -19
  77. package/dist/types/core/store-write.d.ts +0 -13
  78. package/dist/types/features/feature-registry.d.ts +0 -91
  79. package/dist/types/features/lifecycle.d.ts +0 -40
  80. package/dist/types/index.d.ts +0 -17
  81. package/dist/types/integrations/query.d.ts +0 -8
  82. package/dist/types/internals/computed-order.d.ts +0 -3
  83. package/dist/types/internals/config.d.ts +0 -116
  84. package/dist/types/internals/diagnostics.d.ts +0 -21
  85. package/dist/types/internals/reporting.d.ts +0 -9
  86. package/dist/types/internals/store-admin.d.ts +0 -7
  87. package/dist/types/internals/store-ops.d.ts +0 -13
  88. package/dist/types/internals/test-reset.d.ts +0 -2
  89. package/dist/types/internals/write-context.d.ts +0 -15
  90. package/dist/types/notification/delivery.d.ts +0 -3
  91. package/dist/types/notification/index.d.ts +0 -10
  92. package/dist/types/notification/metrics.d.ts +0 -12
  93. package/dist/types/notification/priority.d.ts +0 -9
  94. package/dist/types/notification/scheduler.d.ts +0 -11
  95. package/dist/types/notification/snapshot.d.ts +0 -8
  96. package/dist/types/runtime-admin/index.d.ts +0 -2
  97. package/dist/types/runtime-tools/index.d.ts +0 -58
  98. package/dist/types/store.d.ts +0 -16
  99. package/dist/types/types/utility.d.ts +0 -17
  100. package/dist/types/utils/clone.d.ts +0 -4
  101. package/dist/types/utils/devfreeze.d.ts +0 -2
  102. package/dist/types/utils/hash.d.ts +0 -8
  103. package/dist/types/utils/path.d.ts +0 -5
  104. package/dist/types/utils/validation.d.ts +0 -14
  105. package/dist/types/utils.d.ts +0 -13
@@ -51,7 +51,6 @@ type NotifyState = {
51
51
  pendingNotifications: Set<string>;
52
52
  pendingBuffer: string[];
53
53
  orderedNames: string[];
54
- subscriberBuffer: RegistrySubscriber[];
55
54
  notifyScheduled: boolean;
56
55
  batchDepth: number;
57
56
  flushId: number;
package/dist/sync.js CHANGED
@@ -1,2 +1,2 @@
1
- var O=new Map,ee=(e,t)=>{O.set(e,t);};var te=e=>O.get(e),re=()=>Array.from(O.keys());var oe=({value:e,sanitize:t,validate:o,onSanitizeError:a})=>{let c;if(t)try{c=t(e);}catch(l){return a?.(l),{ok:false}}else c=e;let u=o(c);return u.ok?{ok:true,value:u.value??c}:{ok:false}},x=({value:e,fallbackMs:t=Date.now(),onInvalid:o})=>{if(typeof e=="number")return Number.isFinite(e)?e:(o?.(),t);if(typeof e=="string"){let a=Date.parse(e);return Number.isFinite(a)?a:(o?.(),t)}return o?.(),t};var Ce=new Map,V=(e,t,o=0)=>{!e||typeof t!="function"||Ce.set(e,{name:e,order:o,fn:t});};var we=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),ne=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:we(),storeCleanups:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}});var _=new Map,se=new WeakSet,Me=e=>{se.has(e)||(se.add(e),re().forEach(t=>{if(!e.featureRuntimes.get(t)){let o=te(t);o&&e.featureRuntimes.set(t,o());}}));},Fe=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,ae,ie=e=>(ae||Fe||e).replace(/\.ts(\?|$)/,".js$1"),Ee=ie(new URL("../../store.js",import.meta.url).href);var Te=()=>{ae=void 0,_.clear();};V("registry.scope-override",Te,110);var Ae=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],subscriberBuffer:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false});var xe=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Ve=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:xe(),async:ne(),notify:Ae(),lifecycleListener:null};return Me(t),t},je=e=>{let t=ie(e),o=_.get(t);if(o)return o;let a=Ve();return _.set(t,a),a};var m=[],Oe={run:(e,t)=>{m.push(e);try{return t()}finally{m.pop();}},get:()=>m.length>0?m[m.length-1]:null,enterWith:e=>{if(m.length>0){m[m.length-1]=e;return}m.push(e);}};var ce=e=>(Oe).get()||e||je(Ee);var _e={log:(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},warn:(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},critical:(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));}},le={logSink:_e,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},$=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),N=new WeakMap,ue=$(le),Ne=e=>{let t=N.get(e);return t||(t=$(ue),N.set(e,t)),t};var P=()=>Ne(ce());var ze=()=>{N=new WeakMap,ue=$(le);};V("config.reset",ze,90);var Le=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,We=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,de=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,He="production",Ue=Le??We??He,pe=typeof de=="boolean"?de:Ue!=="production",I=()=>pe,Be=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));};var z=(e,t)=>{if((P().logSink.warn??Be)(e,t),P().assertRuntime)throw new Error(e)};var fe=false,F=1,qe=e=>typeof e?.v=="number"?e.v:typeof e?.protocol=="number"?e.protocol:void 0,L=new Set,W=new Set,j=100,Se=e=>{if(!e)return null;if(e===true)return j;if(typeof e!="object")return null;let t=e.loopGuard;if(t===false)return null;if(t===true||t===void 0)return j;if(typeof t=="object"){let o=t.windowMs;return typeof o=="number"&&Number.isFinite(o)&&o>0?o:j}return j},Ge=e=>typeof TextEncoder<"u"?new TextEncoder().encode(e).length:typeof Buffer<"u"?Buffer.byteLength(e):e.length,Ke=({incoming:e,accepted:t})=>{let o=t?.clock??0,a=typeof e.clock=="number"?e.clock:0;if(a!==o)return a-o;let c=e.source??"",u=t?.source??"";return c===u?0:c.localeCompare(u,"en",{sensitivity:"variant"})},Ye=e=>e?.updatedAtMs??x({value:e?.updatedAt,fallbackMs:0}),Je=e=>{if(typeof e!="object"||e===null)return false;let t=e;return (typeof t.v=="number"||typeof t.protocol=="number")&&typeof t.type=="string"&&typeof t.name=="string"&&typeof t.clock=="number"&&typeof t.source=="string"},ge=({name:e,syncChannels:t,instanceId:o,authToken:a,reportStoreError:c})=>{let u=t[e];if(u)try{let l={v:F,protocol:F,type:"sync-request",source:o,name:e,clock:0,requestedAt:Date.now()};a&&(l.token=a),u.postMessage(l);}catch(l){c(e,`Failed to request sync snapshot for "${e}": ${l?.message??l}`);}},Qe=(e,t)=>(t[e]=(t[e]??0)+1,t[e]),Xe=(e,t,o)=>(o[e]=Math.max(o[e]??0,t)+1,o[e]),Ze=({name:e,syncChannels:t,syncWindowCleanup:o,syncClocks:a,syncVersions:c})=>{t[e]?.close(),delete t[e],o[e]?.(),delete o[e],delete a[e],delete c[e];},et=({syncChannels:e,syncWindowCleanup:t})=>{Object.values(t).forEach(o=>{try{o();}catch{}}),Object.values(e).forEach(o=>{try{o.close();}catch{}});},tt=({name:e,syncOption:t,syncChannels:o,syncClocks:a,syncVersions:c,syncWindowCleanup:u,instanceId:l,getMeta:b,getAcceptedSyncVersion:S,getStoreValue:v,hasStoreEntry:h,notify:r,validate:n,reportStoreError:i,warn:d,setStoreValue:R,normalizeIncomingState:E,acceptIncomingSyncVersion:H,resolveSyncVersion:p,broadcastSync:f,markLoopGuard:g})=>{if(!t)return;if(typeof window>"u"||typeof BroadcastChannel>"u"){i(e,`Sync enabled for "${e}" but BroadcastChannel not available in this environment.`);return}let y=typeof t=="object"?t.policy:void 0,U=y==="insecure"||y!=="strict"&&typeof t=="object"&&t.insecure===true,B=typeof t=="object"&&typeof t.authToken=="string"&&t.authToken.length>0,D=typeof t=="object"&&typeof t.verify=="function",be=typeof t=="object"&&typeof t.sign=="function",q=y==="strict"||!I()&&y!=="insecure";if(q&&!U&&!B&&!D){i(e,`Sync for "${e}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`);return}!q&&!U&&!B&&!D&&!L.has(e)&&(L.add(e),z(`Sync for "${e}" is unauthenticated. Any same-origin tab can forge sync messages. Provide sync.authToken or sync.verify to enforce authentication.`)),be&&!D&&!W.has(e)&&(W.add(e),d(`Sync for "${e}" is configured with "sign" but no "verify". "sign" has no effect unless incoming messages are verified.`));let T=typeof t=="object"?t.authToken:void 0,A=Se(t),G=false,ve=typeof t=="object"&&t.channel?t.channel:`stroid_sync_${e}`;try{let k=new BroadcastChannel(ve);if(o[e]=k,k.onmessage=C=>{let s=C.data;if(!s||s.source===l||s.name!==e||o[e]!==k||!h(e)||!b(e))return;if(!Je(s)){i(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(T&&s.token!==T){G||(i(e,`Sync message for "${e}" failed auth token verification; ignoring.`),G=!0);return}let K=qe(s);if(K!==F){i(e,`Sync protocol mismatch for "${e}". Expected v${F} but received ${String(K??"unknown")}. Ignoring message.`);return}if(s.type==="sync-state"&&(typeof s.data>"u"||typeof s.clock!="number")){i(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(typeof t=="object"&&typeof t.verify=="function"){let w=!1;try{w=!!t.verify(s);}catch(M){i(e,`Sync message verification failed for "${e}": ${M?.message??M}`);return}if(!w){i(e,`Sync message for "${e}" failed verification; ignoring.`);return}}if(s.type==="sync-request"){f(e);return}let Y=typeof t=="object"?t.conflictResolver:null;if(Ke({incoming:{clock:s.clock,source:s.source},accepted:S(e)})<=0){let w=Ye(b(e)),M=typeof s.updatedAt=="number"?s.updatedAt:Date.now();if(Y){let Q=Y({local:v(e),incoming:s.data,localUpdated:w,incomingUpdated:M});if(Q!==void 0){let X=E(e,Q);if(X===null)return;R(e,X);let Z=typeof t=="object"?t.resolveUpdatedAt:null,Re=Z?Z({localUpdated:w,incomingUpdated:M,now:Date.now()}):Math.max(Date.now(),w,M);p(e,Re,typeof s.clock=="number"?s.clock:0),A&&g(e,A),r(e),f(e);}}return}let J=E(e,s.data);J!==null&&(R(e,J),H(e,typeof s.updatedAt=="number"?s.updatedAt:Date.now(),typeof s.clock=="number"?s.clock:0,typeof s.source=="string"?s.source:""),A&&g(e,A),r(e));},typeof window<"u"&&typeof window.addEventListener=="function"){u[e]?.();let C=window,s=()=>{ge({name:e,syncChannels:o,instanceId:l,authToken:T,reportStoreError:i});};C.addEventListener("focus",s),C.addEventListener("online",s),u[e]=()=>{C.removeEventListener("focus",s),C.removeEventListener("online",s);};}queueMicrotask(()=>{ge({name:e,syncChannels:o,instanceId:l,authToken:T,reportStoreError:i});});}catch(k){d(`Failed to setup sync for "${e}": ${k?.message||k}`);}},ye=({name:e,syncOption:t,syncChannels:o,syncClocks:a,instanceId:c,updatedAt:u,data:l,hashState:b,reportStoreError:S})=>{let v=o[e];if(v)try{let h=typeof t=="object"&&t.checksum==="none"?"none":"hash",r={v:F,protocol:F,type:"sync-state",source:c,name:e,clock:a[e]??0,updatedAt:x({value:u,fallbackMs:Date.now()}),data:l,checksum:h==="hash"?b(l):null};if(typeof t=="object"&&t.authToken&&(r.token=t.authToken),typeof t=="object"&&typeof t.sign=="function")try{let d=t.sign(r);if(d&&typeof d.then=="function"){S(e,`Sync signer for "${e}" returned a Promise. "sign" must be synchronous.`);return}d!==void 0&&(r.auth=d);}catch(d){S(e,`Failed to sign sync payload for "${e}": ${d?.message??d}`);return}let n=typeof t=="object"&&typeof t.maxPayloadBytes=="number"?t.maxPayloadBytes:64*1024,i=Ge(JSON.stringify(r));if(i>n){S(e,`Sync payload for "${e}" exceeds ${n} bytes (${i} bytes). Skipping BroadcastChannel sync.`);return}try{v.postMessage(r);}catch(d){if(d&&typeof d=="object"&&d.name==="DataCloneError"){S(e,`Sync payload for "${e}" could not be cloned (DataCloneError). Remove non-serializable values or provide a custom serializer. Payload size ~${i} bytes.`);return}throw d}}catch(h){S(e,`Failed to broadcast sync for "${e}": ${h?.message??h}`);}},rt=()=>{let e=Object.create(null),t=Object.create(null),o=Object.create(null),a=Object.create(null),c=Object.create(null),u=new Set,l=`stroid_${Math.random().toString(16).slice(2)}`,b=(r,n)=>{o[r]={clock:t[r]??0,updatedAt:x({value:n,fallbackMs:Date.now()}),source:l};},S=(r,n)=>{Qe(r,t),b(r,n);},v=(r,n)=>{!n||!Number.isFinite(n)||(c[r]=Date.now()+n);},h=(r,n)=>{if(!n)return false;let i=c[r];return i?Date.now()>=i?(delete c[r],false):true:false};return {onStoreCreate(r){if(!r.options.sync)return;let n=r.options.sync,i=typeof n=="object"?n.policy:void 0,d=i==="insecure"||i!=="strict"&&typeof n=="object"&&n.insecure===true,R=typeof n=="object"&&typeof n.authToken=="string"&&n.authToken.length>0,E=typeof n=="object"&&typeof n.verify=="function";if((i==="strict"||!r.isDev()&&i!=="insecure")&&n&&!d&&!R&&!E){r.reportStoreError(`Sync for "${r.name}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`),r.options.sync=false;return}if(tt({name:r.name,syncOption:n,syncChannels:e,syncClocks:t,syncVersions:o,syncWindowCleanup:a,instanceId:l,getMeta:r.getMeta,getAcceptedSyncVersion:p=>o[p],getStoreValue:p=>r.getStoreValue(),hasStoreEntry:()=>r.hasStore(),notify:()=>r.notify(),validate:(p,f)=>r.validate(f),reportStoreError:(p,f)=>r.reportStoreError(f),warn:r.warn,setStoreValue:(p,f)=>r.setStoreValue(f),normalizeIncomingState:(p,f)=>{let g=oe({value:f,sanitize:r.sanitize,validate:r.validate,onSanitizeError:y=>{r.reportStoreError(`Sanitize failed for incoming sync "${p}": ${y?.message??y}`);}});return g.ok?g.value:null},acceptIncomingSyncVersion:(p,f,g,y)=>{r.applyFeatureState(r.getStoreValue(),f),t[r.name]=Math.max(t[r.name]??0,g),o[r.name]={clock:g,updatedAt:f,source:y};},resolveSyncVersion:(p,f,g)=>{r.applyFeatureState(r.getStoreValue(),f);let y=Xe(r.name,g,t);return o[r.name]={clock:y,updatedAt:f,source:l},y},broadcastSync:()=>{let p=r.getMeta();p&&ye({name:r.name,syncOption:r.options.sync,syncChannels:e,syncClocks:t,instanceId:l,updatedAt:p.updatedAtMs??p.updatedAt,data:r.getStoreValue(),hashState:r.hashState,reportStoreError:(f,g)=>r.reportStoreError(g)});},markLoopGuard:v}),e[r.name]){let p=r.getMeta();b(r.name,p?.updatedAtMs??p?.updatedAt??new Date().toISOString());}},onStoreWrite(r){if(!r.options.sync)return;let n=r.getMeta();if(!n)return;let i=Se(r.options.sync);if(h(r.name,i)){S(r.name,n.updatedAtMs??n.updatedAt),u.has(r.name)||(u.add(r.name),r.warn(`Sync broadcast for "${r.name}" suppressed by loopGuard to prevent feedback loops.`));return}S(r.name,n.updatedAtMs??n.updatedAt),ye({name:r.name,syncOption:r.options.sync,syncChannels:e,syncClocks:t,instanceId:l,updatedAt:n.updatedAtMs??n.updatedAt,data:r.next,hashState:r.hashState,reportStoreError:(d,R)=>r.reportStoreError(R)});},beforeStoreDelete(r){Ze({name:r.name,syncChannels:e,syncWindowCleanup:a,syncClocks:t,syncVersions:o}),delete c[r.name],u.delete(r.name);},resetAll(){et({syncChannels:e,syncWindowCleanup:a}),Object.keys(e).forEach(r=>delete e[r]),Object.keys(t).forEach(r=>delete t[r]),Object.keys(o).forEach(r=>delete o[r]),Object.keys(a).forEach(r=>delete a[r]),Object.keys(c).forEach(r=>delete c[r]),L.clear(),W.clear(),u.clear();}}},me=()=>{fe||(fe=true,ee("sync",rt));};var he=()=>{me();};he();export{he as installSync};//# sourceMappingURL=sync.js.map
1
+ var Pe=new Map,mt=null,bt=(e,t)=>{Pe.set(e,t),mt?.(e,t);};var Fe=e=>Pe.get(e),ce=()=>Array.from(Pe.keys()),kt=e=>{mt=e;};var wt=({value:e,sanitize:t,validate:r,onSanitizeError:o})=>{let n;if(t)try{n=t(e);}catch(a){return o?.(a),{ok:false}}else n=e;let i=r(n);return i.ok?{ok:true,value:i.value??n}:{ok:false}},Ee=({value:e,fallbackMs:t=Date.now(),onInvalid:r})=>{if(typeof e=="number")return Number.isFinite(e)?e:(r?.(),t);if(typeof e=="string"){let o=Date.parse(e);return Number.isFinite(o)?o:(r?.(),t)}return r?.(),t};var Cr=new Map,V=(e,t,r=0)=>{!e||typeof t!="function"||Cr.set(e,{name:e,order:r,fn:t});};var vt=()=>new Map([["noSignal",new Set],["shape",new Set],["autoCreate",new Set],["mutableResult",new Set]]),Ct=()=>({fetchRegistry:Object.create(null),inflight:Object.create(null),requestVersion:Object.create(null),cacheMeta:Object.create(null),rateWindowStart:Object.create(null),rateCount:Object.create(null),ratePruneState:{lastAt:0},ratePruneTimer:null,warnedOnce:vt(),storeCleanups:Object.create(null),revalidateKeys:new Set,revalidateHandlers:Object.create(null),asyncMetrics:{cacheHits:0,cacheMisses:0,dedupes:0,requests:0,failures:0,avgMs:0,lastMs:0}}),Rt=e=>{Object.values(e.storeCleanups).forEach(t=>{Object.values(t).forEach(r=>{r?.forEach(o=>{try{o();}catch{}});});}),Object.keys(e.fetchRegistry).forEach(t=>delete e.fetchRegistry[t]),Object.keys(e.inflight).forEach(t=>delete e.inflight[t]),Object.keys(e.requestVersion).forEach(t=>delete e.requestVersion[t]),Object.keys(e.cacheMeta).forEach(t=>delete e.cacheMeta[t]),Object.keys(e.rateWindowStart).forEach(t=>delete e.rateWindowStart[t]),Object.keys(e.rateCount).forEach(t=>delete e.rateCount[t]),Object.keys(e.storeCleanups).forEach(t=>delete e.storeCleanups[t]),Object.keys(e.revalidateHandlers).forEach(t=>delete e.revalidateHandlers[t]),e.revalidateKeys.clear(),e.warnedOnce.forEach(t=>t.clear()),e.warnedOnce.clear(),vt().forEach((t,r)=>{e.warnedOnce.set(r,t);}),e.ratePruneState.lastAt=0,e.ratePruneTimer&&(clearTimeout(e.ratePruneTimer),e.ratePruneTimer=null),e.asyncMetrics.cacheHits=0,e.asyncMetrics.cacheMisses=0,e.asyncMetrics.dedupes=0,e.asyncMetrics.requests=0,e.asyncMetrics.failures=0,e.asyncMetrics.avgMs=0,e.asyncMetrics.lastMs=0;};var _e=new Map,xt=new WeakSet,ze=e=>{xt.has(e)||(xt.add(e),ce().forEach(t=>{if(!e.featureRuntimes.get(t)){let r=Fe(t);r&&e.featureRuntimes.set(t,r());}}));},Rr=typeof __STROID_REGISTRY_ID__<"u"&&__STROID_REGISTRY_ID__||typeof process<"u"&&process.env?.STROID_REGISTRY_ID||void 0,Mt,We=e=>(Mt||Rr||e).replace(/\.ts(\?|$)/,".js$1"),ue=We("stroid:default-registry");var xr=()=>{Mt=void 0,_e.clear();};V("registry.scope-override",xr,110);var Mr=()=>({pendingNotifications:new Set,pendingBuffer:[],orderedNames:[],notifyScheduled:false,batchDepth:0,flushId:0,isFlushing:false}),Fr=e=>{e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0,e.flushId=0,e.isFlushing=false;},Er=()=>({depth:0,pending:[],stagedValues:new Map,snapshotCache:new Map,failed:false,error:void 0}),Tr=(e="default")=>{let t={scope:e,stores:Object.create(null),subscribers:Object.create(null),initialStates:Object.create(null),initialFactories:Object.create(null),metaEntries:Object.create(null),snapshotCache:Object.create(null),featureRuntimes:new Map,deletingStores:new Set,computedEntries:Object.create(null),computedDependents:Object.create(null),computedCleanups:new Map,transaction:Er(),async:Ct(),notify:Mr(),lifecycleListener:null};return ze(t),t},le=e=>{let t=We(e),r=_e.get(t);if(r)return r;let o=Tr();return _e.set(t,o),o},oe=(e,t)=>Object.prototype.hasOwnProperty.call(e.stores,t);var Ft=e=>{e.computedCleanups.forEach(t=>{try{t();}catch{}}),e.computedCleanups.clear(),[e.stores,e.subscribers,e.initialStates,e.initialFactories,e.metaEntries,e.snapshotCache,e.computedEntries,e.computedDependents].forEach(t=>{Object.keys(t).forEach(r=>{delete t[r];});}),e.deletingStores.clear(),e.transaction.depth=0,e.transaction.pending=[],e.transaction.stagedValues.clear(),e.transaction.snapshotCache.clear(),e.transaction.failed=false,e.transaction.error=void 0,Fr(e.notify),Rt(e.async),e.lifecycleListener=null;};var He=(e,t)=>{try{e.lifecycleListener?.(t);}catch{}};var Y=[],Tt={run:(e,t)=>{Y.push(e);try{return t()}finally{Y.pop();}},get:()=>Y.length>0?Y[Y.length-1]:null,enterWith:e=>{if(Y.length>0){Y[Y.length-1]=e;return}Y.push(e);}};var de=e=>(Tt).get()||e||le(ue);var Vr={log:(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},warn:(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},critical:(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));}},Vt={logSink:Vr,flush:{chunkSize:Number.POSITIVE_INFINITY,chunkDelayMs:0,priorityStores:[]},revalidateOnFocus:{debounceMs:0,maxConcurrent:3,staggerMs:100},namespace:"",strictMissingFeatures:true,assertRuntime:false,strictMutatorReturns:true,asyncAutoCreate:false,asyncCloneResult:"none",autoCorrelationIds:false,acknowledgeLooseTypes:false,pathCacheSize:500,defaultSnapshotMode:"deep",strictAsyncUsageErrors:false,middleware:[],allowUntrustedHydration:false,mutatorProduce:void 0,selectorCloneFrozen:true},Be=e=>({logSink:{...e.logSink},flush:{...e.flush},revalidateOnFocus:{...e.revalidateOnFocus},namespace:e.namespace,strictMissingFeatures:e.strictMissingFeatures,assertRuntime:e.assertRuntime,strictMutatorReturns:e.strictMutatorReturns,asyncAutoCreate:e.asyncAutoCreate,asyncCloneResult:e.asyncCloneResult,autoCorrelationIds:e.autoCorrelationIds,acknowledgeLooseTypes:e.acknowledgeLooseTypes,pathCacheSize:e.pathCacheSize,defaultSnapshotMode:e.defaultSnapshotMode,strictAsyncUsageErrors:e.strictAsyncUsageErrors,middleware:[...e.middleware],allowUntrustedHydration:e.allowUntrustedHydration,mutatorProduce:e.mutatorProduce,selectorCloneFrozen:e.selectorCloneFrozen}),Le=new WeakMap,At=Be(Vt),Ar=e=>{let t=Le.get(e);return t||(t=Be(At),Le.set(e,t)),t};var N=()=>Ar(de());var Ir=()=>{Le=new WeakMap,At=Be(Vt);};V("config.reset",Ir,90);var Nr=typeof process<"u"&&typeof process.env?.NODE_ENV=="string"?process.env.NODE_ENV:void 0,Pr=typeof import.meta<"u"&&import.meta?.env?.MODE?import.meta.env.MODE:void 0,Dt=typeof globalThis<"u"&&typeof globalThis.__STROID_DEV__=="boolean"?globalThis.__STROID_DEV__:void 0,_r="production",zr=Nr??Pr??_r,je=typeof Dt=="boolean"?Dt:zr!=="production",A=()=>je,Ot=(e,t)=>{typeof console<"u"&&typeof console.warn=="function"&&(t?console.warn(`[stroid] ${e}`,t):console.warn(`[stroid] ${e}`));},Wr=(e,t)=>{typeof console<"u"&&typeof console.error=="function"&&(t?console.error(`[stroid] ${e}`,t):console.error(`[stroid] ${e}`));},Hr=(e,t)=>{typeof console<"u"&&typeof console.log=="function"&&(t?console.log(`[stroid] ${e}`,t):console.log(`[stroid] ${e}`));},we=(e,t)=>{if((N().logSink.critical??Wr)(e,t),N().assertRuntime)throw new Error(e)},k=(e,t)=>{if(!je)return;if((N().logSink.warn??Ot)(e,t),N().assertRuntime)throw new Error(e)},q=(e,t)=>{if((N().logSink.warn??Ot)(e,t),N().assertRuntime)throw new Error(e)};var ee=(e,t)=>{if(!je)return;(N().logSink.log??Hr)(e,t);};var $t=()=>"Date detected; stored as ISO string. Use new Date(value) when reading.",It=()=>"Map detected; converting to plain object.",Nt=()=>"Set detected; converting to array.";var fe=new Set(["__proto__","constructor","prototype"]),Ue=(e,t)=>{if(!e)return {ok:true};try{if(typeof e.safeParse=="function"){let r=e.safeParse(t);return r.success?{ok:!0,data:r.data}:{ok:!1,error:r.error}}if(typeof e.parse=="function")return e.parse(t),{ok:!0,data:t};if(typeof e.validateSync=="function")return e.validateSync(t),{ok:!0,data:t};if(typeof e.isValidSync=="function")return e.isValidSync(t)?{ok:!0,data:t}:{ok:!1,error:"Schema validation failed"};if(typeof e.validate=="function"){let r=e.validate(t);if(r===!0)return {ok:!0,data:t};if(r===!1)return {ok:!1,error:e.errors||"Schema validation failed"};if(r&&typeof r=="object"){let n=r.error,i=n?.details?.[0]?.message||n?.message||r.message||e.errors;if(i)return {ok:!1,error:i};if(n)return {ok:!1,error:n}}return {ok:!1,error:e.errors||"Schema validation failed"}}if(typeof e=="function"){let r=e(t);return r===!1?{ok:!1,error:"Schema validation failed"}:{ok:!0,data:r===!0?t:r}}return {ok:!0,data:t}}catch(r){return {ok:false,error:r?.message??r}}};var qe=e=>e===null?"null":Array.isArray(e)?"array":e instanceof Map?"map":e instanceof Set?"set":e instanceof Date?"date":typeof e=="function"?"function":typeof e,Br=e=>{if(!e||typeof e!="object")return null;let t=globalThis?.WeakRef;return t&&e instanceof t?"WeakRef":typeof WeakMap<"u"&&e instanceof WeakMap?"WeakMap":typeof WeakSet<"u"&&e instanceof WeakSet?"WeakSet":typeof EventTarget<"u"&&e instanceof EventTarget?"EventTarget":typeof ReadableStream<"u"&&e instanceof ReadableStream?"ReadableStream":typeof WritableStream<"u"&&e instanceof WritableStream?"WritableStream":typeof Request<"u"&&e instanceof Request?"Request":typeof Response<"u"&&e instanceof Response?"Response":typeof Headers<"u"&&e instanceof Headers?"Headers":typeof FormData<"u"&&e instanceof FormData?"FormData":null};var ve=(e,t)=>{let r=Br(e);if(r)throw new Error(`${r} values are not supported`);let o=qe(e);if(o==="number"){if(!Number.isFinite(e))throw new Error("Non-finite numbers are not supported");return e}if(o==="bigint")throw new Error("BigInt values are not supported");if(o==="symbol")throw new Error("Symbol values are not supported");if(o==="date")return A()&&k($t()),e.toISOString();if(o==="map"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e),A()&&k(It());let n={};for(let[i,a]of e){if(typeof i!="string")throw new Error("Map keys must be strings to remain JSON-safe");n[String(i)]=ve(a,t);}return n}if(o==="set"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),A()&&k(Nt()),Array.from(e,n=>ve(n,t))}if(o==="object"){if(t.has(e))throw new Error("Circular reference detected during sanitize");t.add(e);let n={},i=Object.getOwnPropertyDescriptors(e);for(let[a,f]of Object.entries(i))if(f.enumerable&&!fe.has(a)){if("get"in f||"set"in f)throw new Error(`Accessor properties are not supported during sanitize ("${a}")`);n[a]=ve(f.value,t);}return n}if(o==="array"){if(t.has(e))throw new Error("Circular reference detected during sanitize");return t.add(e),e.map(n=>ve(n,t))}return e},pe=e=>ve(e,new WeakSet);var Ge=null,Ur=()=>{if(Ge)return Ge;let e,t=[];for(let r=0;r<256;r++){e=r;for(let o=0;o<8;o++)e=e&1?3988292384^e>>>1:e>>>1;t[r]=e>>>0;}return Ge=t,t},_t=e=>{let t=Ur(),r=-1;for(let o=0;o<e.length;o++)r=r>>>0,r=r>>>8^t[(r^e.charCodeAt(o))&255];return (r^-1)>>>0},qr=2166136261,Gr=2654435761,Kr=1e5,te=(e,t)=>{let r=t>>>0;e.h1=Math.imul(e.h1^r,2246822507),e.h2=Math.imul(e.h2^r,3266489909);},ne=(e,t)=>{te(e,t.length);for(let r=0;r<t.length;r++)te(e,t.charCodeAt(r));},T=(e,t)=>{ne(e,t);},Pt=(e,t)=>{if(Number.isNaN(t)){T(e,"NaN");return}if(!Number.isFinite(t)){T(e,t>0?"Infinity":"-Infinity");return}if(Object.is(t,-0)){T(e,"-0");return}let r=t|0;if(t===r){T(e,"int"),te(e,r);return}T(e,"num"),ne(e,String(t));},ge=(e,t)=>{if(e.nodes++>Kr){T(e,"[max]");return}if(t===null){T(e,"null");return}let r=typeof t;if(r==="string"){T(e,"string"),ne(e,t);return}if(r==="number"){T(e,"number"),Pt(e,t);return}if(r==="boolean"){T(e,t?"true":"false");return}if(r==="undefined"){T(e,"undefined");return}if(r==="bigint"){T(e,"bigint"),ne(e,t.toString());return}if(r==="symbol"){T(e,"symbol");let p=t;ne(e,Symbol.keyFor(p)??p.description??String(p));return}if(r==="function"){T(e,"function"),ne(e,t.name||"anonymous");return}let o=t,n=e.seen.get(o);if(n!==void 0){T(e,"ref"),te(e,n);return}let i=e.nextId++;if(e.seen.set(o,i),Array.isArray(o)){T(e,"array"),te(e,o.length);for(let p=0;p<o.length;p++)Object.prototype.hasOwnProperty.call(o,p)?ge(e,o[p]):T(e,"hole");return}if(o instanceof Date){T(e,"date"),Pt(e,o.getTime());return}if(o instanceof Map){T(e,"map"),te(e,o.size),o.forEach((p,m)=>{ge(e,m),ge(e,p);});return}if(o instanceof Set){T(e,"set"),te(e,o.size),o.forEach(p=>{ge(e,p);});return}T(e,"object");let a=Object.getOwnPropertyDescriptors(o),f=[];Object.entries(a).forEach(([p,m])=>{m?.enumerable&&(fe.has(p)||"get"in m||"set"in m||f.push([p,m]));}),te(e,f.length);for(let[p,m]of f)ne(e,p),ge(e,m.value);},Ce=e=>{if(typeof e=="string")return _t(JSON.stringify(e));let t={h1:qr,h2:Gr,seen:new WeakMap,nextId:1,nodes:0};ge(t,e);let r=t.h1>>>0,o=t.h2>>>0;return r^=r>>>16,r=Math.imul(r,2246822507),r^=r>>>13,r=Math.imul(r,3266489909),r^=r>>>16,o^=o>>>16,o=Math.imul(o,668265261),o^=o>>>15,o=Math.imul(o,374761393),o^=o>>>16,(r&2097151)*4294967296+(o>>>0)};var Yr=typeof globalThis<"u"&&typeof globalThis.structuredClone=="function",Ye=e=>{if(typeof e=="function")return "function";if(typeof e=="symbol")return "symbol";if(e===null||typeof e!="object")return null;let t=[["WeakMap",globalThis.WeakMap],["WeakSet",globalThis.WeakSet],["WeakRef",globalThis.WeakRef],["Promise",globalThis.Promise],["ReadableStream",globalThis.ReadableStream],["WritableStream",globalThis.WritableStream],["TransformStream",globalThis.TransformStream],["EventTarget",globalThis.EventTarget]];for(let[o,n]of t)if(typeof n=="function"&&e instanceof n)return o;let r=globalThis.Node;return typeof r=="function"&&e instanceof r?"DOM Node":null},Jr=e=>Ye(e)===null,Xr=e=>{let t=Ye(e);if(t)throw new Error(`deepClone failed: value is not structured-cloneable (${t}). Avoid storing this type in stroid state.`)},se=(e,t=new WeakMap)=>{if(Xr(e),e===null||typeof e!="object")return e;if(t.has(e))return t.get(e);if(e instanceof Date)return new Date(e.getTime());if(e instanceof Map){let n=new Map;return t.set(e,n),e.forEach((i,a)=>{n.set(se(a,t),se(i,t));}),n}if(e instanceof Set){let n=new Set;return t.set(e,n),e.forEach(i=>{n.add(se(i,t));}),n}if(Array.isArray(e)){let n=[];return t.set(e,n),e.forEach((i,a)=>{n[a]=se(i,t);}),n}let r={};t.set(e,r);let o;try{o=Object.getOwnPropertyDescriptors(e);}catch(n){throw new Error(`deepClone failed to read object descriptors (possible Proxy or host object): ${n?.message??n}`)}return Object.entries(o).forEach(([n,i])=>{!i.enumerable||fe.has(n)||"get"in i||"set"in i||(r[n]=se(i.value,t));}),r},B=e=>{if(Yr)try{return structuredClone(e)}catch(t){if(!Jr(e)){let r=Ye(e)??"unknown";throw new Error(`deepClone failed: value is not structured-cloneable (${r}). Avoid storing this type in stroid state.`)}return k(`deepClone fell back to manual clone after structuredClone failed: ${t?.message??t}`),se(e)}return se(e)};var Je=(e,t,...r)=>{if(typeof e=="function")try{e(...r);}catch(o){let n=o?.message??o;q(`${t} callback threw: ${String(n)}`);}},ye=(e,t={})=>{let{severity:r="warn",visibility:o="dev",onError:n}=t;if(Je(n,"onError",e),r==="critical"){o==="dev"&&k(e),we(e);return}if(o==="always"){q(e);return}k(e);};var zt=({name:e,label:t,fn:r,args:o,reportIssue:n})=>{if(typeof r=="function")try{r(...o);}catch(i){let a=`${t} for "${e}" failed: ${i?.message??i}`;n(a,"always");}};V("computed.order-resolver",()=>{},105);var Lt=()=>de(le(ue)),Xe=()=>Lt().computedEntries,Bt=()=>Lt().computedDependents;var Ut=e=>Object.prototype.hasOwnProperty.call(Xe(),e);var Qe=e=>{let t=Xe()[e];if(!t)return null;let r=Bt()[e];return {deps:[...t.deps],dependents:r?[...r]:[]}};var eo=new Set;var to=()=>{eo.clear();};V("ssr.warnings",to,60);var ro=(e,t,r={})=>{ye(t,{...r,onError:O[e]?.options?.onError});};var Ze=(e,t)=>ro(e,t,{severity:"critical",visibility:"always"});var qt=new WeakMap,Gt=new WeakMap;var Oe=e=>{let t=qt.get(e);return t||(t=new Map,qt.set(e,t)),t},Kt=e=>{let t=Gt.get(e);return t||(t=new Map,Gt.set(e,t)),t};new Proxy(new Map,{get:(e,t)=>{let r=Oe(P());if(t==="size")return r.size;if(t===Symbol.iterator)return r[Symbol.iterator].bind(r);let o=r[t];return typeof o=="function"?o.bind(r):o},set:(e,t,r)=>(Oe(P())[t]=r,true)});var oo=(e,t)=>{let r=new Set,o=O[e]?.options?.onError;return typeof o=="function"&&r.add(o),r},Yt=(e,t,r,o)=>{if(!r)return {ok:true,value:t};let n=oo(e),i=(f,p)=>{n.forEach(m=>Je(m,`onError(${e})`,f)),p==="critical"?we(f):k(f);};if(typeof r=="function")try{let f=r(t);return f===!1?(i(`Validation blocked update for "${e}"`,"warn"),{ok:!1}):{ok:!0,value:f===!0?t:f}}catch(f){return i(`Validation for "${e}" failed: ${f?.message??f}`,"critical"),{ok:false}}let a=Ue(r,t);return a.ok?{ok:true,value:a.data??t}:(i(`Validation failed for "${e}": ${a.error}`,"critical"),{ok:false})};var et=e=>{let t=P();Oe(t).delete(e),Kt(t).delete(e);},no=()=>{let e=P();Oe(e).clear(),Kt(e).clear();};V("validation.path-cache",no,50);Jt(et);var or=new Map;var xe=(e,t,r)=>{let o=or.get(e);!o||o.size===0||o.forEach(n=>{try{n(t,r);}catch(i){typeof console<"u"&&console.warn&&console.warn(`[stroid] lifecycle hook "${e}" failed:`,i);}});};var so=()=>{};V("write-context.runner",so,121);var co=()=>{let e=P().notify;e.pendingNotifications.clear(),e.pendingBuffer.length=0,e.orderedNames.length=0,e.notifyScheduled=false,e.batchDepth=0;};V("notify.reset",co,40);var uo=()=>P().computedCleanups,ir=new WeakMap;var lo=e=>{let t=ir.get(e);return t||(t=new Map,ir.set(e,t)),t};var ar=e=>{let t=uo(),r=t.get(e);if(!r){A()&&k(`deleteComputed("${e}") -- not found`);return}r(),t.delete(e);};var cr=(e,t=P())=>lo(t).get(e)?.autoDispose===true;var ur=e=>{let t=e.stores,r=e.subscribers,o=e.initialStates,n=e.initialFactories,i=e.metaEntries,a=e.snapshotCache,f=e.featureRuntimes,p=e.deletingStores,m=(l,R)=>{ye(R,{onError:i[l]?.options?.onError,severity:"warn",visibility:"dev"});},S=({name:l,prev:R,options:v,initialState:D,getMeta:w,getStoreValue:C,hasStore:x})=>({name:l,options:v,prev:R,getMeta:w,getStoreValue:C,getAllStores:()=>t,getInitialState:()=>D,hasStore:x,setStoreValue:()=>{},applyFeatureState:()=>{},notify:()=>{},reportStoreError:b=>{ye(b,{onError:v.onError,severity:"warn",visibility:"dev"});},warn:k,warnAlways:q,log:ee,hashState:Ce,deepClone:B,sanitize:pe,validate:()=>({ok:true,value:R}),isDev:A}),s=({name:l,prev:R,options:v,initialState:D,phase:w})=>{let C=S({name:l,prev:R,options:v,initialState:D,getMeta:()=>i[l],getStoreValue:()=>t[l],hasStore:()=>oe(e,l)}),x=S({name:l,prev:R,options:v,initialState:D,getMeta:()=>{},getStoreValue:()=>R,hasStore:()=>false});ce().forEach(b=>{let $=f.get(b);w==="before"?$?.beforeStoreDelete?.(C):$?.afterStoreDelete?.(x);});},c=l=>{if(!oe(e,l))return;let R=t[l],v=i[l].options,D=o[l],w=r[l];p.add(l);try{w?.forEach(b=>{try{b(null);}catch($){k(`Subscriber for "${l}" threw during delete: ${$?.message??$}`);}}),zt({name:l,label:"onDelete",fn:v.onDelete,args:[R],reportIssue:(b,$)=>{ye(b,{onError:v.onError,severity:"warn",visibility:$});}}),s({name:l,prev:R,options:v,initialState:D,phase:"before"}),delete t[l],delete r[l],delete o[l],delete n[l],delete i[l],delete a[l],Ut(l)&&ar(l);let x=e.computedDependents[l];if(x)for(let b of [...x]){let $=Qe(b);if($&&cr(b,e)&&$.deps.every(X=>!oe(e,X))){c(b);continue}k(`[stroid] source store "${l}" was deleted. Computed store "${b}" depends on it and will return stale data. Call deleteComputed("${b}") to clean up.`);}s({name:l,prev:R,options:v,initialState:D,phase:"after"}),xe("afterStoreDelete",l,{type:"afterStoreDelete",prev:R}),He(e,{type:"deleted",name:l}),ee(`Store "${l}" deleted`);}finally{p.delete(l);}};return {deleteExistingStore:c,clearAllStores:()=>{let l=[],v=0,D=Number.POSITIVE_INFINITY;for(;v<20;){let C=Object.keys(t);if(C.length===0)break;C.forEach(b=>{oe(e,b)&&(c(b),l.push(b));}),v+=1;let x=Object.keys(t).length;if(x===0||x>=D)break;D=x;}let w=Object.keys(t).length;return w>0?k(`clearAllStores stopped after ${v} pass${v===1?"":"es"}; ${w} store(s) still registered (likely recreated during deletion).`):ee(`All stores cleared (${l.length} stores removed)`),l},clearStores:l=>{let R=Object.keys(t).filter(v=>l?l.endsWith("*")?v.startsWith(l.slice(0,-1)):v===l:true);return R.forEach(v=>c(v)),R},reportStoreError:m}};var dt=ue,dr=le(dt),fr=null,H=()=>{let e=de(dr);return ze(e),e};var P=()=>H();function Jt(e){fr=e;}var he=e=>new Proxy(Object.create(null),{get:(t,r)=>e()[r],set:(t,r,o)=>(e()[r]=o,true),deleteProperty:(t,r)=>(delete e()[r],true),has:(t,r)=>r in e(),ownKeys:()=>Reflect.ownKeys(e()),getOwnPropertyDescriptor:(t,r)=>{let o=Object.getOwnPropertyDescriptor(e(),r);if(o)return {...o,configurable:true}}}),fo=e=>new Proxy(new Map,{get:(t,r)=>{let o=e();if(r==="size")return o.size;if(r===Symbol.iterator)return o[Symbol.iterator].bind(o);let n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),po=e=>new Proxy({},{get:(t,r)=>{let o=e(),n=o[r];return typeof n=="function"?n.bind(o):n},set:(t,r,o)=>(e()[r]=o,true)}),Ae=he(()=>H().stores);he(()=>H().subscribers);var pr=he(()=>H().initialStates);he(()=>H().initialFactories);var O=he(()=>H().metaEntries);he(()=>H().snapshotCache);var J=fo(()=>H().featureRuntimes),lr=new WeakMap,go=e=>{let t=lr.get(e);return t||(t=ur(e),lr.set(e,t)),t};po(()=>go(H()));var yo=e=>{let t=J.get(e);if(t)return t;let r=Fe(e);if(!r)return;let o=r();return J.set(e,o),o},ft=()=>{ce().forEach(e=>{yo(e);});};kt((e,t)=>{J.get(e)||J.set(e,t());});ft();var De=(e,t)=>oe(H(),e);var $e=(e,t,r=H())=>{r.stores[e]=t;},gr=(e,t,r=Date.now())=>{$e(e,t),O[e]&&(O[e].updatedAt=new Date(r).toISOString(),O[e].updatedAtMs=r,O[e].lastCorrelationId=null,O[e].lastCorrelationAt=null,O[e].lastCorrelationAtMs=null,O[e].lastTraceContext=null,O[e].updateCount>=Number.MAX_SAFE_INTEGER?O[e].updateCount=0:O[e].updateCount+=1,fr?.(e));};var ho=()=>{Ft(H());},So=()=>{J.forEach(e=>{try{e.resetAll?.();}catch{}}),J.clear();};V("features.reset",So,10);V("registries.clear",ho,20);V("registry.default",()=>{dt=ue,dr=le(dt);},115);var yr=new WeakMap,hr=e=>{let t=yr.get(e);return t||(t=new Map,yr.set(e,t)),t},mo=()=>{hr(P()).clear();};V("features.contexts",mo,100);var bo=e=>{let t=P(),r=hr(t),o=r.get(e);if(o)return o;let n=O[e];if(!n)return k(`Internal feature context requested for "${e}" after metadata was cleared.`),null;let i={name:e,options:n.options,getMeta:()=>O[e],getStoreValue:()=>Ae[e],getAllStores:()=>Ae,getInitialState:()=>pr[e],hasStore:()=>De(e),setStoreValue:a=>{$e(e,a);},applyFeatureState:(a,f)=>{gr(e,a,f),et(e);},notify:()=>{},reportStoreError:a=>{Ze(e,a);},warn:k,warnAlways:q,log:ee,hashState:Ce,deepClone:B,sanitize:pe,validate:a=>Yt(e,a,O[e]?.options?.validate),isDev:A};return r.set(e,i),i},ko=(e,t)=>{let r=N();if(!r.strictMissingFeatures&&!r.assertRuntime)return;let o=[];if(typeof t.getMeta!="function"&&o.push("getMeta"),typeof t.getStoreValue!="function"&&o.push("getStoreValue"),typeof t.getAllStores!="function"&&o.push("getAllStores"),typeof t.getInitialState!="function"&&o.push("getInitialState"),typeof t.hasStore!="function"&&o.push("hasStore"),typeof t.setStoreValue!="function"&&o.push("setStoreValue"),typeof t.applyFeatureState!="function"&&o.push("applyFeatureState"),typeof t.notify!="function"&&o.push("notify"),typeof t.reportStoreError!="function"&&o.push("reportStoreError"),typeof t.warn!="function"&&o.push("warn"),typeof t.warnAlways!="function"&&o.push("warnAlways"),typeof t.log!="function"&&o.push("log"),typeof t.hashState!="function"&&o.push("hashState"),typeof t.deepClone!="function"&&o.push("deepClone"),typeof t.sanitize!="function"&&o.push("sanitize"),typeof t.validate!="function"&&o.push("validate"),typeof t.isDev!="function"&&o.push("isDev"),o.length===0)return;let n=`Feature hook context missing fields for "${e}": ${o.join(", ")}.`;if(Ze(e,n),r.assertRuntime)throw new Error(n)};var pt=(e,t,r,o,n,i)=>{ft();let a=bo(e);if(!a)return;a.notify=()=>n(e);let f=Object.assign(Object.create(a),{action:t,prev:r,next:o});ko(e,f);let p=new Set(i);J.forEach((m,S)=>{p.has(S)||m.onStoreWrite?.(f);});};var Sr=false,Se=1,wo=e=>typeof e?.v=="number"?e.v:typeof e?.protocol=="number"?e.protocol:void 0,gt=new Set,yt=new Set,Ne=100,kr=e=>{if(!e)return null;if(e===true)return Ne;if(typeof e!="object")return null;let t=e.loopGuard;if(t===false)return null;if(t===true||t===void 0)return Ne;if(typeof t=="object"){let r=t.windowMs;return typeof r=="number"&&Number.isFinite(r)&&r>0?r:Ne}return Ne},vo=e=>typeof TextEncoder<"u"?new TextEncoder().encode(e).length:typeof Buffer<"u"?Buffer.byteLength(e):e.length,Co=({incoming:e,accepted:t})=>{let r=t?.clock??0,o=typeof e.clock=="number"?e.clock:0;if(o!==r)return o-r;let n=e.source??"",i=t?.source??"";return n===i?0:n.localeCompare(i,"en",{sensitivity:"variant"})},Ro=e=>e?.updatedAtMs??Ee({value:e?.updatedAt,fallbackMs:0}),xo=e=>{if(typeof e!="object"||e===null)return false;let t=e;return (typeof t.v=="number"||typeof t.protocol=="number")&&typeof t.type=="string"&&typeof t.name=="string"&&typeof t.clock=="number"&&typeof t.source=="string"},mr=({name:e,syncChannels:t,instanceId:r,authToken:o,reportStoreError:n})=>{let i=t[e];if(i)try{let a={v:Se,protocol:Se,type:"sync-request",source:r,name:e,clock:0,requestedAt:Date.now()};o&&(a.token=o),i.postMessage(a);}catch(a){n(e,`Failed to request sync snapshot for "${e}": ${a?.message??a}`);}},Mo=(e,t)=>(t[e]=(t[e]??0)+1,t[e]),Fo=(e,t,r)=>(r[e]=Math.max(r[e]??0,t)+1,r[e]),Eo=({name:e,syncChannels:t,syncWindowCleanup:r,syncClocks:o,syncVersions:n})=>{t[e]?.close(),delete t[e],r[e]?.(),delete r[e],delete o[e],delete n[e];},To=({syncChannels:e,syncWindowCleanup:t})=>{Object.values(t).forEach(r=>{try{r();}catch{}}),Object.values(e).forEach(r=>{try{r.close();}catch{}});},jo=({name:e,syncOption:t,syncChannels:r,syncClocks:o,syncVersions:n,syncWindowCleanup:i,instanceId:a,getMeta:f,getAcceptedSyncVersion:p,getStoreValue:m,hasStoreEntry:S,notify:s,validate:c,reportStoreError:g,warn:y,setStoreValue:l,normalizeIncomingState:R,acceptIncomingSyncVersion:v,resolveSyncVersion:D,broadcastSync:w,markLoopGuard:C,hashState:x})=>{if(!t)return;if(typeof window>"u"||typeof BroadcastChannel>"u"){g(e,`Sync enabled for "${e}" but BroadcastChannel not available in this environment.`);return}let b=typeof t=="object"?t.policy:void 0,$=b==="insecure"||b!=="strict"&&typeof t=="object"&&t.insecure===true,X=typeof t=="object"&&typeof t.authToken=="string"&&t.authToken.length>0,ie=typeof t=="object"&&typeof t.verify=="function",Me=typeof t=="object"&&typeof t.sign=="function",me=b==="strict"||!A()&&b!=="insecure";if(me&&!$&&!X&&!ie){g(e,`Sync for "${e}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`);return}!me&&!$&&!X&&!ie&&!gt.has(e)&&(gt.add(e),q(`Sync for "${e}" is unauthenticated. Any same-origin tab can forge sync messages. Provide sync.authToken or sync.verify to enforce authentication.`)),Me&&!ie&&!yt.has(e)&&(yt.add(e),y(`Sync for "${e}" is configured with "sign" but no "verify". "sign" has no effect unless incoming messages are verified.`));let Q=typeof t=="object"?t.authToken:void 0,d=kr(t),E=false,M=typeof t=="object"&&t.channel?t.channel:`stroid_sync_${e}`;try{let u=new BroadcastChannel(M);if(r[e]=u,u.onmessage=_=>{let h=_.data;if(!h||h.source===a||h.name!==e||r[e]!==u||!S(e)||!f(e))return;if(!xo(h)){g(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(Q&&h.token!==Q){E||(g(e,`Sync message for "${e}" failed auth token verification; ignoring.`),E=!0);return}let I=wo(h);if(I!==Se){g(e,`Sync protocol mismatch for "${e}". Expected v${Se} but received ${String(I??"unknown")}. Ignoring message.`);return}let W=h.type==="sync-state";if(W&&(typeof h.data>"u"||typeof h.clock!="number")){g(e,`Sync message for "${e}" is malformed; ignoring.`);return}if(typeof t=="object"&&typeof t.verify=="function"){let j=!1;try{j=!!t.verify(h);}catch(F){g(e,`Sync message verification failed for "${e}": ${F?.message??F}`);return}if(!j){g(e,`Sync message for "${e}" failed verification; ignoring.`);return}}let G=typeof t=="object"&&t.checksum==="none"?"none":"hash";if(W&&G!=="none"){let j=x(h.data);if(h.checksum!==j){g(e,`Sync checksum mismatch for "${e}". Expected ${String(j)}, got ${String(h.checksum)}. Ignoring message.`);return}}if(h.type==="sync-request"){w(e);return}let L=typeof t=="object"?t.conflictResolver:null;if(Co({incoming:{clock:h.clock,source:h.source},accepted:p(e)})<=0){let j=Ro(f(e)),F=typeof h.updatedAt=="number"?h.updatedAt:Date.now();if(L){let U=L({local:m(e),incoming:h.data,localUpdated:j,incomingUpdated:F});if(U!==void 0){let z=R(e,U);if(z===null)return;let be=m(e);l(e,z);let Z=typeof t=="object"?t.resolveUpdatedAt:null,ke=Z?Z({localUpdated:j,incomingUpdated:F,now:Date.now()}):Math.max(Date.now(),j,F);D(e,ke,typeof h.clock=="number"?h.clock:0),pt(e,"sync",be,z,()=>s(e),["sync"]),d&&C(e,d),s(e),w(e);}}return}let K=R(e,h.data);if(K===null)return;let re=m(e);l(e,K),v(e,typeof h.updatedAt=="number"?h.updatedAt:Date.now(),typeof h.clock=="number"?h.clock:0,typeof h.source=="string"?h.source:""),pt(e,"sync",re,K,()=>s(e),["sync"]),d&&C(e,d),s(e);},typeof window<"u"&&typeof window.addEventListener=="function"){i[e]?.();let _=window,h=()=>{mr({name:e,syncChannels:r,instanceId:a,authToken:Q,reportStoreError:g});};_.addEventListener("focus",h),_.addEventListener("online",h),i[e]=()=>{_.removeEventListener("focus",h),_.removeEventListener("online",h);};}queueMicrotask(()=>{mr({name:e,syncChannels:r,instanceId:a,authToken:Q,reportStoreError:g});});}catch(u){y(`Failed to setup sync for "${e}": ${u?.message||u}`);}},br=({name:e,syncOption:t,syncChannels:r,syncClocks:o,instanceId:n,updatedAt:i,data:a,hashState:f,reportStoreError:p})=>{let m=r[e];if(m)try{let S=typeof t=="object"&&t.checksum==="none"?"none":"hash",s={v:Se,protocol:Se,type:"sync-state",source:n,name:e,clock:o[e]??0,updatedAt:Ee({value:i,fallbackMs:Date.now()}),data:a,checksum:S==="hash"?f(a):null};if(typeof t=="object"&&t.authToken&&(s.token=t.authToken),typeof t=="object"&&typeof t.sign=="function")try{let y=t.sign(s);if(y&&typeof y.then=="function"){p(e,`Sync signer for "${e}" returned a Promise. "sign" must be synchronous.`);return}y!==void 0&&(s.auth=y);}catch(y){p(e,`Failed to sign sync payload for "${e}": ${y?.message??y}`);return}let c=typeof t=="object"&&typeof t.maxPayloadBytes=="number"?t.maxPayloadBytes:64*1024,g=vo(JSON.stringify(s));if(g>c){p(e,`Sync payload for "${e}" exceeds ${c} bytes (${g} bytes). Skipping BroadcastChannel sync.`);return}try{m.postMessage(s);}catch(y){if(y&&typeof y=="object"&&y.name==="DataCloneError"){p(e,`Sync payload for "${e}" could not be cloned (DataCloneError). Remove non-serializable values or provide a custom serializer. Payload size ~${g} bytes.`);return}throw y}}catch(S){p(e,`Failed to broadcast sync for "${e}": ${S?.message??S}`);}},Vo=()=>{let e=Object.create(null),t=Object.create(null),r=Object.create(null),o=Object.create(null),n=Object.create(null),i=new Set,a=`stroid_${Math.random().toString(16).slice(2)}`,f=(s,c)=>{r[s]={clock:t[s]??0,updatedAt:Ee({value:c,fallbackMs:Date.now()}),source:a};},p=(s,c)=>{Mo(s,t),f(s,c);},m=(s,c)=>{!c||!Number.isFinite(c)||(n[s]=Date.now()+c);},S=(s,c)=>{if(!c)return false;let g=n[s];return g?Date.now()>=g?(delete n[s],false):true:false};return {onStoreCreate(s){if(!s.options.sync)return;let c=s.options.sync,g=s.notify,y=typeof c=="object"?c.policy:void 0,l=y==="insecure"||y!=="strict"&&typeof c=="object"&&c.insecure===true,R=typeof c=="object"&&typeof c.authToken=="string"&&c.authToken.length>0,v=typeof c=="object"&&typeof c.verify=="function";if((y==="strict"||!s.isDev()&&y!=="insecure")&&c&&!l&&!R&&!v){s.reportStoreError(`Sync for "${s.name}" requires authToken or verify in strict mode. Use sync: { policy: "insecure" } to acknowledge the risk.`),s.options.sync=false;return}if(jo({name:s.name,syncOption:c,syncChannels:e,syncClocks:t,syncVersions:r,syncWindowCleanup:o,instanceId:a,getMeta:s.getMeta,getAcceptedSyncVersion:w=>r[w],getStoreValue:w=>s.getStoreValue(),hasStoreEntry:()=>s.hasStore(),notify:()=>g(),validate:(w,C)=>s.validate(C),reportStoreError:(w,C)=>s.reportStoreError(C),warn:s.warn,setStoreValue:(w,C)=>s.setStoreValue(C),normalizeIncomingState:(w,C)=>{let x=wt({value:C,sanitize:s.sanitize,validate:s.validate,onSanitizeError:b=>{s.reportStoreError(`Sanitize failed for incoming sync "${w}": ${b?.message??b}`);}});return x.ok?x.value:null},acceptIncomingSyncVersion:(w,C,x,b)=>{s.applyFeatureState(s.getStoreValue(),C),t[s.name]=Math.max(t[s.name]??0,x),r[s.name]={clock:x,updatedAt:C,source:b};},resolveSyncVersion:(w,C,x)=>{s.applyFeatureState(s.getStoreValue(),C);let b=Fo(s.name,x,t);return r[s.name]={clock:b,updatedAt:C,source:a},b},broadcastSync:()=>{let w=s.getMeta();w&&br({name:s.name,syncOption:s.options.sync,syncChannels:e,syncClocks:t,instanceId:a,updatedAt:w.updatedAtMs??w.updatedAt,data:s.getStoreValue(),hashState:s.hashState,reportStoreError:(C,x)=>s.reportStoreError(x)});},markLoopGuard:m,hashState:s.hashState}),e[s.name]){let w=s.getMeta();f(s.name,w?.updatedAtMs??w?.updatedAt??new Date().toISOString());}},onStoreWrite(s){if(!s.options.sync)return;let c=s.getMeta();if(!c)return;let g=kr(s.options.sync);if(S(s.name,g)){p(s.name,c.updatedAtMs??c.updatedAt),i.has(s.name)||(i.add(s.name),s.warn(`Sync broadcast for "${s.name}" suppressed by loopGuard to prevent feedback loops.`));return}p(s.name,c.updatedAtMs??c.updatedAt),br({name:s.name,syncOption:s.options.sync,syncChannels:e,syncClocks:t,instanceId:a,updatedAt:c.updatedAtMs??c.updatedAt,data:s.next,hashState:s.hashState,reportStoreError:(y,l)=>s.reportStoreError(l)});},beforeStoreDelete(s){Eo({name:s.name,syncChannels:e,syncWindowCleanup:o,syncClocks:t,syncVersions:r}),delete n[s.name],i.delete(s.name);},resetAll(){To({syncChannels:e,syncWindowCleanup:o}),Object.keys(e).forEach(s=>delete e[s]),Object.keys(t).forEach(s=>delete t[s]),Object.keys(r).forEach(s=>delete r[s]),Object.keys(o).forEach(s=>delete o[s]),Object.keys(n).forEach(s=>delete n[s]),gt.clear(),yt.clear(),i.clear();}}},wr=()=>{Sr||(Sr=true,bt("sync",Vo));};var vr=()=>{wr();};vr();export{vr as installSync};//# sourceMappingURL=sync.js.map
2
2
  //# sourceMappingURL=sync.js.map