@instantdb/resumable-stream 1.0.32 → 1.0.33-branch-webhooks-docs.25894421517.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.
@@ -1,17 +1,17 @@
1
1
 
2
- > @instantdb/resumable-stream@1.0.32 build /home/runner/work/instant/instant/client/packages/resumable-stream
2
+ > @instantdb/resumable-stream@1.0.33-branch-webhooks-docs.25894421517.1 build /home/runner/work/instant/instant/client/packages/resumable-stream
3
3
  > rm -rf dist; npm run build:tshy && npm run build:standalone && npm run check-exports
4
4
 
5
5
  npm warn Unknown env config "verify-deps-before-run". This will stop working in the next major version of npm. See `npm help npmrc` for supported config options.
6
6
  npm warn Unknown user config "always-auth". This will stop working in the next major version of npm. See `npm help npmrc` for supported config options.
7
7
 
8
- > @instantdb/resumable-stream@1.0.32 build:tshy
8
+ > @instantdb/resumable-stream@1.0.33-branch-webhooks-docs.25894421517.1 build:tshy
9
9
  > tshy
10
10
 
11
11
  npm warn Unknown env config "verify-deps-before-run". This will stop working in the next major version of npm. See `npm help npmrc` for supported config options.
12
12
  npm warn Unknown user config "always-auth". This will stop working in the next major version of npm. See `npm help npmrc` for supported config options.
13
13
 
14
- > @instantdb/resumable-stream@1.0.32 build:standalone
14
+ > @instantdb/resumable-stream@1.0.33-branch-webhooks-docs.25894421517.1 build:standalone
15
15
  > vite build
16
16
 
17
17
  vite v5.4.14 building for production...
@@ -19,17 +19,17 @@ transforming...
19
19
  ✓ 77 modules transformed.
20
20
  rendering chunks...
21
21
  computing gzip size...
22
- dist/standalone/index.umd.cjs 77.88 kB │ gzip: 24.68 kB
23
- dist/standalone/index.js 131.42 kB │ gzip: 35.32 kB
24
- ✓ built in 889ms
22
+ dist/standalone/index.umd.cjs 77.93 kB │ gzip: 24.72 kB
23
+ dist/standalone/index.js 131.49 kB │ gzip: 35.37 kB
24
+ ✓ built in 970ms
25
25
  npm warn Unknown env config "verify-deps-before-run". This will stop working in the next major version of npm. See `npm help npmrc` for supported config options.
26
26
  npm warn Unknown user config "always-auth". This will stop working in the next major version of npm. See `npm help npmrc` for supported config options.
27
27
 
28
- > @instantdb/resumable-stream@1.0.32 check-exports
28
+ > @instantdb/resumable-stream@1.0.33-branch-webhooks-docs.25894421517.1 check-exports
29
29
  > attw --pack .
30
30
 
31
31
 
32
- @instantdb/resumable-stream v1.0.32
32
+ @instantdb/resumable-stream v1.0.33-branch-webhooks-docs.25894421517.1
33
33
 
34
34
  Build tools:
35
35
  - @arethetypeswrong/cli@^0.17.4
@@ -834,7 +834,7 @@ class le extends _ {
834
834
  }
835
835
  }
836
836
  typeof window < "u" && typeof window.localStorage < "u" && (window.localStorage.getItem("devBackend"), window.localStorage.getItem("__instantLogging"), window.localStorage.getItem("__devtoolLocalDash"));
