@communecter/cocolight-api-client 1.0.120 → 1.0.122
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/203.cocolight-api-client.cjs +1 -0
- package/dist/278.cocolight-api-client.browser.js +1 -0
- package/dist/278.cocolight-api-client.cjs +1 -0
- package/dist/278.cocolight-api-client.mjs.js +1 -0
- package/dist/401.cocolight-api-client.mjs.js +1 -1
- package/dist/407.cocolight-api-client.browser.js +1 -0
- package/dist/407.cocolight-api-client.mjs.js +1 -0
- package/dist/499.cocolight-api-client.browser.js +1 -0
- package/dist/499.cocolight-api-client.cjs +1 -0
- package/dist/499.cocolight-api-client.mjs.js +1 -0
- package/dist/556.cocolight-api-client.browser.js +1 -0
- package/dist/556.cocolight-api-client.cjs +1 -0
- package/dist/556.cocolight-api-client.mjs.js +1 -0
- package/dist/588.cocolight-api-client.mjs.js +1 -1
- package/dist/593.cocolight-api-client.mjs.js +1 -1
- package/dist/839.cocolight-api-client.mjs.js +1 -1
- package/dist/85.cocolight-api-client.browser.js +1 -0
- package/dist/85.cocolight-api-client.cjs +1 -0
- package/dist/85.cocolight-api-client.mjs.js +1 -0
- package/dist/906.cocolight-api-client.browser.js +1 -0
- package/dist/906.cocolight-api-client.cjs +1 -0
- package/dist/906.cocolight-api-client.mjs.js +1 -0
- package/dist/cocolight-api-client.browser.js +3 -3
- package/dist/cocolight-api-client.cjs +1 -1
- package/dist/cocolight-api-client.mjs.js +1 -1
- package/dist/cocolight-api-client.vite.mjs.js +1 -1
- package/dist/cocolight-api-client.vite.mjs.js.map +1 -1
- package/package.json +1 -1
- package/src/Api.ts +21 -2
- package/src/api/BaseEntity.ts +171 -12
- package/src/api/EndpointApi.ts +140 -1
- package/src/api/EndpointApi.types.ts +201 -1
- package/src/api/EntityRegistry.ts +11 -3
- package/src/api/Form.ts +60 -0
- package/src/api/User.ts +2 -0
- package/src/api/UserApi.ts +3 -2
- package/src/api/serverDataType/Country.ts +1 -0
- package/src/api/serverDataType/Form.ts +56 -0
- package/src/endpoints.module.ts +1 -1
- package/src/index.ts +4 -1
- package/src/types/entities.ts +3 -2
- package/types/Api.d.ts +7 -0
- package/types/api/BaseEntity.d.ts +112 -3
- package/types/api/EndpointApi.d.ts +86 -1
- package/types/api/EndpointApi.types.d.ts +183 -1
- package/types/api/EntityRegistry.d.ts +1 -1
- package/types/api/Form.d.ts +23 -0
- package/types/api/Organization.d.ts +1 -1
- package/types/api/User.d.ts +1 -0
- package/types/api/serverDataType/Country.d.ts +1 -0
- package/types/api/serverDataType/Form.d.ts +51 -0
- package/types/endpoints.module.d.ts +2834 -141
- package/types/index.d.ts +4 -1
- package/types/types/entities.d.ts +3 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const __webpack_esm_id__=407;export const __webpack_esm_ids__=[407];export const __webpack_esm_modules__={407:(e,t,s)=>{s.d(t,{s:()=>BaseConvexClient,ConvexClient:()=>ConvexClient});const n="1.32.0";for(var i=[],r=[],o=Uint8Array,a="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",u=0;u<64;++u)i[u]=a[u],r[a.charCodeAt(u)]=u;function c(e){var t,s,n=function(e){var t=e.length;if(t%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var s=e.indexOf("=");return-1===s&&(s=t),[s,s===t?0:4-s%4]}(e),i=n[0],a=n[1],u=new o(function(e,t,s){return 3*(t+s)/4-s}(0,i,a)),c=0,h=a>0?i-4:i;for(s=0;s<h;s+=4)t=r[e.charCodeAt(s)]<<18|r[e.charCodeAt(s+1)]<<12|r[e.charCodeAt(s+2)]<<6|r[e.charCodeAt(s+3)],u[c++]=t>>16&255,u[c++]=t>>8&255,u[c++]=255&t;return 2===a&&(t=r[e.charCodeAt(s)]<<2|r[e.charCodeAt(s+1)]>>4,u[c++]=255&t),1===a&&(t=r[e.charCodeAt(s)]<<10|r[e.charCodeAt(s+1)]<<4|r[e.charCodeAt(s+2)]>>2,u[c++]=t>>8&255,u[c++]=255&t),u}function h(e){return i[e>>18&63]+i[e>>12&63]+i[e>>6&63]+i[63&e]}function l(e,t,s){for(var n,i=[],r=t;r<s;r+=3)n=(e[r]<<16&16711680)+(e[r+1]<<8&65280)+(255&e[r+2]),i.push(h(n));return i.join("")}function d(e){for(var t,s=e.length,n=s%3,r=[],o=16383,a=0,u=s-n;a<u;a+=o)r.push(l(e,a,a+o>u?u:a+o));return 1===n?(t=e[s-1],r.push(i[t>>2]+i[t<<4&63]+"==")):2===n&&(t=(e[s-2]<<8)+e[s-1],r.push(i[t>>10]+i[t>>4&63]+i[t<<2&63]+"=")),r.join("")}function g(e){if(void 0===e)return{};if(!y(e))throw new Error(`The arguments to a Convex function must be an object. Received: ${e}`);return e}function f(e){if(void 0===e)throw new Error("Client created with undefined deployment address. If you used an environment variable, check that it's set.");if("string"!=typeof e)throw new Error(`Invalid deployment address: found ${e}".`);if(!e.startsWith("http:")&&!e.startsWith("https:"))throw new Error(`Invalid deployment address: Must start with "https://" or "http://". Found "${e}".`);try{new URL(e)}catch{throw new Error(`Invalid deployment address: "${e}" is not a valid URL. If you believe this URL is correct, use the \`skipConvexDeploymentUrlCheck\` option to bypass this.`)}if(e.endsWith(".convex.site"))throw new Error(`Invalid deployment address: "${e}" ends with .convex.site, which is used for HTTP Actions. Convex deployment URLs typically end with .convex.cloud? If you believe this URL is correct, use the \`skipConvexDeploymentUrlCheck\` option to bypass this.`)}function y(e){const t="object"==typeof e,s=Object.getPrototypeOf(e),n=null===s||s===Object.prototype||"Object"===s?.constructor?.name;return t&&n}r["-".charCodeAt(0)]=62,r["_".charCodeAt(0)]=63;const p=!0,m=BigInt("-9223372036854775808"),b=BigInt("9223372036854775807"),v=BigInt("0"),w=BigInt("8"),k=BigInt("256");function S(e){return Number.isNaN(e)||!Number.isFinite(e)||Object.is(e,-0)}const C=DataView.prototype.setBigInt64?function(e){if(e<m||b<e)throw new Error(`BigInt ${e} does not fit into a 64-bit signed integer.`);const t=new ArrayBuffer(8);return new DataView(t).setBigInt64(0,e,!0),d(new Uint8Array(t))}:function(e){e<v&&(e-=m+m);let t=e.toString(16);t.length%2==1&&(t="0"+t);const s=new Uint8Array(new ArrayBuffer(8));let n=0;for(const i of t.match(/.{2}/g).reverse())s.set([parseInt(i,16)],n++),e>>=w;return d(s)},T=DataView.prototype.getBigInt64?function(e){const t=c(e);if(8!==t.byteLength)throw new Error(`Received ${t.byteLength} bytes, expected 8 for $integer`);return new DataView(t.buffer).getBigInt64(0,!0)}:function(e){const t=c(e);if(8!==t.byteLength)throw new Error(`Received ${t.byteLength} bytes, expected 8 for $integer`);let s=v,n=v;for(const e of t)s+=BigInt(e)*k**n,n++;return s>b&&(s+=m+m),s};function R(e){if(e.length>1024)throw new Error(`Field name ${e} exceeds maximum field name length 1024.`);if(e.startsWith("$"))throw new Error(`Field name ${e} starts with a '$', which is reserved.`);for(let t=0;t<e.length;t+=1){const s=e.charCodeAt(t);if(s<32||s>=127)throw new Error(`Field name ${e} has invalid character '${e[t]}': Field names can only contain non-control ASCII characters`)}}function q(e){if(null===e)return e;if("boolean"==typeof e)return e;if("number"==typeof e)return e;if("string"==typeof e)return e;if(Array.isArray(e))return e.map(e=>q(e));if("object"!=typeof e)throw new Error(`Unexpected type of ${e}`);const t=Object.entries(e);if(1===t.length){const s=t[0][0];if("$bytes"===s){if("string"!=typeof e.$bytes)throw new Error(`Malformed $bytes field on ${e}`);return c(e.$bytes).buffer}if("$integer"===s){if("string"!=typeof e.$integer)throw new Error(`Malformed $integer field on ${e}`);return T(e.$integer)}if("$float"===s){if("string"!=typeof e.$float)throw new Error(`Malformed $float field on ${e}`);const t=c(e.$float);if(8!==t.byteLength)throw new Error(`Received ${t.byteLength} bytes, expected 8 for $float`);const s=new DataView(t.buffer).getFloat64(0,p);if(!S(s))throw new Error(`Float ${s} should be encoded as a number`);return s}if("$set"===s)throw new Error("Received a Set which is no longer supported as a Convex type.");if("$map"===s)throw new Error("Received a Map which is no longer supported as a Convex type.")}const s={};for(const[t,n]of Object.entries(e))R(t),s[t]=q(n);return s}function A(e){const t=JSON.stringify(e,(e,t)=>void 0===t?"undefined":"bigint"==typeof t?`${t.toString()}n`:t);if(t.length>16384){const e="[...truncated]";let s=16384-e.length;const n=t.codePointAt(s-1);return void 0!==n&&n>65535&&(s-=1),t.substring(0,s)+e}return t}function M(e,t,s,n){if(void 0===e){const e=s&&` (present at path ${s} in original object ${A(t)})`;throw new Error(`undefined is not a valid Convex value${e}. To learn about Convex's supported types, see https://docs.convex.dev/using/types.`)}if(null===e)return e;if("bigint"==typeof e){if(e<m||b<e)throw new Error(`BigInt ${e} does not fit into a 64-bit signed integer.`);return{$integer:C(e)}}if("number"==typeof e){if(S(e)){const t=new ArrayBuffer(8);return new DataView(t).setFloat64(0,e,p),{$float:d(new Uint8Array(t))}}return e}if("boolean"==typeof e)return e;if("string"==typeof e)return e;if(e instanceof ArrayBuffer)return{$bytes:d(new Uint8Array(e))};if(Array.isArray(e))return e.map((e,n)=>M(e,t,s+`[${n}]`,!1));if(e instanceof Set)throw new Error(I(s,"Set",[...e],t));if(e instanceof Map)throw new Error(I(s,"Map",[...e],t));if(!y(e)){const n=e?.constructor?.name;throw new Error(I(s,n?`${n} `:"",e,t))}const i={},r=Object.entries(e);r.sort(([e,t],[s,n])=>e===s?0:e<s?-1:1);for(const[e,o]of r)void 0!==o?(R(e),i[e]=M(o,t,s+`.${e}`,!1)):n&&(R(e),i[e]=O(o,t,s+`.${e}`));return i}function I(e,t,s,n){return e?`${t}${A(s)} is not a supported Convex type (present at path ${e} in original object ${A(n)}). To learn about Convex's supported types, see https://docs.convex.dev/using/types.`:`${t}${A(s)} is not a supported Convex type.`}function O(e,t,s){if(void 0===e)return{$undefined:null};if(void 0===t)throw new Error(`Programming error. Current value is ${A(e)} but original value is undefined`);return M(e,t,s,!1)}function Q(e){return M(e,e,"",!1)}Object.defineProperty;var x,L,E=Object.defineProperty,$=(e,t,s)=>((e,t,s)=>t in e?E(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);const V=Symbol.for("ConvexError");class errors_ConvexError extends(L=Error,x=V,L){constructor(e){super("string"==typeof e?e:A(e)),$(this,"name","ConvexError"),$(this,"data"),$(this,x,!0),this.data=e}}const P=()=>Array.from({length:4},()=>0);P(),P();var _=Object.defineProperty,N=(e,t,s)=>((e,t,s)=>t in e?_(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);function B(e){switch(e){case"query":return"Q";case"mutation":return"M";case"action":return"A";case"any":return"?"}}class DefaultLogger{constructor(e){N(this,"_onLogLineFuncs"),N(this,"_verbose"),this._onLogLineFuncs={},this._verbose=e.verbose}addLogLineListener(e){let t=Math.random().toString(36).substring(2,15);for(let e=0;e<10&&void 0!==this._onLogLineFuncs[t];e++)t=Math.random().toString(36).substring(2,15);return this._onLogLineFuncs[t]=e,()=>{delete this._onLogLineFuncs[t]}}logVerbose(...e){if(this._verbose)for(const t of Object.values(this._onLogLineFuncs))t("debug",`${(new Date).toISOString()}`,...e)}log(...e){for(const t of Object.values(this._onLogLineFuncs))t("info",...e)}warn(...e){for(const t of Object.values(this._onLogLineFuncs))t("warn",...e)}error(...e){for(const t of Object.values(this._onLogLineFuncs))t("error",...e)}}function F(e,t,s,n,i){const r=B(s);if("object"==typeof i&&(i=`ConvexError ${JSON.stringify(i.errorData,null,2)}`),"info"===t){const t=i.match(/^\[.*?\] /);if(null===t)return void e.error(`[CONVEX ${r}(${n})] Could not parse console.log`);const s=i.slice(1,t[0].length-2),o=i.slice(t[0].length);e.log(`%c[CONVEX ${r}(${n})] [${s}]`,"color:rgb(0, 145, 255)",o)}else e.error(`[CONVEX ${r}(${n})] ${i}`)}function D(e,t,s){return`[CONVEX ${B(e)}(${t})] ${s.errorMessage}\n Called by client`}function U(e,t){return t.data=e.errorData,t}function j(e){const t=e.split(":");let s,n;return 1===t.length?(s=t[0],n="default"):(s=t.slice(0,t.length-1).join(":"),n=t[t.length-1]),s.endsWith(".js")&&(s=s.slice(0,-3)),`${s}:${n}`}function W(e,t){return JSON.stringify({udfPath:j(e),args:Q(t)})}function K(e,t,s){const{initialNumItems:n,id:i}=s;return JSON.stringify({type:"paginated",udfPath:j(e),args:Q(t),options:Q({initialNumItems:n,id:i})})}function J(e){return"paginated"===JSON.parse(e).type}var H=Object.defineProperty,z=(e,t,s)=>((e,t,s)=>t in e?H(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class LocalSyncState{constructor(){z(this,"nextQueryId"),z(this,"querySetVersion"),z(this,"querySet"),z(this,"queryIdToToken"),z(this,"identityVersion"),z(this,"auth"),z(this,"outstandingQueriesOlderThanRestart"),z(this,"outstandingAuthOlderThanRestart"),z(this,"paused"),z(this,"pendingQuerySetModifications"),this.nextQueryId=0,this.querySetVersion=0,this.identityVersion=0,this.querySet=new Map,this.queryIdToToken=new Map,this.outstandingQueriesOlderThanRestart=new Set,this.outstandingAuthOlderThanRestart=!1,this.paused=!1,this.pendingQuerySetModifications=new Map}hasSyncedPastLastReconnect(){return 0===this.outstandingQueriesOlderThanRestart.size&&!this.outstandingAuthOlderThanRestart}markAuthCompletion(){this.outstandingAuthOlderThanRestart=!1}subscribe(e,t,s,n){const i=j(e),r=W(i,t),o=this.querySet.get(r);if(void 0!==o)return o.numSubscribers+=1,{queryToken:r,modification:null,unsubscribe:()=>this.removeSubscriber(r)};{const e=this.nextQueryId++,o={id:e,canonicalizedUdfPath:i,args:t,numSubscribers:1,journal:s,componentPath:n};this.querySet.set(r,o),this.queryIdToToken.set(e,r);const a=this.querySetVersion,u=this.querySetVersion+1,c={type:"Add",queryId:e,udfPath:i,args:[Q(t)],journal:s,componentPath:n};return this.paused?this.pendingQuerySetModifications.set(e,c):this.querySetVersion=u,{queryToken:r,modification:{type:"ModifyQuerySet",baseVersion:a,newVersion:u,modifications:[c]},unsubscribe:()=>this.removeSubscriber(r)}}}transition(e){for(const t of e.modifications)switch(t.type){case"QueryUpdated":case"QueryFailed":{this.outstandingQueriesOlderThanRestart.delete(t.queryId);const e=t.journal;if(void 0!==e){const s=this.queryIdToToken.get(t.queryId);void 0!==s&&(this.querySet.get(s).journal=e)}break}case"QueryRemoved":this.outstandingQueriesOlderThanRestart.delete(t.queryId);break;default:throw new Error(`Invalid modification ${t.type}`)}}queryId(e,t){const s=W(j(e),t),n=this.querySet.get(s);return void 0!==n?n.id:null}isCurrentOrNewerAuthVersion(e){return e>=this.identityVersion}getAuth(){return this.auth}setAuth(e){this.auth={tokenType:"User",value:e};const t=this.identityVersion;return this.paused||(this.identityVersion=t+1),{type:"Authenticate",baseVersion:t,...this.auth}}setAdminAuth(e,t){const s={tokenType:"Admin",value:e,impersonating:t};this.auth=s;const n=this.identityVersion;return this.paused||(this.identityVersion=n+1),{type:"Authenticate",baseVersion:n,...s}}clearAuth(){this.auth=void 0,this.markAuthCompletion();const e=this.identityVersion;return this.paused||(this.identityVersion=e+1),{type:"Authenticate",tokenType:"None",baseVersion:e}}hasAuth(){return!!this.auth}isNewAuth(e){return this.auth?.value!==e}queryPath(e){const t=this.queryIdToToken.get(e);return t?this.querySet.get(t).canonicalizedUdfPath:null}queryArgs(e){const t=this.queryIdToToken.get(e);return t?this.querySet.get(t).args:null}queryToken(e){return this.queryIdToToken.get(e)??null}queryJournal(e){return this.querySet.get(e)?.journal}restart(e){this.unpause(),this.outstandingQueriesOlderThanRestart.clear();const t=[];for(const s of this.querySet.values()){const n={type:"Add",queryId:s.id,udfPath:s.canonicalizedUdfPath,args:[Q(s.args)],journal:s.journal,componentPath:s.componentPath};t.push(n),e.has(s.id)||this.outstandingQueriesOlderThanRestart.add(s.id)}this.querySetVersion=1;const s={type:"ModifyQuerySet",baseVersion:0,newVersion:1,modifications:t};if(!this.auth)return this.identityVersion=0,[s,void 0];this.outstandingAuthOlderThanRestart=!0;const n={type:"Authenticate",baseVersion:0,...this.auth};return this.identityVersion=1,[s,n]}pause(){this.paused=!0}resume(){const e=this.pendingQuerySetModifications.size>0?{type:"ModifyQuerySet",baseVersion:this.querySetVersion,newVersion:++this.querySetVersion,modifications:Array.from(this.pendingQuerySetModifications.values())}:void 0,t=void 0!==this.auth?{type:"Authenticate",baseVersion:this.identityVersion++,...this.auth}:void 0;return this.unpause(),[e,t]}unpause(){this.paused=!1,this.pendingQuerySetModifications.clear()}removeSubscriber(e){const t=this.querySet.get(e);if(t.numSubscribers>1)return t.numSubscribers-=1,null;{this.querySet.delete(e),this.queryIdToToken.delete(t.id),this.outstandingQueriesOlderThanRestart.delete(t.id);const s=this.querySetVersion,n=this.querySetVersion+1,i={type:"Remove",queryId:t.id};return this.paused?this.pendingQuerySetModifications.has(t.id)?this.pendingQuerySetModifications.delete(t.id):this.pendingQuerySetModifications.set(t.id,i):this.querySetVersion=n,{type:"ModifyQuerySet",baseVersion:s,newVersion:n,modifications:[i]}}}}var G=Object.defineProperty,X=(e,t,s)=>((e,t,s)=>t in e?G(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class RequestManager{constructor(e,t){this.logger=e,this.markConnectionStateDirty=t,X(this,"inflightRequests"),X(this,"requestsOlderThanRestart"),X(this,"inflightMutationsCount",0),X(this,"inflightActionsCount",0),this.inflightRequests=new Map,this.requestsOlderThanRestart=new Set}request(e,t){const s=new Promise(s=>{const n=t?"Requested":"NotSent";this.inflightRequests.set(e.requestId,{message:e,status:{status:n,requestedAt:new Date,onResult:s}}),"Mutation"===e.type?this.inflightMutationsCount++:"Action"===e.type&&this.inflightActionsCount++});return this.markConnectionStateDirty(),s}onResponse(e){const t=this.inflightRequests.get(e.requestId);if(void 0===t)return null;if("Completed"===t.status.status)return null;const s="Mutation"===t.message.type?"mutation":"action",n=t.message.udfPath;for(const t of e.logLines)F(this.logger,"info",s,n,t);const i=t.status;let r,o;if(e.success)r={success:!0,logLines:e.logLines,value:q(e.result)},o=()=>i.onResult(r);else{const t=e.result,{errorData:a}=e;F(this.logger,"error",s,n,t),r={success:!1,errorMessage:t,errorData:void 0!==a?q(a):void 0,logLines:e.logLines},o=()=>i.onResult(r)}return"ActionResponse"!==e.type&&e.success?(t.status={status:"Completed",result:r,ts:e.ts,onResolve:o},null):(o(),this.inflightRequests.delete(e.requestId),this.requestsOlderThanRestart.delete(e.requestId),"Action"===t.message.type?this.inflightActionsCount--:"Mutation"===t.message.type&&this.inflightMutationsCount--,this.markConnectionStateDirty(),{requestId:e.requestId,result:r})}removeCompleted(e){const t=new Map;for(const[s,n]of this.inflightRequests.entries()){const i=n.status;"Completed"===i.status&&i.ts.lessThanOrEqual(e)&&(i.onResolve(),t.set(s,i.result),"Mutation"===n.message.type?this.inflightMutationsCount--:"Action"===n.message.type&&this.inflightActionsCount--,this.inflightRequests.delete(s),this.requestsOlderThanRestart.delete(s))}return t.size>0&&this.markConnectionStateDirty(),t}restart(){this.requestsOlderThanRestart=new Set(this.inflightRequests.keys());const e=[];for(const[t,s]of this.inflightRequests)if("NotSent"!==s.status.status){if("Mutation"===s.message.type)e.push(s.message);else if("Action"===s.message.type){if(this.inflightRequests.delete(t),this.requestsOlderThanRestart.delete(t),this.inflightActionsCount--,"Completed"===s.status.status)throw new Error("Action should never be in 'Completed' state");s.status.onResult({success:!1,errorMessage:"Connection lost while action was in flight",logLines:[]})}}else s.status.status="Requested",e.push(s.message);return this.markConnectionStateDirty(),e}resume(){const e=[];for(const[,t]of this.inflightRequests)"NotSent"!==t.status.status||(t.status.status="Requested",e.push(t.message));return e}hasIncompleteRequests(){for(const e of this.inflightRequests.values())if("Requested"===e.status.status)return!0;return!1}hasInflightRequests(){return this.inflightRequests.size>0}hasSyncedPastLastReconnect(){return 0===this.requestsOlderThanRestart.size}timeOfOldestInflightRequest(){if(0===this.inflightRequests.size)return null;let e=Date.now();for(const t of this.inflightRequests.values())"Completed"!==t.status.status&&t.status.requestedAt.getTime()<e&&(e=t.status.requestedAt.getTime());return new Date(e)}inflightMutations(){return this.inflightMutationsCount}inflightActions(){return this.inflightActionsCount}}const Y=Symbol.for("functionName"),Z=Symbol.for("toReferencePath");function ee(e){const t=function(e){let t;if("string"==typeof e)t=e.startsWith("function://")?{functionHandle:e}:{name:e};else if(e[Y])t={name:e[Y]};else{const s=e[Z]??null;if(!s)throw new Error(`${e} is not a functionReference`);t={reference:s}}return t}(e);if(void 0===t.name){if(void 0!==t.functionHandle)throw new Error(`Expected function reference like "api.file.func" or "internal.file.func", but received function handle ${t.functionHandle}`);if(void 0!==t.reference)throw new Error(`Expected function reference in the current component like "api.file.func" or "internal.file.func", but received reference ${t.reference}`);throw new Error(`Expected function reference like "api.file.func" or "internal.file.func", but received ${JSON.stringify(t)}`)}if("string"==typeof e)return e;const s=e[Y];if(!s)throw new Error(`${e} is not a functionReference`);return s}!function e(t=[]){return new Proxy({},{get(s,n){if("string"==typeof n)return e([...t,n]);if(n===Y){if(t.length<2){const e=["api",...t].join(".");throw new Error(`API path is expected to be of the form \`api.moduleName.functionName\`. Found: \`${e}\``)}const e=t.slice(0,-1).join("/"),s=t[t.length-1];return"default"===s?e:e+":"+s}return n===Symbol.toStringTag?"FunctionReference":void 0}})}();var te=Object.defineProperty,se=(e,t,s)=>((e,t,s)=>t in e?te(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class OptimisticLocalStoreImpl{constructor(e){se(this,"queryResults"),se(this,"modifiedQueries"),this.queryResults=e,this.modifiedQueries=[]}getQuery(e,...t){const s=g(t[0]),n=ee(e),i=this.queryResults.get(W(n,s));if(void 0!==i)return OptimisticLocalStoreImpl.queryValue(i.result)}getAllQueries(e){const t=[],s=ee(e);for(const e of this.queryResults.values())e.udfPath===j(s)&&t.push({args:e.args,value:OptimisticLocalStoreImpl.queryValue(e.result)});return t}setQuery(e,t,s){const n=g(t),i=ee(e),r=W(i,n);let o;o=void 0===s?void 0:{success:!0,value:s,logLines:[]};const a={udfPath:i,args:n,result:o};this.queryResults.set(r,a),this.modifiedQueries.push(r)}static queryValue(e){return void 0===e?void 0:e.success?e.value:void 0}}class OptimisticQueryResults{constructor(){se(this,"queryResults"),se(this,"optimisticUpdates"),this.queryResults=new Map,this.optimisticUpdates=[]}ingestQueryResultsFromServer(e,t){this.optimisticUpdates=this.optimisticUpdates.filter(e=>!t.has(e.mutationId));const s=this.queryResults;this.queryResults=new Map(e);const n=new OptimisticLocalStoreImpl(this.queryResults);for(const e of this.optimisticUpdates)e.update(n);const i=[];for(const[e,t]of this.queryResults){const n=s.get(e);void 0!==n&&n.result===t.result||i.push(e)}return i}applyOptimisticUpdate(e,t){this.optimisticUpdates.push({update:e,mutationId:t});const s=new OptimisticLocalStoreImpl(this.queryResults);return e(s),s.modifiedQueries}rawQueryResult(e){const t=this.queryResults.get(e);if(void 0!==t)return t.result}queryResult(e){const t=this.queryResults.get(e);if(void 0===t)return;const s=t.result;if(void 0!==s){if(s.success)return s.value;if(void 0!==s.errorData)throw U(s,new errors_ConvexError(D("query",t.udfPath,s)));throw new Error(D("query",t.udfPath,s))}}hasQueryResult(e){return void 0!==this.queryResults.get(e)}queryLogs(e){const t=this.queryResults.get(e);return t?.result?.logLines}}var ne=Object.defineProperty,ie=(e,t,s)=>((e,t,s)=>t in e?ne(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class Long{constructor(e,t){ie(this,"low"),ie(this,"high"),ie(this,"__isUnsignedLong__"),this.low=0|e,this.high=0|t,this.__isUnsignedLong__=!0}static isLong(e){return!0===(e&&e.__isUnsignedLong__)}static fromBytesLE(e){return new Long(e[0]|e[1]<<8|e[2]<<16|e[3]<<24,e[4]|e[5]<<8|e[6]<<16|e[7]<<24)}toBytesLE(){const e=this.high,t=this.low;return[255&t,t>>>8&255,t>>>16&255,t>>>24,255&e,e>>>8&255,e>>>16&255,e>>>24]}static fromNumber(e){return isNaN(e)||e<0?re:e>=ae?ue:new Long(e%oe|0,e/oe|0)}toString(){return(BigInt(this.high)*BigInt(oe)+BigInt(this.low)).toString()}equals(e){return Long.isLong(e)||(e=Long.fromValue(e)),(this.high>>>31!=1||e.high>>>31!=1)&&this.high===e.high&&this.low===e.low}notEquals(e){return!this.equals(e)}comp(e){return Long.isLong(e)||(e=Long.fromValue(e)),this.equals(e)?0:e.high>>>0>this.high>>>0||e.high===this.high&&e.low>>>0>this.low>>>0?-1:1}lessThanOrEqual(e){return this.comp(e)<=0}static fromValue(e){return"number"==typeof e?Long.fromNumber(e):new Long(e.low,e.high)}}const re=new Long(0,0),oe=4294967296,ae=oe*oe,ue=new Long(-1,-1);var ce=Object.defineProperty,he=(e,t,s)=>((e,t,s)=>t in e?ce(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class RemoteQuerySet{constructor(e,t){he(this,"version"),he(this,"remoteQuerySet"),he(this,"queryPath"),he(this,"logger"),this.version={querySet:0,ts:Long.fromNumber(0),identity:0},this.remoteQuerySet=new Map,this.queryPath=e,this.logger=t}transition(e){const t=e.startVersion;if(this.version.querySet!==t.querySet||this.version.ts.notEquals(t.ts)||this.version.identity!==t.identity)throw new Error(`Invalid start version: ${t.ts.toString()}:${t.querySet}:${t.identity}, transitioning from ${this.version.ts.toString()}:${this.version.querySet}:${this.version.identity}`);for(const t of e.modifications)switch(t.type){case"QueryUpdated":{const e=this.queryPath(t.queryId);if(e)for(const s of t.logLines)F(this.logger,"info","query",e,s);const s=q(t.value??null);this.remoteQuerySet.set(t.queryId,{success:!0,value:s,logLines:t.logLines});break}case"QueryFailed":{const e=this.queryPath(t.queryId);if(e)for(const s of t.logLines)F(this.logger,"info","query",e,s);const{errorData:s}=t;this.remoteQuerySet.set(t.queryId,{success:!1,errorMessage:t.errorMessage,errorData:void 0!==s?q(s):void 0,logLines:t.logLines});break}case"QueryRemoved":this.remoteQuerySet.delete(t.queryId);break;default:throw new Error(`Invalid modification ${t.type}`)}this.version=e.endVersion}remoteQueryResults(){return this.remoteQuerySet}timestamp(){return this.version.ts}}function le(e){const t=c(e);return Long.fromBytesLE(Array.from(t))}function de(e){switch(e.type){case"FatalError":case"AuthError":case"ActionResponse":case"TransitionChunk":case"Ping":return{...e};case"MutationResponse":return e.success?{...e,ts:le(e.ts)}:{...e};case"Transition":return{...e,startVersion:{...e.startVersion,ts:le(e.startVersion.ts)},endVersion:{...e.endVersion,ts:le(e.endVersion.ts)}}}}var ge=Object.defineProperty,fe=(e,t,s)=>((e,t,s)=>t in e?ge(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);let ye;function pe(){return void 0===ye&&(ye=Date.now()),"undefined"!=typeof performance&&performance.now?Math.round(ye+performance.now()):Date.now()}function me(){return`t=${Math.round((pe()-ye)/100)/10}s`}const be={InternalServerError:{timeout:1e3},SubscriptionsWorkerFullError:{timeout:3e3},TooManyConcurrentRequests:{timeout:3e3},CommitterFullError:{timeout:3e3},AwsTooManyRequestsException:{timeout:3e3},ExecuteFullError:{timeout:3e3},SystemTimeoutError:{timeout:3e3},ExpiredInQueue:{timeout:3e3},VectorIndexesUnavailable:{timeout:1e3},SearchIndexesUnavailable:{timeout:1e3},TableSummariesUnavailable:{timeout:1e3},VectorIndexTooLarge:{timeout:3e3},SearchIndexTooLarge:{timeout:3e3},TooManyWritesInTimePeriod:{timeout:3e3}};class WebSocketManager{constructor(e,t,s,n,i,r){this.markConnectionStateDirty=i,this.debug=r,fe(this,"socket"),fe(this,"connectionCount"),fe(this,"_hasEverConnected",!1),fe(this,"lastCloseReason"),fe(this,"transitionChunkBuffer",null),fe(this,"defaultInitialBackoff"),fe(this,"maxBackoff"),fe(this,"retries"),fe(this,"serverInactivityThreshold"),fe(this,"reconnectDueToServerInactivityTimeout"),fe(this,"scheduledReconnect",null),fe(this,"networkOnlineHandler",null),fe(this,"pendingNetworkRecoveryInfo",null),fe(this,"uri"),fe(this,"onOpen"),fe(this,"onResume"),fe(this,"onMessage"),fe(this,"webSocketConstructor"),fe(this,"logger"),fe(this,"onServerDisconnectError"),this.webSocketConstructor=s,this.socket={state:"disconnected"},this.connectionCount=0,this.lastCloseReason="InitialConnect",this.defaultInitialBackoff=1e3,this.maxBackoff=16e3,this.retries=0,this.serverInactivityThreshold=6e4,this.reconnectDueToServerInactivityTimeout=null,this.uri=e,this.onOpen=t.onOpen,this.onResume=t.onResume,this.onMessage=t.onMessage,this.onServerDisconnectError=t.onServerDisconnectError,this.logger=n,this.setupNetworkListener(),this.connect()}setSocketState(e){this.socket=e,this._logVerbose(`socket state changed: ${this.socket.state}, paused: ${"paused"in this.socket?this.socket.paused:void 0}`),this.markConnectionStateDirty()}setupNetworkListener(){"undefined"!=typeof window&&"function"==typeof window.addEventListener&&null===this.networkOnlineHandler&&(this.networkOnlineHandler=()=>{this._logVerbose("network online event detected"),this.tryReconnectImmediately()},window.addEventListener("online",this.networkOnlineHandler),this._logVerbose("network online event listener registered"))}cleanupNetworkListener(){this.networkOnlineHandler&&"undefined"!=typeof window&&"function"==typeof window.removeEventListener&&(window.removeEventListener("online",this.networkOnlineHandler),this.networkOnlineHandler=null,this._logVerbose("network online event listener removed"))}assembleTransition(e){if(e.partNumber<0||e.partNumber>=e.totalParts||0===e.totalParts||this.transitionChunkBuffer&&(this.transitionChunkBuffer.totalParts!==e.totalParts||this.transitionChunkBuffer.transitionId!==e.transitionId))throw this.transitionChunkBuffer=null,new Error("Invalid TransitionChunk");if(null===this.transitionChunkBuffer&&(this.transitionChunkBuffer={chunks:[],totalParts:e.totalParts,transitionId:e.transitionId}),e.partNumber!==this.transitionChunkBuffer.chunks.length){const t=this.transitionChunkBuffer.chunks.length;throw this.transitionChunkBuffer=null,new Error(`TransitionChunk received out of order: expected part ${t}, got ${e.partNumber}`)}if(this.transitionChunkBuffer.chunks.push(e.chunk),this.transitionChunkBuffer.chunks.length===e.totalParts){const e=this.transitionChunkBuffer.chunks.join("");this.transitionChunkBuffer=null;const t=de(JSON.parse(e));if("Transition"!==t.type)throw new Error(`Expected Transition, got ${t.type} after assembling chunks`);return t}return null}connect(){if("terminated"===this.socket.state)return;if("disconnected"!==this.socket.state&&"stopped"!==this.socket.state)throw new Error("Didn't start connection from disconnected state: "+this.socket.state);const e=new this.webSocketConstructor(this.uri);this._logVerbose("constructed WebSocket"),this.setSocketState({state:"connecting",ws:e,paused:"no"}),this.resetServerInactivityTimeout(),e.onopen=()=>{if(this.logger.logVerbose("begin ws.onopen"),"connecting"!==this.socket.state)throw new Error("onopen called with socket not in connecting state");if(this.setSocketState({state:"ready",ws:e,paused:"yes"===this.socket.paused?"uninitialized":"no"}),this.resetServerInactivityTimeout(),"no"===this.socket.paused&&(this._hasEverConnected=!0,this.onOpen({connectionCount:this.connectionCount,lastCloseReason:this.lastCloseReason,clientTs:pe()})),"InitialConnect"!==this.lastCloseReason&&(this.lastCloseReason?this.logger.log("WebSocket reconnected at",me(),"after disconnect due to",this.lastCloseReason):this.logger.log("WebSocket reconnected at",me())),this.connectionCount+=1,this.lastCloseReason=null,null!==this.pendingNetworkRecoveryInfo){const{timeSavedMs:e}=this.pendingNetworkRecoveryInfo;this.pendingNetworkRecoveryInfo=null,this.sendMessage({type:"Event",eventType:"NetworkRecoveryReconnect",event:{timeSavedMs:e}}),this.logger.log(`Network recovery reconnect saved ~${Math.round(e/1e3)}s of waiting`)}},e.onerror=e=>{this.transitionChunkBuffer=null;const t=e.message;t&&this.logger.log(`WebSocket error message: ${t}`)},e.onmessage=e=>{this.resetServerInactivityTimeout();const t=e.data.length;let s=de(JSON.parse(e.data));if(this._logVerbose(`received ws message with type ${s.type}`),"Ping"!==s.type){if("TransitionChunk"===s.type){const e=this.assembleTransition(s);if(!e)return;s=e,this._logVerbose(`assembled full ws message of type ${s.type}`)}null!==this.transitionChunkBuffer&&(this.transitionChunkBuffer=null,this.logger.log(`Received unexpected ${s.type} while buffering TransitionChunks`)),"Transition"===s.type&&this.reportLargeTransition({messageLength:t,transition:s}),this.onMessage(s).hasSyncedPastLastReconnect&&(this.retries=0,this.markConnectionStateDirty())}},e.onclose=e=>{if(this._logVerbose("begin ws.onclose"),this.transitionChunkBuffer=null,null===this.lastCloseReason&&(this.lastCloseReason=e.reason||`closed with code ${e.code}`),1e3!==e.code&&1001!==e.code&&1005!==e.code&&4040!==e.code){let t=`WebSocket closed with code ${e.code}`;e.reason&&(t+=`: ${e.reason}`),this.logger.log(t),this.onServerDisconnectError&&e.reason&&this.onServerDisconnectError(t)}const t=function(e){if(void 0===e)return"Unknown";for(const t of Object.keys(be))if(e.startsWith(t))return t;return"Unknown"}(e.reason);this.scheduleReconnect(t)}}socketState(){return this.socket.state}sendMessage(e){const t={type:e.type,..."Authenticate"===e.type&&"User"===e.tokenType?{value:`...${e.value.slice(-7)}`}:{}};if("ready"===this.socket.state&&"no"===this.socket.paused){const s=function(e){switch(e.type){case"Authenticate":case"ModifyQuerySet":case"Mutation":case"Action":case"Event":return{...e};case"Connect":return void 0!==e.maxObservedTimestamp?{...e,maxObservedTimestamp:(t=e.maxObservedTimestamp,d(new Uint8Array(t.toBytesLE())))}:{...e,maxObservedTimestamp:void 0}}var t}(e),n=JSON.stringify(s);let i=!1;try{this.socket.ws.send(n),i=!0}catch(e){this.logger.log(`Failed to send message on WebSocket, reconnecting: ${e}`),this.closeAndReconnect("FailedToSendMessage")}return this._logVerbose(`${i?"sent":"failed to send"} message with type ${e.type}: ${JSON.stringify(t)}`),!0}return this._logVerbose(`message not sent (socket state: ${this.socket.state}, paused: ${"paused"in this.socket?this.socket.paused:void 0}): ${JSON.stringify(t)}`),!1}resetServerInactivityTimeout(){"terminated"!==this.socket.state&&(null!==this.reconnectDueToServerInactivityTimeout&&(clearTimeout(this.reconnectDueToServerInactivityTimeout),this.reconnectDueToServerInactivityTimeout=null),this.reconnectDueToServerInactivityTimeout=setTimeout(()=>{this.closeAndReconnect("InactiveServer")},this.serverInactivityThreshold))}scheduleReconnect(e){this.scheduledReconnect&&(clearTimeout(this.scheduledReconnect.timeout),this.scheduledReconnect=null),this.socket={state:"disconnected"};const t=this.nextBackoff(e);this.markConnectionStateDirty(),this.logger.log(`Attempting reconnect in ${Math.round(t)}ms`);const s=pe(),n=setTimeout(()=>{this.scheduledReconnect?.timeout===n&&(this.scheduledReconnect=null,this.connect())},t);this.scheduledReconnect={timeout:n,scheduledAt:s,backoffMs:t}}closeAndReconnect(e){switch(this._logVerbose(`begin closeAndReconnect with reason ${e}`),this.socket.state){case"disconnected":case"terminated":case"stopped":return;case"connecting":case"ready":return this.lastCloseReason=e,this.close(),void this.scheduleReconnect("client");default:this.socket}}close(){switch(this.transitionChunkBuffer=null,this.socket.state){case"disconnected":case"terminated":case"stopped":return Promise.resolve();case"connecting":{const e=this.socket.ws;return e.onmessage=e=>{this._logVerbose("Ignoring message received after close")},new Promise(t=>{e.onclose=()=>{this._logVerbose("Closed after connecting"),t()},e.onopen=()=>{this._logVerbose("Opened after connecting"),e.close()}})}case"ready":{this._logVerbose("ws.close called");const e=this.socket.ws;e.onmessage=e=>{this._logVerbose("Ignoring message received after close")};const t=new Promise(t=>{e.onclose=()=>{t()}});return e.close(),t}default:return this.socket,Promise.resolve()}}terminate(){switch(this.reconnectDueToServerInactivityTimeout&&clearTimeout(this.reconnectDueToServerInactivityTimeout),this.scheduledReconnect&&(clearTimeout(this.scheduledReconnect.timeout),this.scheduledReconnect=null),this.cleanupNetworkListener(),this.socket.state){case"terminated":case"stopped":case"disconnected":case"connecting":case"ready":{const e=this.close();return this.setSocketState({state:"terminated"}),e}default:throw this.socket,new Error(`Invalid websocket state: ${this.socket.state}`)}}stop(){switch(this.socket.state){case"terminated":return Promise.resolve();case"connecting":case"stopped":case"disconnected":case"ready":{this.cleanupNetworkListener();const e=this.close();return this.socket={state:"stopped"},e}default:return this.socket,Promise.resolve()}}tryRestart(){switch(this.socket.state){case"stopped":break;case"terminated":case"connecting":case"ready":case"disconnected":return void this.logger.logVerbose("Restart called without stopping first");default:this.socket}this.setupNetworkListener(),this.connect()}pause(){switch(this.socket.state){case"disconnected":case"stopped":case"terminated":return;case"connecting":case"ready":return void(this.socket={...this.socket,paused:"yes"});default:return void this.socket}}tryReconnectImmediately(){if(this._logVerbose("tryReconnectImmediately called"),"disconnected"!==this.socket.state)return void this._logVerbose(`tryReconnectImmediately called but socket state is ${this.socket.state}, no action taken`);let e=null;if(this.scheduledReconnect){const t=pe()-this.scheduledReconnect.scheduledAt;e=Math.max(0,this.scheduledReconnect.backoffMs-t),this._logVerbose(`would have waited ${Math.round(e)}ms more (backoff was ${Math.round(this.scheduledReconnect.backoffMs)}ms, elapsed ${Math.round(t)}ms)`),clearTimeout(this.scheduledReconnect.timeout),this.scheduledReconnect=null,this._logVerbose("canceled scheduled reconnect")}this.logger.log("Network recovery detected, reconnecting immediately"),this.pendingNetworkRecoveryInfo=null!==e?{timeSavedMs:e}:null,this.connect()}resume(){switch(this.socket.state){case"connecting":return void(this.socket={...this.socket,paused:"no"});case"ready":return void("uninitialized"===this.socket.paused?(this.socket={...this.socket,paused:"no"},this.onOpen({connectionCount:this.connectionCount,lastCloseReason:this.lastCloseReason,clientTs:pe()})):"yes"===this.socket.paused&&(this.socket={...this.socket,paused:"no"},this.onResume()));case"terminated":case"stopped":case"disconnected":return;default:this.socket}this.connect()}connectionState(){return{isConnected:"ready"===this.socket.state,hasEverConnected:this._hasEverConnected,connectionCount:this.connectionCount,connectionRetries:this.retries}}_logVerbose(e){this.logger.logVerbose(e)}nextBackoff(e){const t=("client"===e?100:"Unknown"===e?this.defaultInitialBackoff:be[e].timeout)*Math.pow(2,this.retries);this.retries+=1;const s=Math.min(t,this.maxBackoff);return s+s*(Math.random()-.5)}reportLargeTransition({transition:e,messageLength:t}){if(void 0===e.clientClockSkew||void 0===e.serverTs)return;const s=pe()-e.clientClockSkew-e.serverTs/1e6,n=`${Math.round(s)}ms`,i=Math.round(t/1e4)/100+"MB",r=t/(s/1e3),o=Math.round(r/1e4)/100+"MB per second";this._logVerbose(`received ${i} transition in ${n} at ${o}`),t>2e7?this.logger.log(`received query results totaling more that 20MB (${i}) which will take a long time to download on slower connections`):s>2e4&&this.logger.log(`received query results totaling ${i} which took more than 20s to arrive (${n})`),this.debug&&this.sendMessage({type:"Event",eventType:"ClientReceivedTransition",event:{transitionTransitTime:s,messageLength:t}})}}class InvalidTokenError extends Error{}function ve(e,t){if("string"!=typeof e)throw new InvalidTokenError("Invalid token specified: must be a string");t||(t={});const s=!0===t.header?0:1,n=e.split(".")[s];if("string"!=typeof n)throw new InvalidTokenError(`Invalid token specified: missing part #${s+1}`);let i;try{i=function(e){let t=e.replace(/-/g,"+").replace(/_/g,"/");switch(t.length%4){case 0:break;case 2:t+="==";break;case 3:t+="=";break;default:throw new Error("base64 string is not of the correct length")}try{return function(e){return decodeURIComponent(atob(e).replace(/(.)/g,(e,t)=>{let s=t.charCodeAt(0).toString(16).toUpperCase();return s.length<2&&(s="0"+s),"%"+s}))}(t)}catch{return atob(t)}}(n)}catch(e){throw new InvalidTokenError(`Invalid token specified: invalid base64 for part #${s+1} (${e.message})`)}try{return JSON.parse(i)}catch(e){throw new InvalidTokenError(`Invalid token specified: invalid json for part #${s+1} (${e.message})`)}}InvalidTokenError.prototype.name="InvalidTokenError";var we=Object.defineProperty,ke=(e,t,s)=>((e,t,s)=>t in e?we(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class AuthenticationManager{constructor(e,t,s){ke(this,"authState",{state:"noAuth"}),ke(this,"configVersion",0),ke(this,"syncState"),ke(this,"authenticate"),ke(this,"stopSocket"),ke(this,"tryRestartSocket"),ke(this,"pauseSocket"),ke(this,"resumeSocket"),ke(this,"clearAuth"),ke(this,"logger"),ke(this,"refreshTokenLeewaySeconds"),ke(this,"tokenConfirmationAttempts",0),this.syncState=e,this.authenticate=t.authenticate,this.stopSocket=t.stopSocket,this.tryRestartSocket=t.tryRestartSocket,this.pauseSocket=t.pauseSocket,this.resumeSocket=t.resumeSocket,this.clearAuth=t.clearAuth,this.logger=s.logger,this.refreshTokenLeewaySeconds=s.refreshTokenLeewaySeconds}async setConfig(e,t){this.resetAuthState(),this._logVerbose("pausing WS for auth token fetch"),this.pauseSocket();const s=await this.fetchTokenAndGuardAgainstRace(e,{forceRefreshToken:!1});s.isFromOutdatedConfig||(s.value?(this.setAuthState({state:"waitingForServerConfirmationOfCachedToken",config:{fetchToken:e,onAuthChange:t},hasRetried:!1}),this.authenticate(s.value)):(this.setAuthState({state:"initialRefetch",config:{fetchToken:e,onAuthChange:t}}),await this.refetchToken()),this._logVerbose("resuming WS after auth token fetch"),this.resumeSocket())}onTransition(e){if(this.syncState.isCurrentOrNewerAuthVersion(e.endVersion.identity)&&!(e.endVersion.identity<=e.startVersion.identity))return"waitingForServerConfirmationOfCachedToken"===this.authState.state?(this._logVerbose("server confirmed auth token is valid"),this.refetchToken(),void this.authState.config.onAuthChange(!0)):void("waitingForServerConfirmationOfFreshToken"===this.authState.state&&(this._logVerbose("server confirmed new auth token is valid"),this.scheduleTokenRefetch(this.authState.token),this.tokenConfirmationAttempts=0,this.authState.hadAuth||this.authState.config.onAuthChange(!0)))}onAuthError(e){if(!1===e.authUpdateAttempted&&("waitingForServerConfirmationOfFreshToken"===this.authState.state||"waitingForServerConfirmationOfCachedToken"===this.authState.state))return void this._logVerbose("ignoring non-auth token expired error");const{baseVersion:t}=e;this.syncState.isCurrentOrNewerAuthVersion(t+1)?this.tryToReauthenticate(e):this._logVerbose("ignoring auth error for previous auth attempt")}async tryToReauthenticate(e){if(this._logVerbose(`attempting to reauthenticate: ${e.error}`),"noAuth"===this.authState.state||"waitingForServerConfirmationOfFreshToken"===this.authState.state&&this.tokenConfirmationAttempts>=2)return this.logger.error(`Failed to authenticate: "${e.error}", check your server auth config`),this.syncState.hasAuth()&&this.syncState.clearAuth(),void("noAuth"!==this.authState.state&&this.setAndReportAuthFailed(this.authState.config.onAuthChange));"waitingForServerConfirmationOfFreshToken"===this.authState.state&&(this.tokenConfirmationAttempts++,this._logVerbose(`retrying reauthentication, ${2-this.tokenConfirmationAttempts} attempts remaining`)),await this.stopSocket();const t=await this.fetchTokenAndGuardAgainstRace(this.authState.config.fetchToken,{forceRefreshToken:!0});t.isFromOutdatedConfig||(t.value&&this.syncState.isNewAuth(t.value)?(this.authenticate(t.value),this.setAuthState({state:"waitingForServerConfirmationOfFreshToken",config:this.authState.config,token:t.value,hadAuth:"notRefetching"===this.authState.state||"waitingForScheduledRefetch"===this.authState.state})):(this._logVerbose("reauthentication failed, could not fetch a new token"),this.syncState.hasAuth()&&this.syncState.clearAuth(),this.setAndReportAuthFailed(this.authState.config.onAuthChange)),this.tryRestartSocket())}async refetchToken(){if("noAuth"===this.authState.state)return;this._logVerbose("refetching auth token");const e=await this.fetchTokenAndGuardAgainstRace(this.authState.config.fetchToken,{forceRefreshToken:!0});e.isFromOutdatedConfig||(e.value?this.syncState.isNewAuth(e.value)?(this.setAuthState({state:"waitingForServerConfirmationOfFreshToken",hadAuth:this.syncState.hasAuth(),token:e.value,config:this.authState.config}),this.authenticate(e.value)):this.setAuthState({state:"notRefetching",config:this.authState.config}):(this._logVerbose("refetching token failed"),this.syncState.hasAuth()&&this.clearAuth(),this.setAndReportAuthFailed(this.authState.config.onAuthChange)),this._logVerbose("restarting WS after auth token fetch (if currently stopped)"),this.tryRestartSocket())}scheduleTokenRefetch(e){if("noAuth"===this.authState.state)return;const t=this.decodeToken(e);if(!t)return void this.logger.error("Auth token is not a valid JWT, cannot refetch the token");const{iat:s,exp:n}=t;if(!s||!n)return void this.logger.error("Auth token does not have required fields, cannot refetch the token");const i=n-s;if(i<=2)return void this.logger.error("Auth token does not live long enough, cannot refetch the token");let r=Math.min(1728e6,1e3*(i-this.refreshTokenLeewaySeconds));r<=0&&(this.logger.warn(`Refetching auth token immediately, configured leeway ${this.refreshTokenLeewaySeconds}s is larger than the token's lifetime ${i}s`),r=0);const o=setTimeout(()=>{this._logVerbose("running scheduled token refetch"),this.refetchToken()},r);this.setAuthState({state:"waitingForScheduledRefetch",refetchTokenTimeoutId:o,config:this.authState.config}),this._logVerbose(`scheduled preemptive auth token refetching in ${r}ms`)}async fetchTokenAndGuardAgainstRace(e,t){const s=++this.configVersion;this._logVerbose(`fetching token with config version ${s}`);const n=await e(t);return this.configVersion!==s?(this._logVerbose(`stale config version, expected ${s}, got ${this.configVersion}`),{isFromOutdatedConfig:!0}):{isFromOutdatedConfig:!1,value:n}}stop(){this.resetAuthState(),this.configVersion++,this._logVerbose(`config version bumped to ${this.configVersion}`)}setAndReportAuthFailed(e){e(!1),this.resetAuthState()}resetAuthState(){this.setAuthState({state:"noAuth"})}setAuthState(e){const t="waitingForServerConfirmationOfFreshToken"===e.state?{hadAuth:e.hadAuth,state:e.state,token:`...${e.token.slice(-7)}`}:{state:e.state};switch(this._logVerbose(`setting auth state to ${JSON.stringify(t)}`),e.state){case"waitingForScheduledRefetch":case"notRefetching":case"noAuth":this.tokenConfirmationAttempts=0}"waitingForScheduledRefetch"===this.authState.state&&(clearTimeout(this.authState.refetchTokenTimeoutId),this.syncState.markAuthCompletion()),this.authState=e}decodeToken(e){try{return ve(e)}catch(e){return this._logVerbose(`Error decoding token: ${e instanceof Error?e.message:"Unknown error"}`),null}}_logVerbose(e){this.logger.logVerbose(`${e} [v${this.configVersion}]`)}}const Se=["convexClientConstructed","convexWebSocketOpen","convexFirstMessageReceived"];function Ce(e){let t=e.name.slice(6);return t=t.charAt(0).toLowerCase()+t.slice(1),{name:t,startTime:e.startTime}}var Te=Object.defineProperty,Re=(e,t,s)=>((e,t,s)=>t in e?Te(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class BaseConvexClient{constructor(e,t,s){if(Re(this,"address"),Re(this,"state"),Re(this,"requestManager"),Re(this,"webSocketManager"),Re(this,"authenticationManager"),Re(this,"remoteQuerySet"),Re(this,"optimisticQueryResults"),Re(this,"_transitionHandlerCounter",0),Re(this,"_nextRequestId"),Re(this,"_onTransitionFns",new Map),Re(this,"_sessionId"),Re(this,"firstMessageReceived",!1),Re(this,"debug"),Re(this,"logger"),Re(this,"maxObservedTimestamp"),Re(this,"connectionStateSubscribers",new Map),Re(this,"nextConnectionStateSubscriberId",0),Re(this,"_lastPublishedConnectionState"),Re(this,"markConnectionStateDirty",()=>{Promise.resolve().then(()=>{const e=this.connectionState();if(JSON.stringify(e)!==JSON.stringify(this._lastPublishedConnectionState)){this._lastPublishedConnectionState=e;for(const t of this.connectionStateSubscribers.values())t(e)}})}),Re(this,"mark",e=>{this.debug&&function(e,t){const s={sessionId:t};"undefined"!=typeof performance&&performance.mark&&performance.mark(e,{detail:s})}(e,this.sessionId)}),"object"==typeof e)throw new Error("Passing a ClientConfig object is no longer supported. Pass the URL of the Convex deployment as a string directly.");!0!==s?.skipConvexDeploymentUrlCheck&&f(e);const i=(s={...s}).authRefreshTokenLeewaySeconds??10;let r=s.webSocketConstructor;if(!r&&"undefined"==typeof WebSocket)throw new Error("No WebSocket global variable defined! To use Convex in an environment without WebSocket try the HTTP client: https://docs.convex.dev/api/classes/browser.ConvexHttpClient");r=r||WebSocket,this.debug=s.reportDebugInfoToConvex??!1,this.address=e,this.logger=!1===s.logger?function(e){return new DefaultLogger(e)}({verbose:s.verbose??!1}):!0!==s.logger&&s.logger?s.logger:function(e){const t=new DefaultLogger(e);return t.addLogLineListener((e,...t)=>{switch(e){case"debug":console.debug(...t);break;case"info":default:console.log(...t);break;case"warn":console.warn(...t);break;case"error":console.error(...t)}}),t}({verbose:s.verbose??!1});const o=e.search("://");if(-1===o)throw new Error("Provided address was not an absolute URL.");const a=e.substring(o+3),u=e.substring(0,o);let c;if("http"===u)c="ws";else{if("https"!==u)throw new Error(`Unknown parent protocol ${u}`);c="wss"}const h=`${c}://${a}/api/${n}/sync`;this.state=new LocalSyncState,this.remoteQuerySet=new RemoteQuerySet(e=>this.state.queryPath(e),this.logger),this.requestManager=new RequestManager(this.logger,this.markConnectionStateDirty);const l=()=>{this.webSocketManager.pause(),this.state.pause()};this.authenticationManager=new AuthenticationManager(this.state,{authenticate:e=>{const t=this.state.setAuth(e);return this.webSocketManager.sendMessage(t),t.baseVersion},stopSocket:()=>this.webSocketManager.stop(),tryRestartSocket:()=>this.webSocketManager.tryRestart(),pauseSocket:l,resumeSocket:()=>this.webSocketManager.resume(),clearAuth:()=>{this.clearAuth()}},{logger:this.logger,refreshTokenLeewaySeconds:i}),this.optimisticQueryResults=new OptimisticQueryResults,this.addOnTransitionHandler(e=>{t(e.queries.map(e=>e.token))}),this._nextRequestId=0,this._sessionId="xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,e=>{const t=16*Math.random()|0;return("x"===e?t:3&t|8).toString(16)});const{unsavedChangesWarning:d}=s;if("undefined"==typeof window||void 0===window.addEventListener){if(!0===d)throw new Error("unsavedChangesWarning requested, but window.addEventListener not found! Remove {unsavedChangesWarning: true} from Convex client options.")}else!1!==d&&window.addEventListener("beforeunload",e=>{if(this.requestManager.hasIncompleteRequests()){e.preventDefault();const t="Are you sure you want to leave? Your changes may not be saved.";return(e||window.event).returnValue=t,t}});this.webSocketManager=new WebSocketManager(h,{onOpen:e=>{this.mark("convexWebSocketOpen"),this.webSocketManager.sendMessage({...e,type:"Connect",sessionId:this._sessionId,maxObservedTimestamp:this.maxObservedTimestamp});const t=new Set(this.remoteQuerySet.remoteQueryResults().keys());this.remoteQuerySet=new RemoteQuerySet(e=>this.state.queryPath(e),this.logger);const[s,n]=this.state.restart(t);n&&this.webSocketManager.sendMessage(n),this.webSocketManager.sendMessage(s);for(const e of this.requestManager.restart())this.webSocketManager.sendMessage(e)},onResume:()=>{const[e,t]=this.state.resume();t&&this.webSocketManager.sendMessage(t),e&&this.webSocketManager.sendMessage(e);for(const e of this.requestManager.resume())this.webSocketManager.sendMessage(e)},onMessage:e=>{switch(this.firstMessageReceived||(this.firstMessageReceived=!0,this.mark("convexFirstMessageReceived"),this.reportMarks()),e.type){case"Transition":{this.observedTimestamp(e.endVersion.ts),this.authenticationManager.onTransition(e),this.remoteQuerySet.transition(e),this.state.transition(e);const t=this.requestManager.removeCompleted(this.remoteQuerySet.timestamp());this.notifyOnQueryResultChanges(t);break}case"MutationResponse":{e.success&&this.observedTimestamp(e.ts);const t=this.requestManager.onResponse(e);null!==t&&this.notifyOnQueryResultChanges(new Map([[t.requestId,t.result]]));break}case"ActionResponse":this.requestManager.onResponse(e);break;case"AuthError":this.authenticationManager.onAuthError(e);break;case"FatalError":{const t=function(e,t){const s=`[CONVEX FATAL ERROR] ${t}`;return e.error(s),new Error(s)}(this.logger,e.error);throw this.webSocketManager.terminate(),t}}return{hasSyncedPastLastReconnect:this.hasSyncedPastLastReconnect()}},onServerDisconnectError:s.onServerDisconnectError},r,this.logger,this.markConnectionStateDirty,this.debug),this.mark("convexClientConstructed"),s.expectAuth&&l()}hasSyncedPastLastReconnect(){return this.requestManager.hasSyncedPastLastReconnect()||this.state.hasSyncedPastLastReconnect()}observedTimestamp(e){(void 0===this.maxObservedTimestamp||this.maxObservedTimestamp.lessThanOrEqual(e))&&(this.maxObservedTimestamp=e)}getMaxObservedTimestamp(){return this.maxObservedTimestamp}notifyOnQueryResultChanges(e){const t=this.remoteQuerySet.remoteQueryResults(),s=new Map;for(const[e,n]of t){const t=this.state.queryToken(e);if(null!==t){const i={result:n,udfPath:this.state.queryPath(e),args:this.state.queryArgs(e)};s.set(t,i)}}const n=this.optimisticQueryResults.ingestQueryResultsFromServer(s,new Set(e.keys()));this.handleTransition({queries:n.map(e=>({token:e,modification:{kind:"Updated",result:this.optimisticQueryResults.rawQueryResult(e)}})),reflectedMutations:Array.from(e).map(([e,t])=>({requestId:e,result:t})),timestamp:this.remoteQuerySet.timestamp()})}handleTransition(e){for(const t of this._onTransitionFns.values())t(e)}addOnTransitionHandler(e){const t=this._transitionHandlerCounter++;return this._onTransitionFns.set(t,e),()=>this._onTransitionFns.delete(t)}getCurrentAuthClaims(){const e=this.state.getAuth();let t={};if(e&&"User"===e.tokenType){try{t=e?ve(e.value):{}}catch{t={}}return{token:e.value,decoded:t}}}setAuth(e,t){this.authenticationManager.setConfig(e,t)}hasAuth(){return this.state.hasAuth()}setAdminAuth(e,t){const s=this.state.setAdminAuth(e,t);this.webSocketManager.sendMessage(s)}clearAuth(){const e=this.state.clearAuth();this.webSocketManager.sendMessage(e)}subscribe(e,t,s){const n=g(t),{modification:i,queryToken:r,unsubscribe:o}=this.state.subscribe(e,n,s?.journal,s?.componentPath);return null!==i&&this.webSocketManager.sendMessage(i),{queryToken:r,unsubscribe:()=>{const e=o();e&&this.webSocketManager.sendMessage(e)}}}localQueryResult(e,t){const s=W(e,g(t));return this.optimisticQueryResults.queryResult(s)}localQueryResultByToken(e){return this.optimisticQueryResults.queryResult(e)}hasLocalQueryResultByToken(e){return this.optimisticQueryResults.hasQueryResult(e)}localQueryLogs(e,t){const s=W(e,g(t));return this.optimisticQueryResults.queryLogs(s)}queryJournal(e,t){const s=W(e,g(t));return this.state.queryJournal(s)}connectionState(){const e=this.webSocketManager.connectionState();return{hasInflightRequests:this.requestManager.hasInflightRequests(),isWebSocketConnected:e.isConnected,hasEverConnected:e.hasEverConnected,connectionCount:e.connectionCount,connectionRetries:e.connectionRetries,timeOfOldestInflightRequest:this.requestManager.timeOfOldestInflightRequest(),inflightMutations:this.requestManager.inflightMutations(),inflightActions:this.requestManager.inflightActions()}}subscribeToConnectionState(e){const t=this.nextConnectionStateSubscriberId++;return this.connectionStateSubscribers.set(t,e),()=>{this.connectionStateSubscribers.delete(t)}}async mutation(e,t,s){const n=await this.mutationInternal(e,t,s);if(!n.success){if(void 0!==n.errorData)throw U(n,new errors_ConvexError(D("mutation",e,n)));throw new Error(D("mutation",e,n))}return n.value}async mutationInternal(e,t,s,n){const{mutationPromise:i}=this.enqueueMutation(e,t,s,n);return i}enqueueMutation(e,t,s,n){const i=g(t);this.tryReportLongDisconnect();const r=this.nextRequestId;if(this._nextRequestId++,void 0!==s){const e=s.optimisticUpdate;if(void 0!==e){const t=t=>{e(t,i)instanceof Promise&&this.logger.warn("Optimistic update handler returned a Promise. Optimistic updates should be synchronous.")},s=this.optimisticQueryResults.applyOptimisticUpdate(t,r).map(e=>{const t=this.localQueryResultByToken(e);return{token:e,modification:{kind:"Updated",result:void 0===t?void 0:{success:!0,value:t,logLines:[]}}}});this.handleTransition({queries:s,reflectedMutations:[],timestamp:this.remoteQuerySet.timestamp()})}}const o={type:"Mutation",requestId:r,udfPath:e,componentPath:n,args:[Q(i)]},a=this.webSocketManager.sendMessage(o);return{requestId:r,mutationPromise:this.requestManager.request(o,a)}}async action(e,t){const s=await this.actionInternal(e,t);if(!s.success){if(void 0!==s.errorData)throw U(s,new errors_ConvexError(D("action",e,s)));throw new Error(D("action",e,s))}return s.value}async actionInternal(e,t,s){const n=g(t),i=this.nextRequestId;this._nextRequestId++,this.tryReportLongDisconnect();const r={type:"Action",requestId:i,udfPath:e,componentPath:s,args:[Q(n)]},o=this.webSocketManager.sendMessage(r);return this.requestManager.request(r,o)}async close(){return this.authenticationManager.stop(),this.webSocketManager.terminate()}get url(){return this.address}get nextRequestId(){return this._nextRequestId}get sessionId(){return this._sessionId}reportMarks(){if(this.debug){const e=function(e){if("undefined"==typeof performance||!performance.getEntriesByName)return[];const t=[];for(const s of Se){const n=performance.getEntriesByName(s).filter(e=>"mark"===e.entryType).filter(t=>t.detail.sessionId===e);t.push(...n)}return t.map(Ce)}(this.sessionId);this.webSocketManager.sendMessage({type:"Event",eventType:"ClientConnect",event:e})}}tryReportLongDisconnect(){if(!this.debug)return;const e=this.connectionState().timeOfOldestInflightRequest;if(null===e||Date.now()-e.getTime()<=6e4)return;const t=`${this.address}/api/debug_event`;fetch(t,{method:"POST",headers:{"Content-Type":"application/json","Convex-Client":`npm-${n}`},body:JSON.stringify({event:"LongWebsocketDisconnect"})}).then(e=>{e.ok||this.logger.warn("Analytics request failed with response:",e.body)}).catch(e=>{this.logger.warn("Analytics response failed with error:",e)})}}function qe(e){if("object"!=typeof e||null===e||!Array.isArray(e.page)||"boolean"!=typeof e.isDone||"string"!=typeof e.continueCursor)throw new Error(`Not a valid paginated query result: ${e?.toString()}`);return e}var Ae=Object.defineProperty,Me=(e,t,s)=>((e,t,s)=>t in e?Ae(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class PaginatedQueryClient{constructor(e,t){this.client=e,this.onTransition=t,Me(this,"paginatedQuerySet",new Map),Me(this,"lastTransitionTs"),this.lastTransitionTs=Long.fromNumber(0),this.client.addOnTransitionHandler(e=>this.onBaseTransition(e))}subscribe(e,t,s){const n=j(e),i=K(n,t,s),r=()=>this.removePaginatedQuerySubscriber(i),o=this.paginatedQuerySet.get(i);return o?(o.numSubscribers+=1,{paginatedQueryToken:i,unsubscribe:r}):(this.paginatedQuerySet.set(i,{token:i,canonicalizedUdfPath:n,args:t,numSubscribers:1,options:{initialNumItems:s.initialNumItems},nextPageKey:0,pageKeys:[],pageKeyToQuery:new Map,ongoingSplits:new Map,skip:!1,id:s.id}),this.addPageToPaginatedQuery(i,null,s.initialNumItems),{paginatedQueryToken:i,unsubscribe:r})}localQueryResult(e,t,s){const n=K(j(e),t,s);return this.localQueryResultByToken(n)}localQueryResultByToken(e){const t=this.paginatedQuerySet.get(e);if(!t)return;const s=this.activePageQueryTokens(t);if(0===s.length)return{results:[],status:"LoadingFirstPage",loadMore:t=>this.loadMoreOfPaginatedQuery(e,t)};let n,i=[],r=!1,o=!1;for(const e of s){const t=this.client.localQueryResultByToken(e);if(void 0===t){r=!0,o=!1;continue}const s=qe(t);i=i.concat(s.page),o=!!s.isDone}return n=r?0===i.length?"LoadingFirstPage":"LoadingMore":o?"Exhausted":"CanLoadMore",{results:i,status:n,loadMore:t=>this.loadMoreOfPaginatedQuery(e,t)}}onBaseTransition(e){const t=e.queries.map(e=>e.token),s=this.queriesContainingTokens(t);let n=[];s.length>0&&(this.processPaginatedQuerySplits(s,e=>this.client.localQueryResultByToken(e)),n=s.map(e=>({token:e,modification:{kind:"Updated",result:this.localQueryResultByToken(e)}})));const i={...e,paginatedQueries:n};this.onTransition(i)}loadMoreOfPaginatedQuery(e,t){this.mustGetPaginatedQuery(e);const s=this.queryTokenForLastPageOfPaginatedQuery(e),n=this.client.localQueryResultByToken(s);if(!n)return!1;const i=qe(n);if(i.isDone)return!1;this.addPageToPaginatedQuery(e,i.continueCursor,t);const r={timestamp:this.lastTransitionTs,reflectedMutations:[],queries:[],paginatedQueries:[{token:e,modification:{kind:"Updated",result:this.localQueryResultByToken(e)}}]};return this.onTransition(r),!0}queriesContainingTokens(e){if(0===e.length)return[];const t=[],s=new Set(e);for(const[e,n]of this.paginatedQuerySet)for(const i of this.allQueryTokens(n))if(s.has(i)){t.push(e);break}return t}processPaginatedQuerySplits(e,t){for(const s of e){const e=this.mustGetPaginatedQuery(s),{ongoingSplits:n,pageKeyToQuery:i,pageKeys:r}=e;for(const[s,[r,o]]of n)void 0!==t(i.get(r).queryToken)&&void 0!==t(i.get(o).queryToken)&&this.completePaginatedQuerySplit(e,s,r,o);for(const s of r){if(n.has(s))continue;const r=t(i.get(s).queryToken);if(!r)continue;const o=qe(r);o.splitCursor&&("SplitRecommended"===o.pageStatus||"SplitRequired"===o.pageStatus||o.page.length>2*e.options.initialNumItems)&&this.splitPaginatedQueryPage(e,s,o.splitCursor,o.continueCursor)}}}splitPaginatedQueryPage(e,t,s,n){const i=e.nextPageKey++,r=e.nextPageKey++,o={cursor:n,numItems:e.options.initialNumItems,id:e.id},a=this.client.subscribe(e.canonicalizedUdfPath,{...e.args,paginationOpts:{...o,cursor:null,endCursor:s}});e.pageKeyToQuery.set(i,a);const u=this.client.subscribe(e.canonicalizedUdfPath,{...e.args,paginationOpts:{...o,cursor:s,endCursor:n}});e.pageKeyToQuery.set(r,u),e.ongoingSplits.set(t,[i,r])}addPageToPaginatedQuery(e,t,s){const n=this.mustGetPaginatedQuery(e),i=n.nextPageKey++,r={cursor:t,numItems:s,id:n.id},o={...n.args,paginationOpts:r},a=this.client.subscribe(n.canonicalizedUdfPath,o);return n.pageKeys.push(i),n.pageKeyToQuery.set(i,a),a}removePaginatedQuerySubscriber(e){const t=this.paginatedQuerySet.get(e);if(t&&(t.numSubscribers-=1,!(t.numSubscribers>0))){for(const e of t.pageKeyToQuery.values())e.unsubscribe();this.paginatedQuerySet.delete(e)}}completePaginatedQuerySplit(e,t,s,n){const i=e.pageKeyToQuery.get(t);e.pageKeyToQuery.delete(t);const r=e.pageKeys.indexOf(t);e.pageKeys.splice(r,1,s,n),e.ongoingSplits.delete(t),i.unsubscribe()}activePageQueryTokens(e){return e.pageKeys.map(t=>e.pageKeyToQuery.get(t).queryToken)}allQueryTokens(e){return Array.from(e.pageKeyToQuery.values()).map(e=>e.queryToken)}queryTokenForLastPageOfPaginatedQuery(e){const t=this.mustGetPaginatedQuery(e),s=t.pageKeys[t.pageKeys.length-1];if(void 0===s)throw new Error(`No pages for paginated query ${e}`);return t.pageKeyToQuery.get(s).queryToken}mustGetPaginatedQuery(e){const t=this.paginatedQuerySet.get(e);if(!t)throw new Error("paginated query no longer exists for token "+e);return t}}var Ie=Object.defineProperty,Oe=(e,t,s)=>((e,t,s)=>t in e?Ie(e,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[t]=s)(e,"symbol"!=typeof t?t+"":t,s);class ConvexClient{constructor(e,t={}){Oe(this,"listeners"),Oe(this,"_client"),Oe(this,"_paginatedClient"),Oe(this,"callNewListenersWithCurrentValuesTimer"),Oe(this,"_closed"),Oe(this,"_disabled"),!0!==t.skipConvexDeploymentUrlCheck&&f(e);const{disabled:s,...n}=t;this._closed=!1,this._disabled=!!s,"undefined"!=typeof window||"unsavedChangesWarning"in n||(n.unsavedChangesWarning=!1),this.disabled||(this._client=new BaseConvexClient(e,()=>{},n),this._paginatedClient=new PaginatedQueryClient(this._client,e=>this._transition(e))),this.listeners=new Set}get closed(){return this._closed}get client(){if(this._client)return this._client;throw new Error("ConvexClient is disabled")}get paginatedClient(){if(this._paginatedClient)return this._paginatedClient;throw new Error("ConvexClient is disabled")}get disabled(){return this._disabled}onUpdate(e,t,s,n){if(this.disabled)return this.createDisabledUnsubscribe();const{queryToken:i,unsubscribe:r}=this.client.subscribe(ee(e),t),o={queryToken:i,callback:s,onError:n,unsubscribe:r,hasEverRun:!1,query:e,args:t,paginationOptions:void 0};this.listeners.add(o),this.queryResultReady(i)&&void 0===this.callNewListenersWithCurrentValuesTimer&&(this.callNewListenersWithCurrentValuesTimer=setTimeout(()=>this.callNewListenersWithCurrentValues(),0));const a={unsubscribe:()=>{this.closed||(this.listeners.delete(o),r())},getCurrentValue:()=>this.client.localQueryResultByToken(i),getQueryLogs:()=>this.client.localQueryLogs(i)},u=a.unsubscribe;return Object.assign(u,a),u}onPaginatedUpdate_experimental(e,t,s,n,i){if(this.disabled)return this.createDisabledUnsubscribe();const r={initialNumItems:s.initialNumItems,id:-1},{paginatedQueryToken:o,unsubscribe:a}=this.paginatedClient.subscribe(ee(e),t,r),u={queryToken:o,callback:n,onError:i,unsubscribe:a,hasEverRun:!1,query:e,args:t,paginationOptions:r};this.listeners.add(u),this.paginatedClient.localQueryResultByToken(o)&&void 0===this.callNewListenersWithCurrentValuesTimer&&(this.callNewListenersWithCurrentValuesTimer=setTimeout(()=>this.callNewListenersWithCurrentValues(),0));const c={unsubscribe:()=>{this.closed||(this.listeners.delete(u),a())},getCurrentValue:()=>this.paginatedClient.localQueryResult(ee(e),t,r),getQueryLogs:()=>[]},h=c.unsubscribe;return Object.assign(h,c),h}callNewListenersWithCurrentValues(){this.callNewListenersWithCurrentValuesTimer=void 0,this._transition({queries:[],paginatedQueries:[]},!0)}queryResultReady(e){return this.client.hasLocalQueryResultByToken(e)}createDisabledUnsubscribe(){const e=()=>{},t={unsubscribe:e,getCurrentValue:()=>{},getQueryLogs:()=>{}};return Object.assign(e,t),e}async close(){if(!this.disabled)return this.listeners.clear(),this._closed=!0,this._paginatedClient&&(this._paginatedClient=void 0),this.client.close()}getAuth(){if(!this.disabled)return this.client.getCurrentAuthClaims()}setAuth(e,t){this.disabled||this.client.setAuth(e,t??(()=>{}))}setAdminAuth(e,t){if(this.closed)throw new Error("ConvexClient has already been closed.");this.disabled||this.client.setAdminAuth(e,t)}_transition({queries:e,paginatedQueries:t},s=!1){const n=[...e.map(e=>e.token),...t.map(e=>e.token)];for(const e of this.listeners){const{callback:t,queryToken:i,onError:r,hasEverRun:o}=e,a=J(i),u=a?!!this.paginatedClient.localQueryResultByToken(i):this.client.hasLocalQueryResultByToken(i);if(n.includes(i)||s&&!o&&u){let s;e.hasEverRun=!0;try{s=a?this.paginatedClient.localQueryResultByToken(i):this.client.localQueryResultByToken(i)}catch(e){if(!(e instanceof Error))throw e;r?r(e,"Second argument to onUpdate onError is reserved for later use"):Promise.reject(e);continue}t(s,"Second argument to onUpdate callback is reserved for later use")}}}async mutation(e,t,s){if(this.disabled)throw new Error("ConvexClient is disabled");return await this.client.mutation(ee(e),t,s)}async action(e,t){if(this.disabled)throw new Error("ConvexClient is disabled");return await this.client.action(ee(e),t)}async query(e,t){if(this.disabled)throw new Error("ConvexClient is disabled");const s=this.client.localQueryResult(ee(e),t);return void 0!==s?Promise.resolve(s):new Promise((s,n)=>{const{unsubscribe:i}=this.onUpdate(e,t,e=>{i(),s(e)},e=>{i(),n(e)})})}connectionState(){if(this.disabled)throw new Error("ConvexClient is disabled");return this.client.connectionState()}subscribeToConnectionState(e){return this.disabled?()=>{}:this.client.subscribeToConnectionState(e)}}Object.defineProperty}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";(this.webpackChunkCocolightApiClient=this.webpackChunkCocolightApiClient||[]).push([[499],{1499:(t,e,r)=>{r.r(e),r.d(e,{ConvexDataNormalizer:()=>ConvexDataNormalizer});class ConvexDataNormalizer{_convexUrl;_tableToCollectionMap;constructor(t={}){this._convexUrl=t.convexUrl??"",this._tableToCollectionMap=t.tableToCollectionMap??{}}transformResponse(t){return null==t?t:Array.isArray(t)?t.map(t=>this.normalizeEntity(t)):"object"==typeof t?this.normalizeEntity(t):t}transformRequest(t,e){return t}normalizeEntity(t){if(!t||"object"!=typeof t)return t;const e={};for(const[r,i]of Object.entries(t))switch(r){case"_id":e.id=String(i),e._id=String(i);break;case"_creationTime":e.created={$date:i};break;default:e[r]=this._normalizeValue(i)}return e}ensureFullURL(t){return t?/^https?:\/\//i.test(t)?t:this._convexUrl?`${this._convexUrl}/api/storage/${t}`:t:t}_normalizeValue(t){return null==t?t:Array.isArray(t)?t.map(t=>this._normalizeValue(t)):"object"==typeof t&&t._id?this.normalizeEntity(t):t}}}}]);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";exports.id=499,exports.ids=[499],exports.modules={499:(e,t,r)=>{r.r(t),r.d(t,{ConvexDataNormalizer:()=>ConvexDataNormalizer});class ConvexDataNormalizer{_convexUrl;_tableToCollectionMap;constructor(e={}){this._convexUrl=e.convexUrl??"",this._tableToCollectionMap=e.tableToCollectionMap??{}}transformResponse(e){return null==e?e:Array.isArray(e)?e.map(e=>this.normalizeEntity(e)):"object"==typeof e?this.normalizeEntity(e):e}transformRequest(e,t){return e}normalizeEntity(e){if(!e||"object"!=typeof e)return e;const t={};for(const[r,o]of Object.entries(e))switch(r){case"_id":t.id=String(o),t._id=String(o);break;case"_creationTime":t.created={$date:o};break;default:t[r]=this._normalizeValue(o)}return t}ensureFullURL(e){return e?/^https?:\/\//i.test(e)?e:this._convexUrl?`${this._convexUrl}/api/storage/${e}`:e:e}_normalizeValue(e){return null==e?e:Array.isArray(e)?e.map(e=>this._normalizeValue(e)):"object"==typeof e&&e._id?this.normalizeEntity(e):e}}}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const __webpack_esm_id__=499;export const __webpack_esm_ids__=[499];export const __webpack_esm_modules__={499:(e,t,r)=>{r.r(t),r.d(t,{ConvexDataNormalizer:()=>ConvexDataNormalizer});class ConvexDataNormalizer{_convexUrl;_tableToCollectionMap;constructor(e={}){this._convexUrl=e.convexUrl??"",this._tableToCollectionMap=e.tableToCollectionMap??{}}transformResponse(e){return null==e?e:Array.isArray(e)?e.map(e=>this.normalizeEntity(e)):"object"==typeof e?this.normalizeEntity(e):e}transformRequest(e,t){return e}normalizeEntity(e){if(!e||"object"!=typeof e)return e;const t={};for(const[r,o]of Object.entries(e))switch(r){case"_id":t.id=String(o),t._id=String(o);break;case"_creationTime":t.created={$date:o};break;default:t[r]=this._normalizeValue(o)}return t}ensureFullURL(e){return e?/^https?:\/\//i.test(e)?e:this._convexUrl?`${this._convexUrl}/api/storage/${e}`:e:e}_normalizeValue(e){return null==e?e:Array.isArray(e)?e.map(e=>this._normalizeValue(e)):"object"==typeof e&&e._id?this.normalizeEntity(e):e}}}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";(this.webpackChunkCocolightApiClient=this.webpackChunkCocolightApiClient||[]).push([[556],{7556:(e,t,n)=>{n.r(t),n.d(t,{ConvexTransportAdapter:()=>ConvexTransportAdapter});var i=n(9359);class ConvexTransportAdapter{_convexUrl;_operationMap;_tokenProvider;_logger;_convexClient=null;constructor(e){this._convexUrl=e.convexUrl,this._operationMap=e.operationMap,this._tokenProvider=e.tokenProvider,this._logger=e.logger}async execute(e){const t=this._operationMap[e.operationName];if(!t)throw new i.ApiClientError(`Pas de mapping Convex pour l'operation : ${e.operationName}`,404);const n=await this._getClient(),o={...e.data,...e.resolvedPathParams||{}},r=this._resolveRef(t.functionRef);try{let e;switch(t.kind){case"query":e=await n.query(r,o);break;case"mutation":e=await n.mutation(r,o);break;case"action":e=await n.action(r,o);break;default:throw new i.ApiClientError(`Type de fonction Convex inconnu : ${t.kind}`,400)}return{data:e,status:200,meta:{backend:"convex",functionRef:t.functionRef}}}catch(t){throw this._logger?.error(`[ConvexTransport] Erreur sur ${e.operationName}:`,t?.message),new i.ApiClientError(t?.message||`Erreur Convex pour ${e.operationName}`,t?.data?.code||500,t?.data)}}isAvailable(){if(!this._convexClient)return!1;try{const e=this._convexClient.connectionState?.();return e?.isWebSocketConnected??!0}catch{return!0}}setTokenProvider(e){this._tokenProvider=e,this._convexClient&&this._convexClient.setAuth(e)}async getClient(){return this._getClient()}async subscribe(e,t,n){const o=this._operationMap[e];if(!o)throw new i.ApiClientError(`Pas de mapping Convex pour l'operation : ${e}`,404);if("query"!==o.kind)throw new i.ApiClientError(`Seules les queries Convex supportent les subscriptions (${e} est un ${o.kind})`,400);if(!o.subscribable)throw new i.ApiClientError(`L'operation ${e} n'est pas marquee comme subscribable`,400);const r=await this._getClient(),s=this._resolveRef(o.functionRef);return r.onUpdate(s,t,n)}dispose(){this._convexClient&&(this._convexClient.close?.(),this._convexClient=null)}_resolveRef(e){let t=e;t.startsWith("api.")&&(t=t.slice(4));const n=t.lastIndexOf(".");return n>0&&(t=t.substring(0,n)+":"+t.substring(n+1)),t}async _getClient(){if(!this._convexClient)try{const{ConvexClient:e}=await n.e(407).then(n.bind(n,3407));this._convexClient=new e(this._convexUrl),this._tokenProvider&&this._convexClient.setAuth(this._tokenProvider)}catch{throw new i.ApiClientError("Le package 'convex' n'est pas installe. Executez: npm install convex",500)}return this._convexClient}}}}]);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";exports.id=556,exports.ids=[556],exports.modules={556:(e,t,n)=>{n.r(t),n.d(t,{ConvexTransportAdapter:()=>ConvexTransportAdapter});var r=n(359);class ConvexTransportAdapter{_convexUrl;_operationMap;_tokenProvider;_logger;_convexClient=null;constructor(e){this._convexUrl=e.convexUrl,this._operationMap=e.operationMap,this._tokenProvider=e.tokenProvider,this._logger=e.logger}async execute(e){const t=this._operationMap[e.operationName];if(!t)throw new r.ApiClientError(`Pas de mapping Convex pour l'operation : ${e.operationName}`,404);const n=await this._getClient(),o={...e.data,...e.resolvedPathParams||{}},i=this._resolveRef(t.functionRef);try{let e;switch(t.kind){case"query":e=await n.query(i,o);break;case"mutation":e=await n.mutation(i,o);break;case"action":e=await n.action(i,o);break;default:throw new r.ApiClientError(`Type de fonction Convex inconnu : ${t.kind}`,400)}return{data:e,status:200,meta:{backend:"convex",functionRef:t.functionRef}}}catch(t){throw this._logger?.error(`[ConvexTransport] Erreur sur ${e.operationName}:`,t?.message),new r.ApiClientError(t?.message||`Erreur Convex pour ${e.operationName}`,t?.data?.code||500,t?.data)}}isAvailable(){if(!this._convexClient)return!1;try{const e=this._convexClient.connectionState?.();return e?.isWebSocketConnected??!0}catch{return!0}}setTokenProvider(e){this._tokenProvider=e,this._convexClient&&this._convexClient.setAuth(e)}async getClient(){return this._getClient()}async subscribe(e,t,n){const o=this._operationMap[e];if(!o)throw new r.ApiClientError(`Pas de mapping Convex pour l'operation : ${e}`,404);if("query"!==o.kind)throw new r.ApiClientError(`Seules les queries Convex supportent les subscriptions (${e} est un ${o.kind})`,400);if(!o.subscribable)throw new r.ApiClientError(`L'operation ${e} n'est pas marquee comme subscribable`,400);const i=await this._getClient(),s=this._resolveRef(o.functionRef);return i.onUpdate(s,t,n)}dispose(){this._convexClient&&(this._convexClient.close?.(),this._convexClient=null)}_resolveRef(e){let t=e;t.startsWith("api.")&&(t=t.slice(4));const n=t.lastIndexOf(".");return n>0&&(t=t.substring(0,n)+":"+t.substring(n+1)),t}async _getClient(){if(!this._convexClient)try{const{ConvexClient:e}=await n.e(203).then(n.bind(n,203));this._convexClient=new e(this._convexUrl),this._tokenProvider&&this._convexClient.setAuth(this._tokenProvider)}catch{throw new r.ApiClientError("Le package 'convex' n'est pas installe. Executez: npm install convex",500)}return this._convexClient}}}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const __webpack_esm_id__=556;export const __webpack_esm_ids__=[556];export const __webpack_esm_modules__={556:(e,t,n)=>{n.r(t),n.d(t,{ConvexTransportAdapter:()=>ConvexTransportAdapter});var o=n(359);class ConvexTransportAdapter{_convexUrl;_operationMap;_tokenProvider;_logger;_convexClient=null;constructor(e){this._convexUrl=e.convexUrl,this._operationMap=e.operationMap,this._tokenProvider=e.tokenProvider,this._logger=e.logger}async execute(e){const t=this._operationMap[e.operationName];if(!t)throw new o.ApiClientError(`Pas de mapping Convex pour l'operation : ${e.operationName}`,404);const n=await this._getClient(),r={...e.data,...e.resolvedPathParams||{}},i=this._resolveRef(t.functionRef);try{let e;switch(t.kind){case"query":e=await n.query(i,r);break;case"mutation":e=await n.mutation(i,r);break;case"action":e=await n.action(i,r);break;default:throw new o.ApiClientError(`Type de fonction Convex inconnu : ${t.kind}`,400)}return{data:e,status:200,meta:{backend:"convex",functionRef:t.functionRef}}}catch(t){throw this._logger?.error(`[ConvexTransport] Erreur sur ${e.operationName}:`,t?.message),new o.ApiClientError(t?.message||`Erreur Convex pour ${e.operationName}`,t?.data?.code||500,t?.data)}}isAvailable(){if(!this._convexClient)return!1;try{const e=this._convexClient.connectionState?.();return e?.isWebSocketConnected??!0}catch{return!0}}setTokenProvider(e){this._tokenProvider=e,this._convexClient&&this._convexClient.setAuth(e)}async getClient(){return this._getClient()}async subscribe(e,t,n){const r=this._operationMap[e];if(!r)throw new o.ApiClientError(`Pas de mapping Convex pour l'operation : ${e}`,404);if("query"!==r.kind)throw new o.ApiClientError(`Seules les queries Convex supportent les subscriptions (${e} est un ${r.kind})`,400);if(!r.subscribable)throw new o.ApiClientError(`L'operation ${e} n'est pas marquee comme subscribable`,400);const i=await this._getClient(),s=this._resolveRef(r.functionRef);return i.onUpdate(s,t,n)}dispose(){this._convexClient&&(this._convexClient.close?.(),this._convexClient=null)}_resolveRef(e){let t=e;t.startsWith("api.")&&(t=t.slice(4));const n=t.lastIndexOf(".");return n>0&&(t=t.substring(0,n)+":"+t.substring(n+1)),t}async _getClient(){if(!this._convexClient)try{const{ConvexClient:e}=await n.e(407).then(n.bind(n,407));this._convexClient=new e(this._convexUrl),this._tokenProvider&&this._convexClient.setAuth(this._tokenProvider)}catch{throw new o.ApiClientError("Le package 'convex' n'est pas installe. Executez: npm install convex",500)}return this._convexClient}}}};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const
|
|
1
|
+
export const __webpack_esm_id__=588;export const __webpack_esm_ids__=[588];export const __webpack_esm_modules__={588:(e,i,r)=>{r.d(i,{FileOfflineStorage:()=>FileOfflineStorage});var t=r(421),s=r(116),n=r(521),c=r(285);class FileOfflineStorage extends c.LD{dir;filePath;constructor(e="offline-queue.json",i=n.join(s.homedir(),".config","cocolight")){super(),this.dir=i,this.filePath=n.join(i,e),this._ensureDirectoryExists()}_ensureDirectoryExists(){t.existsSync(this.dir)||t.mkdirSync(this.dir,{recursive:!0})}_readFile(){if(!t.existsSync(this.filePath))return[];try{return JSON.parse(t.readFileSync(this.filePath,"utf8"))}catch(e){return console.error("Erreur lecture offline queue :",e),[]}}_writeFile(e){try{t.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf8")}catch(e){console.warn("[OfflineQueue] Erreur d'écriture:",e)}}async loadQueue(){return this._readFile()}async saveQueue(e){this._writeFile(e)}}}};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const
|
|
1
|
+
export const __webpack_esm_id__=593;export const __webpack_esm_ids__=[593];export const __webpack_esm_modules__={593:(e,t,r)=>{r.d(t,{MultiServerFileStorageStrategy:()=>MultiServerFileStorageStrategy});var i=r(421),s=r(116),n=r(521),l=r(602);class MultiServerFileStorageStrategy extends l.SJ{filePath;constructor(e="tokens.json",t=n.join(s.homedir(),".config","cocolight")){super(),this.filePath=n.join(t,e),i.existsSync(t)||i.mkdirSync(t,{recursive:!0})}_readFile(){if(!i.existsSync(this.filePath))return{};try{return JSON.parse(i.readFileSync(this.filePath,"utf8"))}catch{return{}}}_writeFile(e){i.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf8")}getAccessToken(){const e=this._requireBaseURL();return this._readFile()[e]?.accessToken??null}setAccessToken(e){const t=this._requireBaseURL(),r=this._readFile();r[t]={...r[t]||{},accessToken:e},this._writeFile(r)}getRefreshToken(){const e=this._requireBaseURL();return this._readFile()[e]?.refreshToken??null}setRefreshToken(e){const t=this._requireBaseURL(),r=this._readFile();r[t]={...r[t]||{},refreshToken:e},this._writeFile(r)}clear(){const e=this._requireBaseURL(),t=this._readFile();delete t[e],this._writeFile(t)}getServers(){return Object.keys(this._readFile())}exportAll(){return this._readFile()}}}};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export const
|
|
1
|
+
export const __webpack_esm_id__=839;export const __webpack_esm_ids__=[839];export const __webpack_esm_modules__={839:(e,t,r)=>{r.d(t,{FileStorageStrategy:()=>FileStorageStrategy});var i=r(421),s=r(116),n=r(521),o=r(193);class FileStorageStrategy extends o.u3{dir;filePath;constructor(e="tokens.json",t=n.join(s.homedir(),".config","cocolight")){super(),this.dir=t,this.filePath=n.join(t,e),this._ensureDirectoryExists()}_ensureDirectoryExists(){i.existsSync(this.dir)||i.mkdirSync(this.dir,{recursive:!0})}_readFile(){if(!i.existsSync(this.filePath))return{};try{return JSON.parse(i.readFileSync(this.filePath,"utf8"))}catch(e){return console.error("Error reading token file:",e),{}}}_writeFile(e){i.writeFileSync(this.filePath,JSON.stringify(e,null,2),"utf8")}getAccessToken(){return this._readFile().accessToken||null}setAccessToken(e){const t=this._readFile();t.accessToken=e,this._writeFile(t)}getRefreshToken(){return this._readFile().refreshToken||null}setRefreshToken(e){const t=this._readFile();t.refreshToken=e,this._writeFile(t)}clear(){this._writeFile({})}}}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";(this.webpackChunkCocolightApiClient=this.webpackChunkCocolightApiClient||[]).push([[85],{3085:(e,r,s)=>{s.r(r),s.d(r,{ConvexNativeAuthProvider:()=>ConvexNativeAuthProvider});var t=s(5537);class ConvexNativeAuthProvider{_logger;_accessToken=null;_refreshToken=null;_userId=null;_refreshFn;constructor(e){this._logger=e?.logger}getAccessToken(){return this._accessToken}getRefreshToken(){return this._refreshToken}getUserId(){return this._userId}isAuthenticated(){return!!this._accessToken}canRefresh(){return!!this._refreshToken&&!!this._refreshFn}async refresh(){if(!this._refreshToken||!this._refreshFn)return!1;try{const e=await this._refreshFn(this._refreshToken);return!!e&&(this.setAccessToken(e.token),e.refreshToken&&this.setRefreshToken(e.refreshToken),!0)}catch(e){return this._logger?.error("[ConvexNativeAuthProvider] Refresh failed:",e),this.resetSession(),!1}}setAccessToken(e){this._accessToken=e,this._userId=e?this._extractUserIdFromToken(e):null}setRefreshToken(e){this._refreshToken=e}resetSession(){this._accessToken=null,this._refreshToken=null,this._userId=null,this._logger?.info("[ConvexNativeAuthProvider] Session reset")}setRefreshFn(e){this._refreshFn=e}getTokenProvider(){return async({forceRefreshToken:e})=>(e&&this.canRefresh()&&await this.refresh(),this._accessToken)}_extractUserIdFromToken(e){try{const r=(0,t.s)(e);return r.sub??r.id??r.userId??null}catch{return this._logger?.warn("[ConvexNativeAuthProvider] Failed to decode JWT"),null}}}}}]);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";exports.id=85,exports.ids=[85],exports.modules={85:(e,r,s)=>{s.r(r),s.d(r,{ConvexNativeAuthProvider:()=>ConvexNativeAuthProvider});var t=s(158);class ConvexNativeAuthProvider{_logger;_accessToken=null;_refreshToken=null;_userId=null;_refreshFn;constructor(e){this._logger=e?.logger}getAccessToken(){return this._accessToken}getRefreshToken(){return this._refreshToken}getUserId(){return this._userId}isAuthenticated(){return!!this._accessToken}canRefresh(){return!!this._refreshToken&&!!this._refreshFn}async refresh(){if(!this._refreshToken||!this._refreshFn)return!1;try{const e=await this._refreshFn(this._refreshToken);return!!e&&(this.setAccessToken(e.token),e.refreshToken&&this.setRefreshToken(e.refreshToken),!0)}catch(e){return this._logger?.error("[ConvexNativeAuthProvider] Refresh failed:",e),this.resetSession(),!1}}setAccessToken(e){this._accessToken=e,this._userId=e?this._extractUserIdFromToken(e):null}setRefreshToken(e){this._refreshToken=e}resetSession(){this._accessToken=null,this._refreshToken=null,this._userId=null,this._logger?.info("[ConvexNativeAuthProvider] Session reset")}setRefreshFn(e){this._refreshFn=e}getTokenProvider(){return async({forceRefreshToken:e})=>(e&&this.canRefresh()&&await this.refresh(),this._accessToken)}_extractUserIdFromToken(e){try{const r=(0,t.jwtDecode)(e);return r.sub??r.id??r.userId??null}catch{return this._logger?.warn("[ConvexNativeAuthProvider] Failed to decode JWT"),null}}}}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const __webpack_esm_id__=85;export const __webpack_esm_ids__=[85];export const __webpack_esm_modules__={85:(e,r,s)=>{s.r(r),s.d(r,{ConvexNativeAuthProvider:()=>ConvexNativeAuthProvider});var t=s(564);class ConvexNativeAuthProvider{_logger;_accessToken=null;_refreshToken=null;_userId=null;_refreshFn;constructor(e){this._logger=e?.logger}getAccessToken(){return this._accessToken}getRefreshToken(){return this._refreshToken}getUserId(){return this._userId}isAuthenticated(){return!!this._accessToken}canRefresh(){return!!this._refreshToken&&!!this._refreshFn}async refresh(){if(!this._refreshToken||!this._refreshFn)return!1;try{const e=await this._refreshFn(this._refreshToken);return!!e&&(this.setAccessToken(e.token),e.refreshToken&&this.setRefreshToken(e.refreshToken),!0)}catch(e){return this._logger?.error("[ConvexNativeAuthProvider] Refresh failed:",e),this.resetSession(),!1}}setAccessToken(e){this._accessToken=e,this._userId=e?this._extractUserIdFromToken(e):null}setRefreshToken(e){this._refreshToken=e}resetSession(){this._accessToken=null,this._refreshToken=null,this._userId=null,this._logger?.info("[ConvexNativeAuthProvider] Session reset")}setRefreshFn(e){this._refreshFn=e}getTokenProvider(){return async({forceRefreshToken:e})=>(e&&this.canRefresh()&&await this.refresh(),this._accessToken)}_extractUserIdFromToken(e){try{const r=(0,t.jwtDecode)(e);return r.sub??r.id??r.userId??null}catch{return this._logger?.warn("[ConvexNativeAuthProvider] Failed to decode JWT"),null}}}}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";(this.webpackChunkCocolightApiClient=this.webpackChunkCocolightApiClient||[]).push([[906],{5906:(e,r,o)=>{o.r(r),o.d(r,{ConvexAuthProvider:()=>ConvexAuthProvider});class ConvexAuthProvider{_tokenProvider;_userIdProvider;_logger;_cachedToken=null;_userId=null;constructor(e){this._tokenProvider=e.tokenProvider,this._userIdProvider=e.userIdProvider,this._logger=e.logger}getAccessToken(){return this._cachedToken}getRefreshToken(){return null}getUserId(){return this._userIdProvider?this._userIdProvider():this._userId}isAuthenticated(){return null!==this._cachedToken}canRefresh(){return!0}async refresh(){try{const e=await this._tokenProvider();return this._cachedToken=e,this._logger?.debug("[ConvexAuthProvider] Token refreshed via external provider"),!!e}catch(e){return this._logger?.error("[ConvexAuthProvider] Token refresh failed:",e),!1}}setAccessToken(e){this._cachedToken=e}setRefreshToken(e){this._logger?.debug("[ConvexAuthProvider] setRefreshToken is a no-op for Convex")}resetSession(){this._cachedToken=null,this._userId=null,this._logger?.info("[ConvexAuthProvider] Session reset")}}}}]);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";exports.id=906,exports.ids=[906],exports.modules={906:(e,r,o)=>{o.r(r),o.d(r,{ConvexAuthProvider:()=>ConvexAuthProvider});class ConvexAuthProvider{_tokenProvider;_userIdProvider;_logger;_cachedToken=null;_userId=null;constructor(e){this._tokenProvider=e.tokenProvider,this._userIdProvider=e.userIdProvider,this._logger=e.logger}getAccessToken(){return this._cachedToken}getRefreshToken(){return null}getUserId(){return this._userIdProvider?this._userIdProvider():this._userId}isAuthenticated(){return null!==this._cachedToken}canRefresh(){return!0}async refresh(){try{const e=await this._tokenProvider();return this._cachedToken=e,this._logger?.debug("[ConvexAuthProvider] Token refreshed via external provider"),!!e}catch(e){return this._logger?.error("[ConvexAuthProvider] Token refresh failed:",e),!1}}setAccessToken(e){this._cachedToken=e}setRefreshToken(e){this._logger?.debug("[ConvexAuthProvider] setRefreshToken is a no-op for Convex")}resetSession(){this._cachedToken=null,this._userId=null,this._logger?.info("[ConvexAuthProvider] Session reset")}}}};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const __webpack_esm_id__=906;export const __webpack_esm_ids__=[906];export const __webpack_esm_modules__={906:(e,r,o)=>{o.r(r),o.d(r,{ConvexAuthProvider:()=>ConvexAuthProvider});class ConvexAuthProvider{_tokenProvider;_userIdProvider;_logger;_cachedToken=null;_userId=null;constructor(e){this._tokenProvider=e.tokenProvider,this._userIdProvider=e.userIdProvider,this._logger=e.logger}getAccessToken(){return this._cachedToken}getRefreshToken(){return null}getUserId(){return this._userIdProvider?this._userIdProvider():this._userId}isAuthenticated(){return null!==this._cachedToken}canRefresh(){return!0}async refresh(){try{const e=await this._tokenProvider();return this._cachedToken=e,this._logger?.debug("[ConvexAuthProvider] Token refreshed via external provider"),!!e}catch(e){return this._logger?.error("[ConvexAuthProvider] Token refresh failed:",e),!1}}setAccessToken(e){this._cachedToken=e}setRefreshToken(e){this._logger?.debug("[ConvexAuthProvider] setRefreshToken is a no-op for Convex")}resetSession(){this._cachedToken=null,this._userId=null,this._logger?.info("[ConvexAuthProvider] Session reset")}}}};
|