837
- const _e = "v1.0.32";
837
+ const _e = "v1.0.33-branch-webhooks-docs.25894421517.1";
838
838
  class de {
839
839
  constructor(t, n, s, r = { indexed: !1, unique: !1 }) {
840
840
  d(this, "valueType");
@@ -2748,7 +2748,7 @@ function xe(e) {
2748
2748
  return {
2749
2749
  id: e.id,
2750
2750
  sink: e.sink,
2751
- etypes: e.etypes ?? [],
2751
+ namespaces: e.namespaces ?? [],
2752
2752
  actions: e.actions,
2753
2753
  status: e.status,
2754
2754
  disabledReason: e.disabled_reason ?? null,
@@ -2800,7 +2800,7 @@ class cr {
2800
2800
  * starts receiving matching events immediately.
2801
2801
  *
2802
2802
  * The server rejects the request if `url` is not an HTTPS URL pointing at a
2803
- * public host, if `etypes` doesn't reference any entity in the app's
2803
+ * public host, if `namespaces` doesn't reference any entity in the app's
2804
2804
  * schema, if `actions` is empty, or if the app has hit its webhook limit.
2805
2805
  *
2806
2806
  * An app may have at most **100 active webhooks** at a time; {@link delete}
@@ -2809,7 +2809,7 @@ class cr {
2809
2809
  * @example
2810
2810
  * const webhook = await db.webhooks.manager.create({
2811
2811
  * url: 'https://example.com/instant',
2812
- * etypes: ['posts', 'comments'],
2812
+ * namespaces: ['posts', 'comments'],
2813
2813
  * actions: ['create', 'update'],
2814
2814
  * });
2815
2815
  */
@@ -2821,7 +2821,7 @@ class cr {
2821
2821
  return xe(n.webhook);
2822
2822
  }
2823
2823
  /**
2824
- * Updates a webhook's `url`, `etypes`, and/or `actions`. Pass only the
2824
+ * Updates a webhook's `url`, `namespaces`, and/or `actions`. Pass only the
2825
2825
  * fields you want to change; omitted fields keep their current value.
2826
2826
  *
2827
2827
  * Does not affect the webhook's status — use {@link enable} or
@@ -2948,8 +2948,8 @@ const qt = class qt {
2948
2948
  /**
2949
2949
  * Schema-bound helpers for building typed handler maps.
2950
2950
  *
2951
- * - `typedHandlers(etype, action, handler)` builds a single typed entry.
2952
- * Pass `'$default'` for `etype` to register a catch-all handler.
2951
+ * - `typedHandlers(namespace, action, handler)` builds a single typed entry.
2952
+ * Pass `'$default'` for `namespace` to register a catch-all handler.
2953
2953
  * - `combineHandlers(...entries)` merges entries into a
2954
2954
  * {@link WebhookHandlers} object suitable for {@link processPayload} and
2955
2955
  * {@link processRequest}.
@@ -3061,8 +3061,8 @@ const qt = class qt {
3061
3061
  }
3062
3062
  /**
3063
3063
  * Dispatches each record in `payload` to its matching handler in
3064
- * `handlers`. Resolution order per record: exact `etype` + `action` →
3065
- * `etype`'s `$default` → top-level `$default`. Records with no matching
3064
+ * `handlers`. Resolution order per record: exact `namespace` + `action` →
3065
+ * `namespace`'s `$default` → top-level `$default`. Records with no matching
3066
3066
  * handler are skipped.
3067
3067
  *
3068
3068
  * Handlers run concurrently. If any handler rejects, the call rejects so
@@ -3073,7 +3073,7 @@ const qt = class qt {
3073
3073
  var r, o;
3074
3074
  const s = [];
3075
3075
  for (const i of n.data) {
3076
- const { etype: a, action: c } = i, u = ((r = t == null ? void 0 : t[a]) == null ? void 0 : r[c]) || ((o = t == null ? void 0 : t[a]) == null ? void 0 : o.$default) || (t == null ? void 0 : t.$default);
3076
+ const { namespace: a, action: c } = i, u = ((r = t == null ? void 0 : t[a]) == null ? void 0 : r[c]) || ((o = t == null ? void 0 : t[a]) == null ? void 0 : o.$default) || (t == null ? void 0 : t.$default);
3077
3077
  u && s.push(u(i));
3078
3078
  }
3079
3079
  await Promise.all(s);
@@ -1,5 +1,5 @@
1
- (function($,E){typeof exports=="object"&&typeof module<"u"?E(exports):typeof define=="function"&&define.amd?define(["exports"],E):($=typeof globalThis<"u"?globalThis:$||self,E($.instant={}))})(this,function($){"use strict";var Ir=Object.defineProperty;var Ln=$=>{throw TypeError($)};var vr=($,E,A)=>E in $?Ir($,E,{enumerable:!0,configurable:!0,writable:!0,value:A}):$[E]=A;var d=($,E,A)=>vr($,typeof E!="symbol"?E+"":E,A),Qt=($,E,A)=>E.has($)||Ln("Cannot "+A);var y=($,E,A)=>(Qt($,E,"read from private field"),A?A.call($):E.get($)),L=($,E,A)=>E.has($)?Ln("Cannot add the same private member more than once"):E instanceof WeakSet?E.add($):E.set($,A),B=($,E,A,D)=>(Qt($,E,"write to private field"),D?D.call($,A):E.set($,A),A),j=($,E,A)=>(Qt($,E,"access private method"),A);var G,Ye,Le,Fe,Ze,ne,fe,et,Ce,ze,H,Te,X,Y,z,zn,bt,Vn,Jn,Hn,lt,ht,pt,Gt,Kn,yt;const E=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function A(e){return typeof e=="string"&&E.test(e)}const D=[];for(let e=0;e<256;++e)D.push((e+256).toString(16).slice(1));function qn(e,t=0){return(D[e[t+0]]+D[e[t+1]]+D[e[t+2]]+D[e[t+3]]+"-"+D[e[t+4]]+D[e[t+5]]+"-"+D[e[t+6]]+D[e[t+7]]+"-"+D[e[t+8]]+D[e[t+9]]+"-"+D[e[t+10]]+D[e[t+11]]+D[e[t+12]]+D[e[t+13]]+D[e[t+14]]+D[e[t+15]]).toLowerCase()}let wt;const Bn=new Uint8Array(16);function Qn(){if(!wt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");wt=crypto.getRandomValues.bind(crypto)}return wt(Bn)}const Xt={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Gn(e,t,n){var r;if(Xt.randomUUID&&!e)return Xt.randomUUID();e=e||{};const s=e.random??((r=e.rng)==null?void 0:r.call(e))??Qn();if(s.length<16)throw new Error("Random bytes length must be >= 16");return s[6]=s[6]&15|64,s[8]=s[8]&63|128,qn(s)}const F={Remove:"remove",Replace:"replace",Add:"add"},Yt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),tt=Symbol.iterator,ie={mutable:"mutable",immutable:"immutable"},gt={};function Je(e,t){return e instanceof Map?e.has(t):Object.prototype.hasOwnProperty.call(e,t)}function Zt(e,t){if(t in e){let n=Reflect.getPrototypeOf(e);for(;n;){const s=Reflect.getOwnPropertyDescriptor(n,t);if(s)return s;n=Reflect.getPrototypeOf(n)}}}function en(e){return Object.getPrototypeOf(e)===Set.prototype}function tn(e){return Object.getPrototypeOf(e)===Map.prototype}function te(e){var t;return(t=e.copy)!==null&&t!==void 0?t:e.original}function St(e){return!!O(e)}function O(e){return typeof e!="object"?null:e==null?void 0:e[Yt]}function It(e){var t;const n=O(e);return n?(t=n.copy)!==null&&t!==void 0?t:n.original:e}function ke(e,t){if(!e||typeof e!="object")return!1;let n;return Object.getPrototypeOf(e)===Object.prototype||Array.isArray(e)||e instanceof Map||e instanceof Set||!!(t!=null&&t.mark)&&((n=t.mark(e,ie))===ie.immutable||typeof n=="function")}function nn(e,t=[]){if(Object.hasOwnProperty.call(e,"key")){const n=e.parent.copy,s=O(be(n,e.key));if(s!==null&&(s==null?void 0:s.original)!==e.original)return null;const r=e.parent.type===3,o=r?Array.from(e.parent.setMap.keys()).indexOf(e.key):e.key;if(!(r&&n.size>o||Je(n,o)))return null;t.push(o)}if(e.parent)return nn(e.parent,t);t.reverse();try{Xn(e.copy,t)}catch{return null}return t}function He(e){return Array.isArray(e)?1:e instanceof Map?2:e instanceof Set?3:0}function be(e,t){return He(e)===2?e.get(t):e[t]}function vt(e,t,n){He(e)===2?e.set(t,n):e[t]=n}function kt(e,t){const n=O(e);return(n?te(n):e)[t]}function $e(e,t){return e===t?e!==0||1/e===1/t:e!==e&&t!==t}function Oe(e,t){return t?e:[""].concat(e).map(n=>{const s=`${n}`;return s.indexOf("/")===-1&&s.indexOf("~")===-1?s:s.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function Xn(e,t){for(let n=0;n<t.length-1;n+=1){const s=t[n];if(e=be(He(e)===3?Array.from(e):e,s),typeof e!="object")throw new Error(`Cannot resolve patch at '${t.join("/")}'.`)}return e}function Yn(e){const t=Object.create(Object.getPrototypeOf(e));return Reflect.ownKeys(e).forEach(n=>{let s=Reflect.getOwnPropertyDescriptor(e,n);if(s.enumerable&&s.configurable&&s.writable){t[n]=e[n];return}s.writable||(s.writable=!0,s.configurable=!0),(s.get||s.set)&&(s={configurable:!0,writable:!0,enumerable:s.enumerable,value:e[n]}),Reflect.defineProperty(t,n,s)}),t}const Zn=Object.prototype.propertyIsEnumerable;function es(e,t){let n;if(Array.isArray(e))return Array.prototype.concat.call(e);if(e instanceof Set){if(!en(e)){const s=Object.getPrototypeOf(e).constructor;return new s(e.values())}return Set.prototype.difference?Set.prototype.difference.call(e,new Set):new Set(e.values())}else if(e instanceof Map){if(!tn(e)){const s=Object.getPrototypeOf(e).constructor;return new s(e)}return new Map(e)}else if(t!=null&&t.mark&&(n=t.mark(e,ie),n!==void 0)&&n!==ie.mutable){if(n===ie.immutable)return Yn(e);if(typeof n=="function"){if(t.enablePatches||t.enableAutoFreeze)throw new Error("You can't use mark and patches or auto freeze together.");return n()}throw new Error(`Unsupported mark result: ${n}`)}else if(typeof e=="object"&&Object.getPrototypeOf(e)===Object.prototype){const s={};return Object.keys(e).forEach(r=>{s[r]=e[r]}),Object.getOwnPropertySymbols(e).forEach(r=>{Zn.call(e,r)&&(s[r]=e[r])}),s}else throw new Error("Please check mark() to ensure that it is a stable marker draftable function.")}function Q(e){e.copy||(e.copy=es(e.original,e.options))}function Ke(e){if(!ke(e))return It(e);if(Array.isArray(e))return e.map(Ke);if(e instanceof Map){const n=Array.from(e.entries()).map(([s,r])=>[s,Ke(r)]);if(!tn(e)){const s=Object.getPrototypeOf(e).constructor;return new s(n)}return new Map(n)}if(e instanceof Set){const n=Array.from(e).map(Ke);if(!en(e)){const s=Object.getPrototypeOf(e).constructor;return new s(n)}return new Set(n)}const t=Object.create(Object.getPrototypeOf(e));for(const n in e)t[n]=Ke(e[n]);return t}function nt(e){return St(e)?Ke(e):e}function de(e){var t;e.assignedMap=(t=e.assignedMap)!==null&&t!==void 0?t:new Map,e.operated||(e.operated=!0,e.parent&&de(e.parent))}function ts(e,t){const n=He(e);if(n===0)Reflect.ownKeys(e).forEach(s=>{t(s,e[s],e)});else if(n===1){let s=0;for(const r of e)t(s,r,e),s+=1}else e.forEach((s,r)=>t(r,s,e))}function sn(e,t,n){if(St(e)||!ke(e,n)||t.has(e)||Object.isFrozen(e))return;const s=e instanceof Set,r=s?new Map:void 0;if(t.add(e),ts(e,(o,i)=>{var a;if(St(i)){const c=O(i);Q(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;vt(s?r:e,o,u)}else sn(i,t,n)}),r){const o=e,i=Array.from(o);o.clear(),i.forEach(a=>{o.add(r.has(a)?r.get(a):a)})}}function ns(e,t){const n=e.type===3?e.setMap:e.copy;e.finalities.revoke.length>1&&e.assignedMap.get(t)&&n&&sn(be(n,t),e.finalities.handledSet,e.options)}function $t(e){e.type===3&&e.copy&&(e.copy.clear(),e.setMap.forEach(t=>{e.copy.add(It(t))}))}function Ot(e,t,n,s){if(e.operated&&e.assignedMap&&e.assignedMap.size>0&&!e.finalized){if(n&&s){const o=nn(e);o&&t(e,o,n,s)}e.finalized=!0}}function Et(e,t,n,s){const r=O(n);r&&(r.callbacks||(r.callbacks=[]),r.callbacks.push((o,i)=>{var a;const c=e.type===3?e.setMap:e.copy;if($e(be(c,t),n)){let u=r.original;r.copy&&(u=r.copy),$t(e),Ot(e,s,o,i),e.options.enableAutoFreeze&&(e.options.updatedValues=(a=e.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,e.options.updatedValues.set(u,r.original)),vt(c,t,u)}}),e.options.enableAutoFreeze&&r.finalities!==e.finalities&&(e.options.enableAutoFreeze=!1)),ke(n,e.options)&&e.finalities.draft.push(()=>{const o=e.type===3?e.setMap:e.copy;$e(be(o,t),n)&&ns(e,t)})}function ss(e,t,n,s,r){let{original:o,assignedMap:i,options:a}=e,c=e.copy;c.length<o.length&&([o,c]=[c,o],[n,s]=[s,n]);for(let u=0;u<o.length;u+=1)if(i.get(u.toString())&&c[u]!==o[u]){const l=t.concat([u]),f=Oe(l,r);n.push({op:F.Replace,path:f,value:nt(c[u])}),s.push({op:F.Replace,path:f,value:nt(o[u])})}for(let u=o.length;u<c.length;u+=1){const l=t.concat([u]),f=Oe(l,r);n.push({op:F.Add,path:f,value:nt(c[u])})}if(o.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=t.concat(["length"]),f=Oe(l,r);s.push({op:F.Replace,path:f,value:o.length})}else for(let l=c.length;o.length<l;l-=1){const f=t.concat([l-1]),p=Oe(f,r);s.push({op:F.Remove,path:p})}}}function rs({original:e,copy:t,assignedMap:n},s,r,o,i){n.forEach((a,c)=>{const u=be(e,c),l=nt(be(t,c)),f=a?Je(e,c)?F.Replace:F.Add:F.Remove;if($e(u,l)&&f===F.Replace)return;const p=s.concat(c),m=Oe(p,i);r.push(f===F.Remove?{op:f,path:m}:{op:f,path:m,value:l}),o.push(f===F.Add?{op:F.Remove,path:m}:f===F.Remove?{op:F.Add,path:m,value:u}:{op:F.Replace,path:m,value:u})})}function is({original:e,copy:t},n,s,r,o){let i=0;e.forEach(a=>{if(!t.has(a)){const c=n.concat([i]),u=Oe(c,o);s.push({op:F.Remove,path:u,value:a}),r.unshift({op:F.Add,path:u,value:a})}i+=1}),i=0,t.forEach(a=>{if(!e.has(a)){const c=n.concat([i]),u=Oe(c,o);s.push({op:F.Add,path:u,value:a}),r.unshift({op:F.Remove,path:u,value:a})}i+=1})}function qe(e,t,n,s){const{pathAsArray:r=!0}=e.options.enablePatches;switch(e.type){case 0:case 2:return rs(e,t,n,s,r);case 1:return ss(e,t,n,s,r);case 3:return is(e,t,n,s,r)}}const st=(e,t,n=!1)=>{if(typeof e=="object"&&e!==null&&(!ke(e,t)||n))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},_t={get size(){return te(O(this)).size},has(e){return te(O(this)).has(e)},set(e,t){const n=O(this),s=te(n);return(!s.has(e)||!$e(s.get(e),t))&&(Q(n),de(n),n.assignedMap.set(e,!0),n.copy.set(e,t),Et(n,e,t,qe)),this},delete(e){if(!this.has(e))return!1;const t=O(this);return Q(t),de(t),t.original.has(e)?t.assignedMap.set(e,!1):t.assignedMap.delete(e),t.copy.delete(e),!0},clear(){const e=O(this);if(this.size){Q(e),de(e),e.assignedMap=new Map;for(const[t]of e.original)e.assignedMap.set(t,!1);e.copy.clear()}},forEach(e,t){const n=O(this);te(n).forEach((s,r)=>{e.call(t,this.get(r),r,this)})},get(e){var t,n;const s=O(this),r=te(s).get(e),o=((n=(t=s.options).mark)===null||n===void 0?void 0:n.call(t,r,ie))===ie.mutable;if(s.options.strict&&st(r,s.options,o),o||s.finalized||!ke(r,s.options)||r!==s.original.get(e))return r;const i=gt.createDraft({original:r,parentDraft:s,key:e,finalities:s.finalities,options:s.options});return Q(s),s.copy.set(e,i),i},keys(){return te(O(this)).keys()},values(){const e=this.keys();return{[tt]:()=>this.values(),next:()=>{const t=e.next();return t.done?t:{done:!1,value:this.get(t.value)}}}},entries(){const e=this.keys();return{[tt]:()=>this.entries(),next:()=>{const t=e.next();if(t.done)return t;const n=this.get(t.value);return{done:!1,value:[t.value,n]}}}},[tt](){return this.entries()}},os=Reflect.ownKeys(_t),rn=(e,t,{isValuesIterator:n})=>()=>{var s,r;const o=t.next();if(o.done)return o;const i=o.value;let a=e.setMap.get(i);const c=O(a),u=((r=(s=e.options).mark)===null||r===void 0?void 0:r.call(s,a,ie))===ie.mutable;if(e.options.strict&&st(i,e.options,u),!u&&!c&&ke(i,e.options)&&!e.finalized&&e.original.has(i)){const l=gt.createDraft({original:i,parentDraft:e,key:i,finalities:e.finalities,options:e.options});e.setMap.set(i,l),a=l}else c&&(a=c.proxy);return{done:!1,value:n?a:[a,a]}},rt={get size(){return O(this).setMap.size},has(e){const t=O(this);if(t.setMap.has(e))return!0;Q(t);const n=O(e);return!!(n&&t.setMap.has(n.original))},add(e){const t=O(this);return this.has(e)||(Q(t),de(t),t.assignedMap.set(e,!0),t.setMap.set(e,e),Et(t,e,e,qe)),this},delete(e){if(!this.has(e))return!1;const t=O(this);Q(t),de(t);const n=O(e);return n&&t.setMap.has(n.original)?(t.assignedMap.set(n.original,!1),t.setMap.delete(n.original)):(!n&&t.setMap.has(e)?t.assignedMap.set(e,!1):t.assignedMap.delete(e),t.setMap.delete(e))},clear(){if(!this.size)return;const e=O(this);Q(e),de(e);for(const t of e.original)e.assignedMap.set(t,!1);e.setMap.clear()},values(){const e=O(this);Q(e);const t=e.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:rn(e,t,{isValuesIterator:!0})}},entries(){const e=O(this);Q(e);const t=e.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:rn(e,t,{isValuesIterator:!1})}},keys(){return this.values()},[tt](){return this.values()},forEach(e,t){const n=this.values();let s=n.next();for(;!s.done;)e.call(t,s.value,s.value,this),s=n.next()}};Set.prototype.difference&&Object.assign(rt,{intersection(e){return Set.prototype.intersection.call(new Set(this.values()),e)},union(e){return Set.prototype.union.call(new Set(this.values()),e)},difference(e){return Set.prototype.difference.call(new Set(this.values()),e)},symmetricDifference(e){return Set.prototype.symmetricDifference.call(new Set(this.values()),e)},isSubsetOf(e){return Set.prototype.isSubsetOf.call(new Set(this.values()),e)},isSupersetOf(e){return Set.prototype.isSupersetOf.call(new Set(this.values()),e)},isDisjointFrom(e){return Set.prototype.isDisjointFrom.call(new Set(this.values()),e)}});const as=Reflect.ownKeys(rt),on=new WeakSet,an={get(e,t,n){var s,r;const o=(s=e.copy)===null||s===void 0?void 0:s[t];if(o&&on.has(o))return o;if(t===Yt)return e;let i;if(e.options.mark){const u=t==="size"&&(e.original instanceof Map||e.original instanceof Set)?Reflect.get(e.original,t):Reflect.get(e.original,t,n);if(i=e.options.mark(u,ie),i===ie.mutable)return e.options.strict&&st(u,e.options,!0),u}const a=te(e);if(a instanceof Map&&os.includes(t)){if(t==="size")return Object.getOwnPropertyDescriptor(_t,"size").get.call(e.proxy);const u=_t[t];if(u)return u.bind(e.proxy)}if(a instanceof Set&&as.includes(t)){if(t==="size")return Object.getOwnPropertyDescriptor(rt,"size").get.call(e.proxy);const u=rt[t];if(u)return u.bind(e.proxy)}if(!Je(a,t)){const u=Zt(a,t);return u?"value"in u?u.value:(r=u.get)===null||r===void 0?void 0:r.call(e.proxy):void 0}const c=a[t];if(e.options.strict&&st(c,e.options),e.finalized||!ke(c,e.options))return c;if(c===kt(e.original,t)){if(Q(e),e.copy[t]=cn({original:e.original[t],parentDraft:e,key:e.type===1?Number(t):t,finalities:e.finalities,options:e.options}),typeof i=="function"){const u=O(e.copy[t]);return Q(u),de(u),u.copy}return e.copy[t]}return c},set(e,t,n){var s;if(e.type===3||e.type===2)throw new Error("Map/Set draft does not support any property assignment.");let r;if(e.type===1&&t!=="length"&&!(Number.isInteger(r=Number(t))&&r>=0&&(t===0||r===0||String(r)===String(t))))throw new Error("Only supports setting array indices and the 'length' property.");const o=Zt(te(e),t);if(o!=null&&o.set)return o.set.call(e.proxy,n),!0;const i=kt(te(e),t),a=O(i);return a&&$e(a.original,n)?(e.copy[t]=n,e.assignedMap=(s=e.assignedMap)!==null&&s!==void 0?s:new Map,e.assignedMap.set(t,!1),!0):($e(n,i)&&(n!==void 0||Je(e.original,t))||(Q(e),de(e),Je(e.original,t)&&$e(n,e.original[t])?e.assignedMap.delete(t):e.assignedMap.set(t,!0),e.copy[t]=n,Et(e,t,n,qe)),!0)},has(e,t){return t in te(e)},ownKeys(e){return Reflect.ownKeys(te(e))},getOwnPropertyDescriptor(e,t){const n=te(e),s=Reflect.getOwnPropertyDescriptor(n,t);return s&&{writable:!0,configurable:e.type!==1||t!=="length",enumerable:s.enumerable,value:n[t]}},getPrototypeOf(e){return Reflect.getPrototypeOf(e.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(e,t){var n;return e.type===1?an.set.call(this,e,t,void 0,e.proxy):(kt(e.original,t)!==void 0||t in e.original?(Q(e),de(e),e.assignedMap.set(t,!1)):(e.assignedMap=(n=e.assignedMap)!==null&&n!==void 0?n:new Map,e.assignedMap.delete(t)),e.copy&&delete e.copy[t],!0)}};function cn(e){const{original:t,parentDraft:n,key:s,finalities:r,options:o}=e,i=He(t),a={type:i,finalized:!1,parent:n,original:t,copy:null,proxy:null,finalities:r,options:o,setMap:i===3?new Map(t.entries()):void 0};(s||"key"in e)&&(a.key=s);const{proxy:c,revoke:u}=Proxy.revocable(i===1?Object.assign([],a):a,an);if(r.revoke.push(u),on.add(c),a.proxy=c,n){const l=n;l.finalities.draft.push((f,p)=>{var m,g;const w=O(c);let h=l.type===3?l.setMap:l.copy;const v=be(h,s),k=O(v);if(k){let K=k.original;k.operated&&(K=It(v)),$t(k),Ot(k,qe,f,p),l.options.enableAutoFreeze&&(l.options.updatedValues=(m=l.options.updatedValues)!==null&&m!==void 0?m:new WeakMap,l.options.updatedValues.set(K,k.original)),vt(h,s,K)}(g=w.callbacks)===null||g===void 0||g.forEach(K=>{K(f,p)})})}else{const l=O(c);l.finalities.draft.push((f,p)=>{$t(l),Ot(l,qe,f,p)})}return c}gt.createDraft=cn,Object.prototype.constructor.toString();function Ae(){return Gn()}function cs(e,t){return e.localeCompare(t)}function us(){let e=cs;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{e=Intl.Collator("en-US").compare}catch{}return e}us();function fs(){const t={__etype:1,__ops:1,create:1,update:1,link:1,unlink:1,delete:1,merge:1,ruleParams:1};return new Set(Object.keys(t))}const ds=fs();function it(e,t,n){const s={__etype:e,__ops:n};return new Proxy(s,{get:(r,o)=>{if(o==="__ops")return n;if(o==="__etype")return e;if(ds.has(o))return(i,a)=>it(e,t,[...n,a?[o,e,t,i,a]:[o,e,t,i]])}})}function ls(e,t){return`lookup__${e}__${JSON.stringify(t)}`}function un(e){return e.startsWith("lookup__")}function fn(e){const[t,n,...s]=e.split("__");return[n,JSON.parse(s.join("__"))]}function hs(e){return new Proxy({__etype:e},{get(t,n){if(n==="lookup")return(r,o)=>it(e,fn(ls(r,o)),[]);if(n==="__etype")return e;const s=n;return un(s)?it(e,fn(s),[]):it(e,s,[])}})}function dn(){return new Proxy({},{get(e,t){return hs(t)}})}dn();function ps(e){return e.__ops}class C extends Error{constructor(n,s,r){super(n);d(this,"hint");d(this,"traceId");this.hint=s,r&&(this.traceId=r);const o=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,o),Error.captureStackTrace&&Error.captureStackTrace(this,C),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class le extends C{constructor(n){var o,i;const s=((o=n.body)==null?void 0:o.message)||`API Error (${n.status})`;super(s,n.body.hint,((i=n.body)==null?void 0:i.traceId)||n.body["trace-id"]);d(this,"body");d(this,"status");const r=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,r),Error.captureStackTrace&&Error.captureStackTrace(this,le),this.name="InstantAPIError",this.status=n.status,this.body=n.body}get[Symbol.toStringTag](){return"InstantAPIError"}}typeof window<"u"&&typeof window.localStorage<"u"&&(window.localStorage.getItem("devBackend"),window.localStorage.getItem("__instantLogging"),window.localStorage.getItem("__devtoolLocalDash"));const Ee="v1.0.32";class he{constructor(t,n,s,r={indexed:!1,unique:!1}){d(this,"valueType");d(this,"required");d(this,"isIndexed");d(this,"config");d(this,"metadata",{});this.valueType=t,this.required=n,this.isIndexed=s,this.config=r}clientRequired(){return new he(this.valueType,!1,this.isIndexed,this.config)}optional(){return new he(this.valueType,!1,this.isIndexed,this.config)}unique(){return new he(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new he(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class x extends Error{constructor(t,n){const s=n?`At path '${n}': ${t}`:t;super(s),this.name="QueryValidationError"}}const ln=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],ys=e=>e.valueType||"unknown",hn=(e,t,n=!1)=>{if(n||e==null)return!0;switch(t){case"string":return typeof e=="string";case"number":return typeof e=="number"&&!isNaN(e);case"boolean":return typeof e=="boolean";case"date":return e instanceof Date||typeof e=="string"||typeof e=="number";default:return!0}},ms=(e,t,n,s,r,o,i)=>{const a=o.valueType==="json",c=(u,l,f)=>{if(!hn(f,l,a))throw new x(`Invalid value for operator '${u}' on attribute '${s}' in entity '${r}'. Expected ${l}, but received: ${typeof f}`,i)};switch(e){case"in":case"$in":if(!Array.isArray(t))throw new x(`Operator '${e}' for attribute '${s}' in entity '${r}' must be an array, but received: ${typeof t}`,i);for(const u of t)c(e,n,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(e,n,t);break;case"$like":case"$ilike":if(c(e,"string",t),e==="$ilike"&&!o.isIndexed)throw new x(`Operator '${e}' can only be used with indexed attributes, but '${s}' in entity '${r}' is not indexed`,i);break;case"$isNull":c(e,"boolean",t);break;default:throw new x(`Unknown operator '${e}' for attribute '${s}' in entity '${r}'`,i)}},Pe=(e,t,n,s,r)=>{const o=ys(n),i=n.valueType==="json";if(typeof e=="object"&&e!==null&&!Array.isArray(e)){if(i)return;const c=e;for(const[u,l]of Object.entries(c))ms(u,l,o,t,s,n,`${r}.${u}`)}else if(!hn(e,o,i))throw new x(`Invalid value for attribute '${t}' in entity '${s}'. Expected ${o}, but received: ${typeof e}`,r)},bs=(e,t,n,s,r)=>{const o=e.split(".");if(o.length<2)throw new x(`Invalid dot notation path '${e}'. Must contain at least one dot.`,r);let i=n;for(let l=0;l<o.length-1;l++){const f=o[l],p=s.entities[i];if(!p)throw new x(`Entity '${i}' does not exist in schema while traversing dot notation path '${e}'.`,r);const m=p.links[f];if(!m){const g=Object.keys(p.links);throw new x(`Link '${f}' does not exist on entity '${i}' in dot notation path '${e}'. Available links: ${g.length>0?g.join(", "):"none"}`,r)}i=m.entityName}const a=o[o.length-1],c=s.entities[i];if(!c)throw new x(`Target entity '${i}' does not exist in schema for dot notation path '${e}'.`,r);if(a==="id"){if(typeof t=="string"&&!A(t))throw new x(`Invalid value for id field in entity '${i}'. Expected a UUID, but received: ${t}`,r);Pe(t,e,new he("string",!1,!0),n,r);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof t=="string"&&!A(t))throw new x(`Invalid value for link '${a}' in entity '${i}'. Expected a UUID, but received: ${t}`,r);Pe(t,e,new he("string",!1,!0),n,r);return}if(!u){const l=Object.keys(c.attrs);throw new x(`Attribute '${a}' does not exist on entity '${i}' in dot notation path '${e}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,r)}Pe(t,e,u,n,r)},pn=(e,t,n,s)=>{for(const[r,o]of Object.entries(e)){if(r==="or"||r==="and"){if(Array.isArray(o))for(const u of o)typeof u=="object"&&u!==null&&pn(u,t,n,`${s}.${r}[${u}]`);continue}if(r==="id"){Pe(o,"id",new he("string",!1,!0),t,`${s}.id`);continue}if(r.includes(".")){bs(r,o,t,n,`${s}.${r}`);continue}const i=n.entities[t];if(!i)continue;const a=i.attrs[r],c=i.links[r];if(!a&&!c){const u=Object.keys(i.attrs),l=Object.keys(i.links);throw new x(`Attribute or link '${r}' does not exist on entity '${t}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${s}.${r}`)}if(a)Pe(o,r,a,t,`${s}.${r}`);else if(c){if(typeof o=="string"&&!A(o))throw new x(`Invalid value for link '${r}' in entity '${t}'. Expected a UUID, but received: ${o}`,`${s}.${r}`);const u=new he("string",!1,!0);Pe(o,r,u,t,`${s}.${r}`)}}},ws=(e,t,n,s,r=0)=>{for(const i of Object.keys(e))if(!ln.includes(i))throw new x(`Invalid query parameter '${i}' in $ object. Valid parameters are: ${ln.join(", ")}. Found: ${i}`,s);const o=["offset","before","beforeInclusive","after","afterInclusive","first","last"];for(const i of o)if(e[i]!==void 0&&r>0)throw new x(`'${i}' can only be used on top-level namespaces. It cannot be used in nested queries.`,s);if(e.where&&n){if(typeof e.where!="object"||e.where===null)throw new x(`'where' clause must be an object in entity '${t}', but received: ${typeof e.where}`,s?`${s}.where`:void 0);pn(e.where,t,n,s?`${s}.where`:"where")}},yn=(e,t,n,s,r=0)=>{var o;if(!e||typeof e!="object")throw new x(`Query part for entity '${t}' must be an object, but received: ${typeof e}`,s);for(const i of Object.keys(e))if(i!=="$"){if(n&&!(i in n.entities[t].links)){const c=Object.keys(n.entities[t].links);throw new x(`Link '${i}' does not exist on entity '${t}'. Available links: ${c.length>0?c.join(", "):"none"}`,`${s}.${i}`)}const a=e[i];if(typeof a=="object"&&a!==null){const c=(o=n==null?void 0:n.entities[t].links[i])==null?void 0:o.entityName;c&&yn(a,c,n,`${s}.${i}`,r+1)}}else{const a=e[i];if(typeof a!="object"||a===null)throw new x(`Query parameter '$' must be an object in entity '${t}', but received: ${typeof a}`,`${s}.$`);ws(a,t,n,`${s}.$`,r)}},mn=(e,t)=>{if(typeof e!="object"||e===null)throw new x(`Query must be an object, but received: ${typeof e}${e===null?" (null)":""}`);if(Array.isArray(e))throw new x(`Query must be an object, but received: ${typeof e}`);const n=e;for(const s of Object.keys(n)){if(Array.isArray(e[s]))throw new x(`Query keys must be strings, but found key of type: ${typeof s}`,s);if(typeof s!="string")throw new x(`Query keys must be strings, but found key of type: ${typeof s}`,s);if(s!=="$$ruleParams"){if(t&&!t.entities[s]){const r=Object.keys(t.entities);throw new x(`Entity '${s}' does not exist in schema. Available entities: ${r.length>0?r.join(", "):"none"}`,s)}yn(n[s],s,t,s,0)}}},bn=e=>typeof e!="string"?!1:un(e)?!0:A(e);class se extends Error{constructor(t){super(t),this.name="TransactionValidationError"}}const wn=e=>e.length>0?e.join(", "):"none",gs=(e,t)=>new se(`Entity '${e}' does not exist in schema. Available entities: ${wn(t)}`),Ct={string:e=>typeof e=="string",number:e=>typeof e=="number"&&!isNaN(e),boolean:e=>typeof e=="boolean",date:e=>e instanceof Date||typeof e=="string"||typeof e=="number",json:()=>!0},Ss=(e,t)=>{var n;return e==null?!0:((n=Ct[t.valueType])==null?void 0:n.call(Ct,e))??!1},gn=(e,t)=>{const n=t.entities[e];if(!n)throw gs(e,Object.keys(t.entities));return n},Tt=(e,t,n)=>{const s=gn(e,n);if(typeof t!="object"||t===null)throw new se(`Arguments for data operation on entity '${e}' must be an object, but received: ${typeof t}`);for(const[r,o]of Object.entries(t)){if(r==="id")continue;const i=s.attrs[r];if(i&&!Ss(o,i))throw new se(`Invalid value for attribute '${r}' in entity '${e}'. Expected ${i.valueType}, but received: ${typeof o}`)}},Sn=(e,t,n)=>{const s=gn(e,n);if(typeof t!="object"||t===null)throw new se(`Arguments for link operation on entity '${e}' must be an object, but received: ${typeof t}`);for(const[r,o]of Object.entries(t)){if(!s.links[r]){const a=Object.keys(s.links);throw new se(`Link '${r}' does not exist on entity '${e}'. Available links: ${wn(a)}`)}if(o!=null){if(Array.isArray(o)){for(const a of o)if(!bn(a))throw new se(`Invalid entity ID in link '${r}' for entity '${e}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!bn(o))throw new se(`Invalid UUID in link '${r}' for entity '${e}'. Expected a UUID, but received: ${o}`)}}},Is={create:Tt,update:Tt,merge:Tt,link:Sn,unlink:Sn,delete:()=>{}},vs=(e,t)=>{if(!t)return;const[n,s,r,o]=e;if(!Array.isArray(r)&&!A(r))throw new se(`Invalid id for entity '${s}'. Expected a UUID, but received: ${r}`);if(typeof s!="string")throw new se(`Entity name must be a string, but received: ${typeof s}`);const i=Is[n];i&&o!==void 0&&i(s,o,t)},ks=(e,t)=>{const n=Array.isArray(e)?e:[e];for(const s of n){if(!s||typeof s!="object")throw new se(`Transaction chunk must be an object, but received: ${typeof s}`);if(!Array.isArray(s.__ops))throw new se(`Transaction chunk must have __ops array, but received: ${typeof s.__ops}`);for(const r of s.__ops){if(!Array.isArray(r))throw new se(`Transaction operation must be an array, but received: ${typeof r}`);vs(r,t)}}};let $s=0;class Os{constructor(t,n,s){d(this,"type","sse");d(this,"initParams",null);d(this,"sendQueue",[]);d(this,"sendPromise");d(this,"closeFired",!1);d(this,"sseInitTimeout");d(this,"ES");d(this,"messageUrl");d(this,"conn");d(this,"url");d(this,"id");d(this,"onopen");d(this,"onmessage");d(this,"onclose");d(this,"onerror");this.id=`${this.type}_${$s++}`,this.url=n,this.messageUrl=s||this.url,this.ES=t,this.conn=new t(n),this.sseInitTimeout=setTimeout(()=>{this.initParams||this.handleError()},1e4),this.conn.onmessage=r=>{const o=JSON.parse(r.data);if(Array.isArray(o))for(const i of o)this.handleMessage(i);else this.handleMessage(o)},this.conn.onerror=r=>{this.handleError()}}handleMessage(t){if(t.op==="sse-init"){this.initParams={machineId:t["machine-id"],sessionId:t["session-id"],sseToken:t["sse-token"]},this.onopen&&this.onopen({target:this}),clearTimeout(this.sseInitTimeout);return}this.onmessage&&this.onmessage({target:this,message:t})}handleError(){try{this.onerror&&this.onerror({target:this})}finally{this.handleClose()}}handleClose(){this.conn.close(),this.onclose&&!this.closeFired&&(this.closeFired=!0,this.onclose({target:this}))}async postMessages(t){var n,s,r;try{(await fetch(this.messageUrl,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:(n=this.initParams)==null?void 0:n.machineId,session_id:(s=this.initParams)==null?void 0:s.sessionId,sse_token:(r=this.initParams)==null?void 0:r.sseToken,messages:t})})).ok||this.handleError()}catch{this.handleError()}}async flushQueue(){if(this.sendPromise||!this.sendQueue.length)return;const t=this.sendQueue;this.sendQueue=[];const n=this.postMessages(t);this.sendPromise=n,n.then(()=>{this.sendPromise=null,this.flushQueue()})}send(t){if(!this.isOpen()||!this.initParams)throw this.isConnecting()?new Error("Failed to execute 'send' on 'EventSource': Still in CONNECTING state."):this.conn.readyState===this.ES.CLOSED?new Error("EventSource is already in CLOSING or CLOSED state."):new Error("EventSource is in invalid state.");this.sendQueue.push(t),this.flushQueue()}isOpen(){return this.conn.readyState===this.ES.OPEN&&this.initParams!==null}isConnecting(){return this.conn.readyState===this.ES.CONNECTING||this.conn.readyState===this.ES.OPEN&&this.initParams===null}close(){this.handleClose()}}var In;(function(e){e.InitialSyncBatch="InitialSyncBatch",e.InitialSyncComplete="InitialSyncComplete",e.LoadFromStorage="LoadFromStorage",e.SyncTransaction="SyncTransaction",e.Error="Error"})(In||(In={}));function Es({WStream:e,opts:t,startStream:n,appendStream:s,registerStream:r}){const o=t.clientId;let i=null,a=null,c=null;const u=Ae();let l=!1,f=!1;const p=[],m=[],g=[];let w=!1,h=0,v=0;const k=[],K=new TextEncoder;function xe(){f=!0;for(const b of p)b(a??void 0)}function qt(b){return p.push(b),f&&b(a??void 0),()=>{const S=p.indexOf(b);S!==-1&&p.splice(S,1)}}function Nn(b){return g.push(b),()=>{const S=g.indexOf(b);S!==-1&&g.splice(S,1)}}t.waitUntil&&t.waitUntil(new Promise(b=>{g.push(b)}));function P(){for(const b of g)try{b()}catch{}}function _(b){return m.push(b),i&&b(i),()=>{const S=m.indexOf(b);S!==-1&&m.splice(S,1)}}function ce(b){i=b;for(const S of m)S(i)}function T(){w=!0}function V(b){let S=h,J=0,ee=0;for(const{byteLen:ue}of k){const me=S+ue;if(me>b)break;S=me,J++,ee+=ue}J>0&&(h+=ee,v-=ee,k.splice(0,J))}function W(b,S){a=S,xe(),b.error(S),P()}async function re(){const b=await n({clientId:o,reconnectToken:u,ruleParams:t.ruleParams});switch(b.type){case"ok":{const{streamId:S,offset:J}=b;i=S,V(J),k.length&&s({streamId:S,chunks:k.map(ee=>ee.chunk),offset:h}),w=!1;break}case"disconnect":{T();break}case"error":{c&&W(c,b.error);break}}}function q(){T(),re()}function mt({offset:b,done:S}){V(b),S&&(l=!0,P())}function Wn(b){return l?(W(b,new C("Stream has been closed.")),null):i||(W(b,new C("Stream has not been initialized.")),null)}async function Ve(b){c=b;let S=!0,J=0;for(;S;){let ee=Date.now()+Math.min(15e3,500*(J-1));S=!1;const ue=await n({clientId:t.clientId,reconnectToken:u,ruleParams:t.ruleParams});switch(ue.type){case"ok":{const{streamId:me,offset:Bt}=ue;if(Bt!==0){const Re=new C("Write stream is corrupted");W(b,Re);return}ce(me),r(me,{onDisconnect:T,onFlush:mt,onConnectionReconnect:re,onAppendFailed:q}),w=!1;return}case"disconnect":{S=!0,T(),J++,await new Promise(me=>{setTimeout(me,Math.max(0,ee-Date.now()))});break}case"error":{W(b,ue.error);return}}}}class Ie extends e{constructor(S,J){super(S,J)}async streamId(){return i||new Promise((S,J)=>{const ee=[],ue=()=>{for(const Re of ee)Re()},me=Re=>{S(Re),ue()},Bt=Re=>{J(Re||new C("Stream is closed.")),ue()};ee.push(_(me)),ee.push(qt(Bt))})}}return{stream:new Ie({async start(b){try{await Ve(b)}catch(S){W(b,S)}},write(b,S){const J=Wn(S);if(J){const ee=K.encode(b).length;k.push({chunk:b,byteLen:ee});const ue=h+v;v+=ee,w||s({streamId:J,chunks:[b],offset:ue})}},close(){i?s({streamId:i,chunks:[],offset:h+v,isDone:!0}):P(),xe()},abort(b){i?s({streamId:i,chunks:[],offset:h+v,isDone:!0,abortReason:b}):P(),xe()}}),addCompleteCb:Nn,closed(){return f}}}class _s{constructor(){d(this,"items",[]);d(this,"resolvers",[]);d(this,"isClosed",!1)}push(t){if(this.isClosed)return;const n=this.resolvers.shift();n?n({value:t,done:!1}):this.items.push(t)}close(){for(this.isClosed=!0;this.resolvers.length>0;)this.resolvers.shift()({value:void 0,done:!0})}async*[Symbol.asyncIterator](){for(;;)if(this.items.length>0)yield this.items.shift();else{if(this.isClosed)return;{const{value:t,done:n}=await new Promise(s=>{this.resolvers.push(s)});if(n||!t)return;yield t}}}}function Cs({RStream:e,opts:t,startStream:n,cancelStream:s}){let r=t.byteOffset||0,o=!1;const i=new TextDecoder("utf-8"),a=new TextEncoder;let c,u=!1;const l=[],f=[];let p=null,m=null;function g(P){u=!0;for(const _ of l)_(P)}function w(P){return l.push(P),()=>{const _=l.indexOf(P);_!==-1&&l.splice(_,1)}}function h(P){return f.push(P),p&&P(p),()=>{const _=f.indexOf(P);_!==-1&&f.splice(_,1)}}function v(P,_){m=_,P.error(_),g(_)}let k=0;async function K(P,_){c=Ae();const ce={...P||{},eventId:c};for await(const T of n(ce)){if(o)return;if(T.type==="reconnect")return{retry:!0};if(T.type==="error"){v(_,T.error);return}if(T.offset>r){v(_,new C("Stream is corrupted.")),o=!0;return}p=T.streamId;for(const W of f)W(p);let V=r-T.offset;if(T.files&&T.files.length){const W=new AbortController;let re=fetch(T.files[0].url,{signal:W.signal});for(let q=0;q<T.files.length;q++){const mt=T.files[q+1],Ve=await re;if(mt&&(re=fetch(mt.url,{signal:W.signal})),!Ve.ok){if(k++,k>10){v(_,new C("Unable to process stream."));return}return{retry:!0}}if(Ve.body){const Ie=Ve.body.getReader();try{for(;;){const{done:ve,value:b}=await Ie.read();if(ve)break;if(o){W.abort();return}let S=b;if(V>0&&(S=b.subarray(V),V-=b.length-S.length),!S.length)continue;r+=S.length;const J=i.decode(S);_.enqueue(J)}}finally{Ie.releaseLock()}}else{const Ie=await Ve.arrayBuffer();let ve=Ie;if(o){W.abort();return}if(V>0&&(ve=new Uint8Array(Ie).subarray(V),V-=Ie.byteLength-ve.length),!ve.byteLength)continue;r+=ve.byteLength;const b=i.decode(ve);_.enqueue(b)}}}if(k=0,T.content){let W=T.content,re=a.encode(T.content);if(V>0){const q=re.subarray(V);if(V-=re.length-q.length,!q.length)continue;re=q,W=i.decode(q)}r+=re.length,_.enqueue(W)}}}async function xe(P){let _=!0,ce=0;for(;_;){_=!1;let T=Date.now()+Math.min(15e3,500*(ce-1));const V=await K({...t,offset:r},P);V!=null&&V.retry&&(_=!0,ce++,T<Date.now()-3e5&&(ce=0),await new Promise(W=>{setTimeout(W,Math.max(0,T-Date.now()))}))}!o&&!u&&(P.close(),g())}class qt extends e{constructor(_,ce){super(_,ce)}async streamId(){if(p)return p;if(m)throw m;return new Promise((_,ce)=>{const T=[],V=()=>{for(const q of T)q()},W=q=>{_(q),V()},re=q=>{ce(q||new C("Stream is closed.")),V()};T.push(h(W)),T.push(w(re))})}}return{stream:new qt({start(P){xe(P)},cancel(P){o=!0,c&&s({eventId:c}),g()}}),addCloseCb:w,closed(){return u}}}class Ts{constructor({WStream:t,RStream:n,trySend:s,log:r}){d(this,"trySend");d(this,"WStream");d(this,"RStream");d(this,"writeStreams",{});d(this,"startWriteStreamCbs",{});d(this,"readStreamIterators",{});d(this,"log");d(this,"activeStreams",new Set);this.WStream=t,this.RStream=n,this.trySend=s,this.log=r}createWriteStream(t){const{stream:n,addCompleteCb:s}=Es({WStream:this.WStream,startStream:this.startWriteStream.bind(this),appendStream:this.appendStream.bind(this),registerStream:this.registerWriteStream.bind(this),opts:t});return this.activeStreams.add(n),s(()=>{this.activeStreams.delete(n)}),n}createReadStream(t){const{stream:n,addCloseCb:s}=Cs({RStream:this.RStream,opts:t,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(n),s(()=>{this.activeStreams.delete(n)}),n}startWriteStream(t){const n=Ae();let s=null;const r=new Promise(i=>{s=i});this.startWriteStreamCbs[n]=s;const o={op:"start-stream","client-id":t.clientId,"reconnect-token":t.reconnectToken};return t.ruleParams&&(o["rule-params"]=t.ruleParams),this.trySend(n,o),r}registerWriteStream(t,n){this.writeStreams[t]=n}appendStream({streamId:t,chunks:n,isDone:s,offset:r,abortReason:o}){const i={op:"append-stream","stream-id":t,chunks:n,offset:r,done:!!s};o&&(i["abort-reason"]=o),this.trySend(Ae(),i)}onAppendFailed(t){const n=this.writeStreams[t["stream-id"]];n&&n.onAppendFailed()}onStartStreamOk(t){const n=this.startWriteStreamCbs[t["client-event-id"]];if(!n){this.log.info("No stream for start-stream-ok",t);return}n({type:"ok",streamId:t["stream-id"],offset:t.offset}),delete this.startWriteStreamCbs[t["client-event-id"]]}onStreamFlushed(t){const n=t["stream-id"],s=this.writeStreams[n];if(!s){this.log.info("No stream cbs for stream-flushed",t);return}s.onFlush({offset:t.offset,done:t.done}),t.done&&delete this.writeStreams[n]}startReadStream({eventId:t,clientId:n,streamId:s,offset:r,ruleParams:o}){const i={op:"subscribe-stream"};if(!s&&!n)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");s&&(i["stream-id"]=s),n&&(i["client-id"]=n),r&&(i.offset=r),o&&(i["rule-params"]=o);const a=new _s;return this.readStreamIterators[t]=a,this.trySend(t,i),a}cancelReadStream({eventId:t}){const n={op:"unsubscribe-stream","subscribe-event-id":t};this.trySend(Ae(),n),delete this.readStreamIterators[t]}onStreamAppend(t){const n=t["client-event-id"],s=this.readStreamIterators[n];if(!s){this.log.info("No iterator for read stream",t);return}if(t.error){t.retry?s.push({type:"reconnect"}):s.push({type:"error",error:new C(t.error)}),s.close(),delete this.readStreamIterators[n];return}s.push({type:"append",offset:t.offset,files:t.files,content:t.content,streamId:t["stream-id"]}),t.done&&(s.close(),delete this.readStreamIterators[n])}onConnectionStatusChange(t){for(const n of Object.values(this.startWriteStreamCbs))n({type:"disconnect"});if(this.startWriteStreamCbs={},t!==xs.AUTHENTICATED)for(const{onDisconnect:n}of Object.values(this.writeStreams))n();else{for(const{onConnectionReconnect:n}of Object.values(this.writeStreams))n();for(const n of Object.values(this.readStreamIterators))n.push({type:"reconnect"}),n.close();this.readStreamIterators={}}}onRecieveError(t){const n=t["original-event"];switch(n.op){case"append-stream":{const s=n["stream-id"],r=this.writeStreams[s];r==null||r.onAppendFailed();break}case"start-stream":{const s=t["client-event-id"],r=this.startWriteStreamCbs[s];r&&(r({type:"error",error:new C(t.message||"Unknown error",t.hint)}),delete this.startWriteStreamCbs[s]);break}case"subscribe-stream":{const s=t["client-event-id"],r=this.readStreamIterators[s];r&&(r.push({type:"error",error:new C(t.message||"Unknown error",t.hint)}),r.close(),delete this.readStreamIterators[s]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const xs={AUTHENTICATED:"authenticated"};function Rs(){return globalThis.__instantDbSchemaHashStore=globalThis.__instantDbSchemaHashStore??new WeakMap,globalThis.__instantDbSchemaHashStore}function As(){return globalThis.__instantDbStore=globalThis.__instantDbStore??{},globalThis.__instantDbStore}As(),Rs();class vn extends Error{constructor(t,n){super(t),this.name="ParseError",this.type=n.type,this.field=n.field,this.value=n.value,this.line=n.line}}function xt(e){}function Ps(e){if(typeof e=="function")throw new TypeError("`callbacks` must be an object, got a function instead. Did you mean `{onEvent: fn}`?");const{onEvent:t=xt,onError:n=xt,onRetry:s=xt,onComment:r}=e;let o="",i=!0,a,c="",u="";function l(w){const h=i?w.replace(/^\xEF\xBB\xBF/,""):w,[v,k]=js(`${o}${h}`);for(const K of v)f(K);o=k,i=!1}function f(w){if(w===""){m();return}if(w.startsWith(":")){r&&r(w.slice(w.startsWith(": ")?2:1));return}const h=w.indexOf(":");if(h!==-1){const v=w.slice(0,h),k=w[h+1]===" "?2:1,K=w.slice(h+k);p(v,K,w);return}p(w,"",w)}function p(w,h,v){switch(w){case"event":u=h;break;case"data":c=`${c}${h}
2
- `;break;case"id":a=h.includes("\0")?void 0:h;break;case"retry":/^\d+$/.test(h)?s(parseInt(h,10)):n(new vn(`Invalid \`retry\` value: "${h}"`,{type:"invalid-retry",value:h,line:v}));break;default:n(new vn(`Unknown field "${w.length>20?`${w.slice(0,20)}…`:w}"`,{type:"unknown-field",field:w,value:h,line:v}));break}}function m(){c.length>0&&t({id:a,event:u||void 0,data:c.endsWith(`
1
+ (function($,E){typeof exports=="object"&&typeof module<"u"?E(exports):typeof define=="function"&&define.amd?define(["exports"],E):($=typeof globalThis<"u"?globalThis:$||self,E($.instant={}))})(this,function($){"use strict";var Ir=Object.defineProperty;var Ln=$=>{throw TypeError($)};var kr=($,E,A)=>E in $?Ir($,E,{enumerable:!0,configurable:!0,writable:!0,value:A}):$[E]=A;var d=($,E,A)=>kr($,typeof E!="symbol"?E+"":E,A),Qt=($,E,A)=>E.has($)||Ln("Cannot "+A);var y=($,E,A)=>(Qt($,E,"read from private field"),A?A.call($):E.get($)),L=($,E,A)=>E.has($)?Ln("Cannot add the same private member more than once"):E instanceof WeakSet?E.add($):E.set($,A),B=($,E,A,D)=>(Qt($,E,"write to private field"),D?D.call($,A):E.set($,A),A),j=($,E,A)=>(Qt($,E,"access private method"),A);var G,Ye,Le,Fe,Ze,ne,fe,et,Ce,ze,H,Te,X,Y,z,zn,bt,Vn,Jn,Hn,lt,ht,pt,Gt,Kn,yt;const E=/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-8][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/i;function A(e){return typeof e=="string"&&E.test(e)}const D=[];for(let e=0;e<256;++e)D.push((e+256).toString(16).slice(1));function qn(e,t=0){return(D[e[t+0]]+D[e[t+1]]+D[e[t+2]]+D[e[t+3]]+"-"+D[e[t+4]]+D[e[t+5]]+"-"+D[e[t+6]]+D[e[t+7]]+"-"+D[e[t+8]]+D[e[t+9]]+"-"+D[e[t+10]]+D[e[t+11]]+D[e[t+12]]+D[e[t+13]]+D[e[t+14]]+D[e[t+15]]).toLowerCase()}let wt;const Bn=new Uint8Array(16);function Qn(){if(!wt){if(typeof crypto>"u"||!crypto.getRandomValues)throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported");wt=crypto.getRandomValues.bind(crypto)}return wt(Bn)}const Xt={randomUUID:typeof crypto<"u"&&crypto.randomUUID&&crypto.randomUUID.bind(crypto)};function Gn(e,t,n){var r;if(Xt.randomUUID&&!e)return Xt.randomUUID();e=e||{};const s=e.random??((r=e.rng)==null?void 0:r.call(e))??Qn();if(s.length<16)throw new Error("Random bytes length must be >= 16");return s[6]=s[6]&15|64,s[8]=s[8]&63|128,qn(s)}const F={Remove:"remove",Replace:"replace",Add:"add"},Yt=Symbol.for("__MUTATIVE_PROXY_DRAFT__"),tt=Symbol.iterator,ie={mutable:"mutable",immutable:"immutable"},gt={};function Je(e,t){return e instanceof Map?e.has(t):Object.prototype.hasOwnProperty.call(e,t)}function Zt(e,t){if(t in e){let n=Reflect.getPrototypeOf(e);for(;n;){const s=Reflect.getOwnPropertyDescriptor(n,t);if(s)return s;n=Reflect.getPrototypeOf(n)}}}function en(e){return Object.getPrototypeOf(e)===Set.prototype}function tn(e){return Object.getPrototypeOf(e)===Map.prototype}function te(e){var t;return(t=e.copy)!==null&&t!==void 0?t:e.original}function St(e){return!!O(e)}function O(e){return typeof e!="object"?null:e==null?void 0:e[Yt]}function It(e){var t;const n=O(e);return n?(t=n.copy)!==null&&t!==void 0?t:n.original:e}function ve(e,t){if(!e||typeof e!="object")return!1;let n;return Object.getPrototypeOf(e)===Object.prototype||Array.isArray(e)||e instanceof Map||e instanceof Set||!!(t!=null&&t.mark)&&((n=t.mark(e,ie))===ie.immutable||typeof n=="function")}function nn(e,t=[]){if(Object.hasOwnProperty.call(e,"key")){const n=e.parent.copy,s=O(be(n,e.key));if(s!==null&&(s==null?void 0:s.original)!==e.original)return null;const r=e.parent.type===3,o=r?Array.from(e.parent.setMap.keys()).indexOf(e.key):e.key;if(!(r&&n.size>o||Je(n,o)))return null;t.push(o)}if(e.parent)return nn(e.parent,t);t.reverse();try{Xn(e.copy,t)}catch{return null}return t}function He(e){return Array.isArray(e)?1:e instanceof Map?2:e instanceof Set?3:0}function be(e,t){return He(e)===2?e.get(t):e[t]}function kt(e,t,n){He(e)===2?e.set(t,n):e[t]=n}function vt(e,t){const n=O(e);return(n?te(n):e)[t]}function $e(e,t){return e===t?e!==0||1/e===1/t:e!==e&&t!==t}function Oe(e,t){return t?e:[""].concat(e).map(n=>{const s=`${n}`;return s.indexOf("/")===-1&&s.indexOf("~")===-1?s:s.replace(/~/g,"~0").replace(/\//g,"~1")}).join("/")}function Xn(e,t){for(let n=0;n<t.length-1;n+=1){const s=t[n];if(e=be(He(e)===3?Array.from(e):e,s),typeof e!="object")throw new Error(`Cannot resolve patch at '${t.join("/")}'.`)}return e}function Yn(e){const t=Object.create(Object.getPrototypeOf(e));return Reflect.ownKeys(e).forEach(n=>{let s=Reflect.getOwnPropertyDescriptor(e,n);if(s.enumerable&&s.configurable&&s.writable){t[n]=e[n];return}s.writable||(s.writable=!0,s.configurable=!0),(s.get||s.set)&&(s={configurable:!0,writable:!0,enumerable:s.enumerable,value:e[n]}),Reflect.defineProperty(t,n,s)}),t}const Zn=Object.prototype.propertyIsEnumerable;function es(e,t){let n;if(Array.isArray(e))return Array.prototype.concat.call(e);if(e instanceof Set){if(!en(e)){const s=Object.getPrototypeOf(e).constructor;return new s(e.values())}return Set.prototype.difference?Set.prototype.difference.call(e,new Set):new Set(e.values())}else if(e instanceof Map){if(!tn(e)){const s=Object.getPrototypeOf(e).constructor;return new s(e)}return new Map(e)}else if(t!=null&&t.mark&&(n=t.mark(e,ie),n!==void 0)&&n!==ie.mutable){if(n===ie.immutable)return Yn(e);if(typeof n=="function"){if(t.enablePatches||t.enableAutoFreeze)throw new Error("You can't use mark and patches or auto freeze together.");return n()}throw new Error(`Unsupported mark result: ${n}`)}else if(typeof e=="object"&&Object.getPrototypeOf(e)===Object.prototype){const s={};return Object.keys(e).forEach(r=>{s[r]=e[r]}),Object.getOwnPropertySymbols(e).forEach(r=>{Zn.call(e,r)&&(s[r]=e[r])}),s}else throw new Error("Please check mark() to ensure that it is a stable marker draftable function.")}function Q(e){e.copy||(e.copy=es(e.original,e.options))}function Ke(e){if(!ve(e))return It(e);if(Array.isArray(e))return e.map(Ke);if(e instanceof Map){const n=Array.from(e.entries()).map(([s,r])=>[s,Ke(r)]);if(!tn(e)){const s=Object.getPrototypeOf(e).constructor;return new s(n)}return new Map(n)}if(e instanceof Set){const n=Array.from(e).map(Ke);if(!en(e)){const s=Object.getPrototypeOf(e).constructor;return new s(n)}return new Set(n)}const t=Object.create(Object.getPrototypeOf(e));for(const n in e)t[n]=Ke(e[n]);return t}function nt(e){return St(e)?Ke(e):e}function de(e){var t;e.assignedMap=(t=e.assignedMap)!==null&&t!==void 0?t:new Map,e.operated||(e.operated=!0,e.parent&&de(e.parent))}function ts(e,t){const n=He(e);if(n===0)Reflect.ownKeys(e).forEach(s=>{t(s,e[s],e)});else if(n===1){let s=0;for(const r of e)t(s,r,e),s+=1}else e.forEach((s,r)=>t(r,s,e))}function sn(e,t,n){if(St(e)||!ve(e,n)||t.has(e)||Object.isFrozen(e))return;const s=e instanceof Set,r=s?new Map:void 0;if(t.add(e),ts(e,(o,i)=>{var a;if(St(i)){const c=O(i);Q(c);const u=!((a=c.assignedMap)===null||a===void 0)&&a.size||c.operated?c.copy:c.original;kt(s?r:e,o,u)}else sn(i,t,n)}),r){const o=e,i=Array.from(o);o.clear(),i.forEach(a=>{o.add(r.has(a)?r.get(a):a)})}}function ns(e,t){const n=e.type===3?e.setMap:e.copy;e.finalities.revoke.length>1&&e.assignedMap.get(t)&&n&&sn(be(n,t),e.finalities.handledSet,e.options)}function $t(e){e.type===3&&e.copy&&(e.copy.clear(),e.setMap.forEach(t=>{e.copy.add(It(t))}))}function Ot(e,t,n,s){if(e.operated&&e.assignedMap&&e.assignedMap.size>0&&!e.finalized){if(n&&s){const o=nn(e);o&&t(e,o,n,s)}e.finalized=!0}}function Et(e,t,n,s){const r=O(n);r&&(r.callbacks||(r.callbacks=[]),r.callbacks.push((o,i)=>{var a;const c=e.type===3?e.setMap:e.copy;if($e(be(c,t),n)){let u=r.original;r.copy&&(u=r.copy),$t(e),Ot(e,s,o,i),e.options.enableAutoFreeze&&(e.options.updatedValues=(a=e.options.updatedValues)!==null&&a!==void 0?a:new WeakMap,e.options.updatedValues.set(u,r.original)),kt(c,t,u)}}),e.options.enableAutoFreeze&&r.finalities!==e.finalities&&(e.options.enableAutoFreeze=!1)),ve(n,e.options)&&e.finalities.draft.push(()=>{const o=e.type===3?e.setMap:e.copy;$e(be(o,t),n)&&ns(e,t)})}function ss(e,t,n,s,r){let{original:o,assignedMap:i,options:a}=e,c=e.copy;c.length<o.length&&([o,c]=[c,o],[n,s]=[s,n]);for(let u=0;u<o.length;u+=1)if(i.get(u.toString())&&c[u]!==o[u]){const l=t.concat([u]),f=Oe(l,r);n.push({op:F.Replace,path:f,value:nt(c[u])}),s.push({op:F.Replace,path:f,value:nt(o[u])})}for(let u=o.length;u<c.length;u+=1){const l=t.concat([u]),f=Oe(l,r);n.push({op:F.Add,path:f,value:nt(c[u])})}if(o.length<c.length){const{arrayLengthAssignment:u=!0}=a.enablePatches;if(u){const l=t.concat(["length"]),f=Oe(l,r);s.push({op:F.Replace,path:f,value:o.length})}else for(let l=c.length;o.length<l;l-=1){const f=t.concat([l-1]),p=Oe(f,r);s.push({op:F.Remove,path:p})}}}function rs({original:e,copy:t,assignedMap:n},s,r,o,i){n.forEach((a,c)=>{const u=be(e,c),l=nt(be(t,c)),f=a?Je(e,c)?F.Replace:F.Add:F.Remove;if($e(u,l)&&f===F.Replace)return;const p=s.concat(c),m=Oe(p,i);r.push(f===F.Remove?{op:f,path:m}:{op:f,path:m,value:l}),o.push(f===F.Add?{op:F.Remove,path:m}:f===F.Remove?{op:F.Add,path:m,value:u}:{op:F.Replace,path:m,value:u})})}function is({original:e,copy:t},n,s,r,o){let i=0;e.forEach(a=>{if(!t.has(a)){const c=n.concat([i]),u=Oe(c,o);s.push({op:F.Remove,path:u,value:a}),r.unshift({op:F.Add,path:u,value:a})}i+=1}),i=0,t.forEach(a=>{if(!e.has(a)){const c=n.concat([i]),u=Oe(c,o);s.push({op:F.Add,path:u,value:a}),r.unshift({op:F.Remove,path:u,value:a})}i+=1})}function qe(e,t,n,s){const{pathAsArray:r=!0}=e.options.enablePatches;switch(e.type){case 0:case 2:return rs(e,t,n,s,r);case 1:return ss(e,t,n,s,r);case 3:return is(e,t,n,s,r)}}const st=(e,t,n=!1)=>{if(typeof e=="object"&&e!==null&&(!ve(e,t)||n))throw new Error("Strict mode: Mutable data cannot be accessed directly, please use 'unsafe(callback)' wrap.")},_t={get size(){return te(O(this)).size},has(e){return te(O(this)).has(e)},set(e,t){const n=O(this),s=te(n);return(!s.has(e)||!$e(s.get(e),t))&&(Q(n),de(n),n.assignedMap.set(e,!0),n.copy.set(e,t),Et(n,e,t,qe)),this},delete(e){if(!this.has(e))return!1;const t=O(this);return Q(t),de(t),t.original.has(e)?t.assignedMap.set(e,!1):t.assignedMap.delete(e),t.copy.delete(e),!0},clear(){const e=O(this);if(this.size){Q(e),de(e),e.assignedMap=new Map;for(const[t]of e.original)e.assignedMap.set(t,!1);e.copy.clear()}},forEach(e,t){const n=O(this);te(n).forEach((s,r)=>{e.call(t,this.get(r),r,this)})},get(e){var t,n;const s=O(this),r=te(s).get(e),o=((n=(t=s.options).mark)===null||n===void 0?void 0:n.call(t,r,ie))===ie.mutable;if(s.options.strict&&st(r,s.options,o),o||s.finalized||!ve(r,s.options)||r!==s.original.get(e))return r;const i=gt.createDraft({original:r,parentDraft:s,key:e,finalities:s.finalities,options:s.options});return Q(s),s.copy.set(e,i),i},keys(){return te(O(this)).keys()},values(){const e=this.keys();return{[tt]:()=>this.values(),next:()=>{const t=e.next();return t.done?t:{done:!1,value:this.get(t.value)}}}},entries(){const e=this.keys();return{[tt]:()=>this.entries(),next:()=>{const t=e.next();if(t.done)return t;const n=this.get(t.value);return{done:!1,value:[t.value,n]}}}},[tt](){return this.entries()}},os=Reflect.ownKeys(_t),rn=(e,t,{isValuesIterator:n})=>()=>{var s,r;const o=t.next();if(o.done)return o;const i=o.value;let a=e.setMap.get(i);const c=O(a),u=((r=(s=e.options).mark)===null||r===void 0?void 0:r.call(s,a,ie))===ie.mutable;if(e.options.strict&&st(i,e.options,u),!u&&!c&&ve(i,e.options)&&!e.finalized&&e.original.has(i)){const l=gt.createDraft({original:i,parentDraft:e,key:i,finalities:e.finalities,options:e.options});e.setMap.set(i,l),a=l}else c&&(a=c.proxy);return{done:!1,value:n?a:[a,a]}},rt={get size(){return O(this).setMap.size},has(e){const t=O(this);if(t.setMap.has(e))return!0;Q(t);const n=O(e);return!!(n&&t.setMap.has(n.original))},add(e){const t=O(this);return this.has(e)||(Q(t),de(t),t.assignedMap.set(e,!0),t.setMap.set(e,e),Et(t,e,e,qe)),this},delete(e){if(!this.has(e))return!1;const t=O(this);Q(t),de(t);const n=O(e);return n&&t.setMap.has(n.original)?(t.assignedMap.set(n.original,!1),t.setMap.delete(n.original)):(!n&&t.setMap.has(e)?t.assignedMap.set(e,!1):t.assignedMap.delete(e),t.setMap.delete(e))},clear(){if(!this.size)return;const e=O(this);Q(e),de(e);for(const t of e.original)e.assignedMap.set(t,!1);e.setMap.clear()},values(){const e=O(this);Q(e);const t=e.setMap.keys();return{[Symbol.iterator]:()=>this.values(),next:rn(e,t,{isValuesIterator:!0})}},entries(){const e=O(this);Q(e);const t=e.setMap.keys();return{[Symbol.iterator]:()=>this.entries(),next:rn(e,t,{isValuesIterator:!1})}},keys(){return this.values()},[tt](){return this.values()},forEach(e,t){const n=this.values();let s=n.next();for(;!s.done;)e.call(t,s.value,s.value,this),s=n.next()}};Set.prototype.difference&&Object.assign(rt,{intersection(e){return Set.prototype.intersection.call(new Set(this.values()),e)},union(e){return Set.prototype.union.call(new Set(this.values()),e)},difference(e){return Set.prototype.difference.call(new Set(this.values()),e)},symmetricDifference(e){return Set.prototype.symmetricDifference.call(new Set(this.values()),e)},isSubsetOf(e){return Set.prototype.isSubsetOf.call(new Set(this.values()),e)},isSupersetOf(e){return Set.prototype.isSupersetOf.call(new Set(this.values()),e)},isDisjointFrom(e){return Set.prototype.isDisjointFrom.call(new Set(this.values()),e)}});const as=Reflect.ownKeys(rt),on=new WeakSet,an={get(e,t,n){var s,r;const o=(s=e.copy)===null||s===void 0?void 0:s[t];if(o&&on.has(o))return o;if(t===Yt)return e;let i;if(e.options.mark){const u=t==="size"&&(e.original instanceof Map||e.original instanceof Set)?Reflect.get(e.original,t):Reflect.get(e.original,t,n);if(i=e.options.mark(u,ie),i===ie.mutable)return e.options.strict&&st(u,e.options,!0),u}const a=te(e);if(a instanceof Map&&os.includes(t)){if(t==="size")return Object.getOwnPropertyDescriptor(_t,"size").get.call(e.proxy);const u=_t[t];if(u)return u.bind(e.proxy)}if(a instanceof Set&&as.includes(t)){if(t==="size")return Object.getOwnPropertyDescriptor(rt,"size").get.call(e.proxy);const u=rt[t];if(u)return u.bind(e.proxy)}if(!Je(a,t)){const u=Zt(a,t);return u?"value"in u?u.value:(r=u.get)===null||r===void 0?void 0:r.call(e.proxy):void 0}const c=a[t];if(e.options.strict&&st(c,e.options),e.finalized||!ve(c,e.options))return c;if(c===vt(e.original,t)){if(Q(e),e.copy[t]=cn({original:e.original[t],parentDraft:e,key:e.type===1?Number(t):t,finalities:e.finalities,options:e.options}),typeof i=="function"){const u=O(e.copy[t]);return Q(u),de(u),u.copy}return e.copy[t]}return c},set(e,t,n){var s;if(e.type===3||e.type===2)throw new Error("Map/Set draft does not support any property assignment.");let r;if(e.type===1&&t!=="length"&&!(Number.isInteger(r=Number(t))&&r>=0&&(t===0||r===0||String(r)===String(t))))throw new Error("Only supports setting array indices and the 'length' property.");const o=Zt(te(e),t);if(o!=null&&o.set)return o.set.call(e.proxy,n),!0;const i=vt(te(e),t),a=O(i);return a&&$e(a.original,n)?(e.copy[t]=n,e.assignedMap=(s=e.assignedMap)!==null&&s!==void 0?s:new Map,e.assignedMap.set(t,!1),!0):($e(n,i)&&(n!==void 0||Je(e.original,t))||(Q(e),de(e),Je(e.original,t)&&$e(n,e.original[t])?e.assignedMap.delete(t):e.assignedMap.set(t,!0),e.copy[t]=n,Et(e,t,n,qe)),!0)},has(e,t){return t in te(e)},ownKeys(e){return Reflect.ownKeys(te(e))},getOwnPropertyDescriptor(e,t){const n=te(e),s=Reflect.getOwnPropertyDescriptor(n,t);return s&&{writable:!0,configurable:e.type!==1||t!=="length",enumerable:s.enumerable,value:n[t]}},getPrototypeOf(e){return Reflect.getPrototypeOf(e.original)},setPrototypeOf(){throw new Error("Cannot call 'setPrototypeOf()' on drafts")},defineProperty(){throw new Error("Cannot call 'defineProperty()' on drafts")},deleteProperty(e,t){var n;return e.type===1?an.set.call(this,e,t,void 0,e.proxy):(vt(e.original,t)!==void 0||t in e.original?(Q(e),de(e),e.assignedMap.set(t,!1)):(e.assignedMap=(n=e.assignedMap)!==null&&n!==void 0?n:new Map,e.assignedMap.delete(t)),e.copy&&delete e.copy[t],!0)}};function cn(e){const{original:t,parentDraft:n,key:s,finalities:r,options:o}=e,i=He(t),a={type:i,finalized:!1,parent:n,original:t,copy:null,proxy:null,finalities:r,options:o,setMap:i===3?new Map(t.entries()):void 0};(s||"key"in e)&&(a.key=s);const{proxy:c,revoke:u}=Proxy.revocable(i===1?Object.assign([],a):a,an);if(r.revoke.push(u),on.add(c),a.proxy=c,n){const l=n;l.finalities.draft.push((f,p)=>{var m,g;const w=O(c);let h=l.type===3?l.setMap:l.copy;const k=be(h,s),v=O(k);if(v){let K=v.original;v.operated&&(K=It(k)),$t(v),Ot(v,qe,f,p),l.options.enableAutoFreeze&&(l.options.updatedValues=(m=l.options.updatedValues)!==null&&m!==void 0?m:new WeakMap,l.options.updatedValues.set(K,v.original)),kt(h,s,K)}(g=w.callbacks)===null||g===void 0||g.forEach(K=>{K(f,p)})})}else{const l=O(c);l.finalities.draft.push((f,p)=>{$t(l),Ot(l,qe,f,p)})}return c}gt.createDraft=cn,Object.prototype.constructor.toString();function Ae(){return Gn()}function cs(e,t){return e.localeCompare(t)}function us(){let e=cs;if(typeof Intl=="object"&&Intl.hasOwnProperty("Collator"))try{e=Intl.Collator("en-US").compare}catch{}return e}us();function fs(){const t={__etype:1,__ops:1,create:1,update:1,link:1,unlink:1,delete:1,merge:1,ruleParams:1};return new Set(Object.keys(t))}const ds=fs();function it(e,t,n){const s={__etype:e,__ops:n};return new Proxy(s,{get:(r,o)=>{if(o==="__ops")return n;if(o==="__etype")return e;if(ds.has(o))return(i,a)=>it(e,t,[...n,a?[o,e,t,i,a]:[o,e,t,i]])}})}function ls(e,t){return`lookup__${e}__${JSON.stringify(t)}`}function un(e){return e.startsWith("lookup__")}function fn(e){const[t,n,...s]=e.split("__");return[n,JSON.parse(s.join("__"))]}function hs(e){return new Proxy({__etype:e},{get(t,n){if(n==="lookup")return(r,o)=>it(e,fn(ls(r,o)),[]);if(n==="__etype")return e;const s=n;return un(s)?it(e,fn(s),[]):it(e,s,[])}})}function dn(){return new Proxy({},{get(e,t){return hs(t)}})}dn();function ps(e){return e.__ops}class C extends Error{constructor(n,s,r){super(n);d(this,"hint");d(this,"traceId");this.hint=s,r&&(this.traceId=r);const o=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,o),Error.captureStackTrace&&Error.captureStackTrace(this,C),this.name="InstantError"}get[Symbol.toStringTag](){return"InstantError"}}class le extends C{constructor(n){var o,i;const s=((o=n.body)==null?void 0:o.message)||`API Error (${n.status})`;super(s,n.body.hint,((i=n.body)==null?void 0:i.traceId)||n.body["trace-id"]);d(this,"body");d(this,"status");const r=new.target.prototype;Object.setPrototypeOf&&Object.setPrototypeOf(this,r),Error.captureStackTrace&&Error.captureStackTrace(this,le),this.name="InstantAPIError",this.status=n.status,this.body=n.body}get[Symbol.toStringTag](){return"InstantAPIError"}}typeof window<"u"&&typeof window.localStorage<"u"&&(window.localStorage.getItem("devBackend"),window.localStorage.getItem("__instantLogging"),window.localStorage.getItem("__devtoolLocalDash"));const Ee="v1.0.33-branch-webhooks-docs.25894421517.1";class he{constructor(t,n,s,r={indexed:!1,unique:!1}){d(this,"valueType");d(this,"required");d(this,"isIndexed");d(this,"config");d(this,"metadata",{});this.valueType=t,this.required=n,this.isIndexed=s,this.config=r}clientRequired(){return new he(this.valueType,!1,this.isIndexed,this.config)}optional(){return new he(this.valueType,!1,this.isIndexed,this.config)}unique(){return new he(this.valueType,this.required,this.isIndexed,{...this.config,unique:!0})}indexed(){return new he(this.valueType,this.required,!0,{...this.config,indexed:!0})}}class x extends Error{constructor(t,n){const s=n?`At path '${n}': ${t}`:t;super(s),this.name="QueryValidationError"}}const ln=["where","order","limit","last","first","offset","after","afterInclusive","before","beforeInclusive","fields","aggregate"],ys=e=>e.valueType||"unknown",hn=(e,t,n=!1)=>{if(n||e==null)return!0;switch(t){case"string":return typeof e=="string";case"number":return typeof e=="number"&&!isNaN(e);case"boolean":return typeof e=="boolean";case"date":return e instanceof Date||typeof e=="string"||typeof e=="number";default:return!0}},ms=(e,t,n,s,r,o,i)=>{const a=o.valueType==="json",c=(u,l,f)=>{if(!hn(f,l,a))throw new x(`Invalid value for operator '${u}' on attribute '${s}' in entity '${r}'. Expected ${l}, but received: ${typeof f}`,i)};switch(e){case"in":case"$in":if(!Array.isArray(t))throw new x(`Operator '${e}' for attribute '${s}' in entity '${r}' must be an array, but received: ${typeof t}`,i);for(const u of t)c(e,n,u);break;case"$not":case"$ne":case"$gt":case"$lt":case"$gte":case"$lte":c(e,n,t);break;case"$like":case"$ilike":if(c(e,"string",t),e==="$ilike"&&!o.isIndexed)throw new x(`Operator '${e}' can only be used with indexed attributes, but '${s}' in entity '${r}' is not indexed`,i);break;case"$isNull":c(e,"boolean",t);break;default:throw new x(`Unknown operator '${e}' for attribute '${s}' in entity '${r}'`,i)}},Pe=(e,t,n,s,r)=>{const o=ys(n),i=n.valueType==="json";if(typeof e=="object"&&e!==null&&!Array.isArray(e)){if(i)return;const c=e;for(const[u,l]of Object.entries(c))ms(u,l,o,t,s,n,`${r}.${u}`)}else if(!hn(e,o,i))throw new x(`Invalid value for attribute '${t}' in entity '${s}'. Expected ${o}, but received: ${typeof e}`,r)},bs=(e,t,n,s,r)=>{const o=e.split(".");if(o.length<2)throw new x(`Invalid dot notation path '${e}'. Must contain at least one dot.`,r);let i=n;for(let l=0;l<o.length-1;l++){const f=o[l],p=s.entities[i];if(!p)throw new x(`Entity '${i}' does not exist in schema while traversing dot notation path '${e}'.`,r);const m=p.links[f];if(!m){const g=Object.keys(p.links);throw new x(`Link '${f}' does not exist on entity '${i}' in dot notation path '${e}'. Available links: ${g.length>0?g.join(", "):"none"}`,r)}i=m.entityName}const a=o[o.length-1],c=s.entities[i];if(!c)throw new x(`Target entity '${i}' does not exist in schema for dot notation path '${e}'.`,r);if(a==="id"){if(typeof t=="string"&&!A(t))throw new x(`Invalid value for id field in entity '${i}'. Expected a UUID, but received: ${t}`,r);Pe(t,e,new he("string",!1,!0),n,r);return}const u=c.attrs[a];if(Object.keys(c.links).includes(a)){if(typeof t=="string"&&!A(t))throw new x(`Invalid value for link '${a}' in entity '${i}'. Expected a UUID, but received: ${t}`,r);Pe(t,e,new he("string",!1,!0),n,r);return}if(!u){const l=Object.keys(c.attrs);throw new x(`Attribute '${a}' does not exist on entity '${i}' in dot notation path '${e}'. Available attributes: ${l.length>0?l.join(", ")+", id":"id"}`,r)}Pe(t,e,u,n,r)},pn=(e,t,n,s)=>{for(const[r,o]of Object.entries(e)){if(r==="or"||r==="and"){if(Array.isArray(o))for(const u of o)typeof u=="object"&&u!==null&&pn(u,t,n,`${s}.${r}[${u}]`);continue}if(r==="id"){Pe(o,"id",new he("string",!1,!0),t,`${s}.id`);continue}if(r.includes(".")){bs(r,o,t,n,`${s}.${r}`);continue}const i=n.entities[t];if(!i)continue;const a=i.attrs[r],c=i.links[r];if(!a&&!c){const u=Object.keys(i.attrs),l=Object.keys(i.links);throw new x(`Attribute or link '${r}' does not exist on entity '${t}'. Available attributes: ${u.length>0?u.join(", "):"none"}. Available links: ${l.length>0?l.join(", "):"none"}`,`${s}.${r}`)}if(a)Pe(o,r,a,t,`${s}.${r}`);else if(c){if(typeof o=="string"&&!A(o))throw new x(`Invalid value for link '${r}' in entity '${t}'. Expected a UUID, but received: ${o}`,`${s}.${r}`);const u=new he("string",!1,!0);Pe(o,r,u,t,`${s}.${r}`)}}},ws=(e,t,n,s,r=0)=>{for(const i of Object.keys(e))if(!ln.includes(i))throw new x(`Invalid query parameter '${i}' in $ object. Valid parameters are: ${ln.join(", ")}. Found: ${i}`,s);const o=["offset","before","beforeInclusive","after","afterInclusive","first","last"];for(const i of o)if(e[i]!==void 0&&r>0)throw new x(`'${i}' can only be used on top-level namespaces. It cannot be used in nested queries.`,s);if(e.where&&n){if(typeof e.where!="object"||e.where===null)throw new x(`'where' clause must be an object in entity '${t}', but received: ${typeof e.where}`,s?`${s}.where`:void 0);pn(e.where,t,n,s?`${s}.where`:"where")}},yn=(e,t,n,s,r=0)=>{var o;if(!e||typeof e!="object")throw new x(`Query part for entity '${t}' must be an object, but received: ${typeof e}`,s);for(const i of Object.keys(e))if(i!=="$"){if(n&&!(i in n.entities[t].links)){const c=Object.keys(n.entities[t].links);throw new x(`Link '${i}' does not exist on entity '${t}'. Available links: ${c.length>0?c.join(", "):"none"}`,`${s}.${i}`)}const a=e[i];if(typeof a=="object"&&a!==null){const c=(o=n==null?void 0:n.entities[t].links[i])==null?void 0:o.entityName;c&&yn(a,c,n,`${s}.${i}`,r+1)}}else{const a=e[i];if(typeof a!="object"||a===null)throw new x(`Query parameter '$' must be an object in entity '${t}', but received: ${typeof a}`,`${s}.$`);ws(a,t,n,`${s}.$`,r)}},mn=(e,t)=>{if(typeof e!="object"||e===null)throw new x(`Query must be an object, but received: ${typeof e}${e===null?" (null)":""}`);if(Array.isArray(e))throw new x(`Query must be an object, but received: ${typeof e}`);const n=e;for(const s of Object.keys(n)){if(Array.isArray(e[s]))throw new x(`Query keys must be strings, but found key of type: ${typeof s}`,s);if(typeof s!="string")throw new x(`Query keys must be strings, but found key of type: ${typeof s}`,s);if(s!=="$$ruleParams"){if(t&&!t.entities[s]){const r=Object.keys(t.entities);throw new x(`Entity '${s}' does not exist in schema. Available entities: ${r.length>0?r.join(", "):"none"}`,s)}yn(n[s],s,t,s,0)}}},bn=e=>typeof e!="string"?!1:un(e)?!0:A(e);class se extends Error{constructor(t){super(t),this.name="TransactionValidationError"}}const wn=e=>e.length>0?e.join(", "):"none",gs=(e,t)=>new se(`Entity '${e}' does not exist in schema. Available entities: ${wn(t)}`),Ct={string:e=>typeof e=="string",number:e=>typeof e=="number"&&!isNaN(e),boolean:e=>typeof e=="boolean",date:e=>e instanceof Date||typeof e=="string"||typeof e=="number",json:()=>!0},Ss=(e,t)=>{var n;return e==null?!0:((n=Ct[t.valueType])==null?void 0:n.call(Ct,e))??!1},gn=(e,t)=>{const n=t.entities[e];if(!n)throw gs(e,Object.keys(t.entities));return n},Tt=(e,t,n)=>{const s=gn(e,n);if(typeof t!="object"||t===null)throw new se(`Arguments for data operation on entity '${e}' must be an object, but received: ${typeof t}`);for(const[r,o]of Object.entries(t)){if(r==="id")continue;const i=s.attrs[r];if(i&&!Ss(o,i))throw new se(`Invalid value for attribute '${r}' in entity '${e}'. Expected ${i.valueType}, but received: ${typeof o}`)}},Sn=(e,t,n)=>{const s=gn(e,n);if(typeof t!="object"||t===null)throw new se(`Arguments for link operation on entity '${e}' must be an object, but received: ${typeof t}`);for(const[r,o]of Object.entries(t)){if(!s.links[r]){const a=Object.keys(s.links);throw new se(`Link '${r}' does not exist on entity '${e}'. Available links: ${wn(a)}`)}if(o!=null){if(Array.isArray(o)){for(const a of o)if(!bn(a))throw new se(`Invalid entity ID in link '${r}' for entity '${e}'. Expected a UUID or a lookup, but received: ${a}`)}else if(!bn(o))throw new se(`Invalid UUID in link '${r}' for entity '${e}'. Expected a UUID, but received: ${o}`)}}},Is={create:Tt,update:Tt,merge:Tt,link:Sn,unlink:Sn,delete:()=>{}},ks=(e,t)=>{if(!t)return;const[n,s,r,o]=e;if(!Array.isArray(r)&&!A(r))throw new se(`Invalid id for entity '${s}'. Expected a UUID, but received: ${r}`);if(typeof s!="string")throw new se(`Entity name must be a string, but received: ${typeof s}`);const i=Is[n];i&&o!==void 0&&i(s,o,t)},vs=(e,t)=>{const n=Array.isArray(e)?e:[e];for(const s of n){if(!s||typeof s!="object")throw new se(`Transaction chunk must be an object, but received: ${typeof s}`);if(!Array.isArray(s.__ops))throw new se(`Transaction chunk must have __ops array, but received: ${typeof s.__ops}`);for(const r of s.__ops){if(!Array.isArray(r))throw new se(`Transaction operation must be an array, but received: ${typeof r}`);ks(r,t)}}};let $s=0;class Os{constructor(t,n,s){d(this,"type","sse");d(this,"initParams",null);d(this,"sendQueue",[]);d(this,"sendPromise");d(this,"closeFired",!1);d(this,"sseInitTimeout");d(this,"ES");d(this,"messageUrl");d(this,"conn");d(this,"url");d(this,"id");d(this,"onopen");d(this,"onmessage");d(this,"onclose");d(this,"onerror");this.id=`${this.type}_${$s++}`,this.url=n,this.messageUrl=s||this.url,this.ES=t,this.conn=new t(n),this.sseInitTimeout=setTimeout(()=>{this.initParams||this.handleError()},1e4),this.conn.onmessage=r=>{const o=JSON.parse(r.data);if(Array.isArray(o))for(const i of o)this.handleMessage(i);else this.handleMessage(o)},this.conn.onerror=r=>{this.handleError()}}handleMessage(t){if(t.op==="sse-init"){this.initParams={machineId:t["machine-id"],sessionId:t["session-id"],sseToken:t["sse-token"]},this.onopen&&this.onopen({target:this}),clearTimeout(this.sseInitTimeout);return}this.onmessage&&this.onmessage({target:this,message:t})}handleError(){try{this.onerror&&this.onerror({target:this})}finally{this.handleClose()}}handleClose(){this.conn.close(),this.onclose&&!this.closeFired&&(this.closeFired=!0,this.onclose({target:this}))}async postMessages(t){var n,s,r;try{(await fetch(this.messageUrl,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machine_id:(n=this.initParams)==null?void 0:n.machineId,session_id:(s=this.initParams)==null?void 0:s.sessionId,sse_token:(r=this.initParams)==null?void 0:r.sseToken,messages:t})})).ok||this.handleError()}catch{this.handleError()}}async flushQueue(){if(this.sendPromise||!this.sendQueue.length)return;const t=this.sendQueue;this.sendQueue=[];const n=this.postMessages(t);this.sendPromise=n,n.then(()=>{this.sendPromise=null,this.flushQueue()})}send(t){if(!this.isOpen()||!this.initParams)throw this.isConnecting()?new Error("Failed to execute 'send' on 'EventSource': Still in CONNECTING state."):this.conn.readyState===this.ES.CLOSED?new Error("EventSource is already in CLOSING or CLOSED state."):new Error("EventSource is in invalid state.");this.sendQueue.push(t),this.flushQueue()}isOpen(){return this.conn.readyState===this.ES.OPEN&&this.initParams!==null}isConnecting(){return this.conn.readyState===this.ES.CONNECTING||this.conn.readyState===this.ES.OPEN&&this.initParams===null}close(){this.handleClose()}}var In;(function(e){e.InitialSyncBatch="InitialSyncBatch",e.InitialSyncComplete="InitialSyncComplete",e.LoadFromStorage="LoadFromStorage",e.SyncTransaction="SyncTransaction",e.Error="Error"})(In||(In={}));function Es({WStream:e,opts:t,startStream:n,appendStream:s,registerStream:r}){const o=t.clientId;let i=null,a=null,c=null;const u=Ae();let l=!1,f=!1;const p=[],m=[],g=[];let w=!1,h=0,k=0;const v=[],K=new TextEncoder;function xe(){f=!0;for(const b of p)b(a??void 0)}function qt(b){return p.push(b),f&&b(a??void 0),()=>{const S=p.indexOf(b);S!==-1&&p.splice(S,1)}}function Nn(b){return g.push(b),()=>{const S=g.indexOf(b);S!==-1&&g.splice(S,1)}}t.waitUntil&&t.waitUntil(new Promise(b=>{g.push(b)}));function P(){for(const b of g)try{b()}catch{}}function _(b){return m.push(b),i&&b(i),()=>{const S=m.indexOf(b);S!==-1&&m.splice(S,1)}}function ce(b){i=b;for(const S of m)S(i)}function T(){w=!0}function V(b){let S=h,J=0,ee=0;for(const{byteLen:ue}of v){const me=S+ue;if(me>b)break;S=me,J++,ee+=ue}J>0&&(h+=ee,k-=ee,v.splice(0,J))}function W(b,S){a=S,xe(),b.error(S),P()}async function re(){const b=await n({clientId:o,reconnectToken:u,ruleParams:t.ruleParams});switch(b.type){case"ok":{const{streamId:S,offset:J}=b;i=S,V(J),v.length&&s({streamId:S,chunks:v.map(ee=>ee.chunk),offset:h}),w=!1;break}case"disconnect":{T();break}case"error":{c&&W(c,b.error);break}}}function q(){T(),re()}function mt({offset:b,done:S}){V(b),S&&(l=!0,P())}function Wn(b){return l?(W(b,new C("Stream has been closed.")),null):i||(W(b,new C("Stream has not been initialized.")),null)}async function Ve(b){c=b;let S=!0,J=0;for(;S;){let ee=Date.now()+Math.min(15e3,500*(J-1));S=!1;const ue=await n({clientId:t.clientId,reconnectToken:u,ruleParams:t.ruleParams});switch(ue.type){case"ok":{const{streamId:me,offset:Bt}=ue;if(Bt!==0){const Re=new C("Write stream is corrupted");W(b,Re);return}ce(me),r(me,{onDisconnect:T,onFlush:mt,onConnectionReconnect:re,onAppendFailed:q}),w=!1;return}case"disconnect":{S=!0,T(),J++,await new Promise(me=>{setTimeout(me,Math.max(0,ee-Date.now()))});break}case"error":{W(b,ue.error);return}}}}class Ie extends e{constructor(S,J){super(S,J)}async streamId(){return i||new Promise((S,J)=>{const ee=[],ue=()=>{for(const Re of ee)Re()},me=Re=>{S(Re),ue()},Bt=Re=>{J(Re||new C("Stream is closed.")),ue()};ee.push(_(me)),ee.push(qt(Bt))})}}return{stream:new Ie({async start(b){try{await Ve(b)}catch(S){W(b,S)}},write(b,S){const J=Wn(S);if(J){const ee=K.encode(b).length;v.push({chunk:b,byteLen:ee});const ue=h+k;k+=ee,w||s({streamId:J,chunks:[b],offset:ue})}},close(){i?s({streamId:i,chunks:[],offset:h+k,isDone:!0}):P(),xe()},abort(b){i?s({streamId:i,chunks:[],offset:h+k,isDone:!0,abortReason:b}):P(),xe()}}),addCompleteCb:Nn,closed(){return f}}}class _s{constructor(){d(this,"items",[]);d(this,"resolvers",[]);d(this,"isClosed",!1)}push(t){if(this.isClosed)return;const n=this.resolvers.shift();n?n({value:t,done:!1}):this.items.push(t)}close(){for(this.isClosed=!0;this.resolvers.length>0;)this.resolvers.shift()({value:void 0,done:!0})}async*[Symbol.asyncIterator](){for(;;)if(this.items.length>0)yield this.items.shift();else{if(this.isClosed)return;{const{value:t,done:n}=await new Promise(s=>{this.resolvers.push(s)});if(n||!t)return;yield t}}}}function Cs({RStream:e,opts:t,startStream:n,cancelStream:s}){let r=t.byteOffset||0,o=!1;const i=new TextDecoder("utf-8"),a=new TextEncoder;let c,u=!1;const l=[],f=[];let p=null,m=null;function g(P){u=!0;for(const _ of l)_(P)}function w(P){return l.push(P),()=>{const _=l.indexOf(P);_!==-1&&l.splice(_,1)}}function h(P){return f.push(P),p&&P(p),()=>{const _=f.indexOf(P);_!==-1&&f.splice(_,1)}}function k(P,_){m=_,P.error(_),g(_)}let v=0;async function K(P,_){c=Ae();const ce={...P||{},eventId:c};for await(const T of n(ce)){if(o)return;if(T.type==="reconnect")return{retry:!0};if(T.type==="error"){k(_,T.error);return}if(T.offset>r){k(_,new C("Stream is corrupted.")),o=!0;return}p=T.streamId;for(const W of f)W(p);let V=r-T.offset;if(T.files&&T.files.length){const W=new AbortController;let re=fetch(T.files[0].url,{signal:W.signal});for(let q=0;q<T.files.length;q++){const mt=T.files[q+1],Ve=await re;if(mt&&(re=fetch(mt.url,{signal:W.signal})),!Ve.ok){if(v++,v>10){k(_,new C("Unable to process stream."));return}return{retry:!0}}if(Ve.body){const Ie=Ve.body.getReader();try{for(;;){const{done:ke,value:b}=await Ie.read();if(ke)break;if(o){W.abort();return}let S=b;if(V>0&&(S=b.subarray(V),V-=b.length-S.length),!S.length)continue;r+=S.length;const J=i.decode(S);_.enqueue(J)}}finally{Ie.releaseLock()}}else{const Ie=await Ve.arrayBuffer();let ke=Ie;if(o){W.abort();return}if(V>0&&(ke=new Uint8Array(Ie).subarray(V),V-=Ie.byteLength-ke.length),!ke.byteLength)continue;r+=ke.byteLength;const b=i.decode(ke);_.enqueue(b)}}}if(v=0,T.content){let W=T.content,re=a.encode(T.content);if(V>0){const q=re.subarray(V);if(V-=re.length-q.length,!q.length)continue;re=q,W=i.decode(q)}r+=re.length,_.enqueue(W)}}}async function xe(P){let _=!0,ce=0;for(;_;){_=!1;let T=Date.now()+Math.min(15e3,500*(ce-1));const V=await K({...t,offset:r},P);V!=null&&V.retry&&(_=!0,ce++,T<Date.now()-3e5&&(ce=0),await new Promise(W=>{setTimeout(W,Math.max(0,T-Date.now()))}))}!o&&!u&&(P.close(),g())}class qt extends e{constructor(_,ce){super(_,ce)}async streamId(){if(p)return p;if(m)throw m;return new Promise((_,ce)=>{const T=[],V=()=>{for(const q of T)q()},W=q=>{_(q),V()},re=q=>{ce(q||new C("Stream is closed.")),V()};T.push(h(W)),T.push(w(re))})}}return{stream:new qt({start(P){xe(P)},cancel(P){o=!0,c&&s({eventId:c}),g()}}),addCloseCb:w,closed(){return u}}}class Ts{constructor({WStream:t,RStream:n,trySend:s,log:r}){d(this,"trySend");d(this,"WStream");d(this,"RStream");d(this,"writeStreams",{});d(this,"startWriteStreamCbs",{});d(this,"readStreamIterators",{});d(this,"log");d(this,"activeStreams",new Set);this.WStream=t,this.RStream=n,this.trySend=s,this.log=r}createWriteStream(t){const{stream:n,addCompleteCb:s}=Es({WStream:this.WStream,startStream:this.startWriteStream.bind(this),appendStream:this.appendStream.bind(this),registerStream:this.registerWriteStream.bind(this),opts:t});return this.activeStreams.add(n),s(()=>{this.activeStreams.delete(n)}),n}createReadStream(t){const{stream:n,addCloseCb:s}=Cs({RStream:this.RStream,opts:t,startStream:this.startReadStream.bind(this),cancelStream:this.cancelReadStream.bind(this)});return this.activeStreams.add(n),s(()=>{this.activeStreams.delete(n)}),n}startWriteStream(t){const n=Ae();let s=null;const r=new Promise(i=>{s=i});this.startWriteStreamCbs[n]=s;const o={op:"start-stream","client-id":t.clientId,"reconnect-token":t.reconnectToken};return t.ruleParams&&(o["rule-params"]=t.ruleParams),this.trySend(n,o),r}registerWriteStream(t,n){this.writeStreams[t]=n}appendStream({streamId:t,chunks:n,isDone:s,offset:r,abortReason:o}){const i={op:"append-stream","stream-id":t,chunks:n,offset:r,done:!!s};o&&(i["abort-reason"]=o),this.trySend(Ae(),i)}onAppendFailed(t){const n=this.writeStreams[t["stream-id"]];n&&n.onAppendFailed()}onStartStreamOk(t){const n=this.startWriteStreamCbs[t["client-event-id"]];if(!n){this.log.info("No stream for start-stream-ok",t);return}n({type:"ok",streamId:t["stream-id"],offset:t.offset}),delete this.startWriteStreamCbs[t["client-event-id"]]}onStreamFlushed(t){const n=t["stream-id"],s=this.writeStreams[n];if(!s){this.log.info("No stream cbs for stream-flushed",t);return}s.onFlush({offset:t.offset,done:t.done}),t.done&&delete this.writeStreams[n]}startReadStream({eventId:t,clientId:n,streamId:s,offset:r,ruleParams:o}){const i={op:"subscribe-stream"};if(!s&&!n)throw new Error("Must provide one of streamId or clientId to subscribe to the stream.");s&&(i["stream-id"]=s),n&&(i["client-id"]=n),r&&(i.offset=r),o&&(i["rule-params"]=o);const a=new _s;return this.readStreamIterators[t]=a,this.trySend(t,i),a}cancelReadStream({eventId:t}){const n={op:"unsubscribe-stream","subscribe-event-id":t};this.trySend(Ae(),n),delete this.readStreamIterators[t]}onStreamAppend(t){const n=t["client-event-id"],s=this.readStreamIterators[n];if(!s){this.log.info("No iterator for read stream",t);return}if(t.error){t.retry?s.push({type:"reconnect"}):s.push({type:"error",error:new C(t.error)}),s.close(),delete this.readStreamIterators[n];return}s.push({type:"append",offset:t.offset,files:t.files,content:t.content,streamId:t["stream-id"]}),t.done&&(s.close(),delete this.readStreamIterators[n])}onConnectionStatusChange(t){for(const n of Object.values(this.startWriteStreamCbs))n({type:"disconnect"});if(this.startWriteStreamCbs={},t!==xs.AUTHENTICATED)for(const{onDisconnect:n}of Object.values(this.writeStreams))n();else{for(const{onConnectionReconnect:n}of Object.values(this.writeStreams))n();for(const n of Object.values(this.readStreamIterators))n.push({type:"reconnect"}),n.close();this.readStreamIterators={}}}onRecieveError(t){const n=t["original-event"];switch(n.op){case"append-stream":{const s=n["stream-id"],r=this.writeStreams[s];r==null||r.onAppendFailed();break}case"start-stream":{const s=t["client-event-id"],r=this.startWriteStreamCbs[s];r&&(r({type:"error",error:new C(t.message||"Unknown error",t.hint)}),delete this.startWriteStreamCbs[s]);break}case"subscribe-stream":{const s=t["client-event-id"],r=this.readStreamIterators[s];r&&(r.push({type:"error",error:new C(t.message||"Unknown error",t.hint)}),r.close(),delete this.readStreamIterators[s]);break}}}hasActiveStreams(){return this.activeStreams.size>0}}const xs={AUTHENTICATED:"authenticated"};function Rs(){return globalThis.__instantDbSchemaHashStore=globalThis.__instantDbSchemaHashStore??new WeakMap,globalThis.__instantDbSchemaHashStore}function As(){return globalThis.__instantDbStore=globalThis.__instantDbStore??{},globalThis.__instantDbStore}As(),Rs();class kn extends Error{constructor(t,n){super(t),this.name="ParseError",this.type=n.type,this.field=n.field,this.value=n.value,this.line=n.line}}function xt(e){}function Ps(e){if(typeof e=="function")throw new TypeError("`callbacks` must be an object, got a function instead. Did you mean `{onEvent: fn}`?");const{onEvent:t=xt,onError:n=xt,onRetry:s=xt,onComment:r}=e;let o="",i=!0,a,c="",u="";function l(w){const h=i?w.replace(/^\xEF\xBB\xBF/,""):w,[k,v]=js(`${o}${h}`);for(const K of k)f(K);o=v,i=!1}function f(w){if(w===""){m();return}if(w.startsWith(":")){r&&r(w.slice(w.startsWith(": ")?2:1));return}const h=w.indexOf(":");if(h!==-1){const k=w.slice(0,h),v=w[h+1]===" "?2:1,K=w.slice(h+v);p(k,K,w);return}p(w,"",w)}function p(w,h,k){switch(w){case"event":u=h;break;case"data":c=`${c}${h}
2
+ `;break;case"id":a=h.includes("\0")?void 0:h;break;case"retry":/^\d+$/.test(h)?s(parseInt(h,10)):n(new kn(`Invalid \`retry\` value: "${h}"`,{type:"invalid-retry",value:h,line:k}));break;default:n(new kn(`Unknown field "${w.length>20?`${w.slice(0,20)}…`:w}"`,{type:"unknown-field",field:w,value:h,line:k}));break}}function m(){c.length>0&&t({id:a,event:u||void 0,data:c.endsWith(`
3
3
  `)?c.slice(0,-1):c}),a=void 0,c="",u=""}function g(w={}){o&&w.consume&&f(o),i=!0,a=void 0,c="",u="",o=""}return{feed:l,reset:g}}function js(e){const t=[];let n="",s=0;for(;s<e.length;){const r=e.indexOf("\r",s),o=e.indexOf(`
4
4
  `,s);let i=-1;if(r!==-1&&o!==-1?i=Math.min(r,o):r!==-1?r===e.length-1?i=-1:i=r:o!==-1&&(i=o),i===-1){n=e.slice(s);break}else{const a=e.slice(s,i);t.push(a),s=i+1,e[s-1]==="\r"&&e[s]===`
5
- `&&s++}}return[t,n]}class kn extends Event{constructor(t,n){var s,r;super(t),this.code=(s=n==null?void 0:n.code)!=null?s:void 0,this.message=(r=n==null?void 0:n.message)!=null?r:void 0}[Symbol.for("nodejs.util.inspect.custom")](t,n,s){return s($n(this),n)}[Symbol.for("Deno.customInspect")](t,n){return t($n(this),n)}}function Ms(e){const t=globalThis.DOMException;return typeof t=="function"?new t(e,"SyntaxError"):new SyntaxError(e)}function Rt(e){return e instanceof Error?"errors"in e&&Array.isArray(e.errors)?e.errors.map(Rt).join(", "):"cause"in e&&e.cause instanceof Error?`${e}: ${Rt(e.cause)}`:e.message:`${e}`}function $n(e){return{type:e.type,message:e.message,code:e.code,defaultPrevented:e.defaultPrevented,cancelable:e.cancelable,timeStamp:e.timeStamp}}var On=e=>{throw TypeError(e)},At=(e,t,n)=>t.has(e)||On("Cannot "+n),I=(e,t,n)=>(At(e,t,"read from private field"),n?n.call(e):t.get(e)),N=(e,t,n)=>t.has(e)?On("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(e):t.set(e,n),R=(e,t,n,s)=>(At(e,t,"write to private field"),t.set(e,n),n),pe=(e,t,n)=>(At(e,t,"access private method"),n),Z,_e,je,ot,at,ct,Be,Me,Qe,we,Ue,De,Ne,Ge,oe,Pt,jt,Mt,En,Ut,Dt,Xe,Nt,Wt;class ae extends EventTarget{constructor(t,n){var s,r,o;super(),N(this,oe),this.CONNECTING=0,this.OPEN=1,this.CLOSED=2,N(this,Z),N(this,_e),N(this,je),N(this,ot),N(this,at),N(this,ct),N(this,Be),N(this,Me),N(this,Qe,null),N(this,we),N(this,Ue),N(this,De,null),N(this,Ne,null),N(this,Ge,null),N(this,jt,async i=>{var a;I(this,Ue).reset();const{body:c,redirected:u,status:l,headers:f}=i;if(l===204){pe(this,oe,Xe).call(this,"Server sent HTTP 204, not reconnecting",204),this.close();return}if(u?R(this,je,new URL(i.url)):R(this,je,void 0),l!==200){pe(this,oe,Xe).call(this,`Non-200 status code (${l})`,l);return}if(!(f.get("content-type")||"").startsWith("text/event-stream")){pe(this,oe,Xe).call(this,'Invalid content type, expected "text/event-stream"',l);return}if(I(this,Z)===this.CLOSED)return;R(this,Z,this.OPEN);const p=new Event("open");if((a=I(this,Ge))==null||a.call(this,p),this.dispatchEvent(p),typeof c!="object"||!c||!("getReader"in c)){pe(this,oe,Xe).call(this,"Invalid response body, expected a web ReadableStream",l),this.close();return}const m=new TextDecoder,g=c.getReader();let w=!0;do{const{done:h,value:v}=await g.read();v&&I(this,Ue).feed(m.decode(v,{stream:!h})),h&&(w=!1,I(this,Ue).reset(),pe(this,oe,Nt).call(this))}while(w)}),N(this,Mt,i=>{R(this,we,void 0),!(i.name==="AbortError"||i.type==="aborted")&&pe(this,oe,Nt).call(this,Rt(i))}),N(this,Ut,i=>{typeof i.id=="string"&&R(this,Qe,i.id);const a=new(I(this,ct))(i.event||"message",{data:i.data,origin:I(this,je)?I(this,je).origin:I(this,_e).origin,lastEventId:i.id||""});I(this,Ne)&&(!i.event||i.event==="message")&&I(this,Ne).call(this,a),this.dispatchEvent(a)}),N(this,Dt,i=>{R(this,Be,i)}),N(this,Wt,()=>{R(this,Me,void 0),I(this,Z)===this.CONNECTING&&pe(this,oe,Pt).call(this)});try{if(t instanceof URL)R(this,_e,t);else if(typeof t=="string")R(this,_e,new URL(t,Us()));else throw new Error("Invalid URL")}catch{throw Ms("An invalid or illegal string was specified")}R(this,Ue,Ps({onEvent:I(this,Ut),onRetry:I(this,Dt)})),R(this,Z,this.CONNECTING),R(this,Be,3e3),R(this,at,(s=n==null?void 0:n.fetch)!=null?s:globalThis.fetch),R(this,ct,(r=n==null?void 0:n.messageEvent)!=null?r:globalThis.MessageEvent),R(this,ot,(o=n==null?void 0:n.withCredentials)!=null?o:!1),pe(this,oe,Pt).call(this)}get readyState(){return I(this,Z)}get url(){return I(this,_e).href}get withCredentials(){return I(this,ot)}get onerror(){return I(this,De)}set onerror(t){R(this,De,t)}get onmessage(){return I(this,Ne)}set onmessage(t){R(this,Ne,t)}get onopen(){return I(this,Ge)}set onopen(t){R(this,Ge,t)}addEventListener(t,n,s){const r=n;super.addEventListener(t,r,s)}removeEventListener(t,n,s){const r=n;super.removeEventListener(t,r,s)}close(){I(this,Me)&&clearTimeout(I(this,Me)),I(this,Z)!==this.CLOSED&&(I(this,we)&&I(this,we).abort(),R(this,Z,this.CLOSED),R(this,we,void 0))}}Z=new WeakMap,_e=new WeakMap,je=new WeakMap,ot=new WeakMap,at=new WeakMap,ct=new WeakMap,Be=new WeakMap,Me=new WeakMap,Qe=new WeakMap,we=new WeakMap,Ue=new WeakMap,De=new WeakMap,Ne=new WeakMap,Ge=new WeakMap,oe=new WeakSet,Pt=function(){R(this,Z,this.CONNECTING),R(this,we,new AbortController),I(this,at)(I(this,_e),pe(this,oe,En).call(this)).then(I(this,jt)).catch(I(this,Mt))},jt=new WeakMap,Mt=new WeakMap,En=function(){var e;const t={mode:"cors",redirect:"follow",headers:{Accept:"text/event-stream",...I(this,Qe)?{"Last-Event-ID":I(this,Qe)}:void 0},cache:"no-store",signal:(e=I(this,we))==null?void 0:e.signal};return"window"in globalThis&&(t.credentials=this.withCredentials?"include":"same-origin"),t},Ut=new WeakMap,Dt=new WeakMap,Xe=function(e,t){var n;I(this,Z)!==this.CLOSED&&R(this,Z,this.CLOSED);const s=new kn("error",{code:t,message:e});(n=I(this,De))==null||n.call(this,s),this.dispatchEvent(s)},Nt=function(e,t){var n;if(I(this,Z)===this.CLOSED)return;R(this,Z,this.CONNECTING);const s=new kn("error",{code:t,message:e});(n=I(this,De))==null||n.call(this,s),this.dispatchEvent(s),R(this,Me,setTimeout(I(this,Wt),I(this,Be)))},Wt=new WeakMap,ae.CONNECTING=0,ae.OPEN=1,ae.CLOSED=2,Object.defineProperty(ae,Symbol.for("eventsource.supports-fetch-override"),{value:!0,writable:!1,configurable:!1,enumerable:!1});function Us(){const e="document"in globalThis?globalThis.document:void 0;return e&&typeof e=="object"&&"baseURI"in e&&typeof e.baseURI=="string"?e.baseURI:void 0}class _n extends Event{constructor(n,s){super(n);d(this,"data");d(this,"origin");d(this,"lastEventId");d(this,"source");d(this,"ports");this.data=(s==null?void 0:s.data)??null,this.origin=(s==null?void 0:s.origin)??"",this.lastEventId=(s==null?void 0:s.lastEventId)??"",this.source=(s==null?void 0:s.source)??null,this.ports=(s==null?void 0:s.ports)??[]}initMessageEvent(n,s,r,o,i,a,c,u){}}function Ds(e,t,n,s){let r=null,o=!1;const i=[],a=f=>{i.push(f),i.length>100&&i.shift(),r&&(r(),r=null)};e(a);const c=()=>(n(a),Promise.resolve({done:!0,value:void 0}));return t(()=>{o=!0,r&&r(),c()}),{next:async()=>{for(;;){if(s()==="closed"||o)return c();const f=i.shift();if(f)return{value:f,done:!1};await new Promise(m=>{r=m})}},return:c,throw(f){return n(a),Promise.reject(f)},[Symbol.asyncIterator](){return this}}}function ge(e){switch(e.readyState){case e.CLOSED:return"closed";case e.CONNECTING:return"connecting";case e.OPEN:return"open";default:return"connecting"}}function Ns(e){let t=null;return{...e,text(){return t||(t=e.text()),t},json(){return t||(t=e.text()),t.then(n=>JSON.parse(n))}}}function Cn(e){if(!e)return;const t={};for(const[n,s]of Object.entries(e))t[n]={startCursor:s["start-cursor"],endCursor:s["end-cursor"],hasNextPage:s["has-next-page?"],hasPreviousPage:s["has-previous-page?"]};return t}function Ws(e,t,n){let s,r=!1;const o=Ae(),i=new ae(`${n.apiURI}/admin/subscribe-query?local_connection_id=${o}`,{messageEvent:_n,fetch(h,v){return s=null,fetch(h,{...v,method:"POST",headers:n.headers,body:JSON.stringify({query:e,"inference?":n.inference,versions:{"@instantdb/admin":Ee,"@instantdb/core":Ee}})}).then(k=>(k.ok||(s=Ns(k)),k))}}),a=[],c=[],u=h=>{a.push(h)},l=h=>{a.splice(a.indexOf(h),1)},f=h=>{c.push(h)};t&&u(t);let p=null;function m(h){if(!r)for(const v of a)try{v(h)}catch(k){console.error("Error in subscribeQuery callback",k)}}function g(h){var v,k;switch(h.op){case"sse-init":{const K=h["machine-id"],xe=h["session-id"];p={machineId:K,sessionId:xe};break}case"add-query-ok":{m({type:"ok",data:h.result,pageInfo:Cn((v=h["result-meta"])==null?void 0:v["page-info"]),sessionInfo:p});break}case"refresh-ok":{h.computations.length&&m({type:"ok",data:h.computations[0]["instaql-result"],pageInfo:Cn((k=h.computations[0]["result-meta"])==null?void 0:k["page-info"]),sessionInfo:p});break}case"error":{m({type:"error",error:new le({body:h,status:h.status}),get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},sessionInfo:p});break}}}return i.onerror=h=>{if(s)s.text().then(v=>{let k={type:void 0,message:v};try{k=JSON.parse(v)}catch{}m({type:"error",error:new le({status:s.status,body:k}),get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},sessionInfo:p})});else{const v=()=>{m({type:"error",error:new le({status:h.code||500,body:{type:void 0,message:h.message||"Unknown error in subscribe query."}}),get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},sessionInfo:p})};if(i.readyState===ae.CLOSED){v();return}setTimeout(()=>{i.readyState!==ae.OPEN&&v()},5e3)}},i.onmessage=h=>{g(JSON.parse(h.data))},{close:()=>{r=!0;for(const h of c)try{h()}catch(v){console.error("Error in onClose callback",v)}i.close()},[Symbol.iterator]:()=>{throw new Error("subscribeQuery does not support synchronous iteration. Use `for await` instead.")},get sessionInfo(){return p},get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},[Symbol.asyncIterator]:Ds.bind(this,u,f,l,()=>1)}}var ye={};Object.defineProperty(ye,"__esModule",{value:!0});var Ls=ye.parseCookie=Rn;ye.parse=Rn,ye.stringifyCookie=Ks,ye.stringifySetCookie=ut,ye.serialize=ut,ye.parseSetCookie=qs,ye.stringifySetCookie=ut,ye.serialize=ut;const Tn=/^[\u0021-\u003A\u003C\u003E-\u007E]+$/,xn=/^[\u0021-\u003A\u003C-\u007E]*$/,Fs=/^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i,zs=/^[\u0020-\u003A\u003D-\u007E]*$/,Vs=/^-?\d+$/,Js=Object.prototype.toString,Hs=(()=>{const e=function(){};return e.prototype=Object.create(null),e})();function Rn(e,t){const n=new Hs,s=e.length;if(s<2)return n;const r=(t==null?void 0:t.decode)||An;let o=0;do{const i=Ft(e,o,s);if(i===-1)break;const a=Lt(e,o,s);if(i>a){o=e.lastIndexOf(";",i-1)+1;continue}const c=Se(e,o,i);n[c]===void 0&&(n[c]=r(Se(e,i+1,a))),o=a+1}while(o<s);return n}function Ks(e,t){const n=(t==null?void 0:t.encode)||encodeURIComponent,s=[];for(const r of Object.keys(e)){const o=e[r];if(o===void 0)continue;if(!Tn.test(r))throw new TypeError(`cookie name is invalid: ${r}`);const i=n(o);if(!xn.test(i))throw new TypeError(`cookie val is invalid: ${o}`);s.push(`${r}=${i}`)}return s.join("; ")}function ut(e,t,n){const s=typeof e=="object"?e:{...n,name:e,value:String(t)},r=typeof t=="object"?t:n,o=(r==null?void 0:r.encode)||encodeURIComponent;if(!Tn.test(s.name))throw new TypeError(`argument name is invalid: ${s.name}`);const i=s.value?o(s.value):"";if(!xn.test(i))throw new TypeError(`argument val is invalid: ${s.value}`);let a=s.name+"="+i;if(s.maxAge!==void 0){if(!Number.isInteger(s.maxAge))throw new TypeError(`option maxAge is invalid: ${s.maxAge}`);a+="; Max-Age="+s.maxAge}if(s.domain){if(!Fs.test(s.domain))throw new TypeError(`option domain is invalid: ${s.domain}`);a+="; Domain="+s.domain}if(s.path){if(!zs.test(s.path))throw new TypeError(`option path is invalid: ${s.path}`);a+="; Path="+s.path}if(s.expires){if(!Bs(s.expires)||!Number.isFinite(s.expires.valueOf()))throw new TypeError(`option expires is invalid: ${s.expires}`);a+="; Expires="+s.expires.toUTCString()}if(s.httpOnly&&(a+="; HttpOnly"),s.secure&&(a+="; Secure"),s.partitioned&&(a+="; Partitioned"),s.priority)switch(typeof s.priority=="string"?s.priority.toLowerCase():void 0){case"low":a+="; Priority=Low";break;case"medium":a+="; Priority=Medium";break;case"high":a+="; Priority=High";break;default:throw new TypeError(`option priority is invalid: ${s.priority}`)}if(s.sameSite)switch(typeof s.sameSite=="string"?s.sameSite.toLowerCase():s.sameSite){case!0:case"strict":a+="; SameSite=Strict";break;case"lax":a+="; SameSite=Lax";break;case"none":a+="; SameSite=None";break;default:throw new TypeError(`option sameSite is invalid: ${s.sameSite}`)}return a}function qs(e,t){const n=(t==null?void 0:t.decode)||An,s=e.length,r=Lt(e,0,s),o=Ft(e,0,r),i=o===-1?{name:"",value:n(Se(e,0,r))}:{name:Se(e,0,o),value:n(Se(e,o+1,r))};let a=r+1;for(;a<s;){const c=Lt(e,a,s),u=Ft(e,a,c),l=u===-1?Se(e,a,c):Se(e,a,u),f=u===-1?void 0:Se(e,u+1,c);switch(l.toLowerCase()){case"httponly":i.httpOnly=!0;break;case"secure":i.secure=!0;break;case"partitioned":i.partitioned=!0;break;case"domain":i.domain=f;break;case"path":i.path=f;break;case"max-age":f&&Vs.test(f)&&(i.maxAge=Number(f));break;case"expires":if(!f)break;const p=new Date(f);Number.isFinite(p.valueOf())&&(i.expires=p);break;case"priority":if(!f)break;const m=f.toLowerCase();(m==="low"||m==="medium"||m==="high")&&(i.priority=m);break;case"samesite":if(!f)break;const g=f.toLowerCase();(g==="lax"||g==="strict"||g==="none")&&(i.sameSite=g);break}a=c+1}return i}function Lt(e,t,n){const s=e.indexOf(";",t);return s===-1?n:s}function Ft(e,t,n){const s=e.indexOf("=",t);return s<n?s:-1}function Se(e,t,n){let s=t,r=n;do{const o=e.charCodeAt(s);if(o!==32&&o!==9)break}while(++s<r);for(;r>s;){const o=e.charCodeAt(r-1);if(o!==32&&o!==9)break;r--}return e.slice(s,r)}function An(e){if(e.indexOf("%")===-1)return e;try{return decodeURIComponent(e)}catch{return e}}function Bs(e){return Js.call(e)==="[object Date]"}const Qs={"https://api.instantdb.com":{keys:[{kty:"OKP",crv:"Ed25519",alg:"EdDSA",use:"sig",kid:"1034696293",x:"N-C41432STKAKkXAWmeIOXMnZcGRR1b9u1L3bTVqI_o"}]},"http://localhost:8888":{keys:[{kty:"OKP",crv:"Ed25519",alg:"EdDSA",use:"sig",kid:"503090235",x:"qrSkwDaMITRMF9nOgpueqxgaAiuFmJperYE3mkyl8Ow"}]}};function Gs(e){if(e.kty==="OKP"&&e.crv==="Ed25519")return{name:"Ed25519"};if(e.kty==="EC")return{name:"ECDSA",namedCurve:e.crv};if(e.kty==="RSA")return{name:"RSASSA-PKCS1-v1_5",hash:{RS256:"SHA-256",RS384:"SHA-384",RS512:"SHA-512"}[e.alg]||"SHA-256"};throw new Error(`Unsupported JWK configuration: kty=${e.kty}, crv=${e.crv}`)}async function Xs(e){const t=Gs(e),n=await crypto.subtle.importKey("jwk",e,t,!1,["verify"]);return{alg:t,key:n}}function Ys(e,t,n,s){return crypto.subtle.verify(e,t,n,s)}function Zs(e){const t=new Uint8Array(Math.ceil(e.length/2));for(let n=0;n<t.length;n++)t[n]=parseInt(e.substring(n*2,n*2+2),16);return t}function er(e){let t,n,s;for(const o of e.split(",")){const[i,a]=o.split("=");switch(i){case"t":{t=a;break}case"kid":{n=a;break}case"v1":{s=a;break}}}const r=[];if(t||r.push("t"),n||r.push("kid"),s||r.push("v1"),r.length||!t||!n||!s)throw new C("Invalid Instant-Signature header.",{header:e,missingKeys:r});return{t,kid:n,v1:s}}function tr(e,t,n){if(Math.floor(e.getTime()/1e3)-parseInt(t,10)>n)throw new C("Webhook signature is too old",{tolerance:n,receivedAt:e,t})}const Pn={},nr=300;async function sr(e,t){const n=await t.text();try{const s=JSON.parse(n);return e(new le({status:t.status,body:s}))}catch{return e(new le({status:t.status,body:{type:void 0,message:n}}))}}const rr=async(e,t)=>{const n={...(t==null?void 0:t.headers)||{},"Instant-Core-Version":Ee},s=await fetch(e,{...t,headers:n});return s.status===200?s.json():sr(r=>Promise.reject(r),s)};function jn(e){return e?new Date(e):null}function We(e){return{id:e.id,sink:e.sink,etypes:e.etypes??[],actions:e.actions,status:e.status,disabledReason:e.disabled_reason??null,createdAt:new Date(e.created_at),updatedAt:new Date(e.updated_at)}}function ir(e){return{attemptAt:jn(e["attempt-at"]),durationMs:e["duration-ms"]??null,success:e["success?"]??null,statusCode:e["status-code"]??null,responseText:e["response-text"]??null,errorType:e["error-type"]??null,errorMessage:e["error-message"]??null}}function zt(e){return{isn:e.isn,status:e.status,attempts:e.attempts?e.attempts.map(ir):null,nextAttemptAfter:jn(e.next_attempt_after),createdAt:new Date(e.created_at),updatedAt:new Date(e.updated_at)}}class or{constructor(t){L(this,ne);L(this,G);L(this,Ye);L(this,Le);L(this,Fe);L(this,Ze);B(this,G,t.appId),B(this,Ye,t.apiURI),B(this,Le,t.token),B(this,Fe,t.withAuth),B(this,Ze,t.jsonFetch)}async list(){return((await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks`)).webhooks||[]).map(We)}async create(t){const n=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks`,{method:"POST",body:t});return We(n.webhook)}async update(t,n){const s=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}`,{method:"POST",body:n});return We(s.webhook)}async delete(t){const n=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}`,{method:"DELETE"});return We(n.webhook)}async enable(t){const n=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/enable`,{method:"POST",body:{}});return We(n.webhook)}async disable(t,n){const s=n!=null&&n.reason?{reason:n.reason}:{},r=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/disable`,{method:"POST",body:s});return We(r.webhook)}async listEvents(t,n){var o,i,a;const s=n!=null&&n.after?`?after=${encodeURIComponent(n.after)}`:"",r=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/events${s}`);return{events:(r.events||[]).map(zt),pageInfo:{startCursor:((o=r.pageInfo)==null?void 0:o.startCursor)??null,endCursor:((i=r.pageInfo)==null?void 0:i.endCursor)??null,hasNextPage:!!((a=r.pageInfo)!=null&&a.hasNextPage)}}}async getEvent(t,n){const s=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/events/${n}`);return zt(s.event)}async getPayload(t,n){return j(this,ne,fe).call(this,`/webhooks/payload/${y(this,G)}/${t}/${n}`)}async resendEvent(t,n){const s=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/events/${n}`,{method:"POST",body:{}});return zt(s.event)}}G=new WeakMap,Ye=new WeakMap,Le=new WeakMap,Fe=new WeakMap,Ze=new WeakMap,ne=new WeakSet,fe=function(t,n){if(!y(this,G))throw new C("appId is required to manage webhooks. Pass it to the Webhooks constructor.");const s=r=>{const o={method:n==null?void 0:n.method,headers:{authorization:`Bearer ${r}`,"content-type":"application/json"}};return(n==null?void 0:n.body)!==void 0&&(o.body=JSON.stringify(n.body)),y(this,Ze).call(this,`${y(this,Ye)}${t}`,o)};if(y(this,Fe))return y(this,Fe).call(this,s);if(!y(this,Le))throw new C("A token is required to manage webhooks. Pass `adminToken` or `token` to the Webhooks constructor.");return s(y(this,Le))};const Ht=class Ht{constructor(t,n){d(this,"appId");d(this,"schema");L(this,et);d(this,"apiURI");L(this,Ce);d(this,"manager");this.appId=t.appId,this.schema=t.schema,B(this,et,t.adminToken||t.token),this.apiURI=t.apiURI||"https://api.instantdb.com",B(this,Ce,n||rr),this.manager=new or({appId:this.appId,apiURI:this.apiURI,token:y(this,et),withAuth:t.withAuth,jsonFetch:y(this,Ce)})}static helpers(){function t(...s){if(s.length===2)return{$default:s[1]};const[r,o,i]=s;return{[r]:{[o]:i}}}function n(...s){const r={};for(const o of s)for(const i of Object.keys(o))i==="$default"?r.$default=o.$default:r[i]={...r[i],...o[i]};return r}return{typedHandlers:t,combineHandlers:n}}helpers(){return Ht.helpers()}async fetchJwks(){return await y(this,Ce).call(this,`${this.apiURI}/.well-known/webhooks/jwks.json`)}async keyOfKid(t){var i,a,c;const n=`${this.apiURI}:${t}`,s=Pn[n];if(s)return s;const r=((i=Qs[this.apiURI])==null?void 0:i.keys.find(u=>u.kid===t))||((c=(a=await this.fetchJwks())==null?void 0:a.keys)==null?void 0:c.find(u=>u.kid===t));if(!r)throw new C("Could not find matching signing key",{kid:t});const o=await Xs(r);return Pn[n]=o,o}async validate(t,n,s){const r=(s==null?void 0:s.receivedAt)||new Date,{t:o,kid:i,v1:a}=er(t),c=(s==null?void 0:s.tolerance)??nr;tr(r,o,c);const{alg:u,key:l}=await this.keyOfKid(i),f=typeof n=="function"?await n():n,p=new TextEncoder().encode(`${o}.${f}`);if(!await Ys(u,l,Zs(a),p))throw new C("Instant Signature did not validate",{header:t});const g=JSON.parse(f);if(typeof g!="object"||typeof g.payloadUrl!="string"||typeof g.token!="string")throw new C("Invalid webhook body, expected an object with payloadUrl and token fields",{body:g});return g}async validateRequest(t,n){const s=t.headers.get("instant-signature");if(!s)throw new C("Request is missing Instant-Signature header");return this.validate(s,()=>t.text(),n)}fetchPayloads({payloadUrl:t,token:n}){return y(this,Ce).call(this,t,{headers:{Authorization:`Bearer ${n}`,accept:"application/json"}})}async processPayload(t,n){var r,o;const s=[];for(const i of n.data){const{etype:a,action:c}=i,u=((r=t==null?void 0:t[a])==null?void 0:r[c])||((o=t==null?void 0:t[a])==null?void 0:o.$default)||(t==null?void 0:t.$default);u&&s.push(u(i))}await Promise.all(s)}async processRequest(t,n,s){const r=await this.validateRequest(n,s),o=await this.fetchPayloads(r);await this.processPayload(t,o)}async processNodeRequest(t,n,s){let r,o=!1,i=(s==null?void 0:s.body)??n.rawBody??n.body;if(i!=null&&typeof i.then=="function"&&(i=await i),typeof i=="string")r=i;else if(i instanceof Uint8Array)r=new TextDecoder("utf-8").decode(i);else if(i!=null&&typeof i=="object")try{r=JSON.stringify(i),o=!0}catch{throw new C("Webhook request body has already been parsed and could not be re-serialized. Configure this route to receive the raw request body instead of parsed JSON.")}else if(n[Symbol.asyncIterator]){const f=new TextEncoder,p=[];for await(const h of n)p.push(typeof h=="string"?f.encode(h):h);let m=0;for(const h of p)m+=h.byteLength;const g=new Uint8Array(m);let w=0;for(const h of p)g.set(h,w),w+=h.byteLength;r=new TextDecoder("utf-8").decode(g)}else throw new C("Could not read the webhook request body. Pass a Node IncomingMessage with an unconsumed stream, or set `req.body` to the raw bytes (Buffer/Uint8Array) or string.");const a=typeof n.headers.host=="string"?n.headers.host:"localhost",c=new URL(n.url??"/",`https://${a}`),u=new Headers;for(const[f,p]of Object.entries(n.headers))typeof p=="string"?u.set(f,p):Array.isArray(p)&&u.set(f,p.join(", "));const l=new Request(c,{method:n.method??"POST",headers:u,body:r});try{await this.processRequest(t,l,s)}catch(f){throw o&&f instanceof C&&f.message==="Instant Signature did not validate"?new C("Webhook signature did not validate. The request body was re-serialized from a parsed JSON object, which can produce different bytes than the server signed. Configure this route to receive the raw request body instead of parsed JSON.",{hint:f.hint}):f}}};et=new WeakMap,Ce=new WeakMap;let Vt=Ht;function ar(e){const t={apiURI:"https://api.instantdb.com"},n={...t,...e};return n.apiURI||(n.apiURI=t.apiURI),n}function cr(e,t){return"email"in t?e["as-email"]=t.email:"token"in t?e["as-token"]=t.token:"guest"in t&&(e["as-guest"]="true"),e}function ur(e,t){if(!(t&&("token"in t||"guest"in t))&&!e.adminToken)throw t&&"email"in t?new Error("Admin token required. To impersonate users with an email you must pass `adminToken` to `init`."):new Error("Admin token required. To run this operation pass `adminToken` to `init`, or use `db.asUser`.")}function M(e,t){ur(e,t);const{adminToken:n,appId:s}=e,r={"content-type":"application/json","app-id":s};return n&&(r.authorization=`Bearer ${n}`),t?cr(r,t):r}function fr(){return fetch.__nextPatched&&!globalThis[Symbol.for("next-patch")]}function dr(){return fr()?{cache:"no-store"}:{}}async function lr(e,t){const n=await t.text();try{const s=JSON.parse(n);return e(new le({status:t.status,body:s}))}catch{return e(new le({status:t.status,body:{type:void 0,message:n}}))}}async function U(e,t){const n=dr(),s={...(t==null?void 0:t.headers)||{},"Instant-Admin-Version":Ee,"Instant-Core-Version":Ee},r=await fetch(e,{...n,...t,headers:s});if(r.status===200){const o=await r.json();return Promise.resolve(o)}return lr(o=>Promise.reject(o),r)}function hr(e){var t,n,Fn;return t=class{constructor(o){L(this,n);d(this,"source");d(this,"url");this.url=o,this.source=j(this,n,Fn).call(this,o)}get onopen(){return this.source.onopen}set onopen(o){this.source.onopen=o}get onmessage(){return this.source.onmessage}set onmessage(o){this.source.onmessage=o}get onerror(){return this.source.onerror}set onerror(o){this.source.onerror=o}get readyState(){return this.source.readyState}close(){this.source.close()}},n=new WeakSet,Fn=function(o){return new ae(o,{messageEvent:_n,fetch(a,c){return fetch(a,{...c,method:"POST",headers:e.headers,body:JSON.stringify({"inference?":e.inference,versions:{"@instantdb/admin":Ee,"@instantdb/core":Ee}})})}})},d(t,"OPEN",ae.OPEN),d(t,"CONNECTING",ae.CONNECTING),d(t,"CLOSED",ae.CLOSED),t}function pr(e){var n,s;(!e.appId||!A(e.appId))&&console.warn("warning: Instant Admin DB must be initialized with a valid appId. Received: "+JSON.stringify(e.appId));const t={...e,appId:(n=e.appId)==null?void 0:n.trim(),adminToken:(s=e.adminToken)==null?void 0:s.trim(),useDateObjects:e.useDateObjects??!1};return new Jt(t)}function Mn(e){return(Array.isArray(e)?e:[e]).flatMap(ps)}class yr{constructor(t){d(this,"config");this.config=t}async getPresence(t,n){return(await U(`${this.config.apiURI}/admin/rooms/presence?app_id=${this.config.appId}&room-type=${String(t)}&room-id=${n}`,{method:"GET",headers:M(this.config)})).sessions||{}}}class mr{constructor(t){d(this,"config");d(this,"generateMagicCode",async t=>U(`${this.config.apiURI}/admin/magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t})}));d(this,"sendMagicCode",async t=>U(`${this.config.apiURI}/admin/send_magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t})}));d(this,"verifyMagicCode",async(t,n)=>{const{user:s}=await U(`${this.config.apiURI}/admin/verify_magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t,code:n})});return s});d(this,"checkMagicCode",async(t,n,s)=>{const r=await U(`${this.config.apiURI}/admin/verify_magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t,code:n,...s!=null&&s.extraFields?{"extra-fields":s.extraFields}:{}})});return{user:r.user,created:r.created}});d(this,"verifyToken",async t=>(await U(`${this.config.apiURI}/runtime/auth/verify_refresh_token?app_id=${this.config.appId}`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":this.config.appId,"refresh-token":t})})).user);d(this,"getUser",async t=>{const n=Object.entries(t).map(([r,o])=>`${r}=${encodeURIComponent(o)}`).join("&");return(await U(`${this.config.apiURI}/admin/users?app_id=${this.config.appId}&${n}`,{method:"GET",headers:M(this.config)})).user});d(this,"deleteUser",async t=>{const n=Object.entries(t).map(([r,o])=>`${r}=${o}`);return(await U(`${this.config.apiURI}/admin/users?app_id=${this.config.appId}&${n}`,{method:"DELETE",headers:M(this.config)})).deleted});d(this,"getUserFromRequest",async(t,n)=>{const s=t.headers.get("cookie")||"",r=Ls(s),o="instant_user_"+this.config.appId;if(!r[o])return null;const i=r[o],a=JSON.parse(i);return a!=null&&a.refresh_token?n!=null&&n.disableValidation?a:await this.verifyToken(a.refresh_token):null});this.config=t,this.createToken=this.createToken.bind(this)}async createToken(t){const n=typeof t=="string"?{email:t}:t;return(await U(`${this.config.apiURI}/admin/refresh_tokens?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify(n)})).user.refresh_token}async signOut(t){const n=typeof t=="string"?{email:t}:t,s=this.config;await U(`${s.apiURI}/admin/sign_out?app_id=${this.config.appId}`,{method:"POST",headers:M(s),body:JSON.stringify(n)})}}const Un=e=>e&&typeof e=="object"&&typeof e.pipe=="function"&&typeof e.read=="function",br=e=>e&&typeof e.getReader=="function";class Dn{constructor(t,n){d(this,"config");d(this,"impersonationOpts");d(this,"uploadFile",async(t,n,s={})=>{const r={...M(this.config,this.impersonationOpts),path:t};s.contentDisposition&&(r["content-disposition"]=s.contentDisposition),delete r["content-type"],s.contentType&&(r["content-type"]=s.contentType);let o;if(Un(n)&&(o="half"),Un(n)||br(n)){if(!s.fileSize)throw new Error("fileSize is required in metadata when uploading streams");r["content-length"]=s.fileSize.toString()}let i={method:"PUT",headers:r,body:n,...o&&{duplex:o}};return U(`${this.config.apiURI}/admin/storage/upload?app_id=${this.config.appId}`,i)});d(this,"delete",async t=>U(`${this.config.apiURI}/admin/storage/files?app_id=${this.config.appId}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:M(this.config,this.impersonationOpts)}));d(this,"deleteMany",async t=>U(`${this.config.apiURI}/admin/storage/files/delete?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify({filenames:t})}));d(this,"upload",async(t,n,s={})=>{const{data:r}=await U(`${this.config.apiURI}/admin/storage/signed-upload-url?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({app_id:this.config.appId,filename:t})}),o={},i=s.contentType;i&&(o["Content-Type"]=i);const{ok:a}=await fetch(r,{method:"PUT",body:n,headers:o});return a});d(this,"list",async()=>{const{data:t}=await U(`${this.config.apiURI}/admin/storage/files?app_id=${this.config.appId}`,{method:"GET",headers:M(this.config)});return t});d(this,"getDownloadUrl",async t=>{const{data:n}=await U(`${this.config.apiURI}/admin/storage/signed-download-url?app_id=${this.config.appId}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:M(this.config)});return n});this.config=t,this.impersonationOpts=n}}class wr{constructor(t){L(this,ze);d(this,"createReadStream",t=>y(this,ze).call(this).createReadStream(t));d(this,"createWriteStream",t=>y(this,ze).call(this).createWriteStream(t));B(this,ze,t)}}ze=new WeakMap;function gr(e){return{info:e?(...t)=>console.info(...t):()=>{},debug:e?(...t)=>console.debug(...t):()=>{},error:e?(...t)=>console.error(...t):()=>{}}}const Kt=class Kt{constructor(t){L(this,z);d(this,"config");d(this,"auth");d(this,"storage");d(this,"streams");d(this,"rooms");d(this,"impersonationOpts");d(this,"webhooks");L(this,H,null);L(this,Te,0);L(this,X,null);L(this,Y);d(this,"tx",dn());d(this,"asUser",t=>{const n=new Kt({...this.config});return n.impersonationOpts=t,n.storage=new Dn(this.config,t),n});d(this,"query",(t,n={})=>{t&&n&&"ruleParams"in n&&(t={$$ruleParams:n.ruleParams,...t}),this.config.disableValidation||mn(t,this.config.schema);const s=n.fetchOpts||{},r=s.headers||{};return U(`${this.config.apiURI}/admin/query?app_id=${this.config.appId}`,{...s,method:"POST",headers:{...r,...M(this.config,this.impersonationOpts)},body:JSON.stringify({query:t,"inference?":!!this.config.schema})})});d(this,"transact",t=>(this.config.disableValidation||ks(t,this.config.schema),U(`${this.config.apiURI}/admin/transact?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify({steps:Mn(t),"throw-on-missing-attrs?":!!this.config.schema})})));d(this,"debugQuery",async(t,n)=>{t&&n&&"ruleParams"in n&&(t={$$ruleParams:n.ruleParams,...t});const s={query:t,"rules-override":n==null?void 0:n.rules,"inference?":(n==null?void 0:n.cardinalityInference)??!!this.config.schema};n!=null&&n.ip&&(s["ip-override"]=n.ip),n!=null&&n.origin&&(s["origin-override"]=n.origin);const r=await U(`${this.config.apiURI}/admin/query_perms_check?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify(s)});return{result:r.result,checkResults:r["check-results"]}});d(this,"debugTransact",(t,n)=>{const s={steps:Mn(t),"rules-override":n==null?void 0:n.rules,"dangerously-commit-tx":n==null?void 0:n.__dangerouslyCommit};return n!=null&&n.ip&&(s["ip-override"]=n.ip),n!=null&&n.origin&&(s["origin-override"]=n.origin),U(`${this.config.apiURI}/admin/transact_perms_check?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify(s)})});L(this,lt,t=>{var n;if(t.target!==y(this,H)){y(this,Y).info("[socket][open]",t.target.id,"skip; this is no longer the current transport");return}y(this,Y).info("[socket][open]",t.target.id),B(this,Te,0),(n=y(this,X))==null||n.onConnectionStatusChange("authenticated")});L(this,ht,t=>{var n;if(t.target!==y(this,H)){y(this,Y).info("[socket][close]",t.target.id,"skip; this is no longer the current transport");return}y(this,Y).info("[socket][close]",t.target.id),(n=y(this,X))==null||n.onConnectionStatusChange("closed"),y(this,H)&&(B(this,H,null),j(this,z,Gt).call(this)||(setTimeout(()=>j(this,z,bt).call(this),y(this,Te)),B(this,Te,Math.min(15e3,Math.max(y(this,Te),500)*2))))});L(this,pt,t=>{var n;if(t.target!==y(this,H)){y(this,Y).info("[socket][error]",t.target.id,"skip; this is no longer the current transport");return}y(this,Y).info("[socket][error]",t.target.id),(n=y(this,X))==null||n.onConnectionStatusChange("closed")});L(this,yt,t=>{var s,r,o,i,a,c;if(t.target!==y(this,H)){y(this,Y).info("[socket][message]",t.target.id,"skip; this is no longer the current transport");return}const n=t.message;switch(y(this,Y).info("[receive]",n),n.op){case"start-stream-ok":{(s=y(this,X))==null||s.onStartStreamOk(n);break}case"stream-flushed":{(r=y(this,X))==null||r.onStreamFlushed(n);break}case"append-failed":{(o=y(this,X))==null||o.onAppendFailed(n);break}case"stream-append":{(i=y(this,X))==null||i.onStreamAppend(n);break}case"error":{switch((a=n["original-event"])==null?void 0:a.op){case"start-stream":case"append-stream":case"subscribe-stream":case"unsubscribe-stream":{(c=y(this,X))==null||c.onRecieveError(n);break}}break}}j(this,z,Kn).call(this)});this.config=ar(t),this.auth=new mr(this.config),this.storage=new Dn(this.config,this.impersonationOpts),this.streams=new wr(j(this,z,Hn).bind(this)),this.rooms=new yr(this.config),this.webhooks=new Vt(this.config,U),B(this,Y,gr(!!this.config.verbose))}subscribeQuery(t,n,s={}){t&&s&&"ruleParams"in s&&(t={$$ruleParams:s.ruleParams,...t}),this.config.disableValidation||mn(t,this.config.schema);const i={...(s.fetchOpts||{}).headers||{},...M(this.config,this.impersonationOpts)},a=!!this.config.schema;return Ws(t,n,{headers:i,inference:a,apiURI:this.config.apiURI})}};H=new WeakMap,Te=new WeakMap,X=new WeakMap,Y=new WeakMap,z=new WeakSet,zn=function(){y(this,H)&&y(this,H).close();const t={...M(this.config,this.impersonationOpts)},n=!!this.config.schema,s=hr({headers:t,inference:n}),r=new Os(s,`${this.config.apiURI}/admin/sse?app_id=${this.config.appId}`,`${this.config.apiURI}/admin/sse/push?app_id=${this.config.appId}`);return r.onopen=y(this,lt),r.onmessage=y(this,yt),r.onclose=y(this,ht),r.onerror=y(this,pt),B(this,H,r),r},bt=function(){return y(this,H)||j(this,z,zn).call(this)},Vn=function(t,n){const s=j(this,z,bt).call(this);y(this,Y).info("[send]",t,n,{isOpen:s.isOpen()}),s.isOpen()&&s.send({"client-event-id":t,...n})},Jn=function(){j(this,z,bt).call(this);const t=new Ts({WStream:this.config.WritableStream||WritableStream,RStream:this.config.ReadableStream||ReadableStream,trySend:(n,s)=>{j(this,z,Vn).call(this,n,s)},log:y(this,Y)});return B(this,X,t),t},Hn=function(){return y(this,X)||j(this,z,Jn).call(this)},lt=new WeakMap,ht=new WeakMap,pt=new WeakMap,Gt=function(){return!y(this,X)||!y(this,X).hasActiveStreams()},Kn=function(){if(y(this,H)&&j(this,z,Gt).call(this)){const t=y(this,H);y(this,Y).info("cleaning up unused socket",t.id),B(this,H,null),t.close()}},yt=new WeakMap;let Jt=Kt;var ft={};function dt(e){let t=e;return new TransformStream({transform(n,s){if(!t){s.enqueue(n);return}if(t>n.length){t-=n.length;return}const r=n.slice(t);t=0,s.enqueue(r)}})}function Sr(e){const t=e.appId||ft.INSTANT_APP_ID||ft.NEXT_PUBLIC_INSTANT_APP_ID;if(!t)throw new Error("Missing appId. Pass it as an argument to createResumableStreamContext or set either the INSTANT_APP_ID or NEXT_PUBLIC_INSTANT_APP_ID environment variable.");const n=e.adminToken||ft.INSTANT_APP_ADMIN_TOKEN;if(!n)throw new Error("Missing adminToken. Pass it as an argument to createResumableStreamContext or set the INSTANT_APP_ADMIN_TOKEN environment variable.");const s={appId:t,adminToken:n},r=e.apiURI||ft.INSTANT_API_URI;r&&(s.apiURI=r),e.verbose&&(s.verbose=e.verbose);const o=pr(s);async function i(l,f,p){const m=o.streams.createWriteStream({clientId:l,waitUntil:e.waitUntil??void 0});try{const g=await m.streamId();f().pipeTo(m);const h=o.streams.createReadStream({streamId:g});return p?h.pipeThrough(dt(p)):h}catch{const w=o.streams.createReadStream({clientId:l});return p?w.pipeThrough(dt(p)):w}}async function a(l,f){var m,g,w;const p=o.streams.createReadStream({clientId:l});try{await p.streamId()}catch(h){if(h instanceof C&&((w=(g=(m=h.hint)==null?void 0:m.errors)==null?void 0:g[0])==null?void 0:w.message)==="Stream is missing.")return;throw h}return f?p.pipeThrough(dt(f)):p}async function c(l,f,p){const m=f(),g=o.streams.createWriteStream({clientId:l,waitUntil:e.waitUntil??void 0});await g.streamId(),m.pipeTo(g);const w=o.streams.createReadStream({clientId:l});return p?w.pipeThrough(dt(p)):w}async function u(l){var m;const f=await o.query({$streams:{$:{where:{clientId:l}}}}),p=(m=f==null?void 0:f.$streams)==null?void 0:m[0];return p!=null&&p.done?"DONE":p?!0:null}return{resumableStream:i,resumeExistingStream:a,createNewResumableStream:c,hasExistingStream:u}}$.createResumableStreamContext=Sr,Object.defineProperty($,Symbol.toStringTag,{value:"Module"})});
5
+ `&&s++}}return[t,n]}class vn extends Event{constructor(t,n){var s,r;super(t),this.code=(s=n==null?void 0:n.code)!=null?s:void 0,this.message=(r=n==null?void 0:n.message)!=null?r:void 0}[Symbol.for("nodejs.util.inspect.custom")](t,n,s){return s($n(this),n)}[Symbol.for("Deno.customInspect")](t,n){return t($n(this),n)}}function Ms(e){const t=globalThis.DOMException;return typeof t=="function"?new t(e,"SyntaxError"):new SyntaxError(e)}function Rt(e){return e instanceof Error?"errors"in e&&Array.isArray(e.errors)?e.errors.map(Rt).join(", "):"cause"in e&&e.cause instanceof Error?`${e}: ${Rt(e.cause)}`:e.message:`${e}`}function $n(e){return{type:e.type,message:e.message,code:e.code,defaultPrevented:e.defaultPrevented,cancelable:e.cancelable,timeStamp:e.timeStamp}}var On=e=>{throw TypeError(e)},At=(e,t,n)=>t.has(e)||On("Cannot "+n),I=(e,t,n)=>(At(e,t,"read from private field"),n?n.call(e):t.get(e)),N=(e,t,n)=>t.has(e)?On("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(e):t.set(e,n),R=(e,t,n,s)=>(At(e,t,"write to private field"),t.set(e,n),n),pe=(e,t,n)=>(At(e,t,"access private method"),n),Z,_e,je,ot,at,ct,Be,Me,Qe,we,Ue,De,Ne,Ge,oe,Pt,jt,Mt,En,Ut,Dt,Xe,Nt,Wt;class ae extends EventTarget{constructor(t,n){var s,r,o;super(),N(this,oe),this.CONNECTING=0,this.OPEN=1,this.CLOSED=2,N(this,Z),N(this,_e),N(this,je),N(this,ot),N(this,at),N(this,ct),N(this,Be),N(this,Me),N(this,Qe,null),N(this,we),N(this,Ue),N(this,De,null),N(this,Ne,null),N(this,Ge,null),N(this,jt,async i=>{var a;I(this,Ue).reset();const{body:c,redirected:u,status:l,headers:f}=i;if(l===204){pe(this,oe,Xe).call(this,"Server sent HTTP 204, not reconnecting",204),this.close();return}if(u?R(this,je,new URL(i.url)):R(this,je,void 0),l!==200){pe(this,oe,Xe).call(this,`Non-200 status code (${l})`,l);return}if(!(f.get("content-type")||"").startsWith("text/event-stream")){pe(this,oe,Xe).call(this,'Invalid content type, expected "text/event-stream"',l);return}if(I(this,Z)===this.CLOSED)return;R(this,Z,this.OPEN);const p=new Event("open");if((a=I(this,Ge))==null||a.call(this,p),this.dispatchEvent(p),typeof c!="object"||!c||!("getReader"in c)){pe(this,oe,Xe).call(this,"Invalid response body, expected a web ReadableStream",l),this.close();return}const m=new TextDecoder,g=c.getReader();let w=!0;do{const{done:h,value:k}=await g.read();k&&I(this,Ue).feed(m.decode(k,{stream:!h})),h&&(w=!1,I(this,Ue).reset(),pe(this,oe,Nt).call(this))}while(w)}),N(this,Mt,i=>{R(this,we,void 0),!(i.name==="AbortError"||i.type==="aborted")&&pe(this,oe,Nt).call(this,Rt(i))}),N(this,Ut,i=>{typeof i.id=="string"&&R(this,Qe,i.id);const a=new(I(this,ct))(i.event||"message",{data:i.data,origin:I(this,je)?I(this,je).origin:I(this,_e).origin,lastEventId:i.id||""});I(this,Ne)&&(!i.event||i.event==="message")&&I(this,Ne).call(this,a),this.dispatchEvent(a)}),N(this,Dt,i=>{R(this,Be,i)}),N(this,Wt,()=>{R(this,Me,void 0),I(this,Z)===this.CONNECTING&&pe(this,oe,Pt).call(this)});try{if(t instanceof URL)R(this,_e,t);else if(typeof t=="string")R(this,_e,new URL(t,Us()));else throw new Error("Invalid URL")}catch{throw Ms("An invalid or illegal string was specified")}R(this,Ue,Ps({onEvent:I(this,Ut),onRetry:I(this,Dt)})),R(this,Z,this.CONNECTING),R(this,Be,3e3),R(this,at,(s=n==null?void 0:n.fetch)!=null?s:globalThis.fetch),R(this,ct,(r=n==null?void 0:n.messageEvent)!=null?r:globalThis.MessageEvent),R(this,ot,(o=n==null?void 0:n.withCredentials)!=null?o:!1),pe(this,oe,Pt).call(this)}get readyState(){return I(this,Z)}get url(){return I(this,_e).href}get withCredentials(){return I(this,ot)}get onerror(){return I(this,De)}set onerror(t){R(this,De,t)}get onmessage(){return I(this,Ne)}set onmessage(t){R(this,Ne,t)}get onopen(){return I(this,Ge)}set onopen(t){R(this,Ge,t)}addEventListener(t,n,s){const r=n;super.addEventListener(t,r,s)}removeEventListener(t,n,s){const r=n;super.removeEventListener(t,r,s)}close(){I(this,Me)&&clearTimeout(I(this,Me)),I(this,Z)!==this.CLOSED&&(I(this,we)&&I(this,we).abort(),R(this,Z,this.CLOSED),R(this,we,void 0))}}Z=new WeakMap,_e=new WeakMap,je=new WeakMap,ot=new WeakMap,at=new WeakMap,ct=new WeakMap,Be=new WeakMap,Me=new WeakMap,Qe=new WeakMap,we=new WeakMap,Ue=new WeakMap,De=new WeakMap,Ne=new WeakMap,Ge=new WeakMap,oe=new WeakSet,Pt=function(){R(this,Z,this.CONNECTING),R(this,we,new AbortController),I(this,at)(I(this,_e),pe(this,oe,En).call(this)).then(I(this,jt)).catch(I(this,Mt))},jt=new WeakMap,Mt=new WeakMap,En=function(){var e;const t={mode:"cors",redirect:"follow",headers:{Accept:"text/event-stream",...I(this,Qe)?{"Last-Event-ID":I(this,Qe)}:void 0},cache:"no-store",signal:(e=I(this,we))==null?void 0:e.signal};return"window"in globalThis&&(t.credentials=this.withCredentials?"include":"same-origin"),t},Ut=new WeakMap,Dt=new WeakMap,Xe=function(e,t){var n;I(this,Z)!==this.CLOSED&&R(this,Z,this.CLOSED);const s=new vn("error",{code:t,message:e});(n=I(this,De))==null||n.call(this,s),this.dispatchEvent(s)},Nt=function(e,t){var n;if(I(this,Z)===this.CLOSED)return;R(this,Z,this.CONNECTING);const s=new vn("error",{code:t,message:e});(n=I(this,De))==null||n.call(this,s),this.dispatchEvent(s),R(this,Me,setTimeout(I(this,Wt),I(this,Be)))},Wt=new WeakMap,ae.CONNECTING=0,ae.OPEN=1,ae.CLOSED=2,Object.defineProperty(ae,Symbol.for("eventsource.supports-fetch-override"),{value:!0,writable:!1,configurable:!1,enumerable:!1});function Us(){const e="document"in globalThis?globalThis.document:void 0;return e&&typeof e=="object"&&"baseURI"in e&&typeof e.baseURI=="string"?e.baseURI:void 0}class _n extends Event{constructor(n,s){super(n);d(this,"data");d(this,"origin");d(this,"lastEventId");d(this,"source");d(this,"ports");this.data=(s==null?void 0:s.data)??null,this.origin=(s==null?void 0:s.origin)??"",this.lastEventId=(s==null?void 0:s.lastEventId)??"",this.source=(s==null?void 0:s.source)??null,this.ports=(s==null?void 0:s.ports)??[]}initMessageEvent(n,s,r,o,i,a,c,u){}}function Ds(e,t,n,s){let r=null,o=!1;const i=[],a=f=>{i.push(f),i.length>100&&i.shift(),r&&(r(),r=null)};e(a);const c=()=>(n(a),Promise.resolve({done:!0,value:void 0}));return t(()=>{o=!0,r&&r(),c()}),{next:async()=>{for(;;){if(s()==="closed"||o)return c();const f=i.shift();if(f)return{value:f,done:!1};await new Promise(m=>{r=m})}},return:c,throw(f){return n(a),Promise.reject(f)},[Symbol.asyncIterator](){return this}}}function ge(e){switch(e.readyState){case e.CLOSED:return"closed";case e.CONNECTING:return"connecting";case e.OPEN:return"open";default:return"connecting"}}function Ns(e){let t=null;return{...e,text(){return t||(t=e.text()),t},json(){return t||(t=e.text()),t.then(n=>JSON.parse(n))}}}function Cn(e){if(!e)return;const t={};for(const[n,s]of Object.entries(e))t[n]={startCursor:s["start-cursor"],endCursor:s["end-cursor"],hasNextPage:s["has-next-page?"],hasPreviousPage:s["has-previous-page?"]};return t}function Ws(e,t,n){let s,r=!1;const o=Ae(),i=new ae(`${n.apiURI}/admin/subscribe-query?local_connection_id=${o}`,{messageEvent:_n,fetch(h,k){return s=null,fetch(h,{...k,method:"POST",headers:n.headers,body:JSON.stringify({query:e,"inference?":n.inference,versions:{"@instantdb/admin":Ee,"@instantdb/core":Ee}})}).then(v=>(v.ok||(s=Ns(v)),v))}}),a=[],c=[],u=h=>{a.push(h)},l=h=>{a.splice(a.indexOf(h),1)},f=h=>{c.push(h)};t&&u(t);let p=null;function m(h){if(!r)for(const k of a)try{k(h)}catch(v){console.error("Error in subscribeQuery callback",v)}}function g(h){var k,v;switch(h.op){case"sse-init":{const K=h["machine-id"],xe=h["session-id"];p={machineId:K,sessionId:xe};break}case"add-query-ok":{m({type:"ok",data:h.result,pageInfo:Cn((k=h["result-meta"])==null?void 0:k["page-info"]),sessionInfo:p});break}case"refresh-ok":{h.computations.length&&m({type:"ok",data:h.computations[0]["instaql-result"],pageInfo:Cn((v=h.computations[0]["result-meta"])==null?void 0:v["page-info"]),sessionInfo:p});break}case"error":{m({type:"error",error:new le({body:h,status:h.status}),get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},sessionInfo:p});break}}}return i.onerror=h=>{if(s)s.text().then(k=>{let v={type:void 0,message:k};try{v=JSON.parse(k)}catch{}m({type:"error",error:new le({status:s.status,body:v}),get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},sessionInfo:p})});else{const k=()=>{m({type:"error",error:new le({status:h.code||500,body:{type:void 0,message:h.message||"Unknown error in subscribe query."}}),get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},sessionInfo:p})};if(i.readyState===ae.CLOSED){k();return}setTimeout(()=>{i.readyState!==ae.OPEN&&k()},5e3)}},i.onmessage=h=>{g(JSON.parse(h.data))},{close:()=>{r=!0;for(const h of c)try{h()}catch(k){console.error("Error in onClose callback",k)}i.close()},[Symbol.iterator]:()=>{throw new Error("subscribeQuery does not support synchronous iteration. Use `for await` instead.")},get sessionInfo(){return p},get readyState(){return ge(i)},get isClosed(){return ge(i)==="closed"},[Symbol.asyncIterator]:Ds.bind(this,u,f,l,()=>1)}}var ye={};Object.defineProperty(ye,"__esModule",{value:!0});var Ls=ye.parseCookie=Rn;ye.parse=Rn,ye.stringifyCookie=Ks,ye.stringifySetCookie=ut,ye.serialize=ut,ye.parseSetCookie=qs,ye.stringifySetCookie=ut,ye.serialize=ut;const Tn=/^[\u0021-\u003A\u003C\u003E-\u007E]+$/,xn=/^[\u0021-\u003A\u003C-\u007E]*$/,Fs=/^([.]?[a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)([.][a-z0-9]([a-z0-9-]{0,61}[a-z0-9])?)*$/i,zs=/^[\u0020-\u003A\u003D-\u007E]*$/,Vs=/^-?\d+$/,Js=Object.prototype.toString,Hs=(()=>{const e=function(){};return e.prototype=Object.create(null),e})();function Rn(e,t){const n=new Hs,s=e.length;if(s<2)return n;const r=(t==null?void 0:t.decode)||An;let o=0;do{const i=Ft(e,o,s);if(i===-1)break;const a=Lt(e,o,s);if(i>a){o=e.lastIndexOf(";",i-1)+1;continue}const c=Se(e,o,i);n[c]===void 0&&(n[c]=r(Se(e,i+1,a))),o=a+1}while(o<s);return n}function Ks(e,t){const n=(t==null?void 0:t.encode)||encodeURIComponent,s=[];for(const r of Object.keys(e)){const o=e[r];if(o===void 0)continue;if(!Tn.test(r))throw new TypeError(`cookie name is invalid: ${r}`);const i=n(o);if(!xn.test(i))throw new TypeError(`cookie val is invalid: ${o}`);s.push(`${r}=${i}`)}return s.join("; ")}function ut(e,t,n){const s=typeof e=="object"?e:{...n,name:e,value:String(t)},r=typeof t=="object"?t:n,o=(r==null?void 0:r.encode)||encodeURIComponent;if(!Tn.test(s.name))throw new TypeError(`argument name is invalid: ${s.name}`);const i=s.value?o(s.value):"";if(!xn.test(i))throw new TypeError(`argument val is invalid: ${s.value}`);let a=s.name+"="+i;if(s.maxAge!==void 0){if(!Number.isInteger(s.maxAge))throw new TypeError(`option maxAge is invalid: ${s.maxAge}`);a+="; Max-Age="+s.maxAge}if(s.domain){if(!Fs.test(s.domain))throw new TypeError(`option domain is invalid: ${s.domain}`);a+="; Domain="+s.domain}if(s.path){if(!zs.test(s.path))throw new TypeError(`option path is invalid: ${s.path}`);a+="; Path="+s.path}if(s.expires){if(!Bs(s.expires)||!Number.isFinite(s.expires.valueOf()))throw new TypeError(`option expires is invalid: ${s.expires}`);a+="; Expires="+s.expires.toUTCString()}if(s.httpOnly&&(a+="; HttpOnly"),s.secure&&(a+="; Secure"),s.partitioned&&(a+="; Partitioned"),s.priority)switch(typeof s.priority=="string"?s.priority.toLowerCase():void 0){case"low":a+="; Priority=Low";break;case"medium":a+="; Priority=Medium";break;case"high":a+="; Priority=High";break;default:throw new TypeError(`option priority is invalid: ${s.priority}`)}if(s.sameSite)switch(typeof s.sameSite=="string"?s.sameSite.toLowerCase():s.sameSite){case!0:case"strict":a+="; SameSite=Strict";break;case"lax":a+="; SameSite=Lax";break;case"none":a+="; SameSite=None";break;default:throw new TypeError(`option sameSite is invalid: ${s.sameSite}`)}return a}function qs(e,t){const n=(t==null?void 0:t.decode)||An,s=e.length,r=Lt(e,0,s),o=Ft(e,0,r),i=o===-1?{name:"",value:n(Se(e,0,r))}:{name:Se(e,0,o),value:n(Se(e,o+1,r))};let a=r+1;for(;a<s;){const c=Lt(e,a,s),u=Ft(e,a,c),l=u===-1?Se(e,a,c):Se(e,a,u),f=u===-1?void 0:Se(e,u+1,c);switch(l.toLowerCase()){case"httponly":i.httpOnly=!0;break;case"secure":i.secure=!0;break;case"partitioned":i.partitioned=!0;break;case"domain":i.domain=f;break;case"path":i.path=f;break;case"max-age":f&&Vs.test(f)&&(i.maxAge=Number(f));break;case"expires":if(!f)break;const p=new Date(f);Number.isFinite(p.valueOf())&&(i.expires=p);break;case"priority":if(!f)break;const m=f.toLowerCase();(m==="low"||m==="medium"||m==="high")&&(i.priority=m);break;case"samesite":if(!f)break;const g=f.toLowerCase();(g==="lax"||g==="strict"||g==="none")&&(i.sameSite=g);break}a=c+1}return i}function Lt(e,t,n){const s=e.indexOf(";",t);return s===-1?n:s}function Ft(e,t,n){const s=e.indexOf("=",t);return s<n?s:-1}function Se(e,t,n){let s=t,r=n;do{const o=e.charCodeAt(s);if(o!==32&&o!==9)break}while(++s<r);for(;r>s;){const o=e.charCodeAt(r-1);if(o!==32&&o!==9)break;r--}return e.slice(s,r)}function An(e){if(e.indexOf("%")===-1)return e;try{return decodeURIComponent(e)}catch{return e}}function Bs(e){return Js.call(e)==="[object Date]"}const Qs={"https://api.instantdb.com":{keys:[{kty:"OKP",crv:"Ed25519",alg:"EdDSA",use:"sig",kid:"1034696293",x:"N-C41432STKAKkXAWmeIOXMnZcGRR1b9u1L3bTVqI_o"}]},"http://localhost:8888":{keys:[{kty:"OKP",crv:"Ed25519",alg:"EdDSA",use:"sig",kid:"503090235",x:"qrSkwDaMITRMF9nOgpueqxgaAiuFmJperYE3mkyl8Ow"}]}};function Gs(e){if(e.kty==="OKP"&&e.crv==="Ed25519")return{name:"Ed25519"};if(e.kty==="EC")return{name:"ECDSA",namedCurve:e.crv};if(e.kty==="RSA")return{name:"RSASSA-PKCS1-v1_5",hash:{RS256:"SHA-256",RS384:"SHA-384",RS512:"SHA-512"}[e.alg]||"SHA-256"};throw new Error(`Unsupported JWK configuration: kty=${e.kty}, crv=${e.crv}`)}async function Xs(e){const t=Gs(e),n=await crypto.subtle.importKey("jwk",e,t,!1,["verify"]);return{alg:t,key:n}}function Ys(e,t,n,s){return crypto.subtle.verify(e,t,n,s)}function Zs(e){const t=new Uint8Array(Math.ceil(e.length/2));for(let n=0;n<t.length;n++)t[n]=parseInt(e.substring(n*2,n*2+2),16);return t}function er(e){let t,n,s;for(const o of e.split(",")){const[i,a]=o.split("=");switch(i){case"t":{t=a;break}case"kid":{n=a;break}case"v1":{s=a;break}}}const r=[];if(t||r.push("t"),n||r.push("kid"),s||r.push("v1"),r.length||!t||!n||!s)throw new C("Invalid Instant-Signature header.",{header:e,missingKeys:r});return{t,kid:n,v1:s}}function tr(e,t,n){if(Math.floor(e.getTime()/1e3)-parseInt(t,10)>n)throw new C("Webhook signature is too old",{tolerance:n,receivedAt:e,t})}const Pn={},nr=300;async function sr(e,t){const n=await t.text();try{const s=JSON.parse(n);return e(new le({status:t.status,body:s}))}catch{return e(new le({status:t.status,body:{type:void 0,message:n}}))}}const rr=async(e,t)=>{const n={...(t==null?void 0:t.headers)||{},"Instant-Core-Version":Ee},s=await fetch(e,{...t,headers:n});return s.status===200?s.json():sr(r=>Promise.reject(r),s)};function jn(e){return e?new Date(e):null}function We(e){return{id:e.id,sink:e.sink,namespaces:e.namespaces??[],actions:e.actions,status:e.status,disabledReason:e.disabled_reason??null,createdAt:new Date(e.created_at),updatedAt:new Date(e.updated_at)}}function ir(e){return{attemptAt:jn(e["attempt-at"]),durationMs:e["duration-ms"]??null,success:e["success?"]??null,statusCode:e["status-code"]??null,responseText:e["response-text"]??null,errorType:e["error-type"]??null,errorMessage:e["error-message"]??null}}function zt(e){return{isn:e.isn,status:e.status,attempts:e.attempts?e.attempts.map(ir):null,nextAttemptAfter:jn(e.next_attempt_after),createdAt:new Date(e.created_at),updatedAt:new Date(e.updated_at)}}class or{constructor(t){L(this,ne);L(this,G);L(this,Ye);L(this,Le);L(this,Fe);L(this,Ze);B(this,G,t.appId),B(this,Ye,t.apiURI),B(this,Le,t.token),B(this,Fe,t.withAuth),B(this,Ze,t.jsonFetch)}async list(){return((await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks`)).webhooks||[]).map(We)}async create(t){const n=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks`,{method:"POST",body:t});return We(n.webhook)}async update(t,n){const s=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}`,{method:"POST",body:n});return We(s.webhook)}async delete(t){const n=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}`,{method:"DELETE"});return We(n.webhook)}async enable(t){const n=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/enable`,{method:"POST",body:{}});return We(n.webhook)}async disable(t,n){const s=n!=null&&n.reason?{reason:n.reason}:{},r=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/disable`,{method:"POST",body:s});return We(r.webhook)}async listEvents(t,n){var o,i,a;const s=n!=null&&n.after?`?after=${encodeURIComponent(n.after)}`:"",r=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/events${s}`);return{events:(r.events||[]).map(zt),pageInfo:{startCursor:((o=r.pageInfo)==null?void 0:o.startCursor)??null,endCursor:((i=r.pageInfo)==null?void 0:i.endCursor)??null,hasNextPage:!!((a=r.pageInfo)!=null&&a.hasNextPage)}}}async getEvent(t,n){const s=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/events/${n}`);return zt(s.event)}async getPayload(t,n){return j(this,ne,fe).call(this,`/webhooks/payload/${y(this,G)}/${t}/${n}`)}async resendEvent(t,n){const s=await j(this,ne,fe).call(this,`/dash/apps/${y(this,G)}/webhooks/${t}/events/${n}`,{method:"POST",body:{}});return zt(s.event)}}G=new WeakMap,Ye=new WeakMap,Le=new WeakMap,Fe=new WeakMap,Ze=new WeakMap,ne=new WeakSet,fe=function(t,n){if(!y(this,G))throw new C("appId is required to manage webhooks. Pass it to the Webhooks constructor.");const s=r=>{const o={method:n==null?void 0:n.method,headers:{authorization:`Bearer ${r}`,"content-type":"application/json"}};return(n==null?void 0:n.body)!==void 0&&(o.body=JSON.stringify(n.body)),y(this,Ze).call(this,`${y(this,Ye)}${t}`,o)};if(y(this,Fe))return y(this,Fe).call(this,s);if(!y(this,Le))throw new C("A token is required to manage webhooks. Pass `adminToken` or `token` to the Webhooks constructor.");return s(y(this,Le))};const Ht=class Ht{constructor(t,n){d(this,"appId");d(this,"schema");L(this,et);d(this,"apiURI");L(this,Ce);d(this,"manager");this.appId=t.appId,this.schema=t.schema,B(this,et,t.adminToken||t.token),this.apiURI=t.apiURI||"https://api.instantdb.com",B(this,Ce,n||rr),this.manager=new or({appId:this.appId,apiURI:this.apiURI,token:y(this,et),withAuth:t.withAuth,jsonFetch:y(this,Ce)})}static helpers(){function t(...s){if(s.length===2)return{$default:s[1]};const[r,o,i]=s;return{[r]:{[o]:i}}}function n(...s){const r={};for(const o of s)for(const i of Object.keys(o))i==="$default"?r.$default=o.$default:r[i]={...r[i],...o[i]};return r}return{typedHandlers:t,combineHandlers:n}}helpers(){return Ht.helpers()}async fetchJwks(){return await y(this,Ce).call(this,`${this.apiURI}/.well-known/webhooks/jwks.json`)}async keyOfKid(t){var i,a,c;const n=`${this.apiURI}:${t}`,s=Pn[n];if(s)return s;const r=((i=Qs[this.apiURI])==null?void 0:i.keys.find(u=>u.kid===t))||((c=(a=await this.fetchJwks())==null?void 0:a.keys)==null?void 0:c.find(u=>u.kid===t));if(!r)throw new C("Could not find matching signing key",{kid:t});const o=await Xs(r);return Pn[n]=o,o}async validate(t,n,s){const r=(s==null?void 0:s.receivedAt)||new Date,{t:o,kid:i,v1:a}=er(t),c=(s==null?void 0:s.tolerance)??nr;tr(r,o,c);const{alg:u,key:l}=await this.keyOfKid(i),f=typeof n=="function"?await n():n,p=new TextEncoder().encode(`${o}.${f}`);if(!await Ys(u,l,Zs(a),p))throw new C("Instant Signature did not validate",{header:t});const g=JSON.parse(f);if(typeof g!="object"||typeof g.payloadUrl!="string"||typeof g.token!="string")throw new C("Invalid webhook body, expected an object with payloadUrl and token fields",{body:g});return g}async validateRequest(t,n){const s=t.headers.get("instant-signature");if(!s)throw new C("Request is missing Instant-Signature header");return this.validate(s,()=>t.text(),n)}fetchPayloads({payloadUrl:t,token:n}){return y(this,Ce).call(this,t,{headers:{Authorization:`Bearer ${n}`,accept:"application/json"}})}async processPayload(t,n){var r,o;const s=[];for(const i of n.data){const{namespace:a,action:c}=i,u=((r=t==null?void 0:t[a])==null?void 0:r[c])||((o=t==null?void 0:t[a])==null?void 0:o.$default)||(t==null?void 0:t.$default);u&&s.push(u(i))}await Promise.all(s)}async processRequest(t,n,s){const r=await this.validateRequest(n,s),o=await this.fetchPayloads(r);await this.processPayload(t,o)}async processNodeRequest(t,n,s){let r,o=!1,i=(s==null?void 0:s.body)??n.rawBody??n.body;if(i!=null&&typeof i.then=="function"&&(i=await i),typeof i=="string")r=i;else if(i instanceof Uint8Array)r=new TextDecoder("utf-8").decode(i);else if(i!=null&&typeof i=="object")try{r=JSON.stringify(i),o=!0}catch{throw new C("Webhook request body has already been parsed and could not be re-serialized. Configure this route to receive the raw request body instead of parsed JSON.")}else if(n[Symbol.asyncIterator]){const f=new TextEncoder,p=[];for await(const h of n)p.push(typeof h=="string"?f.encode(h):h);let m=0;for(const h of p)m+=h.byteLength;const g=new Uint8Array(m);let w=0;for(const h of p)g.set(h,w),w+=h.byteLength;r=new TextDecoder("utf-8").decode(g)}else throw new C("Could not read the webhook request body. Pass a Node IncomingMessage with an unconsumed stream, or set `req.body` to the raw bytes (Buffer/Uint8Array) or string.");const a=typeof n.headers.host=="string"?n.headers.host:"localhost",c=new URL(n.url??"/",`https://${a}`),u=new Headers;for(const[f,p]of Object.entries(n.headers))typeof p=="string"?u.set(f,p):Array.isArray(p)&&u.set(f,p.join(", "));const l=new Request(c,{method:n.method??"POST",headers:u,body:r});try{await this.processRequest(t,l,s)}catch(f){throw o&&f instanceof C&&f.message==="Instant Signature did not validate"?new C("Webhook signature did not validate. The request body was re-serialized from a parsed JSON object, which can produce different bytes than the server signed. Configure this route to receive the raw request body instead of parsed JSON.",{hint:f.hint}):f}}};et=new WeakMap,Ce=new WeakMap;let Vt=Ht;function ar(e){const t={apiURI:"https://api.instantdb.com"},n={...t,...e};return n.apiURI||(n.apiURI=t.apiURI),n}function cr(e,t){return"email"in t?e["as-email"]=t.email:"token"in t?e["as-token"]=t.token:"guest"in t&&(e["as-guest"]="true"),e}function ur(e,t){if(!(t&&("token"in t||"guest"in t))&&!e.adminToken)throw t&&"email"in t?new Error("Admin token required. To impersonate users with an email you must pass `adminToken` to `init`."):new Error("Admin token required. To run this operation pass `adminToken` to `init`, or use `db.asUser`.")}function M(e,t){ur(e,t);const{adminToken:n,appId:s}=e,r={"content-type":"application/json","app-id":s};return n&&(r.authorization=`Bearer ${n}`),t?cr(r,t):r}function fr(){return fetch.__nextPatched&&!globalThis[Symbol.for("next-patch")]}function dr(){return fr()?{cache:"no-store"}:{}}async function lr(e,t){const n=await t.text();try{const s=JSON.parse(n);return e(new le({status:t.status,body:s}))}catch{return e(new le({status:t.status,body:{type:void 0,message:n}}))}}async function U(e,t){const n=dr(),s={...(t==null?void 0:t.headers)||{},"Instant-Admin-Version":Ee,"Instant-Core-Version":Ee},r=await fetch(e,{...n,...t,headers:s});if(r.status===200){const o=await r.json();return Promise.resolve(o)}return lr(o=>Promise.reject(o),r)}function hr(e){var t,n,Fn;return t=class{constructor(o){L(this,n);d(this,"source");d(this,"url");this.url=o,this.source=j(this,n,Fn).call(this,o)}get onopen(){return this.source.onopen}set onopen(o){this.source.onopen=o}get onmessage(){return this.source.onmessage}set onmessage(o){this.source.onmessage=o}get onerror(){return this.source.onerror}set onerror(o){this.source.onerror=o}get readyState(){return this.source.readyState}close(){this.source.close()}},n=new WeakSet,Fn=function(o){return new ae(o,{messageEvent:_n,fetch(a,c){return fetch(a,{...c,method:"POST",headers:e.headers,body:JSON.stringify({"inference?":e.inference,versions:{"@instantdb/admin":Ee,"@instantdb/core":Ee}})})}})},d(t,"OPEN",ae.OPEN),d(t,"CONNECTING",ae.CONNECTING),d(t,"CLOSED",ae.CLOSED),t}function pr(e){var n,s;(!e.appId||!A(e.appId))&&console.warn("warning: Instant Admin DB must be initialized with a valid appId. Received: "+JSON.stringify(e.appId));const t={...e,appId:(n=e.appId)==null?void 0:n.trim(),adminToken:(s=e.adminToken)==null?void 0:s.trim(),useDateObjects:e.useDateObjects??!1};return new Jt(t)}function Mn(e){return(Array.isArray(e)?e:[e]).flatMap(ps)}class yr{constructor(t){d(this,"config");this.config=t}async getPresence(t,n){return(await U(`${this.config.apiURI}/admin/rooms/presence?app_id=${this.config.appId}&room-type=${String(t)}&room-id=${n}`,{method:"GET",headers:M(this.config)})).sessions||{}}}class mr{constructor(t){d(this,"config");d(this,"generateMagicCode",async t=>U(`${this.config.apiURI}/admin/magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t})}));d(this,"sendMagicCode",async t=>U(`${this.config.apiURI}/admin/send_magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t})}));d(this,"verifyMagicCode",async(t,n)=>{const{user:s}=await U(`${this.config.apiURI}/admin/verify_magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t,code:n})});return s});d(this,"checkMagicCode",async(t,n,s)=>{const r=await U(`${this.config.apiURI}/admin/verify_magic_code?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({email:t,code:n,...s!=null&&s.extraFields?{"extra-fields":s.extraFields}:{}})});return{user:r.user,created:r.created}});d(this,"verifyToken",async t=>(await U(`${this.config.apiURI}/runtime/auth/verify_refresh_token?app_id=${this.config.appId}`,{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify({"app-id":this.config.appId,"refresh-token":t})})).user);d(this,"getUser",async t=>{const n=Object.entries(t).map(([r,o])=>`${r}=${encodeURIComponent(o)}`).join("&");return(await U(`${this.config.apiURI}/admin/users?app_id=${this.config.appId}&${n}`,{method:"GET",headers:M(this.config)})).user});d(this,"deleteUser",async t=>{const n=Object.entries(t).map(([r,o])=>`${r}=${o}`);return(await U(`${this.config.apiURI}/admin/users?app_id=${this.config.appId}&${n}`,{method:"DELETE",headers:M(this.config)})).deleted});d(this,"getUserFromRequest",async(t,n)=>{const s=t.headers.get("cookie")||"",r=Ls(s),o="instant_user_"+this.config.appId;if(!r[o])return null;const i=r[o],a=JSON.parse(i);return a!=null&&a.refresh_token?n!=null&&n.disableValidation?a:await this.verifyToken(a.refresh_token):null});this.config=t,this.createToken=this.createToken.bind(this)}async createToken(t){const n=typeof t=="string"?{email:t}:t;return(await U(`${this.config.apiURI}/admin/refresh_tokens?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify(n)})).user.refresh_token}async signOut(t){const n=typeof t=="string"?{email:t}:t,s=this.config;await U(`${s.apiURI}/admin/sign_out?app_id=${this.config.appId}`,{method:"POST",headers:M(s),body:JSON.stringify(n)})}}const Un=e=>e&&typeof e=="object"&&typeof e.pipe=="function"&&typeof e.read=="function",br=e=>e&&typeof e.getReader=="function";class Dn{constructor(t,n){d(this,"config");d(this,"impersonationOpts");d(this,"uploadFile",async(t,n,s={})=>{const r={...M(this.config,this.impersonationOpts),path:t};s.contentDisposition&&(r["content-disposition"]=s.contentDisposition),delete r["content-type"],s.contentType&&(r["content-type"]=s.contentType);let o;if(Un(n)&&(o="half"),Un(n)||br(n)){if(!s.fileSize)throw new Error("fileSize is required in metadata when uploading streams");r["content-length"]=s.fileSize.toString()}let i={method:"PUT",headers:r,body:n,...o&&{duplex:o}};return U(`${this.config.apiURI}/admin/storage/upload?app_id=${this.config.appId}`,i)});d(this,"delete",async t=>U(`${this.config.apiURI}/admin/storage/files?app_id=${this.config.appId}&filename=${encodeURIComponent(t)}`,{method:"DELETE",headers:M(this.config,this.impersonationOpts)}));d(this,"deleteMany",async t=>U(`${this.config.apiURI}/admin/storage/files/delete?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify({filenames:t})}));d(this,"upload",async(t,n,s={})=>{const{data:r}=await U(`${this.config.apiURI}/admin/storage/signed-upload-url?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config),body:JSON.stringify({app_id:this.config.appId,filename:t})}),o={},i=s.contentType;i&&(o["Content-Type"]=i);const{ok:a}=await fetch(r,{method:"PUT",body:n,headers:o});return a});d(this,"list",async()=>{const{data:t}=await U(`${this.config.apiURI}/admin/storage/files?app_id=${this.config.appId}`,{method:"GET",headers:M(this.config)});return t});d(this,"getDownloadUrl",async t=>{const{data:n}=await U(`${this.config.apiURI}/admin/storage/signed-download-url?app_id=${this.config.appId}&filename=${encodeURIComponent(t)}`,{method:"GET",headers:M(this.config)});return n});this.config=t,this.impersonationOpts=n}}class wr{constructor(t){L(this,ze);d(this,"createReadStream",t=>y(this,ze).call(this).createReadStream(t));d(this,"createWriteStream",t=>y(this,ze).call(this).createWriteStream(t));B(this,ze,t)}}ze=new WeakMap;function gr(e){return{info:e?(...t)=>console.info(...t):()=>{},debug:e?(...t)=>console.debug(...t):()=>{},error:e?(...t)=>console.error(...t):()=>{}}}const Kt=class Kt{constructor(t){L(this,z);d(this,"config");d(this,"auth");d(this,"storage");d(this,"streams");d(this,"rooms");d(this,"impersonationOpts");d(this,"webhooks");L(this,H,null);L(this,Te,0);L(this,X,null);L(this,Y);d(this,"tx",dn());d(this,"asUser",t=>{const n=new Kt({...this.config});return n.impersonationOpts=t,n.storage=new Dn(this.config,t),n});d(this,"query",(t,n={})=>{t&&n&&"ruleParams"in n&&(t={$$ruleParams:n.ruleParams,...t}),this.config.disableValidation||mn(t,this.config.schema);const s=n.fetchOpts||{},r=s.headers||{};return U(`${this.config.apiURI}/admin/query?app_id=${this.config.appId}`,{...s,method:"POST",headers:{...r,...M(this.config,this.impersonationOpts)},body:JSON.stringify({query:t,"inference?":!!this.config.schema})})});d(this,"transact",t=>(this.config.disableValidation||vs(t,this.config.schema),U(`${this.config.apiURI}/admin/transact?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify({steps:Mn(t),"throw-on-missing-attrs?":!!this.config.schema})})));d(this,"debugQuery",async(t,n)=>{t&&n&&"ruleParams"in n&&(t={$$ruleParams:n.ruleParams,...t});const s={query:t,"rules-override":n==null?void 0:n.rules,"inference?":(n==null?void 0:n.cardinalityInference)??!!this.config.schema};n!=null&&n.ip&&(s["ip-override"]=n.ip),n!=null&&n.origin&&(s["origin-override"]=n.origin);const r=await U(`${this.config.apiURI}/admin/query_perms_check?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify(s)});return{result:r.result,checkResults:r["check-results"]}});d(this,"debugTransact",(t,n)=>{const s={steps:Mn(t),"rules-override":n==null?void 0:n.rules,"dangerously-commit-tx":n==null?void 0:n.__dangerouslyCommit};return n!=null&&n.ip&&(s["ip-override"]=n.ip),n!=null&&n.origin&&(s["origin-override"]=n.origin),U(`${this.config.apiURI}/admin/transact_perms_check?app_id=${this.config.appId}`,{method:"POST",headers:M(this.config,this.impersonationOpts),body:JSON.stringify(s)})});L(this,lt,t=>{var n;if(t.target!==y(this,H)){y(this,Y).info("[socket][open]",t.target.id,"skip; this is no longer the current transport");return}y(this,Y).info("[socket][open]",t.target.id),B(this,Te,0),(n=y(this,X))==null||n.onConnectionStatusChange("authenticated")});L(this,ht,t=>{var n;if(t.target!==y(this,H)){y(this,Y).info("[socket][close]",t.target.id,"skip; this is no longer the current transport");return}y(this,Y).info("[socket][close]",t.target.id),(n=y(this,X))==null||n.onConnectionStatusChange("closed"),y(this,H)&&(B(this,H,null),j(this,z,Gt).call(this)||(setTimeout(()=>j(this,z,bt).call(this),y(this,Te)),B(this,Te,Math.min(15e3,Math.max(y(this,Te),500)*2))))});L(this,pt,t=>{var n;if(t.target!==y(this,H)){y(this,Y).info("[socket][error]",t.target.id,"skip; this is no longer the current transport");return}y(this,Y).info("[socket][error]",t.target.id),(n=y(this,X))==null||n.onConnectionStatusChange("closed")});L(this,yt,t=>{var s,r,o,i,a,c;if(t.target!==y(this,H)){y(this,Y).info("[socket][message]",t.target.id,"skip; this is no longer the current transport");return}const n=t.message;switch(y(this,Y).info("[receive]",n),n.op){case"start-stream-ok":{(s=y(this,X))==null||s.onStartStreamOk(n);break}case"stream-flushed":{(r=y(this,X))==null||r.onStreamFlushed(n);break}case"append-failed":{(o=y(this,X))==null||o.onAppendFailed(n);break}case"stream-append":{(i=y(this,X))==null||i.onStreamAppend(n);break}case"error":{switch((a=n["original-event"])==null?void 0:a.op){case"start-stream":case"append-stream":case"subscribe-stream":case"unsubscribe-stream":{(c=y(this,X))==null||c.onRecieveError(n);break}}break}}j(this,z,Kn).call(this)});this.config=ar(t),this.auth=new mr(this.config),this.storage=new Dn(this.config,this.impersonationOpts),this.streams=new wr(j(this,z,Hn).bind(this)),this.rooms=new yr(this.config),this.webhooks=new Vt(this.config,U),B(this,Y,gr(!!this.config.verbose))}subscribeQuery(t,n,s={}){t&&s&&"ruleParams"in s&&(t={$$ruleParams:s.ruleParams,...t}),this.config.disableValidation||mn(t,this.config.schema);const i={...(s.fetchOpts||{}).headers||{},...M(this.config,this.impersonationOpts)},a=!!this.config.schema;return Ws(t,n,{headers:i,inference:a,apiURI:this.config.apiURI})}};H=new WeakMap,Te=new WeakMap,X=new WeakMap,Y=new WeakMap,z=new WeakSet,zn=function(){y(this,H)&&y(this,H).close();const t={...M(this.config,this.impersonationOpts)},n=!!this.config.schema,s=hr({headers:t,inference:n}),r=new Os(s,`${this.config.apiURI}/admin/sse?app_id=${this.config.appId}`,`${this.config.apiURI}/admin/sse/push?app_id=${this.config.appId}`);return r.onopen=y(this,lt),r.onmessage=y(this,yt),r.onclose=y(this,ht),r.onerror=y(this,pt),B(this,H,r),r},bt=function(){return y(this,H)||j(this,z,zn).call(this)},Vn=function(t,n){const s=j(this,z,bt).call(this);y(this,Y).info("[send]",t,n,{isOpen:s.isOpen()}),s.isOpen()&&s.send({"client-event-id":t,...n})},Jn=function(){j(this,z,bt).call(this);const t=new Ts({WStream:this.config.WritableStream||WritableStream,RStream:this.config.ReadableStream||ReadableStream,trySend:(n,s)=>{j(this,z,Vn).call(this,n,s)},log:y(this,Y)});return B(this,X,t),t},Hn=function(){return y(this,X)||j(this,z,Jn).call(this)},lt=new WeakMap,ht=new WeakMap,pt=new WeakMap,Gt=function(){return!y(this,X)||!y(this,X).hasActiveStreams()},Kn=function(){if(y(this,H)&&j(this,z,Gt).call(this)){const t=y(this,H);y(this,Y).info("cleaning up unused socket",t.id),B(this,H,null),t.close()}},yt=new WeakMap;let Jt=Kt;var ft={};function dt(e){let t=e;return new TransformStream({transform(n,s){if(!t){s.enqueue(n);return}if(t>n.length){t-=n.length;return}const r=n.slice(t);t=0,s.enqueue(r)}})}function Sr(e){const t=e.appId||ft.INSTANT_APP_ID||ft.NEXT_PUBLIC_INSTANT_APP_ID;if(!t)throw new Error("Missing appId. Pass it as an argument to createResumableStreamContext or set either the INSTANT_APP_ID or NEXT_PUBLIC_INSTANT_APP_ID environment variable.");const n=e.adminToken||ft.INSTANT_APP_ADMIN_TOKEN;if(!n)throw new Error("Missing adminToken. Pass it as an argument to createResumableStreamContext or set the INSTANT_APP_ADMIN_TOKEN environment variable.");const s={appId:t,adminToken:n},r=e.apiURI||ft.INSTANT_API_URI;r&&(s.apiURI=r),e.verbose&&(s.verbose=e.verbose);const o=pr(s);async function i(l,f,p){const m=o.streams.createWriteStream({clientId:l,waitUntil:e.waitUntil??void 0});try{const g=await m.streamId();f().pipeTo(m);const h=o.streams.createReadStream({streamId:g});return p?h.pipeThrough(dt(p)):h}catch{const w=o.streams.createReadStream({clientId:l});return p?w.pipeThrough(dt(p)):w}}async function a(l,f){var m,g,w;const p=o.streams.createReadStream({clientId:l});try{await p.streamId()}catch(h){if(h instanceof C&&((w=(g=(m=h.hint)==null?void 0:m.errors)==null?void 0:g[0])==null?void 0:w.message)==="Stream is missing.")return;throw h}return f?p.pipeThrough(dt(f)):p}async function c(l,f,p){const m=f(),g=o.streams.createWriteStream({clientId:l,waitUntil:e.waitUntil??void 0});await g.streamId(),m.pipeTo(g);const w=o.streams.createReadStream({clientId:l});return p?w.pipeThrough(dt(p)):w}async function u(l){var m;const f=await o.query({$streams:{$:{where:{clientId:l}}}}),p=(m=f==null?void 0:f.$streams)==null?void 0:m[0];return p!=null&&p.done?"DONE":p?!0:null}return{resumableStream:i,resumeExistingStream:a,createNewResumableStream:c,hasExistingStream:u}}$.createResumableStreamContext=Sr,Object.defineProperty($,Symbol.toStringTag,{value:"Module"})});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@instantdb/resumable-stream",
3
- "version": "1.0.32",
3
+ "version": "1.0.33-branch-webhooks-docs.25894421517.1",
4
4
  "description": "Instant's drop-in replacement for Vercel's resumable-stream package.",
5
5
  "license": "Apache-2.0",
6
6
  "homepage": "https://github.com/instantdb/instant/tree/main/client/packages/resumable-stream",
@@ -51,7 +51,7 @@
51
51
  "vitest": "^1.6.0"
52
52
  },
53
53
  "dependencies": {
54
- "@instantdb/admin": "1.0.32"
54
+ "@instantdb/admin": "1.0.33-branch-webhooks-docs.25894421517.1"
55
55
  },
56
56
  "scripts": {
57
57
  "test": "vitest",