@vaiftech/client 1.0.12 → 1.0.13

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/index.d.mts CHANGED
@@ -3452,7 +3452,11 @@ interface RealtimeMonitoringModule {
3452
3452
  /**
3453
3453
  * Get recent realtime events for a project
3454
3454
  */
3455
- getEvents(projectId: string, limit?: number): Promise<RealtimeMonitoringEvent[]>;
3455
+ getEvents(projectId: string, options?: {
3456
+ limit?: number;
3457
+ source?: string;
3458
+ level?: string;
3459
+ }): Promise<RealtimeMonitoringEvent[]>;
3456
3460
  /**
3457
3461
  * Get realtime status (tables with triggers) for a project
3458
3462
  */
@@ -8389,11 +8393,46 @@ interface ExecutePlanResult {
8389
8393
  artifacts?: GeneratedArtifacts;
8390
8394
  error?: string;
8391
8395
  }
8396
+ /**
8397
+ * Available copilot model info
8398
+ */
8399
+ interface CopilotModelInfo {
8400
+ modelId: string;
8401
+ name: string;
8402
+ tier: "free" | "pro" | "enterprise";
8403
+ available: boolean;
8404
+ multiplier: number;
8405
+ }
8406
+ /**
8407
+ * Credit status response
8408
+ */
8409
+ interface CopilotCreditStatus {
8410
+ totalCreditsUsed: number;
8411
+ creditLimit: number;
8412
+ percentUsed: number;
8413
+ remaining: number;
8414
+ status: "ok" | "warning" | "exceeded";
8415
+ premiumMultiplier: number;
8416
+ }
8392
8417
  interface CopilotModule {
8393
8418
  /**
8394
8419
  * Send a chat message to the Copilot
8395
8420
  */
8396
8421
  chat(input: CopilotChatInput): Promise<CopilotChatResponse>;
8422
+ /**
8423
+ * Get streaming URL for chat (returns full API URL)
8424
+ */
8425
+ getStreamUrl(): string;
8426
+ /**
8427
+ * Get available models based on plan entitlements
8428
+ */
8429
+ getModels(projectId: string): Promise<{
8430
+ models: CopilotModelInfo[];
8431
+ }>;
8432
+ /**
8433
+ * Get credit status for the project
8434
+ */
8435
+ getCreditStatus(projectId: string): Promise<CopilotCreditStatus>;
8397
8436
  /**
8398
8437
  * List sessions for a project
8399
8438
  */
@@ -8435,6 +8474,28 @@ interface CopilotModule {
8435
8474
  * Get classification statistics (admin)
8436
8475
  */
8437
8476
  getClassificationStats(): Promise<ClassificationStats>;
8477
+ /**
8478
+ * Get org-level usage statistics (for billing page)
8479
+ */
8480
+ getUsage(orgId: string): Promise<CopilotUsageResponse>;
8481
+ }
8482
+ /**
8483
+ * Org-level usage response
8484
+ */
8485
+ interface CopilotUsageResponse {
8486
+ orgId: string;
8487
+ summary: {
8488
+ totalSessions: number;
8489
+ totalMessages: number;
8490
+ totalCredits: number;
8491
+ totalTokens: number;
8492
+ };
8493
+ byModel: Record<string, {
8494
+ sessions: number;
8495
+ messages: number;
8496
+ credits: number;
8497
+ }>;
8498
+ premiumMultiplier: number;
8438
8499
  }
8439
8500
 
8440
8501
  /**
package/dist/index.d.ts CHANGED
@@ -3452,7 +3452,11 @@ interface RealtimeMonitoringModule {
3452
3452
  /**
3453
3453
  * Get recent realtime events for a project
3454
3454
  */
3455
- getEvents(projectId: string, limit?: number): Promise<RealtimeMonitoringEvent[]>;
3455
+ getEvents(projectId: string, options?: {
3456
+ limit?: number;
3457
+ source?: string;
3458
+ level?: string;
3459
+ }): Promise<RealtimeMonitoringEvent[]>;
3456
3460
  /**
3457
3461
  * Get realtime status (tables with triggers) for a project
3458
3462
  */
@@ -8389,11 +8393,46 @@ interface ExecutePlanResult {
8389
8393
  artifacts?: GeneratedArtifacts;
8390
8394
  error?: string;
8391
8395
  }
8396
+ /**
8397
+ * Available copilot model info
8398
+ */
8399
+ interface CopilotModelInfo {
8400
+ modelId: string;
8401
+ name: string;
8402
+ tier: "free" | "pro" | "enterprise";
8403
+ available: boolean;
8404
+ multiplier: number;
8405
+ }
8406
+ /**
8407
+ * Credit status response
8408
+ */
8409
+ interface CopilotCreditStatus {
8410
+ totalCreditsUsed: number;
8411
+ creditLimit: number;
8412
+ percentUsed: number;
8413
+ remaining: number;
8414
+ status: "ok" | "warning" | "exceeded";
8415
+ premiumMultiplier: number;
8416
+ }
8392
8417
  interface CopilotModule {
8393
8418
  /**
8394
8419
  * Send a chat message to the Copilot
8395
8420
  */
8396
8421
  chat(input: CopilotChatInput): Promise<CopilotChatResponse>;
8422
+ /**
8423
+ * Get streaming URL for chat (returns full API URL)
8424
+ */
8425
+ getStreamUrl(): string;
8426
+ /**
8427
+ * Get available models based on plan entitlements
8428
+ */
8429
+ getModels(projectId: string): Promise<{
8430
+ models: CopilotModelInfo[];
8431
+ }>;
8432
+ /**
8433
+ * Get credit status for the project
8434
+ */
8435
+ getCreditStatus(projectId: string): Promise<CopilotCreditStatus>;
8397
8436
  /**
8398
8437
  * List sessions for a project
8399
8438
  */
@@ -8435,6 +8474,28 @@ interface CopilotModule {
8435
8474
  * Get classification statistics (admin)
8436
8475
  */
8437
8476
  getClassificationStats(): Promise<ClassificationStats>;
8477
+ /**
8478
+ * Get org-level usage statistics (for billing page)
8479
+ */
8480
+ getUsage(orgId: string): Promise<CopilotUsageResponse>;
8481
+ }
8482
+ /**
8483
+ * Org-level usage response
8484
+ */
8485
+ interface CopilotUsageResponse {
8486
+ orgId: string;
8487
+ summary: {
8488
+ totalSessions: number;
8489
+ totalMessages: number;
8490
+ totalCredits: number;
8491
+ totalTokens: number;
8492
+ };
8493
+ byModel: Record<string, {
8494
+ sessions: number;
8495
+ messages: number;
8496
+ credits: number;
8497
+ }>;
8498
+ premiumMultiplier: number;
8438
8499
  }
8439
8500
 
8440
8501
  /**
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- 'use strict';var auth=require('@vaiftech/auth');var O=class s extends Error{constructor(n,e){super(n),this.name="VaifError",this.code=e.code,this.statusCode=e.statusCode,this.requestId=e.requestId,this.details=e.details;let t=Error;t.captureStackTrace&&t.captureStackTrace(this,s);}toJSON(){return {name:this.name,message:this.message,code:this.code,statusCode:this.statusCode,requestId:this.requestId,details:this.details}}},D=class extends O{constructor(n,e){super(n,{code:e?.code??"AUTH_ERROR",statusCode:e?.statusCode??401,requestId:e?.requestId}),this.name="VaifAuthError";}},U=class extends O{constructor(n,e){super(n,{code:"VALIDATION_ERROR",statusCode:400,requestId:e?.requestId,details:e?.details??e?.fieldErrors}),this.name="VaifValidationError",this.fieldErrors=e?.fieldErrors;}},x=class extends O{constructor(n,e){super(n,{code:"NETWORK_ERROR"}),this.name="VaifNetworkError",this.cause=e;}},$=class extends O{constructor(n,e){super(n,{code:"RATE_LIMITED",statusCode:429}),this.name="VaifRateLimitError",this.retryAfter=e;}},F=class extends O{constructor(n,e){super(n,{code:"NOT_FOUND",statusCode:404,requestId:e}),this.name="VaifNotFoundError";}};function be(s){return s instanceof O}async function fe(s){let n;try{n=await s.json();}catch{}let e=n?.message??n?.error??s.statusText??"Request failed",t=n?.requestId;switch(s.status){case 400:return new U(e,{details:n?.details,requestId:t});case 401:return new D(e,{code:"UNAUTHORIZED",statusCode:401,requestId:t});case 403:return new D(e,{code:"FORBIDDEN",statusCode:403,requestId:t});case 404:return new F(e,t);case 429:{let r=s.headers.get("Retry-After"),o=r?parseInt(r,10):void 0;return new $(e,o)}default:return new O(e,{code:n?.error??"HTTP_ERROR",statusCode:s.status,requestId:t,details:n?.details})}}async function Pe(s,n){let{timeout:e=3e4,fetchFn:t,...r}=n,o=new AbortController,a=setTimeout(()=>o.abort(),e);try{let c=await t(s,{...r,signal:o.signal});if(clearTimeout(a),!c.ok)throw await fe(c);if(c.status===204)return;let i=await c.text();return i?JSON.parse(i):void 0}catch(c){throw clearTimeout(a),c instanceof O?c:c instanceof Error&&c.name==="AbortError"?new x("Request timed out"):c instanceof Error?new x(c.message,c):new x("Network request failed")}}function p(s){let{baseUrl:n,apiKey:e,apiKeyHeader:t,accessToken:r,fetch:o,timeout:a}=s;return async function(i,l={}){let u=`${n}${i}`,y={"Content-Type":"application/json",...l.headers??{}};if(e&&(y[t]=e),r){let I=typeof r=="function"?await r():r;y.Authorization=`Bearer ${I}`;}return Pe(u,{...l,headers:y,timeout:l.timeout??a,fetchFn:o})}}function h(s){let n=new URLSearchParams;for(let[t,r]of Object.entries(s))r!==void 0&&n.set(t,String(r));let e=n.toString();return e?`?${e}`:""}function Ie(s){return JSON.stringify(s)}function L(s,n,e={}){let t={...e},r=()=>{let i={};if(t.limit!==void 0&&(i.limit=t.limit),t.offset!==void 0&&(i.offset=t.offset),t.where&&(i.where=Ie(t.where)),t.orderBy){let l=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];i.orderBy=JSON.stringify(l);}return t.select&&t.select.length>0&&(i.select=t.select.join(",")),t.include&&t.include.length>0&&(i.include=JSON.stringify(t.include)),t.distinct&&t.distinct.length>0&&(i.distinct=t.distinct.join(",")),i},o=()=>h(r()),a=i=>L(s,n,{...t,...i}),c={async list(i){i&&(t={...t,...i});let l=o();return n(`/generated/${s}${l}`)},async get(i){let l={};t.select&&t.select.length>0&&(l.select=t.select.join(",")),t.include&&t.include.length>0&&(l.include=JSON.stringify(t.include));let u=h(l);return n(`/generated/${s}/${encodeURIComponent(i)}${u}`)},async first(){let i=await c.limit(1).list();return i.data.length>0?i.data[0]:null},async firstOrFail(){let i=await c.first();if(!i)throw new Error(`No record found in table '${s}' matching the query`);return i},async create(i){return n(`/generated/${s}`,{method:"POST",body:JSON.stringify(i)})},async update(i,l){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"PATCH",body:JSON.stringify(l)})},async delete(i){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"DELETE"})},async createMany(i,l){return n(`/generated/${s}/batch`,{method:"POST",body:JSON.stringify({records:i,skipOnConflict:l?.skipOnConflict,returnRecords:l?.returnRecords})})},async updateMany(i,l){return n(`/generated/${s}/batch`,{method:"PATCH",body:JSON.stringify({data:i,where:t.where,returnRecords:l?.returnRecords})})},async deleteMany(){return n(`/generated/${s}/batch`,{method:"DELETE",body:JSON.stringify({where:t.where})})},async upsert(i,l){return n(`/generated/${s}/upsert`,{method:"POST",body:JSON.stringify({data:i,conflictFields:l.conflictFields,updateFields:l.updateFields})})},async count(){let i=r(),l=h(i);return (await n(`/generated/${s}/count${l}`)).count},async sum(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/sum${u}`)).sum},async avg(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/avg${u}`)).avg},async min(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/min${u}`)).min},async max(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/max${u}`)).max},async aggregate(i,l){return n(`/generated/${s}/aggregate`,{method:"POST",body:JSON.stringify({aggregates:i,where:l?.where||t.where,groupBy:l?.groupBy,having:l?.having})})},async paginate(i){let l=i.page||1,u=i.pageSize||20,y=(l-1)*u,I=r();I.limit=u,I.offset=y,I.includeCount=true;let S=h(I),k=await n(`/generated/${s}${S}`),C=k.total||k.data.length,b=Math.ceil(C/u);return {data:k.data,pageInfo:{total:C,page:l,pageSize:u,pageCount:b,hasNextPage:l<b,hasPrevPage:l>1}}},async cursorPaginate(i){let l=r();l.limit=i.limit||20,i.cursor&&(l.cursor=i.cursor);let u=h(l),y=await n(`/generated/${s}/cursor${u}`);return {data:y.data,nextCursor:y.nextCursor,prevCursor:y.prevCursor,hasMore:y.hasMore}},where(i){if(t.where){let l=t.where;return a({where:{AND:[...Array.isArray(l)?l:[l],i]}})}return a({where:i})},orderBy(i,l="asc"){let u={field:i,direction:l};if(t.orderBy){let y=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];return a({orderBy:[...y,u]})}return a({orderBy:u})},select(...i){return a({select:i})},limit(i){return a({limit:i})},offset(i){return a({offset:i})},include(i){let l=t.include||[];return a({include:[...l,i]})},distinct(...i){return a({distinct:i})}};return c}function q(s){let n=p(s);return {from(e){return L(e,n)},async raw(e,t){return n("/generated/raw",{method:"POST",body:JSON.stringify({query:e,params:t})})},async transaction(e,t){return n("/generated/transaction",{method:"POST",body:JSON.stringify({operations:e,isolationLevel:t?.isolationLevel,timeout:t?.timeout})})},async withTransaction(e,t){let o=(await n("/generated/transaction/start",{method:"POST",body:JSON.stringify({isolationLevel:t?.isolationLevel,timeout:t?.timeout})})).transactionId,a=(i,l)=>{let u=new Headers(l?.headers);return u.set("X-Transaction-Id",o),n(i,{...l,headers:u})},c={from(i){return L(i,a)},async raw(i,l){return a("/generated/raw",{method:"POST",body:JSON.stringify({query:i,params:l})})},async transaction(){throw new Error("Nested transactions are not supported")},async withTransaction(){throw new Error("Nested transactions are not supported")}};try{let i=await e(c);return await n("/generated/transaction/commit",{method:"POST",body:JSON.stringify({transactionId:o})}),i}catch(i){throw await n("/generated/transaction/rollback",{method:"POST",body:JSON.stringify({transactionId:o})}).catch(()=>{}),i}}}}function J(s){let n=p(s);return {async signUp(e,t,r){return n("/auth/signup",{method:"POST",body:JSON.stringify({email:e,password:t,name:r?.name,phone:r?.phone,metadata:r?.metadata,redirectUrl:r?.redirectUrl})})},async login(e,t,r){return n("/auth/login",{method:"POST",body:JSON.stringify({email:e,password:t,mfaCode:r?.mfaCode,rememberMe:r?.rememberMe})})},async logout(){await n("/auth/logout",{method:"POST"});},async logoutAll(){await n("/auth/logout-all",{method:"POST"});},async getUser(){return (await n("/auth/me")).user},async updateProfile(e){return (await n("/users/me",{method:"PATCH",body:JSON.stringify(e)})).user},async changePassword(e){return n("/users/me/change-password",{method:"POST",body:JSON.stringify(e)})},async requestPasswordReset(e){return n("/auth/forgot-password",{method:"POST",body:JSON.stringify(e)})},async confirmPasswordReset(e){return n("/auth/reset-password",{method:"POST",body:JSON.stringify(e)})},async requestEmailVerification(e){return n("/auth/verify-email/send",{method:"POST",body:JSON.stringify(e||{})})},async confirmEmailVerification(e){return n("/auth/verify-email/confirm",{method:"POST",body:JSON.stringify(e)})},async getOAuthSignInUrl(e){return n("/auth/oauth/authorize",{method:"POST",body:JSON.stringify(e)})},async handleOAuthCallback(e){return n("/auth/oauth/callback",{method:"POST",body:JSON.stringify(e)})},async linkOAuthProvider(e){return n("/auth/oauth/link",{method:"POST",body:JSON.stringify(e)})},async unlinkOAuthProvider(e){return n(`/auth/oauth/unlink/${e}`,{method:"POST"})},async listLinkedProviders(){return n("/auth/oauth/providers")},async requestMagicLink(e){return n("/auth/magic-link/send",{method:"POST",body:JSON.stringify(e)})},async verifyMagicLink(e){return n("/auth/magic-link/verify",{method:"POST",body:JSON.stringify(e)})},async requestPhoneVerification(e){return n("/auth/phone/send",{method:"POST",body:JSON.stringify(e)})},async confirmPhoneVerification(e){return n("/auth/phone/verify",{method:"POST",body:JSON.stringify(e)})},async setupMFA(e){return n("/auth/mfa/setup",{method:"POST",body:JSON.stringify({method:e})})},async enableMFA(e){return n("/auth/mfa/enable",{method:"POST",body:JSON.stringify({code:e})})},async disableMFA(e){return n("/auth/mfa/disable",{method:"POST",body:JSON.stringify({code:e})})},async verifyMFA(e,t){return n("/auth/mfa/verify",{method:"POST",body:JSON.stringify({mfaToken:e,code:t})})},async regenerateBackupCodes(){return n("/auth/mfa/backup-codes",{method:"POST"})},async refreshToken(e){return n("/auth/refresh",{method:"POST",body:JSON.stringify({refreshToken:e})})},async listSessions(){return n("/auth/sessions")},async revokeSession(e){return n(`/auth/sessions/${e}`,{method:"DELETE"})},async revokeOtherSessions(){return n("/auth/sessions/revoke-others",{method:"POST"})}}}function W(s){return new Promise(n=>setTimeout(n,s))}function K(s){let n=p(s);async function e(t,r,o){let a=o?.retry||{},c=a.maxRetries??0,i=a.initialDelay??1e3,l=a.maxDelay??3e4,u=a.backoffMultiplier??2,y=a.retryOnStatus??[429,500,502,503,504],I=a.retryOnNetworkError??true,S=null,k=i;for(let C=0;C<=c;C++)try{let b={};o?.version!==void 0&&(b.version=o.version),o?.includeLogs&&(b.includeLogs=!0);let T=h(b),E=await n(`/functions/${t}/invoke${T}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers});if(y.includes(E.status)&&C<c){S=new Error(`Function returned status ${E.status}`),await W(k),k=Math.min(k*u,l);continue}return E}catch(b){S=b;let T=b instanceof TypeError||b.message?.includes("network")||b.message?.includes("fetch");if(I&&T&&C<c){await W(k),k=Math.min(k*u,l);continue}throw b}throw S||new Error("Function invocation failed after retries")}return {invoke:e,async invokeByName(t,r,o){let a={};o?.version!==void 0&&(a.version=o.version),o?.includeLogs&&(a.includeLogs=true);let c=h(a);return n(`/functions/name/${encodeURIComponent(t)}/invoke${c}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers})},async batchInvoke(t,r){let a=(await Promise.allSettled(t.map(c=>this.invoke(c.functionId,c.input,r)))).map((c,i)=>c.status==="fulfilled"?{functionId:t[i].functionId,success:true,result:c.value}:{functionId:t[i].functionId,success:false,error:c.reason?.message||"Unknown error"});return {results:a,successCount:a.filter(c=>c.success).length,errorCount:a.filter(c=>!c.success).length}},rpc(t,r){let o=this,a=async(c,i)=>{let l={...r,...i};return (await e(t,{body:c},l)).data};return Object.defineProperty(a,"id",{value:t,writable:false}),a.getInfo=()=>o.get(t),a.getInvocations=c=>o.getInvocations({...c,functionId:t}),a},async list(t){let r={envId:t.envId,enabled:t.enabled,limit:t.limit,offset:t.offset},o=h(r);return n(`/functions/project/${t.projectId}${o}`)},async get(t){return n(`/functions/${t}`)},async getByName(t,r){return n(`/functions/project/${r}/name/${encodeURIComponent(t)}`)},async create(t){return n("/functions",{method:"POST",body:JSON.stringify(t)})},async update(t,r){return n(`/functions/${t}`,{method:"PATCH",body:JSON.stringify(r)})},async delete(t){return n(`/functions/${t}`,{method:"DELETE"})},async enable(t){return this.update(t,{enabled:true})},async disable(t){return this.update(t,{enabled:false})},async deploy(t,r,o){return n(`/functions/${t}/deploy`,{method:"POST",body:JSON.stringify({sourceCode:r,createVersion:o?.createVersion,versionDescription:o?.versionDescription,envVars:o?.envVars,secrets:o?.secrets})})},async getSource(t,r){let o=r!==void 0?`?version=${r}`:"";return n(`/functions/${t}/source${o}`)},async listVersions(t){return (await n(`/functions/${t}/versions`)).versions},async rollback(t,r){return n(`/functions/${t}/rollback`,{method:"POST",body:JSON.stringify({version:r})})},async getEnvVars(t){return (await n(`/functions/${t}/env`)).envVars},async setEnvVars(t,r){return n(`/functions/${t}/env`,{method:"PUT",body:JSON.stringify({envVars:r})})},async deleteEnvVar(t,r){return n(`/functions/${t}/env/${encodeURIComponent(r)}`,{method:"DELETE"})},async bindSecrets(t,r){return n(`/functions/${t}/secrets`,{method:"PUT",body:JSON.stringify({secrets:r})})},async setSchedule(t,r){return n(`/functions/${t}/schedule`,{method:"PUT",body:JSON.stringify(r)})},async removeSchedule(t){return n(`/functions/${t}/schedule`,{method:"DELETE"})},async getInvocations(t){let r={functionId:t.functionId,projectId:t.projectId,status:t.status,since:t.since,until:t.until,limit:t.limit,offset:t.offset},o=h(r);return (await n(`/functions/invocations${o}`)).invocations},async getInvocation(t){return n(`/functions/invocations/${t}`)},async getLogs(t,r){let o={since:r?.since,until:r?.until,level:r?.level,limit:r?.limit},a=h(o);return (await n(`/functions/${t}/logs${a}`)).logs}}}function G(s){let n=p(s),e="default";return {async getUploadUrl(t,r){return n("/storage/upload-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,sizeBytes:r?.sizeBytes,metadata:r?.metadata,isPublic:r?.isPublic,cacheControl:r?.cacheControl,contentDisposition:r?.contentDisposition,upsert:r?.upsert})})},async getDownloadUrl(t,r){return n("/storage/download-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,expiresIn:r?.expiresIn,download:r?.download,transform:r?.transform})})},async createSignedUrl(t,r=3600,o){return (await this.getDownloadUrl(t,{...o,expiresIn:r})).url},async createSignedUrls(t,r=3600,o){return await Promise.all(t.map(async c=>({key:c,url:await this.createSignedUrl(c,r,o)})))},async upload(t,r,o){let a=r instanceof Blob?r:new Blob([r]),c=a.size,i=o?.contentType||(r instanceof File?r.type:void 0)||"application/octet-stream",l=await this.getUploadUrl(t,{...o,contentType:i,sizeBytes:c}),u=await s.fetch(l.url,{method:"PUT",body:a,headers:{"Content-Type":i,...o?.cacheControl&&{"Cache-Control":o.cacheControl},...o?.contentDisposition&&{"Content-Disposition":o.contentDisposition}}});if(!u.ok)throw new Error(`Upload failed: ${u.statusText}`);let y=o?.bucket||e,I=l.url.split("?")[0];return {ok:true,key:t,bucket:y,url:I,publicUrl:o?.isPublic?this.getPublicUrl(t,{bucket:y}):void 0,size:c,contentType:i}},async uploadFromUrl(t,r,o){return n("/storage/upload-from-url",{method:"POST",body:JSON.stringify({key:t,url:r,bucket:o?.bucket||e,contentType:o?.contentType,metadata:o?.metadata,isPublic:o?.isPublic,timeout:o?.timeout})})},async download(t,r){let o=await this.getDownloadUrl(t,r),a=await s.fetch(o.url);if(!a.ok)throw new Error(`Download failed: ${a.statusText}`);return a.blob()},async list(t){let r={bucket:t?.bucket||e,prefix:t?.prefix,delimiter:t?.delimiter,limit:t?.limit,cursor:t?.cursor,includeUrls:t?.includeUrls},o=h(r);return n(`/storage/files${o}`)},async getMetadata(t,r){let o=r?.bucket||e;return n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}/metadata`)},async updateMetadata(t,r,o){let a=o?.bucket||e;return n(`/storage/files/${encodeURIComponent(a)}/${encodeURIComponent(t)}/metadata`,{method:"PATCH",body:JSON.stringify(r)})},async exists(t,r){try{return await this.getMetadata(t,r),!0}catch{return false}},async copy(t,r,o){return n("/storage/files/copy",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async move(t,r,o){return n("/storage/files/move",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async delete(t,r){let o=r?.bucket||e;await n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}`,{method:"DELETE"});},async deleteMany(t,r){return n("/storage/files/delete-batch",{method:"POST",body:JSON.stringify({keys:t,bucket:r?.bucket||e})})},getPublicUrl(t,r){let o=r?.bucket||e;return `${s.baseUrl.replace("/api","")}/storage/${encodeURIComponent(o)}/${encodeURIComponent(t)}`},async createBucket(t,r){return n("/storage/buckets",{method:"POST",body:JSON.stringify({name:t,isPublic:r?.isPublic,allowedMimeTypes:r?.allowedMimeTypes,maxFileSize:r?.maxFileSize,fileSizeLimit:r?.fileSizeLimit})})},async getBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}`)},async updateBucket(t,r){return n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})},async listBuckets(){return (await n("/storage/buckets")).buckets},async deleteBucket(t){await n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"DELETE"});},async emptyBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}/empty`,{method:"POST"})},async createMultipartUpload(t,r){return n("/storage/multipart/create",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,metadata:r?.metadata,partSize:r?.partSize})})},async uploadPart(t,r,o){let a=o instanceof Blob?o:new Blob([o]),{url:c}=await n(`/storage/multipart/${t}/part-url`,{method:"POST",body:JSON.stringify({partNumber:r})}),i=await s.fetch(c,{method:"PUT",body:a});if(!i.ok)throw new Error(`Part upload failed: ${i.statusText}`);let l=i.headers.get("etag")||"";return {partNumber:r,etag:l}},async completeMultipartUpload(t,r){return n(`/storage/multipart/${t}/complete`,{method:"POST",body:JSON.stringify({parts:r})})},async abortMultipartUpload(t){await n(`/storage/multipart/${t}/abort`,{method:"POST"});}}}function _(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.orgId&&t.set("orgId",e.orgId);let r=t.toString();return n(`/projects${r?`?${r}`:""}`)},async get(e){return n(`/projects/${e}`)},async create(e){return n("/projects",{method:"POST",body:JSON.stringify(e)})},async getApiKeys(e){return n(`/projects/${e}/api-keys`)},async createApiKey(e,t){return n(`/projects/${e}/api-keys`,{method:"POST",body:JSON.stringify(t??{})})},async revokeApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/revoke`,{method:"POST"})},async rotateApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/rotate`,{method:"POST"})},async setCustomDomain(e,t,r){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:r})})},async getDomainVerificationInstructions(e,t){return n(`/projects/${e}/environments/${t}/domain-verification`)},async verifyDomainTxt(e,t){return n(`/projects/${e}/environments/${t}/verify-domain`,{method:"POST"})},async verifyDomainCname(e,t){return n(`/projects/${e}/environments/${t}/verify-cname`,{method:"POST"})},async getDomainStatus(e,t){return n(`/projects/${e}/environments/${t}/domain-status`)},async provisionSsl(e,t){return n(`/projects/${e}/environments/${t}/provision-ssl`,{method:"POST"})},async removeCustomDomain(e,t){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:null})})},async listApiKeys(e){return (await n(`/projects/${e}/api-keys`)).keys}}}function H(s){let n=p(s);return {async list(){return n("/orgs")},async create(e){return n("/orgs",{method:"POST",body:JSON.stringify(e)})},async getProfile(e){return (await n(`/orgs/${e}/profile`)).profile||{}},async updateProfile(e,t){return (await n(`/orgs/${e}/profile`,{method:"PATCH",body:JSON.stringify(t)})).profile},async listBillingContacts(e){return (await n(`/orgs/${e}/billing-contacts`)).contacts},async addBillingContact(e,t){return n(`/orgs/${e}/billing-contacts`,{method:"POST",body:JSON.stringify(t)})},async removeBillingContact(e,t){return n(`/orgs/${e}/billing-contacts/${t}`,{method:"DELETE"})},async listMembers(e){return (await n(`/orgs/${e}/members`)).members},async inviteMember(e,t){return n(`/orgs/${e}/members/invite`,{method:"POST",body:JSON.stringify(t)})},async listInvites(e){return (await n(`/orgs/${e}/invites`)).invites},async cancelInvite(e,t){return n(`/orgs/${e}/invites/${t}`,{method:"DELETE"})},async removeMember(e,t){return n(`/orgs/${e}/members/${t}`,{method:"DELETE"})},async updateMemberRole(e,t,r){return n(`/orgs/${e}/members/${t}/role`,{method:"PATCH",body:JSON.stringify({role:r})})},async getMyMembership(e){try{return (await n(`/orgs/${e}/membership`)).membership}catch{return null}}}}function z(s){let n=p(s);return {async preview(e){return n("/schema-engine/preview",{method:"POST",body:JSON.stringify(e)})},async apply(e){return n("/schema-engine/apply",{method:"POST",body:JSON.stringify(e)})},async getMigrations(e,t){let r=t?`/schema-engine/migrations/project/${e}?limit=${t}`:`/schema-engine/migrations/project/${e}`;return n(r)},async saveSchema(e){return n("/schemas/",{method:"POST",body:JSON.stringify(e)})},async getSchemas(e){return n(`/schemas/project/${e}`)}}}function Q(s){let n=p(s);return {async create(e){return n("/functions/secrets",{method:"POST",body:JSON.stringify(e)})},async list(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/functions/secrets/project/${e}${o?`?${o}`:""}`;return n(a)},async reveal(e){return n(`/functions/secrets/${e}/value`)},async update(e,t){return n(`/functions/secrets/${e}`,{method:"PUT",body:JSON.stringify({value:t})})},async delete(e){return n(`/functions/secrets/${e}`,{method:"DELETE"})}}}function X(s){let n=p(s);return {async list(e,t){let r=new URLSearchParams;t&&r.set("env",t);let o=r.toString(),a=`/deployments/project/${e}${o?`?${o}`:""}`;return (await n(a)).deployments},async get(e){let t=await n(`/deployments/${e}`);return {...t.deployment,steps:t.steps}},async getSteps(e){return (await n(`/deployments/${e}/steps`)).steps},async promote(e){let t={projectId:e.projectId,fromEnv:e.sourceEnv,toEnv:e.targetEnv},r=await n("/deployments/promote",{method:"POST",body:JSON.stringify(t)}),o=await n(`/deployments/${r.deploymentId}`);return {deployment:{...o.deployment,steps:o.steps}}},async rollback(e){return n(`/deployments/${e}/rollback`,{method:"POST"})},async listTokens(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/deployments/tokens/project/${encodeURIComponent(e)}${o?`?${o}`:""}`;return (await n(a)).tokens},async createToken(e){return n("/deployments/tokens",{method:"POST",body:JSON.stringify(e)})},async revokeToken(e){return n(`/deployments/tokens/${encodeURIComponent(e)}/revoke`,{method:"POST"})}}}function Z(s){let n=p(s);return {async getStats(e){return n(`/realtime/stats/project/${e}`)},async getConnections(e){return (await n(`/realtime/connections/project/${e}`)).connections},async getSubscriptions(e){return (await n(`/realtime/subscriptions/project/${e}`)).subscriptions},async getEvents(e,t){let r=new URLSearchParams;t&&r.set("limit",String(t));let o=r.toString(),a=`/realtime/events/project/${e}${o?`?${o}`:""}`;return (await n(a)).events},async getStatus(e){return n(`/realtime/status/project/${e}`)},async install(e){return n("/realtime/install",{method:"POST",body:JSON.stringify(e)})},async enableAll(e){return n("/realtime/enable-all",{method:"POST",body:JSON.stringify(e)})}}}function Y(s){let n=p(s);return {async listBuckets(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/buckets/project/${e}${o?`?${o}`:""}`;return (await n(a)).buckets},async getBucket(e){return (await n(`/buckets/${e}`)).bucket},async createBucket(e){return (await n("/buckets",{method:"POST",body:JSON.stringify(e)})).bucket},async updateBucket(e,t){return (await n(`/buckets/${e}`,{method:"PUT",body:JSON.stringify(t)})).bucket},async deleteBucket(e){return n(`/buckets/${e}`,{method:"DELETE"})},async listFiles(e,t){let r=new URLSearchParams;t?.prefix&&r.set("prefix",t.prefix),t?.maxKeys&&r.set("maxKeys",String(t.maxKeys)),t?.continuationToken&&r.set("continuationToken",t.continuationToken);let o=r.toString(),a=`/buckets/${e}/files${o?`?${o}`:""}`;return n(a)},async deleteFile(e,t){return n(`/buckets/${e}/files?key=${encodeURIComponent(t)}`,{method:"DELETE"})},async getSignedUrl(e,t,r){return n(`/buckets/${e}/signed-url`,{method:"POST",body:JSON.stringify({key:t,expiresIn:r})})},async getUploadUrl(e,t,r){return n(`/buckets/${e}/upload-url`,{method:"POST",body:JSON.stringify({key:t,...r})})},async uploadFile(e,t,r,o){let a=o?.prefix?`${o.prefix}${t}`:t,c=o?.contentType??(r instanceof Blob?r.type:"application/octet-stream"),i=new URLSearchParams;return i.set("key",a),c&&i.set("contentType",c),n(`/buckets/${e}/upload?${i.toString()}`,{method:"POST",body:r,headers:{"Content-Type":c||"application/octet-stream"}})}}}function ee(s){let n=p(s);return {async list(e,t){let r={type:t?.type,enabled:t?.enabled},o=h(r);return (await n(`/integrations/subscriptions/project/${e}${o}`)).subscriptions},async get(e){return n(`/integrations/subscriptions/${e}`)},async create(e){return (await n("/integrations/subscriptions",{method:"POST",body:JSON.stringify(e)})).subscription},async update(e,t){return (await n(`/integrations/subscriptions/${e}`,{method:"PATCH",body:JSON.stringify(t)})).subscription},async delete(e){return n(`/integrations/subscriptions/${e}`,{method:"DELETE"})},async enable(e){return this.update(e,{enabled:true})},async disable(e){return this.update(e,{enabled:false})},async test(e){return n(`/integrations/subscriptions/${e}/test`,{method:"POST"})},async publish(e){return n("/integrations/events/publish",{method:"POST",body:JSON.stringify(e)})},async publishBatch(e){return (await n("/integrations/events/publish-batch",{method:"POST",body:JSON.stringify({events:e})})).results},async listEvents(e){let t={envId:e.envId,source:e.source,name:e.name,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/events/project/${e.projectId}${r}`)).events},async getEvent(e){return n(`/integrations/events/${e}`)},async getDeliveries(e){let t={subscriptionId:e.subscriptionId,eventId:e.eventId,status:e.status,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/deliveries${r}`)).deliveries},async getDelivery(e){return n(`/integrations/deliveries/${e}`)},async retryDelivery(e){return n(`/integrations/deliveries/${e}/retry`,{method:"POST"})},async retryAllFailed(e){return n(`/integrations/subscriptions/${e}/retry-failed`,{method:"POST"})},async getDlq(e,t){let r={limit:t?.limit,offset:t?.offset},o=h(r);return (await n(`/integrations/dlq/project/${e}${o}`)).deliveries},async purgeDlq(e,t){return n(`/integrations/dlq/project/${e}/purge`,{method:"POST",body:JSON.stringify({olderThan:t.olderThan})})},async replayDlq(e,t){return n(`/integrations/dlq/project/${e}/replay`,{method:"POST",body:JSON.stringify(t)})},verifySignature(e){let t=e.tolerance??300;try{let r=e.signature.split(","),o=r.find(b=>b.startsWith("t=")),a=r.find(b=>b.startsWith("v1="));if(!o||!a)return !1;let c=parseInt(o.slice(2),10),i=a.slice(3),l=Math.floor(Date.now()/1e3);if(Math.abs(l-c)>t)return !1;let u=`${c}.${e.payload}`,y=new TextEncoder,I=y.encode(e.secret),S=y.encode(u),k=Array.from(I).concat(Array.from(S)).reduce((b,T)=>b+T,0).toString(16);if(i.length!==k.length)return !1;let C=0;for(let b=0;b<i.length;b++)C|=i.charCodeAt(b)^k.charCodeAt(b);return C===0}catch{return false}},generateSecret(){let e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",t="whsec_";for(let r=0;r<32;r++)t+=e.charAt(Math.floor(Math.random()*e.length));return t}}}function te(s){let n=p(s);return {async getSummary(e){return n(`/billing/org/${e}/summary`)},async getEntitlements(e){return n(`/entitlements/org/${e}`)},async checkEntitlement(e,t){return n(`/entitlements/org/${e}/check`,{method:"POST",body:JSON.stringify(t)})},async getPlans(){return (await n("/pricing/plans")).plans},async createCheckout(e){return n("/billing/checkout",{method:"POST",body:JSON.stringify(e)})},async verifyCheckoutSession(e){return n(`/billing/checkout/verify/${e}`)},async openPortal(e){return n(`/billing/org/${e.orgId}/portal`,{method:"POST",body:JSON.stringify({returnUrl:e.returnUrl})})},async getAIUsageSummary(e){return n(`/ai-usage/org/${e}/summary`)},async getAIUsageHistory(e,t=30){return n(`/ai-usage/org/${e}/history?days=${t}`)},async getAIUsageBreakdown(e){return n(`/ai-usage/org/${e}/breakdown`)},async getRecentAIRequests(e,t=50,r=0){return n(`/ai-usage/org/${e}/recent?limit=${t}&offset=${r}`)}}}function ne(s){let n=p(s);return {async getOverview(){return n("/admin/overview")},async listUsers(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/users${r?`?${r}`:""}`)},async getUser(e){return n(`/admin/users/${e}`)},async updateUserStatus(e,t){return n(`/admin/users/${e}/status`,{method:"PATCH",body:JSON.stringify({status:t})})},async updateUserAdmin(e,t){return n(`/admin/users/${e}/admin`,{method:"PATCH",body:JSON.stringify({isAdmin:t})})},async listOrganizations(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.plan&&t.set("plan",e.plan),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/organizations${r?`?${r}`:""}`)},async getOrganization(e){return n(`/admin/organizations/${e}`)},async updateOrganization(e,t){return n(`/admin/organizations/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listProjects(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.orgId&&t.set("orgId",e.orgId),e?.region&&t.set("region",e.region),e?.tenancy&&t.set("tenancy",e.tenancy),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/projects${r?`?${r}`:""}`)},async getProject(e){return n(`/admin/projects/${e}`)},async updateProject(e,t){return n(`/admin/projects/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getProjectResources(e){return n(`/admin/resources/project/${e}`)},async setDedicatedDb(e){return n(`/admin/resources/project/${e.projectId}/db`,{method:"POST",body:JSON.stringify({connectionString:e.connectionString})})},async listIncidents(e="open"){return (await n(`/admin/incidents?status=${e}`)).incidents},async createIncident(e){return n("/admin/incidents",{method:"POST",body:JSON.stringify(e)})},async acknowledgeIncident(e){return n(`/admin/incidents/${e}/ack`,{method:"POST"})},async resolveIncident(e){return n(`/admin/incidents/${e}/resolve`,{method:"POST"})},async listRegions(){return n("/admin/regions")},async updateRegion(e,t){return n(`/admin/regions/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getHealthComponents(){return n("/admin/health/components")},async updateHealthComponent(e,t){return n(`/admin/health/components/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listQueues(){return n("/admin/queues")},async listDlqMessages(e){let t=new URLSearchParams;e?.queue&&t.set("queue",e.queue),e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/dlq${r?`?${r}`:""}`)},async retryDlqMessage(e){return n(`/admin/dlq/${e}/retry`,{method:"POST"})},async archiveDlqMessage(e){return n(`/admin/dlq/${e}`,{method:"DELETE"})},async listFeatureFlags(){return (await n("/flags")).flags},async createFeatureFlag(e,t){return n("/flags",{method:"POST",body:JSON.stringify({key:e,enabled:t})})},async updateFeatureFlag(e,t){return n(`/flags/${e}`,{method:"PUT",body:JSON.stringify({enabled:t})})},async deleteFeatureFlag(e){return n(`/flags/${e}`,{method:"DELETE"})},async listAdmins(){return (await n("/admin/admins")).admins||[]},async addAdmin(e,t,r){return n("/admin/admins",{method:"POST",body:JSON.stringify({userId:e,role:t,notes:r})})},async updateAdmin(e,t){return n(`/admin/admins/${e}`,{method:"PUT",body:JSON.stringify(t)})},async removeAdmin(e){return n(`/admin/admins/${e}`,{method:"DELETE"})},async getSettings(e){let t=e?`?category=${e}`:"";return n(`/admin/settings${t}`)},async updateSetting(e,t){return n(`/admin/settings/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify({value:t})})},async listAIModels(){return n("/admin/ai/models")},async getAIModel(e){return n(`/admin/ai/models/${e}`)},async createAIModel(e){return n("/admin/ai/models",{method:"POST",body:JSON.stringify(e)})},async updateAIModel(e,t){return n(`/admin/ai/models/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteAIModel(e){return n(`/admin/ai/models/${e}`,{method:"DELETE"})},async toggleAIModel(e,t,r){return n(`/admin/ai/models/${e}/toggle`,{method:"POST",body:JSON.stringify({enabled:t,disabledMessage:r})})},async listAISessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/workspace/sessions${r?`?${r}`:""}`)},async getAISession(e){return n(`/admin/ai/workspace/sessions/${e}`)},async deleteAISession(e){return n(`/admin/ai/workspace/sessions/${e}`,{method:"DELETE"})},async listGeneratedBackends(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/backends${r?`?${r}`:""}`)},async getGeneratedBackend(e){return n(`/admin/ai/backends/${e}`)},async deleteGeneratedBackend(e){return n(`/admin/ai/backends/${e}`,{method:"DELETE"})},async listPromptTemplates(e){let t=new URLSearchParams;e?.category&&t.set("category",e.category),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/prompt-templates${r?`?${r}`:""}`)},async createPromptTemplate(e){return n("/admin/ai/prompt-templates",{method:"POST",body:JSON.stringify(e)})},async updatePromptTemplate(e,t){return n(`/admin/ai/prompt-templates/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deletePromptTemplate(e){return n(`/admin/ai/prompt-templates/${e}`,{method:"DELETE"})},async listContextSnapshots(e){let t=new URLSearchParams;e?.projectId&&t.set("projectId",e.projectId),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/context-snapshots${r?`?${r}`:""}`)},async invalidateContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}/invalidate`,{method:"POST"})},async deleteContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}`,{method:"DELETE"})},async getCopilotOverview(){return n("/admin/copilot/overview")},async listCopilotSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/sessions${r?`?${r}`:""}`)},async getCopilotSession(e){return n(`/admin/copilot/sessions/${e}`)},async deleteCopilotSession(e){return n(`/admin/copilot/sessions/${e}`,{method:"DELETE"})},async listCopilotMemories(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.projectId&&t.set("projectId",e.projectId),e?.memoryType&&t.set("memoryType",e.memoryType),e?.importance&&t.set("importance",e.importance),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/memories${r?`?${r}`:""}`)},async getCopilotMemoryStats(){return n("/admin/copilot/memories/stats")},async getCopilotMemory(e){return n(`/admin/copilot/memories/${e}`)},async updateCopilotMemory(e,t){return n(`/admin/copilot/memories/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteCopilotMemory(e){return n(`/admin/copilot/memories/${e}`,{method:"DELETE"})},async cleanupExpiredMemories(){return n("/admin/copilot/memories/cleanup",{method:"POST"})},async exportTrainingData(e){let t=new URLSearchParams;e?.format&&t.set("format",e.format),e?.dataType&&t.set("dataType",e.dataType),e?.minConfidence!==void 0&&t.set("minConfidence",String(e.minConfidence)),e?.limit&&t.set("limit",String(e.limit)),e?.includeExecuted!==void 0&&t.set("includeExecuted",String(e.includeExecuted)),e?.includeSuccessful!==void 0&&t.set("includeSuccessful",String(e.includeSuccessful));let r=t.toString();return n(`/admin/copilot/training-data/export${r?`?${r}`:""}`)},async getTrainingDataStats(){return n("/admin/copilot/training-data/stats")},async listErrors(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.path&&t.set("path",e.path),e?.errorCode&&t.set("errorCode",e.errorCode),e?.status&&t.set("status",e.status),e?.environment&&t.set("environment",e.environment),e?.startDate&&t.set("startDate",e.startDate),e?.endDate&&t.set("endDate",e.endDate),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/errors${r?`?${r}`:""}`)},async getErrorStats(){return n("/admin/errors/stats")},async getError(e){return n(`/admin/errors/${e}`)},async resolveError(e,t){return n(`/admin/errors/${e}/resolve`,{method:"PUT",body:JSON.stringify({notes:t})})},async deleteError(e){return n(`/admin/errors/${e}`,{method:"DELETE"})},async bulkDeleteErrors(e){let t=e?`?olderThanDays=${e}`:"";return n(`/admin/errors${t}`,{method:"DELETE"})},async getAIWorkspaceOverview(){return n("/admin/ai-workspace/overview")},async listAIWorkspaceSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.taskType&&t.set("taskType",e.taskType),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai-workspace/sessions${r?`?${r}`:""}`)},async getAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`)},async deleteAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`,{method:"DELETE"})}}}function re(s){let n=p(s);return {async list(){return (await n("/flags")).flags},async create(e){return n("/flags",{method:"POST",body:JSON.stringify(e)})},async update(e,t){return n(`/flags/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify(t)})},async delete(e){return n(`/flags/${encodeURIComponent(e)}`,{method:"DELETE"})}}}function oe(s){let n=p(s);return {async getOverview(e){return (await n(`/security/overview/${encodeURIComponent(e)}`)).overview},async getAuditLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.offset&&r.set("offset",String(t.offset));let o=r.toString(),a=`/security/audit/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async listEnvVars(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/projects/${encodeURIComponent(e)}/env-vars${o?`?${o}`:""}`;return (await n(a)).envVars},async createEnvVar(e,t){return (await n(`/projects/${encodeURIComponent(e)}/env-vars`,{method:"POST",body:JSON.stringify(t)})).envVar},async updateEnvVar(e,t,r){return (await n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})).envVar},async deleteEnvVar(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"DELETE"})},async getEnvVarValue(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}/value`)}}}function se(s){let n=p(s);return {async generatePlan(e){return n("/ai/plan",{method:"POST",body:JSON.stringify({projectId:e.projectId,prompt:e.prompt,context:e.context,taskType:e.taskType,mode:e.mode})})},async explainPlan(e){return n("/ai/explain",{method:"POST",body:JSON.stringify({plan:e.plan,projectId:e.projectId,taskType:e.taskType,mode:e.mode})})},async getOrgSettings(e){return n(`/ai/settings/org/${encodeURIComponent(e)}`)},async updateOrgSettings(e,t){return n(`/ai/settings/org/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getProjectOverrides(e){return n(`/ai/settings/project/${encodeURIComponent(e)}`)},async updateProjectOverrides(e,t){return n(`/ai/settings/project/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getUsage(e,t){let r=new URLSearchParams;t&&r.set("month",t);let o=r.toString(),a=`/ai/usage/org/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async getBudgetStatus(e){let[t,r]=await Promise.all([this.getOrgSettings(e),this.getUsage(e)]),o=t?.monthlyBudgetCents??1e4,a=r.costCents,c=Math.max(0,o-a),i=o>0?Math.round(a/o*100):0;return {spent:a,budget:o,remaining:c,hardStop:t?.hardStopEnabled??false,percentUsed:i}},async generateFunction(e){return n("/ai/generate-function",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,inputSchema:e.inputSchema,outputSchema:e.outputSchema,language:e.language??"typescript",mode:e.mode})})},async generateEndpoint(e){return n("/ai/generate-endpoint",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,method:e.method??"GET",authRequired:e.authRequired??true,mode:e.mode})})},async exportCode(e){return n("/ai/export-code",{method:"POST",body:JSON.stringify({projectId:e.projectId,targetLanguage:e.targetLanguage,includeSchema:e.includeSchema??true,includeFunctions:e.includeFunctions??true,includeEndpoints:e.includeEndpoints??true})})},async createConversation(e,t){return n("/ai/conversations",{method:"POST",body:JSON.stringify({projectId:e,title:t?.title,context:t?.context})})},async sendMessage(e,t){return n(`/ai/conversations/${encodeURIComponent(e)}/messages`,{method:"POST",body:JSON.stringify({content:t.content,taskType:t.taskType})})},async getConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`)},async listConversations(e){return (await n(`/ai/conversations/project/${encodeURIComponent(e)}`)).conversations},async deleteConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`,{method:"DELETE"})},async getAvailableModels(){return n("/ai/models/available")},async getModel(e){return n(`/ai/models/${encodeURIComponent(e)}`)},async getProjectContext(e){return n(`/ai/context/${encodeURIComponent(e)}`)},async estimateTokens(e,t){return n("/ai/context/estimate",{method:"POST",body:JSON.stringify({prompt:e,projectId:t})})},async analyzeForClarification(e){return n("/ai/clarify",{method:"POST",body:JSON.stringify(e)})},async getSuggestions(e){return n("/ai/suggestions",{method:"POST",body:JSON.stringify(e)})},workspace:{async create(e){return n("/ai/workspace/create",{method:"POST",body:JSON.stringify(e)})},async get(e){return n(`/ai/workspace/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/workspace/list/${encodeURIComponent(e)}`)},async submitPrompt(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/prompt`,{method:"POST",body:JSON.stringify(t),timeout:12e4})},async submitClarification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/clarify`,{method:"POST",body:JSON.stringify({responses:t}),timeout:9e4})},async generate(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/generate`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitModification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/modify`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitFeedback(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/feedback`,{method:"POST",body:JSON.stringify(t)})}},backends:{async get(e){return n(`/ai/backends/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/backends/list/${encodeURIComponent(e)}`)},async delete(e){return n(`/ai/backends/${encodeURIComponent(e)}`,{method:"DELETE"})},async deploy(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy`,{method:"POST",body:JSON.stringify(t)})},async apply(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/apply`,{method:"POST",body:JSON.stringify(t)})},async deployLive(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy-live`,{method:"POST",body:JSON.stringify(t),timeout:3e5})},async getDeployments(e){return n(`/ai/backends/${encodeURIComponent(e)}/deployments`)}},deployments:{async getLimits(e){return n(`/ai/deployments/limits/${encodeURIComponent(e)}`)},async getStatus(e){return n(`/ai/deployments/${encodeURIComponent(e)}/status`)},async getLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.severity&&r.set("severity",t.severity);let o=r.toString();return n(`/ai/deployments/${encodeURIComponent(e)}/logs${o?`?${o}`:""}`)},async terminate(e){return n(`/ai/deployments/${encodeURIComponent(e)}`,{method:"DELETE"})},async redeploy(e){return n(`/ai/deployments/${encodeURIComponent(e)}/redeploy`,{method:"POST",timeout:3e5})}},async getUserOrganizations(){return n("/ai/user/organizations")},async getProjectLimits(e){return n(`/ai/org/${encodeURIComponent(e)}/project-limits`)},async createProjectWithSchema(e){return n("/ai/schema/create-project",{method:"POST",body:JSON.stringify(e)})}}}function ie(s){let n=p(s);return {async load(){return n("/bootstrap")}}}function ae(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.visibility&&t.set("visibility",e.visibility),e?.category&&t.set("category",e.category),e?.orgId&&t.set("orgId",e.orgId);let r=t.toString(),o=`/templates${r?`?${r}`:""}`;return (await n(o)).templates},async get(e){return n(`/templates/${e}`)},async previewInstall(e){return n("/templates/install/preview",{method:"POST",body:JSON.stringify(e)})},async applyInstall(e){return n("/templates/install/apply",{method:"POST",body:JSON.stringify(e)})},async rollback(e){return n(`/templates/install/${e}/rollback`,{method:"POST"})},async createProject(e){return n("/templates/create-project",{method:"POST",body:JSON.stringify(e)})}}}function le(s){let n=p(s);return {async list(e){return (await n(`/oauth/org/${e}`)).connections},async configure(e,t){return n(`/oauth/org/${e}/configure`,{method:"POST",body:JSON.stringify(t)})},async enable(e){return n(`/oauth/connections/${e}/enable`,{method:"POST"})},async disable(e){return n(`/oauth/connections/${e}/disable`,{method:"POST"})},async delete(e){return n(`/oauth/connections/${e}`,{method:"DELETE"})}}}function ce(s){let n=p(s);return {async listPages(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/pages${t}`)).pages},async getPage(e){return (await n(`/docs/pages/${encodeURIComponent(e)}`)).page},async createPage(e){return (await n("/docs/pages",{method:"POST",body:JSON.stringify(e)})).page},async updatePage(e,t){return (await n(`/docs/pages/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).page},async deletePage(e){return n(`/docs/pages/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdks(){return (await n("/docs/sdks")).sdks},async getSdk(e){return (await n(`/docs/sdks/${encodeURIComponent(e)}`)).sdk},async createSdk(e){return (await n("/docs/sdks",{method:"POST",body:JSON.stringify(e)})).sdk},async updateSdk(e,t){return (await n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).sdk},async deleteSdk(e){return n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdkExamples(e,t){let r=t?`?topic=${encodeURIComponent(t)}`:"";return (await n(`/docs/sdks/${encodeURIComponent(e)}/examples${r}`)).examples},async createSdkExample(e){return (await n("/docs/sdk-examples",{method:"POST",body:JSON.stringify(e)})).example},async deleteSdkExample(e){return n(`/docs/sdk-examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listEndpoints(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/api-endpoints${t}`)).endpoints},async getEndpoint(e){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`)).endpoint},async createEndpoint(e){return (await n("/docs/api-endpoints",{method:"POST",body:JSON.stringify(e)})).endpoint},async updateEndpoint(e,t){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).endpoint},async deleteEndpoint(e){return n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"DELETE"})},async listExamples(e){let t=e!==void 0?`?featured=${e}`:"";return (await n(`/docs/examples${t}`)).examples},async getExample(e){return (await n(`/docs/examples/${encodeURIComponent(e)}`)).example},async createExample(e){return (await n("/docs/examples",{method:"POST",body:JSON.stringify(e)})).example},async updateExample(e,t){return (await n(`/docs/examples/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).example},async deleteExample(e){return n(`/docs/examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listChangelog(){return (await n("/docs/changelog")).entries},async getChangelogEntry(e){return (await n(`/docs/changelog/${encodeURIComponent(e)}`)).entry},async createChangelogEntry(e){return (await n("/docs/changelog",{method:"POST",body:JSON.stringify(e)})).entry},async updateChangelogEntry(e,t){return (await n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).entry},async deleteChangelogEntry(e){return n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"DELETE"})},async search(e){return (await n(`/docs/search?q=${encodeURIComponent(e)}`)).results}}}function V(s,n,e,t){let r=[...n],o=0,a=false,c=false,i=async()=>{if(c||a)return;let l=await e(`/mongodb/${t}/cursor/${s}/next`,{method:"POST"});r=l.batch,o=0,a=l.exhausted;};return {id:s,async hasNext(){return c?false:o<r.length?true:a?false:(await i(),r.length>0)},async next(){return c?null:o<r.length?r[o++]:a||(await i(),r.length===0)?null:r[o++]},async toArray(){if(c)return [];let l=[];for(;o<r.length;)l.push(r[o++]);for(;!a;)await i(),l.push(...r),o=r.length;return l},async forEach(l){if(!c){for(;o<r.length;)await l(r[o++]);for(;!a;){await i();for(let u of r)await l(u);o=r.length;}}},map(l){let u=r.slice(o).map(l);return V(s,u,e,t)},async close(){if(!c){c=true;try{await e(`/mongodb/${t}/cursor/${s}/close`,{method:"POST"});}catch{}}},isClosed(){return c}}}function ke(s,n){let e=`/mongodb/${encodeURIComponent(s)}`;return {collectionName:s,async find(t,r){return n(`${e}/find`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findCursor(t,r){let o=await n(`${e}/find/cursor`,{method:"POST",body:JSON.stringify({filter:t,options:r})});return V(o.cursorId,o.batch,n,s)},async findOne(t,r){return n(`${e}/findOne`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findById(t,r){return n(`${e}/findById/${encodeURIComponent(t)}`,{method:"GET",...r&&{body:JSON.stringify({options:r})}})},async countDocuments(t){return (await n(`${e}/count`,{method:"POST",body:JSON.stringify({filter:t})})).count},async estimatedDocumentCount(){return (await n(`${e}/estimatedCount`)).count},async distinct(t,r){return n(`${e}/distinct`,{method:"POST",body:JSON.stringify({field:t,...r})})},async insertOne(t){return n(`${e}/insertOne`,{method:"POST",body:JSON.stringify({document:t})})},async insertMany(t,r){return n(`${e}/insertMany`,{method:"POST",body:JSON.stringify({documents:t,options:r})})},async updateOne(t,r,o){return n(`${e}/updateOne`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async updateMany(t,r,o){return n(`${e}/updateMany`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async replaceOne(t,r,o){return n(`${e}/replaceOne`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async findOneAndUpdate(t,r,o){return n(`${e}/findOneAndUpdate`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async findOneAndReplace(t,r,o){return n(`${e}/findOneAndReplace`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async deleteOne(t){return n(`${e}/deleteOne`,{method:"POST",body:JSON.stringify({filter:t})})},async deleteMany(t){return n(`${e}/deleteMany`,{method:"POST",body:JSON.stringify({filter:t})})},async findOneAndDelete(t,r){return n(`${e}/findOneAndDelete`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async aggregate(t,r){return n(`${e}/aggregate`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})})},async aggregateCursor(t,r){let o=await n(`${e}/aggregate/cursor`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})});return V(o.cursorId,o.batch,n,s)},async createIndex(t,r){return (await n(`${e}/indexes`,{method:"POST",body:JSON.stringify({keys:t,options:r})})).indexName},async dropIndex(t){await n(`${e}/indexes/${encodeURIComponent(t)}`,{method:"DELETE"});},async listIndexes(){return n(`${e}/indexes`)},async bulkWrite(t,r){return n(`${e}/bulkWrite`,{method:"POST",body:JSON.stringify({operations:t,options:r})})}}}function de(s){let n=p(s);return {collection(e){return ke(e,n)},async listCollections(){return n("/mongodb/collections")},async createCollection(e,t){await n("/mongodb/collections",{method:"POST",body:JSON.stringify({name:e,options:t})});},async dropCollection(e){await n(`/mongodb/collections/${encodeURIComponent(e)}`,{method:"DELETE"});},async renameCollection(e,t){await n(`/mongodb/collections/${encodeURIComponent(e)}/rename`,{method:"POST",body:JSON.stringify({newName:t})});},async command(e){return n("/mongodb/command",{method:"POST",body:JSON.stringify(e)})}}}function ge(s){let n=p(s);return {async chat(e){return n("/ai/copilot/chat",{method:"POST",body:JSON.stringify(e),timeout:12e4})},async listSessions(e){return n(`/ai/copilot/sessions/${encodeURIComponent(e)}`)},async getSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`)},async updateSession(e,t){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"DELETE"})},async executePlan(e){return n("/ai/copilot/execute",{method:"POST",body:JSON.stringify(e),timeout:18e4})},async submitFeedback(e){return n("/ai/copilot/feedback",{method:"POST",body:JSON.stringify(e)})},async getClassificationStats(){return n("/ai/copilot/stats")}}}function he(s,n,e,t){let r=n.type||"public",o="unsubscribed",a=new Map,c=[],i={},l=null,u=null,y=new Set,I=new Set,S=new Set,k=d=>{if(d.event){let P=a.get(d.event);P&&P.forEach(A=>A(d.payload));}},C=d=>{i=d.state||{},y.forEach(P=>P(i));},b=d=>{let P=d.key||"",A=d.currentPresences||[],g=d.joinedPresences||[],m=d.leftPresences||[];g.length>0&&(i[P]=A,I.forEach(f=>f(P,A,g))),m.length>0&&(A.length===0?delete i[P]:i[P]=A,S.forEach(f=>f(P,A,m))),y.forEach(f=>f(i));},T=d=>{let P={type:"db_change",projectId:d.projectId||"",schema:d.schema||"",table:d.table||"",operation:d.op,new:d.record,old:d.old_record,timestamp:d.ts||new Date().toISOString(),partial:d.partial};c.forEach(({options:A,handler:g})=>{if(A.table===P.table){let m=A.event||"*";(m==="*"||(Array.isArray(m)?m.includes(P.operation):m===P.operation))&&g(P);}});},v={get name(){return s},get type(){return r},get status(){return o},_handleMessage:d=>{switch(d.type){case "broadcast":k(d);break;case "presence_state":C(d);break;case "presence":b(d);break;case "db_change":T(d);break;case "subscribed":o="subscribed";break;case "error":o="error";break}},onDbChange(d,P){return c.push({options:d,handler:P}),o==="subscribed"&&e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}}),v},on(d,P){return a.has(d)||a.set(d,new Set),a.get(d).add(P),v},off(d,P){return P?a.get(d)?.delete(P):a.delete(d),v},async broadcast(d){if(o!=="subscribed")throw new Error("Channel must be subscribed before broadcasting");e({type:"broadcast",channel:s,event:d.event,payload:d.payload,includeSelf:d.includeSelf});},presence:{async track(d){if(r!=="presence")throw new Error("Presence tracking is only available on presence channels");l=d.key||t()||"anonymous",u=d.state,e({type:"presence_track",channel:s,key:l,state:u});},async update(d){if(!u)throw new Error("Must call track() before update()");u={...u,...d},e({type:"presence_update",channel:s,key:l??void 0,state:u});},async untrack(){l&&(e({type:"presence_untrack",channel:s,key:l}),l=null,u=null);},state(){return {...i}},onSync(d){return y.add(d),v},onJoin(d){return I.add(d),v},onLeave(d){return S.add(d),v}},async subscribe(){return o==="subscribed"||(o="subscribing",e({type:"subscribe",channel:s}),c.forEach(({options:d})=>{e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}});}),n.presenceState&&r==="presence"&&await v.presence.track({state:n.presenceState})),v},async unsubscribe(){o!=="unsubscribed"&&(l&&await v.presence.untrack(),e({type:"unsubscribe",channel:s}),o="unsubscribed",i={},a.clear(),c.length=0);}};return v}function ue(s,n){let{wsUrl:e=s.baseUrl.replace(/^http/,"ws")+"/realtime/ws",autoReconnect:t=true,reconnectDelay:r=1e3,maxReconnectAttempts:o=10}=n??{},a=null,c="disconnected",i=null,l=null,u=0,y=null,I=null,S=new Map,k=new Map,C=new Set,b={connect:new Set,disconnect:new Set,error:new Set,reconnect:new Set},T=g=>{b[g].forEach(m=>m());},E=g=>{let m=`table:${g.table}`;if(g.filter){let R=(Array.isArray(g.filter)?g.filter:[g.filter]).map(w=>`${w.field}${w.operator||"eq"}${w.value}`).join("&");m+=`?${R}`;}return m},v=g=>{a?.readyState===WebSocket.OPEN&&a.send(JSON.stringify(g));},d=g=>{if(g.channel){let m=S.get(g.channel);if(m){m._handleMessage(g);return}}switch(g.type){case "db_change":{let m={type:"db_change",projectId:g.projectId??"",schema:g.schema??"",table:g.table??"",operation:g.op,new:g.record,old:g.old_record,timestamp:g.ts??new Date().toISOString(),partial:g.partial},f=`table:${g.table}`;k.forEach((R,w)=>{(w===f||w.startsWith(f+"?"))&&R.forEach(B=>B(m));});break}case "presence":{let m={type:"presence",event:g.event,key:g.key||g.connectionId||"",connectionId:g.connectionId??"",projectId:g.projectId??"",currentPresences:g.currentPresences||[],leftPresences:g.leftPresences||[],joinedPresences:g.joinedPresences||[]};C.forEach(f=>f(m));break}case "welcome":i=g.connectionId||null;break;case "error":{console.error("[vaif/realtime] Server error:",g.message),T("error");break}}},P=()=>new Promise((g,m)=>{let f=new URLSearchParams;s.apiKey&&f.set(s.apiKeyHeader,s.apiKey),l&&f.set("token",l);let R=f.toString(),w=R?`${e}?${R}`:e;try{a=new WebSocket(w);}catch{m(new x("Failed to create WebSocket connection"));return}let B=()=>{c="connected",u=0,T("connect"),S.forEach(M=>{(M.status==="subscribed"||M.status==="subscribing")&&M.subscribe();}),k.forEach((M,N)=>{v({type:"subscribe",channel:N});}),I=setInterval(()=>{v({type:"ping"});},3e4),g();},pe=M=>{try{let N=JSON.parse(M.data);d(N);}catch{}},me=()=>{if(c="disconnected",i=null,a=null,I&&(clearInterval(I),I=null),T("disconnect"),t&&u<o){c="reconnecting";let M=r*Math.pow(2,u);y=setTimeout(()=>{u++,T("reconnect"),P().catch(()=>{});},Math.min(M,3e4));}},ye=()=>{T("error"),m(new x("WebSocket connection error"));};a.addEventListener("open",B),a.addEventListener("message",pe),a.addEventListener("close",me),a.addEventListener("error",ye);}),A=()=>{y&&(clearTimeout(y),y=null),I&&(clearInterval(I),I=null),u=o;};return {channel(g,m={}){let f=S.get(g);if(f)return f;let R=he(g,m,v,()=>i);return S.set(g,R),R},async removeChannel(g){let m=S.get(g.name);m&&(await m.unsubscribe(),S.delete(g.name));},getChannels(){return Array.from(S.values())},subscribe(g,m){let f=E(g);return k.has(f)||k.set(f,new Set),k.get(f).add(m),a?.readyState===WebSocket.OPEN&&v({type:"subscribe",channel:f}),()=>{let R=k.get(f);R&&(R.delete(m),R.size===0&&(k.delete(f),a?.readyState===WebSocket.OPEN&&v({type:"unsubscribe",channel:f})));}},subscribeToPresence(g){return C.add(g),()=>{C.delete(g);}},async connect(){if(c!=="connected"){if(!s.apiKey)throw new D("API key is required for realtime connections");c="connecting",await P();}},disconnect(){A(),S.forEach(g=>{g.unsubscribe();}),S.clear(),a&&(a.close(),a=null),c="disconnected",i=null;},get isConnected(){return c==="connected"},get connectionState(){return c},get connectionId(){return i},on(g,m){b[g].add(m);},off(g,m){b[g].delete(m);},setAuth(g){l=g;}}}var j={apiKeyHeader:"x-vaif-key",timeout:3e4,retry:{maxRetries:3,retryDelay:1e3,retryOn:[429,500,502,503,504]}};function Se(s){return {baseUrl:s.baseUrl.replace(/\/$/,""),apiKey:s.apiKey,apiKeyHeader:s.apiKeyHeader??j.apiKeyHeader,accessToken:s.accessToken,fetch:s.fetch??globalThis.fetch.bind(globalThis),timeout:s.timeout??j.timeout,retry:{maxRetries:s.retry?.maxRetries??j.retry.maxRetries,retryDelay:s.retry?.retryDelay??j.retry.retryDelay,retryOn:s.retry?.retryOn??[...j.retry.retryOn]}}}function ve(s){let n=Se(s),e=q(n),t=J(n),r=K(n),o=G(n),a=_(n),c=H(n),i=z(n),l=Q(n),u=X(n),y=Z(n),I=Y(n),S=ee(n),k=te(n),C=ne(n),b=re(n),T=oe(n),E=se(n),v=ie(n),d=ae(n),P=le(n),A=ce(n),g=de(n),m=ge(n);return {from:e.from,auth:t,functions:r,storage:o,projects:a,orgs:c,schema:i,secrets:l,deployments:u,realtimeMonitoring:y,storageDashboard:I,integrations:S,billing:k,admin:C,flags:b,security:T,ai:E,bootstrap:v,templates:d,oauth:P,docs:A,mongodb:g,copilot:m,realtime:f=>ue(n,f)}}Object.defineProperty(exports,"AuthError",{enumerable:true,get:function(){return auth.AuthError}});Object.defineProperty(exports,"InvalidCredentialsError",{enumerable:true,get:function(){return auth.InvalidCredentialsError}});Object.defineProperty(exports,"SessionExpiredError",{enumerable:true,get:function(){return auth.SessionExpiredError}});Object.defineProperty(exports,"SessionStorage",{enumerable:true,get:function(){return auth.SessionStorage}});Object.defineProperty(exports,"VaifAuthClient",{enumerable:true,get:function(){return auth.VaifAuthClient}});Object.defineProperty(exports,"authLocalStorage",{enumerable:true,get:function(){return auth.localStorage}});Object.defineProperty(exports,"authSessionStorage",{enumerable:true,get:function(){return auth.sessionStorage}});Object.defineProperty(exports,"cookieStorage",{enumerable:true,get:function(){return auth.cookieStorage}});Object.defineProperty(exports,"createAuthClient",{enumerable:true,get:function(){return auth.createAuthClient}});Object.defineProperty(exports,"getDefaultStorage",{enumerable:true,get:function(){return auth.getDefaultStorage}});Object.defineProperty(exports,"isBrowser",{enumerable:true,get:function(){return auth.isBrowser}});Object.defineProperty(exports,"isMFAChallenge",{enumerable:true,get:function(){return auth.isMFAChallenge}});Object.defineProperty(exports,"memoryStorage",{enumerable:true,get:function(){return auth.memoryStorage}});exports.VaifAuthError=D;exports.VaifError=O;exports.VaifNetworkError=x;exports.VaifNotFoundError=F;exports.VaifRateLimitError=$;exports.VaifValidationError=U;exports.createVaifClient=ve;exports.isVaifError=be;
1
+ 'use strict';var auth=require('@vaiftech/auth');var O=class s extends Error{constructor(n,e){super(n),this.name="VaifError",this.code=e.code,this.statusCode=e.statusCode,this.requestId=e.requestId,this.details=e.details;let t=Error;t.captureStackTrace&&t.captureStackTrace(this,s);}toJSON(){return {name:this.name,message:this.message,code:this.code,statusCode:this.statusCode,requestId:this.requestId,details:this.details}}},D=class extends O{constructor(n,e){super(n,{code:e?.code??"AUTH_ERROR",statusCode:e?.statusCode??401,requestId:e?.requestId}),this.name="VaifAuthError";}},U=class extends O{constructor(n,e){super(n,{code:"VALIDATION_ERROR",statusCode:400,requestId:e?.requestId,details:e?.details??e?.fieldErrors}),this.name="VaifValidationError",this.fieldErrors=e?.fieldErrors;}},x=class extends O{constructor(n,e){super(n,{code:"NETWORK_ERROR"}),this.name="VaifNetworkError",this.cause=e;}},$=class extends O{constructor(n,e){super(n,{code:"RATE_LIMITED",statusCode:429}),this.name="VaifRateLimitError",this.retryAfter=e;}},F=class extends O{constructor(n,e){super(n,{code:"NOT_FOUND",statusCode:404,requestId:e}),this.name="VaifNotFoundError";}};function be(s){return s instanceof O}async function fe(s){let n;try{n=await s.json();}catch{}let e=n?.message??n?.error??s.statusText??"Request failed",t=n?.requestId;switch(s.status){case 400:return new U(e,{details:n?.details,requestId:t});case 401:return new D(e,{code:"UNAUTHORIZED",statusCode:401,requestId:t});case 403:return new D(e,{code:"FORBIDDEN",statusCode:403,requestId:t});case 404:return new F(e,t);case 429:{let r=s.headers.get("Retry-After"),o=r?parseInt(r,10):void 0;return new $(e,o)}default:return new O(e,{code:n?.error??"HTTP_ERROR",statusCode:s.status,requestId:t,details:n?.details})}}async function Pe(s,n){let{timeout:e=3e4,fetchFn:t,...r}=n,o=new AbortController,a=setTimeout(()=>o.abort(),e);try{let c=await t(s,{...r,signal:o.signal});if(clearTimeout(a),!c.ok)throw await fe(c);if(c.status===204)return;let i=await c.text();return i?JSON.parse(i):void 0}catch(c){throw clearTimeout(a),c instanceof O?c:c instanceof Error&&c.name==="AbortError"?new x("Request timed out"):c instanceof Error?new x(c.message,c):new x("Network request failed")}}function p(s){let{baseUrl:n,apiKey:e,apiKeyHeader:t,accessToken:r,fetch:o,timeout:a}=s;return async function(i,l={}){let u=`${n}${i}`,y={"Content-Type":"application/json",...l.headers??{}};if(e&&(y[t]=e),r){let I=typeof r=="function"?await r():r;y.Authorization=`Bearer ${I}`;}return Pe(u,{...l,headers:y,timeout:l.timeout??a,fetchFn:o})}}function h(s){let n=new URLSearchParams;for(let[t,r]of Object.entries(s))r!==void 0&&n.set(t,String(r));let e=n.toString();return e?`?${e}`:""}function Ie(s){return JSON.stringify(s)}function L(s,n,e={}){let t={...e},r=()=>{let i={};if(t.limit!==void 0&&(i.limit=t.limit),t.offset!==void 0&&(i.offset=t.offset),t.where&&(i.where=Ie(t.where)),t.orderBy){let l=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];i.orderBy=JSON.stringify(l);}return t.select&&t.select.length>0&&(i.select=t.select.join(",")),t.include&&t.include.length>0&&(i.include=JSON.stringify(t.include)),t.distinct&&t.distinct.length>0&&(i.distinct=t.distinct.join(",")),i},o=()=>h(r()),a=i=>L(s,n,{...t,...i}),c={async list(i){i&&(t={...t,...i});let l=o();return n(`/generated/${s}${l}`)},async get(i){let l={};t.select&&t.select.length>0&&(l.select=t.select.join(",")),t.include&&t.include.length>0&&(l.include=JSON.stringify(t.include));let u=h(l);return n(`/generated/${s}/${encodeURIComponent(i)}${u}`)},async first(){let i=await c.limit(1).list();return i.data.length>0?i.data[0]:null},async firstOrFail(){let i=await c.first();if(!i)throw new Error(`No record found in table '${s}' matching the query`);return i},async create(i){return n(`/generated/${s}`,{method:"POST",body:JSON.stringify(i)})},async update(i,l){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"PATCH",body:JSON.stringify(l)})},async delete(i){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"DELETE"})},async createMany(i,l){return n(`/generated/${s}/batch`,{method:"POST",body:JSON.stringify({records:i,skipOnConflict:l?.skipOnConflict,returnRecords:l?.returnRecords})})},async updateMany(i,l){return n(`/generated/${s}/batch`,{method:"PATCH",body:JSON.stringify({data:i,where:t.where,returnRecords:l?.returnRecords})})},async deleteMany(){return n(`/generated/${s}/batch`,{method:"DELETE",body:JSON.stringify({where:t.where})})},async upsert(i,l){return n(`/generated/${s}/upsert`,{method:"POST",body:JSON.stringify({data:i,conflictFields:l.conflictFields,updateFields:l.updateFields})})},async count(){let i=r(),l=h(i);return (await n(`/generated/${s}/count${l}`)).count},async sum(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/sum${u}`)).sum},async avg(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/avg${u}`)).avg},async min(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/min${u}`)).min},async max(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/max${u}`)).max},async aggregate(i,l){return n(`/generated/${s}/aggregate`,{method:"POST",body:JSON.stringify({aggregates:i,where:l?.where||t.where,groupBy:l?.groupBy,having:l?.having})})},async paginate(i){let l=i.page||1,u=i.pageSize||20,y=(l-1)*u,I=r();I.limit=u,I.offset=y,I.includeCount=true;let S=h(I),k=await n(`/generated/${s}${S}`),C=k.total||k.data.length,b=Math.ceil(C/u);return {data:k.data,pageInfo:{total:C,page:l,pageSize:u,pageCount:b,hasNextPage:l<b,hasPrevPage:l>1}}},async cursorPaginate(i){let l=r();l.limit=i.limit||20,i.cursor&&(l.cursor=i.cursor);let u=h(l),y=await n(`/generated/${s}/cursor${u}`);return {data:y.data,nextCursor:y.nextCursor,prevCursor:y.prevCursor,hasMore:y.hasMore}},where(i){if(t.where){let l=t.where;return a({where:{AND:[...Array.isArray(l)?l:[l],i]}})}return a({where:i})},orderBy(i,l="asc"){let u={field:i,direction:l};if(t.orderBy){let y=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];return a({orderBy:[...y,u]})}return a({orderBy:u})},select(...i){return a({select:i})},limit(i){return a({limit:i})},offset(i){return a({offset:i})},include(i){let l=t.include||[];return a({include:[...l,i]})},distinct(...i){return a({distinct:i})}};return c}function q(s){let n=p(s);return {from(e){return L(e,n)},async raw(e,t){return n("/generated/raw",{method:"POST",body:JSON.stringify({query:e,params:t})})},async transaction(e,t){return n("/generated/transaction",{method:"POST",body:JSON.stringify({operations:e,isolationLevel:t?.isolationLevel,timeout:t?.timeout})})},async withTransaction(e,t){let o=(await n("/generated/transaction/start",{method:"POST",body:JSON.stringify({isolationLevel:t?.isolationLevel,timeout:t?.timeout})})).transactionId,a=(i,l)=>{let u=new Headers(l?.headers);return u.set("X-Transaction-Id",o),n(i,{...l,headers:u})},c={from(i){return L(i,a)},async raw(i,l){return a("/generated/raw",{method:"POST",body:JSON.stringify({query:i,params:l})})},async transaction(){throw new Error("Nested transactions are not supported")},async withTransaction(){throw new Error("Nested transactions are not supported")}};try{let i=await e(c);return await n("/generated/transaction/commit",{method:"POST",body:JSON.stringify({transactionId:o})}),i}catch(i){throw await n("/generated/transaction/rollback",{method:"POST",body:JSON.stringify({transactionId:o})}).catch(()=>{}),i}}}}function J(s){let n=p(s);return {async signUp(e,t,r){return n("/auth/signup",{method:"POST",body:JSON.stringify({email:e,password:t,name:r?.name,phone:r?.phone,metadata:r?.metadata,redirectUrl:r?.redirectUrl})})},async login(e,t,r){return n("/auth/login",{method:"POST",body:JSON.stringify({email:e,password:t,mfaCode:r?.mfaCode,rememberMe:r?.rememberMe})})},async logout(){await n("/auth/logout",{method:"POST"});},async logoutAll(){await n("/auth/logout-all",{method:"POST"});},async getUser(){return (await n("/auth/me")).user},async updateProfile(e){return (await n("/users/me",{method:"PATCH",body:JSON.stringify(e)})).user},async changePassword(e){return n("/users/me/change-password",{method:"POST",body:JSON.stringify(e)})},async requestPasswordReset(e){return n("/auth/forgot-password",{method:"POST",body:JSON.stringify(e)})},async confirmPasswordReset(e){return n("/auth/reset-password",{method:"POST",body:JSON.stringify(e)})},async requestEmailVerification(e){return n("/auth/verify-email/send",{method:"POST",body:JSON.stringify(e||{})})},async confirmEmailVerification(e){return n("/auth/verify-email/confirm",{method:"POST",body:JSON.stringify(e)})},async getOAuthSignInUrl(e){return n("/auth/oauth/authorize",{method:"POST",body:JSON.stringify(e)})},async handleOAuthCallback(e){return n("/auth/oauth/callback",{method:"POST",body:JSON.stringify(e)})},async linkOAuthProvider(e){return n("/auth/oauth/link",{method:"POST",body:JSON.stringify(e)})},async unlinkOAuthProvider(e){return n(`/auth/oauth/unlink/${e}`,{method:"POST"})},async listLinkedProviders(){return n("/auth/oauth/providers")},async requestMagicLink(e){return n("/auth/magic-link/send",{method:"POST",body:JSON.stringify(e)})},async verifyMagicLink(e){return n("/auth/magic-link/verify",{method:"POST",body:JSON.stringify(e)})},async requestPhoneVerification(e){return n("/auth/phone/send",{method:"POST",body:JSON.stringify(e)})},async confirmPhoneVerification(e){return n("/auth/phone/verify",{method:"POST",body:JSON.stringify(e)})},async setupMFA(e){return n("/auth/mfa/setup",{method:"POST",body:JSON.stringify({method:e})})},async enableMFA(e){return n("/auth/mfa/enable",{method:"POST",body:JSON.stringify({code:e})})},async disableMFA(e){return n("/auth/mfa/disable",{method:"POST",body:JSON.stringify({code:e})})},async verifyMFA(e,t){return n("/auth/mfa/verify",{method:"POST",body:JSON.stringify({mfaToken:e,code:t})})},async regenerateBackupCodes(){return n("/auth/mfa/backup-codes",{method:"POST"})},async refreshToken(e){return n("/auth/refresh",{method:"POST",body:JSON.stringify({refreshToken:e})})},async listSessions(){return n("/auth/sessions")},async revokeSession(e){return n(`/auth/sessions/${e}`,{method:"DELETE"})},async revokeOtherSessions(){return n("/auth/sessions/revoke-others",{method:"POST"})}}}function W(s){return new Promise(n=>setTimeout(n,s))}function K(s){let n=p(s);async function e(t,r,o){let a=o?.retry||{},c=a.maxRetries??0,i=a.initialDelay??1e3,l=a.maxDelay??3e4,u=a.backoffMultiplier??2,y=a.retryOnStatus??[429,500,502,503,504],I=a.retryOnNetworkError??true,S=null,k=i;for(let C=0;C<=c;C++)try{let b={};o?.version!==void 0&&(b.version=o.version),o?.includeLogs&&(b.includeLogs=!0);let T=h(b),E=await n(`/functions/${t}/invoke${T}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers});if(y.includes(E.status)&&C<c){S=new Error(`Function returned status ${E.status}`),await W(k),k=Math.min(k*u,l);continue}return E}catch(b){S=b;let T=b instanceof TypeError||b.message?.includes("network")||b.message?.includes("fetch");if(I&&T&&C<c){await W(k),k=Math.min(k*u,l);continue}throw b}throw S||new Error("Function invocation failed after retries")}return {invoke:e,async invokeByName(t,r,o){let a={};o?.version!==void 0&&(a.version=o.version),o?.includeLogs&&(a.includeLogs=true);let c=h(a);return n(`/functions/name/${encodeURIComponent(t)}/invoke${c}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers})},async batchInvoke(t,r){let a=(await Promise.allSettled(t.map(c=>this.invoke(c.functionId,c.input,r)))).map((c,i)=>c.status==="fulfilled"?{functionId:t[i].functionId,success:true,result:c.value}:{functionId:t[i].functionId,success:false,error:c.reason?.message||"Unknown error"});return {results:a,successCount:a.filter(c=>c.success).length,errorCount:a.filter(c=>!c.success).length}},rpc(t,r){let o=this,a=async(c,i)=>{let l={...r,...i};return (await e(t,{body:c},l)).data};return Object.defineProperty(a,"id",{value:t,writable:false}),a.getInfo=()=>o.get(t),a.getInvocations=c=>o.getInvocations({...c,functionId:t}),a},async list(t){let r={envId:t.envId,enabled:t.enabled,limit:t.limit,offset:t.offset},o=h(r);return n(`/functions/project/${t.projectId}${o}`)},async get(t){return n(`/functions/${t}`)},async getByName(t,r){return n(`/functions/project/${r}/name/${encodeURIComponent(t)}`)},async create(t){return n("/functions",{method:"POST",body:JSON.stringify(t)})},async update(t,r){return n(`/functions/${t}`,{method:"PATCH",body:JSON.stringify(r)})},async delete(t){return n(`/functions/${t}`,{method:"DELETE"})},async enable(t){return this.update(t,{enabled:true})},async disable(t){return this.update(t,{enabled:false})},async deploy(t,r,o){return n(`/functions/${t}/deploy`,{method:"POST",body:JSON.stringify({sourceCode:r,createVersion:o?.createVersion,versionDescription:o?.versionDescription,envVars:o?.envVars,secrets:o?.secrets})})},async getSource(t,r){let o=r!==void 0?`?version=${r}`:"";return n(`/functions/${t}/source${o}`)},async listVersions(t){return (await n(`/functions/${t}/versions`)).versions},async rollback(t,r){return n(`/functions/${t}/rollback`,{method:"POST",body:JSON.stringify({version:r})})},async getEnvVars(t){return (await n(`/functions/${t}/env`)).envVars},async setEnvVars(t,r){return n(`/functions/${t}/env`,{method:"PUT",body:JSON.stringify({envVars:r})})},async deleteEnvVar(t,r){return n(`/functions/${t}/env/${encodeURIComponent(r)}`,{method:"DELETE"})},async bindSecrets(t,r){return n(`/functions/${t}/secrets`,{method:"PUT",body:JSON.stringify({secrets:r})})},async setSchedule(t,r){return n(`/functions/${t}/schedule`,{method:"PUT",body:JSON.stringify(r)})},async removeSchedule(t){return n(`/functions/${t}/schedule`,{method:"DELETE"})},async getInvocations(t){let r={functionId:t.functionId,projectId:t.projectId,status:t.status,since:t.since,until:t.until,limit:t.limit,offset:t.offset},o=h(r);return (await n(`/functions/invocations${o}`)).invocations},async getInvocation(t){return n(`/functions/invocations/${t}`)},async getLogs(t,r){let o={since:r?.since,until:r?.until,level:r?.level,limit:r?.limit},a=h(o);return (await n(`/functions/${t}/logs${a}`)).logs}}}function G(s){let n=p(s),e="default";return {async getUploadUrl(t,r){return n("/storage/upload-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,sizeBytes:r?.sizeBytes,metadata:r?.metadata,isPublic:r?.isPublic,cacheControl:r?.cacheControl,contentDisposition:r?.contentDisposition,upsert:r?.upsert})})},async getDownloadUrl(t,r){return n("/storage/download-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,expiresIn:r?.expiresIn,download:r?.download,transform:r?.transform})})},async createSignedUrl(t,r=3600,o){return (await this.getDownloadUrl(t,{...o,expiresIn:r})).url},async createSignedUrls(t,r=3600,o){return await Promise.all(t.map(async c=>({key:c,url:await this.createSignedUrl(c,r,o)})))},async upload(t,r,o){let a=r instanceof Blob?r:new Blob([r]),c=a.size,i=o?.contentType||(r instanceof File?r.type:void 0)||"application/octet-stream",l=await this.getUploadUrl(t,{...o,contentType:i,sizeBytes:c}),u=await s.fetch(l.url,{method:"PUT",body:a,headers:{"Content-Type":i,...o?.cacheControl&&{"Cache-Control":o.cacheControl},...o?.contentDisposition&&{"Content-Disposition":o.contentDisposition}}});if(!u.ok)throw new Error(`Upload failed: ${u.statusText}`);let y=o?.bucket||e,I=l.url.split("?")[0];return {ok:true,key:t,bucket:y,url:I,publicUrl:o?.isPublic?this.getPublicUrl(t,{bucket:y}):void 0,size:c,contentType:i}},async uploadFromUrl(t,r,o){return n("/storage/upload-from-url",{method:"POST",body:JSON.stringify({key:t,url:r,bucket:o?.bucket||e,contentType:o?.contentType,metadata:o?.metadata,isPublic:o?.isPublic,timeout:o?.timeout})})},async download(t,r){let o=await this.getDownloadUrl(t,r),a=await s.fetch(o.url);if(!a.ok)throw new Error(`Download failed: ${a.statusText}`);return a.blob()},async list(t){let r={bucket:t?.bucket||e,prefix:t?.prefix,delimiter:t?.delimiter,limit:t?.limit,cursor:t?.cursor,includeUrls:t?.includeUrls},o=h(r);return n(`/storage/files${o}`)},async getMetadata(t,r){let o=r?.bucket||e;return n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}/metadata`)},async updateMetadata(t,r,o){let a=o?.bucket||e;return n(`/storage/files/${encodeURIComponent(a)}/${encodeURIComponent(t)}/metadata`,{method:"PATCH",body:JSON.stringify(r)})},async exists(t,r){try{return await this.getMetadata(t,r),!0}catch{return false}},async copy(t,r,o){return n("/storage/files/copy",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async move(t,r,o){return n("/storage/files/move",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async delete(t,r){let o=r?.bucket||e;await n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}`,{method:"DELETE"});},async deleteMany(t,r){return n("/storage/files/delete-batch",{method:"POST",body:JSON.stringify({keys:t,bucket:r?.bucket||e})})},getPublicUrl(t,r){let o=r?.bucket||e;return `${s.baseUrl.replace("/api","")}/storage/${encodeURIComponent(o)}/${encodeURIComponent(t)}`},async createBucket(t,r){return n("/storage/buckets",{method:"POST",body:JSON.stringify({name:t,isPublic:r?.isPublic,allowedMimeTypes:r?.allowedMimeTypes,maxFileSize:r?.maxFileSize,fileSizeLimit:r?.fileSizeLimit})})},async getBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}`)},async updateBucket(t,r){return n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})},async listBuckets(){return (await n("/storage/buckets")).buckets},async deleteBucket(t){await n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"DELETE"});},async emptyBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}/empty`,{method:"POST"})},async createMultipartUpload(t,r){return n("/storage/multipart/create",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,metadata:r?.metadata,partSize:r?.partSize})})},async uploadPart(t,r,o){let a=o instanceof Blob?o:new Blob([o]),{url:c}=await n(`/storage/multipart/${t}/part-url`,{method:"POST",body:JSON.stringify({partNumber:r})}),i=await s.fetch(c,{method:"PUT",body:a});if(!i.ok)throw new Error(`Part upload failed: ${i.statusText}`);let l=i.headers.get("etag")||"";return {partNumber:r,etag:l}},async completeMultipartUpload(t,r){return n(`/storage/multipart/${t}/complete`,{method:"POST",body:JSON.stringify({parts:r})})},async abortMultipartUpload(t){await n(`/storage/multipart/${t}/abort`,{method:"POST"});}}}function _(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.orgId&&t.set("orgId",e.orgId);let r=t.toString();return n(`/projects${r?`?${r}`:""}`)},async get(e){return n(`/projects/${e}`)},async create(e){return n("/projects",{method:"POST",body:JSON.stringify(e)})},async getApiKeys(e){return n(`/projects/${e}/api-keys`)},async createApiKey(e,t){return n(`/projects/${e}/api-keys`,{method:"POST",body:JSON.stringify(t??{})})},async revokeApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/revoke`,{method:"POST"})},async rotateApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/rotate`,{method:"POST"})},async setCustomDomain(e,t,r){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:r})})},async getDomainVerificationInstructions(e,t){return n(`/projects/${e}/environments/${t}/domain-verification`)},async verifyDomainTxt(e,t){return n(`/projects/${e}/environments/${t}/verify-domain`,{method:"POST"})},async verifyDomainCname(e,t){return n(`/projects/${e}/environments/${t}/verify-cname`,{method:"POST"})},async getDomainStatus(e,t){return n(`/projects/${e}/environments/${t}/domain-status`)},async provisionSsl(e,t){return n(`/projects/${e}/environments/${t}/provision-ssl`,{method:"POST"})},async removeCustomDomain(e,t){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:null})})},async listApiKeys(e){return (await n(`/projects/${e}/api-keys`)).keys}}}function H(s){let n=p(s);return {async list(){return n("/orgs")},async create(e){return n("/orgs",{method:"POST",body:JSON.stringify(e)})},async getProfile(e){return (await n(`/orgs/${e}/profile`)).profile||{}},async updateProfile(e,t){return (await n(`/orgs/${e}/profile`,{method:"PATCH",body:JSON.stringify(t)})).profile},async listBillingContacts(e){return (await n(`/orgs/${e}/billing-contacts`)).contacts},async addBillingContact(e,t){return n(`/orgs/${e}/billing-contacts`,{method:"POST",body:JSON.stringify(t)})},async removeBillingContact(e,t){return n(`/orgs/${e}/billing-contacts/${t}`,{method:"DELETE"})},async listMembers(e){return (await n(`/orgs/${e}/members`)).members},async inviteMember(e,t){return n(`/orgs/${e}/members/invite`,{method:"POST",body:JSON.stringify(t)})},async listInvites(e){return (await n(`/orgs/${e}/invites`)).invites},async cancelInvite(e,t){return n(`/orgs/${e}/invites/${t}`,{method:"DELETE"})},async removeMember(e,t){return n(`/orgs/${e}/members/${t}`,{method:"DELETE"})},async updateMemberRole(e,t,r){return n(`/orgs/${e}/members/${t}/role`,{method:"PATCH",body:JSON.stringify({role:r})})},async getMyMembership(e){try{return (await n(`/orgs/${e}/membership`)).membership}catch{return null}}}}function z(s){let n=p(s);return {async preview(e){return n("/schema-engine/preview",{method:"POST",body:JSON.stringify(e)})},async apply(e){return n("/schema-engine/apply",{method:"POST",body:JSON.stringify(e)})},async getMigrations(e,t){let r=t?`/schema-engine/migrations/project/${e}?limit=${t}`:`/schema-engine/migrations/project/${e}`;return n(r)},async saveSchema(e){return n("/schemas/",{method:"POST",body:JSON.stringify(e)})},async getSchemas(e){return n(`/schemas/project/${e}`)}}}function Q(s){let n=p(s);return {async create(e){return n("/functions/secrets",{method:"POST",body:JSON.stringify(e)})},async list(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/functions/secrets/project/${e}${o?`?${o}`:""}`;return n(a)},async reveal(e){return n(`/functions/secrets/${e}/value`)},async update(e,t){return n(`/functions/secrets/${e}`,{method:"PUT",body:JSON.stringify({value:t})})},async delete(e){return n(`/functions/secrets/${e}`,{method:"DELETE"})}}}function X(s){let n=p(s);return {async list(e,t){let r=new URLSearchParams;t&&r.set("env",t);let o=r.toString(),a=`/deployments/project/${e}${o?`?${o}`:""}`;return (await n(a)).deployments},async get(e){let t=await n(`/deployments/${e}`);return {...t.deployment,steps:t.steps}},async getSteps(e){return (await n(`/deployments/${e}/steps`)).steps},async promote(e){let t={projectId:e.projectId,fromEnv:e.sourceEnv,toEnv:e.targetEnv},r=await n("/deployments/promote",{method:"POST",body:JSON.stringify(t)}),o=await n(`/deployments/${r.deploymentId}`);return {deployment:{...o.deployment,steps:o.steps}}},async rollback(e){return n(`/deployments/${e}/rollback`,{method:"POST"})},async listTokens(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/deployments/tokens/project/${encodeURIComponent(e)}${o?`?${o}`:""}`;return (await n(a)).tokens},async createToken(e){return n("/deployments/tokens",{method:"POST",body:JSON.stringify(e)})},async revokeToken(e){return n(`/deployments/tokens/${encodeURIComponent(e)}/revoke`,{method:"POST"})}}}function Z(s){let n=p(s);return {async getStats(e){return n(`/realtime/stats/project/${e}`)},async getConnections(e){return (await n(`/realtime/connections/project/${e}`)).connections},async getSubscriptions(e){return (await n(`/realtime/subscriptions/project/${e}`)).subscriptions},async getEvents(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.source&&t.source!=="all"&&r.set("source",t.source),t?.level&&t.level!=="all"&&r.set("level",t.level);let o=r.toString(),a=`/realtime/events/project/${e}${o?`?${o}`:""}`;return (await n(a)).events},async getStatus(e){return n(`/realtime/status/project/${e}`)},async install(e){return n("/realtime/install",{method:"POST",body:JSON.stringify(e)})},async enableAll(e){return n("/realtime/enable-all",{method:"POST",body:JSON.stringify(e)})}}}function Y(s){let n=p(s);return {async listBuckets(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/buckets/project/${e}${o?`?${o}`:""}`;return (await n(a)).buckets},async getBucket(e){return (await n(`/buckets/${e}`)).bucket},async createBucket(e){return (await n("/buckets",{method:"POST",body:JSON.stringify(e)})).bucket},async updateBucket(e,t){return (await n(`/buckets/${e}`,{method:"PUT",body:JSON.stringify(t)})).bucket},async deleteBucket(e){return n(`/buckets/${e}`,{method:"DELETE"})},async listFiles(e,t){let r=new URLSearchParams;t?.prefix&&r.set("prefix",t.prefix),t?.maxKeys&&r.set("maxKeys",String(t.maxKeys)),t?.continuationToken&&r.set("continuationToken",t.continuationToken);let o=r.toString(),a=`/buckets/${e}/files${o?`?${o}`:""}`;return n(a)},async deleteFile(e,t){return n(`/buckets/${e}/files?key=${encodeURIComponent(t)}`,{method:"DELETE"})},async getSignedUrl(e,t,r){return n(`/buckets/${e}/signed-url`,{method:"POST",body:JSON.stringify({key:t,expiresIn:r})})},async getUploadUrl(e,t,r){return n(`/buckets/${e}/upload-url`,{method:"POST",body:JSON.stringify({key:t,...r})})},async uploadFile(e,t,r,o){let a=o?.prefix?`${o.prefix}${t}`:t,c=o?.contentType??(r instanceof Blob?r.type:"application/octet-stream"),i=new URLSearchParams;return i.set("key",a),c&&i.set("contentType",c),n(`/buckets/${e}/upload?${i.toString()}`,{method:"POST",body:r,headers:{"Content-Type":c||"application/octet-stream"}})}}}function ee(s){let n=p(s);return {async list(e,t){let r={type:t?.type,enabled:t?.enabled},o=h(r);return (await n(`/integrations/subscriptions/project/${e}${o}`)).subscriptions},async get(e){return n(`/integrations/subscriptions/${e}`)},async create(e){return (await n("/integrations/subscriptions",{method:"POST",body:JSON.stringify(e)})).subscription},async update(e,t){return (await n(`/integrations/subscriptions/${e}`,{method:"PATCH",body:JSON.stringify(t)})).subscription},async delete(e){return n(`/integrations/subscriptions/${e}`,{method:"DELETE"})},async enable(e){return this.update(e,{enabled:true})},async disable(e){return this.update(e,{enabled:false})},async test(e){return n(`/integrations/subscriptions/${e}/test`,{method:"POST"})},async publish(e){return n("/integrations/events/publish",{method:"POST",body:JSON.stringify(e)})},async publishBatch(e){return (await n("/integrations/events/publish-batch",{method:"POST",body:JSON.stringify({events:e})})).results},async listEvents(e){let t={envId:e.envId,source:e.source,name:e.name,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/events/project/${e.projectId}${r}`)).events},async getEvent(e){return n(`/integrations/events/${e}`)},async getDeliveries(e){let t={subscriptionId:e.subscriptionId,eventId:e.eventId,status:e.status,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/deliveries${r}`)).deliveries},async getDelivery(e){return n(`/integrations/deliveries/${e}`)},async retryDelivery(e){return n(`/integrations/deliveries/${e}/retry`,{method:"POST"})},async retryAllFailed(e){return n(`/integrations/subscriptions/${e}/retry-failed`,{method:"POST"})},async getDlq(e,t){let r={limit:t?.limit,offset:t?.offset},o=h(r);return (await n(`/integrations/dlq/project/${e}${o}`)).deliveries},async purgeDlq(e,t){return n(`/integrations/dlq/project/${e}/purge`,{method:"POST",body:JSON.stringify({olderThan:t.olderThan})})},async replayDlq(e,t){return n(`/integrations/dlq/project/${e}/replay`,{method:"POST",body:JSON.stringify(t)})},verifySignature(e){let t=e.tolerance??300;try{let r=e.signature.split(","),o=r.find(b=>b.startsWith("t=")),a=r.find(b=>b.startsWith("v1="));if(!o||!a)return !1;let c=parseInt(o.slice(2),10),i=a.slice(3),l=Math.floor(Date.now()/1e3);if(Math.abs(l-c)>t)return !1;let u=`${c}.${e.payload}`,y=new TextEncoder,I=y.encode(e.secret),S=y.encode(u),k=Array.from(I).concat(Array.from(S)).reduce((b,T)=>b+T,0).toString(16);if(i.length!==k.length)return !1;let C=0;for(let b=0;b<i.length;b++)C|=i.charCodeAt(b)^k.charCodeAt(b);return C===0}catch{return false}},generateSecret(){let e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",t="whsec_";for(let r=0;r<32;r++)t+=e.charAt(Math.floor(Math.random()*e.length));return t}}}function te(s){let n=p(s);return {async getSummary(e){return n(`/billing/org/${e}/summary`)},async getEntitlements(e){return n(`/entitlements/org/${e}`)},async checkEntitlement(e,t){return n(`/entitlements/org/${e}/check`,{method:"POST",body:JSON.stringify(t)})},async getPlans(){return (await n("/pricing/plans")).plans},async createCheckout(e){return n("/billing/checkout",{method:"POST",body:JSON.stringify(e)})},async verifyCheckoutSession(e){return n(`/billing/checkout/verify/${e}`)},async openPortal(e){return n(`/billing/org/${e.orgId}/portal`,{method:"POST",body:JSON.stringify({returnUrl:e.returnUrl})})},async getAIUsageSummary(e){return n(`/ai-usage/org/${e}/summary`)},async getAIUsageHistory(e,t=30){return n(`/ai-usage/org/${e}/history?days=${t}`)},async getAIUsageBreakdown(e){return n(`/ai-usage/org/${e}/breakdown`)},async getRecentAIRequests(e,t=50,r=0){return n(`/ai-usage/org/${e}/recent?limit=${t}&offset=${r}`)}}}function ne(s){let n=p(s);return {async getOverview(){return n("/admin/overview")},async listUsers(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/users${r?`?${r}`:""}`)},async getUser(e){return n(`/admin/users/${e}`)},async updateUserStatus(e,t){return n(`/admin/users/${e}/status`,{method:"PATCH",body:JSON.stringify({status:t})})},async updateUserAdmin(e,t){return n(`/admin/users/${e}/admin`,{method:"PATCH",body:JSON.stringify({isAdmin:t})})},async listOrganizations(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.plan&&t.set("plan",e.plan),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/organizations${r?`?${r}`:""}`)},async getOrganization(e){return n(`/admin/organizations/${e}`)},async updateOrganization(e,t){return n(`/admin/organizations/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listProjects(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.orgId&&t.set("orgId",e.orgId),e?.region&&t.set("region",e.region),e?.tenancy&&t.set("tenancy",e.tenancy),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/projects${r?`?${r}`:""}`)},async getProject(e){return n(`/admin/projects/${e}`)},async updateProject(e,t){return n(`/admin/projects/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getProjectResources(e){return n(`/admin/resources/project/${e}`)},async setDedicatedDb(e){return n(`/admin/resources/project/${e.projectId}/db`,{method:"POST",body:JSON.stringify({connectionString:e.connectionString})})},async listIncidents(e="open"){return (await n(`/admin/incidents?status=${e}`)).incidents},async createIncident(e){return n("/admin/incidents",{method:"POST",body:JSON.stringify(e)})},async acknowledgeIncident(e){return n(`/admin/incidents/${e}/ack`,{method:"POST"})},async resolveIncident(e){return n(`/admin/incidents/${e}/resolve`,{method:"POST"})},async listRegions(){return n("/admin/regions")},async updateRegion(e,t){return n(`/admin/regions/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getHealthComponents(){return n("/admin/health/components")},async updateHealthComponent(e,t){return n(`/admin/health/components/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listQueues(){return n("/admin/queues")},async listDlqMessages(e){let t=new URLSearchParams;e?.queue&&t.set("queue",e.queue),e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/dlq${r?`?${r}`:""}`)},async retryDlqMessage(e){return n(`/admin/dlq/${e}/retry`,{method:"POST"})},async archiveDlqMessage(e){return n(`/admin/dlq/${e}`,{method:"DELETE"})},async listFeatureFlags(){return (await n("/flags")).flags},async createFeatureFlag(e,t){return n("/flags",{method:"POST",body:JSON.stringify({key:e,enabled:t})})},async updateFeatureFlag(e,t){return n(`/flags/${e}`,{method:"PUT",body:JSON.stringify({enabled:t})})},async deleteFeatureFlag(e){return n(`/flags/${e}`,{method:"DELETE"})},async listAdmins(){return (await n("/admin/admins")).admins||[]},async addAdmin(e,t,r){return n("/admin/admins",{method:"POST",body:JSON.stringify({userId:e,role:t,notes:r})})},async updateAdmin(e,t){return n(`/admin/admins/${e}`,{method:"PUT",body:JSON.stringify(t)})},async removeAdmin(e){return n(`/admin/admins/${e}`,{method:"DELETE"})},async getSettings(e){let t=e?`?category=${e}`:"";return n(`/admin/settings${t}`)},async updateSetting(e,t){return n(`/admin/settings/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify({value:t})})},async listAIModels(){return n("/admin/ai/models")},async getAIModel(e){return n(`/admin/ai/models/${e}`)},async createAIModel(e){return n("/admin/ai/models",{method:"POST",body:JSON.stringify(e)})},async updateAIModel(e,t){return n(`/admin/ai/models/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteAIModel(e){return n(`/admin/ai/models/${e}`,{method:"DELETE"})},async toggleAIModel(e,t,r){return n(`/admin/ai/models/${e}/toggle`,{method:"POST",body:JSON.stringify({enabled:t,disabledMessage:r})})},async listAISessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/workspace/sessions${r?`?${r}`:""}`)},async getAISession(e){return n(`/admin/ai/workspace/sessions/${e}`)},async deleteAISession(e){return n(`/admin/ai/workspace/sessions/${e}`,{method:"DELETE"})},async listGeneratedBackends(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/backends${r?`?${r}`:""}`)},async getGeneratedBackend(e){return n(`/admin/ai/backends/${e}`)},async deleteGeneratedBackend(e){return n(`/admin/ai/backends/${e}`,{method:"DELETE"})},async listPromptTemplates(e){let t=new URLSearchParams;e?.category&&t.set("category",e.category),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/prompt-templates${r?`?${r}`:""}`)},async createPromptTemplate(e){return n("/admin/ai/prompt-templates",{method:"POST",body:JSON.stringify(e)})},async updatePromptTemplate(e,t){return n(`/admin/ai/prompt-templates/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deletePromptTemplate(e){return n(`/admin/ai/prompt-templates/${e}`,{method:"DELETE"})},async listContextSnapshots(e){let t=new URLSearchParams;e?.projectId&&t.set("projectId",e.projectId),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/context-snapshots${r?`?${r}`:""}`)},async invalidateContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}/invalidate`,{method:"POST"})},async deleteContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}`,{method:"DELETE"})},async getCopilotOverview(){return n("/admin/copilot/overview")},async listCopilotSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/sessions${r?`?${r}`:""}`)},async getCopilotSession(e){return n(`/admin/copilot/sessions/${e}`)},async deleteCopilotSession(e){return n(`/admin/copilot/sessions/${e}`,{method:"DELETE"})},async listCopilotMemories(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.projectId&&t.set("projectId",e.projectId),e?.memoryType&&t.set("memoryType",e.memoryType),e?.importance&&t.set("importance",e.importance),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/memories${r?`?${r}`:""}`)},async getCopilotMemoryStats(){return n("/admin/copilot/memories/stats")},async getCopilotMemory(e){return n(`/admin/copilot/memories/${e}`)},async updateCopilotMemory(e,t){return n(`/admin/copilot/memories/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteCopilotMemory(e){return n(`/admin/copilot/memories/${e}`,{method:"DELETE"})},async cleanupExpiredMemories(){return n("/admin/copilot/memories/cleanup",{method:"POST"})},async exportTrainingData(e){let t=new URLSearchParams;e?.format&&t.set("format",e.format),e?.dataType&&t.set("dataType",e.dataType),e?.minConfidence!==void 0&&t.set("minConfidence",String(e.minConfidence)),e?.limit&&t.set("limit",String(e.limit)),e?.includeExecuted!==void 0&&t.set("includeExecuted",String(e.includeExecuted)),e?.includeSuccessful!==void 0&&t.set("includeSuccessful",String(e.includeSuccessful));let r=t.toString();return n(`/admin/copilot/training-data/export${r?`?${r}`:""}`)},async getTrainingDataStats(){return n("/admin/copilot/training-data/stats")},async listErrors(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.path&&t.set("path",e.path),e?.errorCode&&t.set("errorCode",e.errorCode),e?.status&&t.set("status",e.status),e?.environment&&t.set("environment",e.environment),e?.startDate&&t.set("startDate",e.startDate),e?.endDate&&t.set("endDate",e.endDate),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/errors${r?`?${r}`:""}`)},async getErrorStats(){return n("/admin/errors/stats")},async getError(e){return n(`/admin/errors/${e}`)},async resolveError(e,t){return n(`/admin/errors/${e}/resolve`,{method:"PUT",body:JSON.stringify({notes:t})})},async deleteError(e){return n(`/admin/errors/${e}`,{method:"DELETE"})},async bulkDeleteErrors(e){let t=e?`?olderThanDays=${e}`:"";return n(`/admin/errors${t}`,{method:"DELETE"})},async getAIWorkspaceOverview(){return n("/admin/ai-workspace/overview")},async listAIWorkspaceSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.taskType&&t.set("taskType",e.taskType),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai-workspace/sessions${r?`?${r}`:""}`)},async getAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`)},async deleteAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`,{method:"DELETE"})}}}function re(s){let n=p(s);return {async list(){return (await n("/flags")).flags},async create(e){return n("/flags",{method:"POST",body:JSON.stringify(e)})},async update(e,t){return n(`/flags/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify(t)})},async delete(e){return n(`/flags/${encodeURIComponent(e)}`,{method:"DELETE"})}}}function oe(s){let n=p(s);return {async getOverview(e){return (await n(`/security/overview/${encodeURIComponent(e)}`)).overview},async getAuditLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.offset&&r.set("offset",String(t.offset));let o=r.toString(),a=`/security/audit/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async listEnvVars(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/projects/${encodeURIComponent(e)}/env-vars${o?`?${o}`:""}`;return (await n(a)).envVars},async createEnvVar(e,t){return (await n(`/projects/${encodeURIComponent(e)}/env-vars`,{method:"POST",body:JSON.stringify(t)})).envVar},async updateEnvVar(e,t,r){return (await n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})).envVar},async deleteEnvVar(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"DELETE"})},async getEnvVarValue(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}/value`)}}}function se(s){let n=p(s);return {async generatePlan(e){return n("/ai/plan",{method:"POST",body:JSON.stringify({projectId:e.projectId,prompt:e.prompt,context:e.context,taskType:e.taskType,mode:e.mode})})},async explainPlan(e){return n("/ai/explain",{method:"POST",body:JSON.stringify({plan:e.plan,projectId:e.projectId,taskType:e.taskType,mode:e.mode})})},async getOrgSettings(e){return n(`/ai/settings/org/${encodeURIComponent(e)}`)},async updateOrgSettings(e,t){return n(`/ai/settings/org/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getProjectOverrides(e){return n(`/ai/settings/project/${encodeURIComponent(e)}`)},async updateProjectOverrides(e,t){return n(`/ai/settings/project/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getUsage(e,t){let r=new URLSearchParams;t&&r.set("month",t);let o=r.toString(),a=`/ai/usage/org/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async getBudgetStatus(e){let[t,r]=await Promise.all([this.getOrgSettings(e),this.getUsage(e)]),o=t?.monthlyBudgetCents??1e4,a=r.costCents,c=Math.max(0,o-a),i=o>0?Math.round(a/o*100):0;return {spent:a,budget:o,remaining:c,hardStop:t?.hardStopEnabled??false,percentUsed:i}},async generateFunction(e){return n("/ai/generate-function",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,inputSchema:e.inputSchema,outputSchema:e.outputSchema,language:e.language??"typescript",mode:e.mode})})},async generateEndpoint(e){return n("/ai/generate-endpoint",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,method:e.method??"GET",authRequired:e.authRequired??true,mode:e.mode})})},async exportCode(e){return n("/ai/export-code",{method:"POST",body:JSON.stringify({projectId:e.projectId,targetLanguage:e.targetLanguage,includeSchema:e.includeSchema??true,includeFunctions:e.includeFunctions??true,includeEndpoints:e.includeEndpoints??true})})},async createConversation(e,t){return n("/ai/conversations",{method:"POST",body:JSON.stringify({projectId:e,title:t?.title,context:t?.context})})},async sendMessage(e,t){return n(`/ai/conversations/${encodeURIComponent(e)}/messages`,{method:"POST",body:JSON.stringify({content:t.content,taskType:t.taskType})})},async getConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`)},async listConversations(e){return (await n(`/ai/conversations/project/${encodeURIComponent(e)}`)).conversations},async deleteConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`,{method:"DELETE"})},async getAvailableModels(){return n("/ai/models/available")},async getModel(e){return n(`/ai/models/${encodeURIComponent(e)}`)},async getProjectContext(e){return n(`/ai/context/${encodeURIComponent(e)}`)},async estimateTokens(e,t){return n("/ai/context/estimate",{method:"POST",body:JSON.stringify({prompt:e,projectId:t})})},async analyzeForClarification(e){return n("/ai/clarify",{method:"POST",body:JSON.stringify(e)})},async getSuggestions(e){return n("/ai/suggestions",{method:"POST",body:JSON.stringify(e)})},workspace:{async create(e){return n("/ai/workspace/create",{method:"POST",body:JSON.stringify(e)})},async get(e){return n(`/ai/workspace/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/workspace/list/${encodeURIComponent(e)}`)},async submitPrompt(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/prompt`,{method:"POST",body:JSON.stringify(t),timeout:12e4})},async submitClarification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/clarify`,{method:"POST",body:JSON.stringify({responses:t}),timeout:9e4})},async generate(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/generate`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitModification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/modify`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitFeedback(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/feedback`,{method:"POST",body:JSON.stringify(t)})}},backends:{async get(e){return n(`/ai/backends/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/backends/list/${encodeURIComponent(e)}`)},async delete(e){return n(`/ai/backends/${encodeURIComponent(e)}`,{method:"DELETE"})},async deploy(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy`,{method:"POST",body:JSON.stringify(t)})},async apply(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/apply`,{method:"POST",body:JSON.stringify(t)})},async deployLive(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy-live`,{method:"POST",body:JSON.stringify(t),timeout:3e5})},async getDeployments(e){return n(`/ai/backends/${encodeURIComponent(e)}/deployments`)}},deployments:{async getLimits(e){return n(`/ai/deployments/limits/${encodeURIComponent(e)}`)},async getStatus(e){return n(`/ai/deployments/${encodeURIComponent(e)}/status`)},async getLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.severity&&r.set("severity",t.severity);let o=r.toString();return n(`/ai/deployments/${encodeURIComponent(e)}/logs${o?`?${o}`:""}`)},async terminate(e){return n(`/ai/deployments/${encodeURIComponent(e)}`,{method:"DELETE"})},async redeploy(e){return n(`/ai/deployments/${encodeURIComponent(e)}/redeploy`,{method:"POST",timeout:3e5})}},async getUserOrganizations(){return n("/ai/user/organizations")},async getProjectLimits(e){return n(`/ai/org/${encodeURIComponent(e)}/project-limits`)},async createProjectWithSchema(e){return n("/ai/schema/create-project",{method:"POST",body:JSON.stringify(e)})}}}function ie(s){let n=p(s);return {async load(){return n("/bootstrap")}}}function ae(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.visibility&&t.set("visibility",e.visibility),e?.category&&t.set("category",e.category),e?.orgId&&t.set("orgId",e.orgId);let r=t.toString(),o=`/templates${r?`?${r}`:""}`;return (await n(o)).templates},async get(e){return n(`/templates/${e}`)},async previewInstall(e){return n("/templates/install/preview",{method:"POST",body:JSON.stringify(e)})},async applyInstall(e){return n("/templates/install/apply",{method:"POST",body:JSON.stringify(e)})},async rollback(e){return n(`/templates/install/${e}/rollback`,{method:"POST"})},async createProject(e){return n("/templates/create-project",{method:"POST",body:JSON.stringify(e)})}}}function le(s){let n=p(s);return {async list(e){return (await n(`/oauth/org/${e}`)).connections},async configure(e,t){return n(`/oauth/org/${e}/configure`,{method:"POST",body:JSON.stringify(t)})},async enable(e){return n(`/oauth/connections/${e}/enable`,{method:"POST"})},async disable(e){return n(`/oauth/connections/${e}/disable`,{method:"POST"})},async delete(e){return n(`/oauth/connections/${e}`,{method:"DELETE"})}}}function ce(s){let n=p(s);return {async listPages(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/pages${t}`)).pages},async getPage(e){return (await n(`/docs/pages/${encodeURIComponent(e)}`)).page},async createPage(e){return (await n("/docs/pages",{method:"POST",body:JSON.stringify(e)})).page},async updatePage(e,t){return (await n(`/docs/pages/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).page},async deletePage(e){return n(`/docs/pages/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdks(){return (await n("/docs/sdks")).sdks},async getSdk(e){return (await n(`/docs/sdks/${encodeURIComponent(e)}`)).sdk},async createSdk(e){return (await n("/docs/sdks",{method:"POST",body:JSON.stringify(e)})).sdk},async updateSdk(e,t){return (await n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).sdk},async deleteSdk(e){return n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdkExamples(e,t){let r=t?`?topic=${encodeURIComponent(t)}`:"";return (await n(`/docs/sdks/${encodeURIComponent(e)}/examples${r}`)).examples},async createSdkExample(e){return (await n("/docs/sdk-examples",{method:"POST",body:JSON.stringify(e)})).example},async deleteSdkExample(e){return n(`/docs/sdk-examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listEndpoints(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/api-endpoints${t}`)).endpoints},async getEndpoint(e){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`)).endpoint},async createEndpoint(e){return (await n("/docs/api-endpoints",{method:"POST",body:JSON.stringify(e)})).endpoint},async updateEndpoint(e,t){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).endpoint},async deleteEndpoint(e){return n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"DELETE"})},async listExamples(e){let t=e!==void 0?`?featured=${e}`:"";return (await n(`/docs/examples${t}`)).examples},async getExample(e){return (await n(`/docs/examples/${encodeURIComponent(e)}`)).example},async createExample(e){return (await n("/docs/examples",{method:"POST",body:JSON.stringify(e)})).example},async updateExample(e,t){return (await n(`/docs/examples/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).example},async deleteExample(e){return n(`/docs/examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listChangelog(){return (await n("/docs/changelog")).entries},async getChangelogEntry(e){return (await n(`/docs/changelog/${encodeURIComponent(e)}`)).entry},async createChangelogEntry(e){return (await n("/docs/changelog",{method:"POST",body:JSON.stringify(e)})).entry},async updateChangelogEntry(e,t){return (await n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).entry},async deleteChangelogEntry(e){return n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"DELETE"})},async search(e){return (await n(`/docs/search?q=${encodeURIComponent(e)}`)).results}}}function V(s,n,e,t){let r=[...n],o=0,a=false,c=false,i=async()=>{if(c||a)return;let l=await e(`/mongodb/${t}/cursor/${s}/next`,{method:"POST"});r=l.batch,o=0,a=l.exhausted;};return {id:s,async hasNext(){return c?false:o<r.length?true:a?false:(await i(),r.length>0)},async next(){return c?null:o<r.length?r[o++]:a||(await i(),r.length===0)?null:r[o++]},async toArray(){if(c)return [];let l=[];for(;o<r.length;)l.push(r[o++]);for(;!a;)await i(),l.push(...r),o=r.length;return l},async forEach(l){if(!c){for(;o<r.length;)await l(r[o++]);for(;!a;){await i();for(let u of r)await l(u);o=r.length;}}},map(l){let u=r.slice(o).map(l);return V(s,u,e,t)},async close(){if(!c){c=true;try{await e(`/mongodb/${t}/cursor/${s}/close`,{method:"POST"});}catch{}}},isClosed(){return c}}}function ke(s,n){let e=`/mongodb/${encodeURIComponent(s)}`;return {collectionName:s,async find(t,r){return n(`${e}/find`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findCursor(t,r){let o=await n(`${e}/find/cursor`,{method:"POST",body:JSON.stringify({filter:t,options:r})});return V(o.cursorId,o.batch,n,s)},async findOne(t,r){return n(`${e}/findOne`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findById(t,r){return n(`${e}/findById/${encodeURIComponent(t)}`,{method:"GET",...r&&{body:JSON.stringify({options:r})}})},async countDocuments(t){return (await n(`${e}/count`,{method:"POST",body:JSON.stringify({filter:t})})).count},async estimatedDocumentCount(){return (await n(`${e}/estimatedCount`)).count},async distinct(t,r){return n(`${e}/distinct`,{method:"POST",body:JSON.stringify({field:t,...r})})},async insertOne(t){return n(`${e}/insertOne`,{method:"POST",body:JSON.stringify({document:t})})},async insertMany(t,r){return n(`${e}/insertMany`,{method:"POST",body:JSON.stringify({documents:t,options:r})})},async updateOne(t,r,o){return n(`${e}/updateOne`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async updateMany(t,r,o){return n(`${e}/updateMany`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async replaceOne(t,r,o){return n(`${e}/replaceOne`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async findOneAndUpdate(t,r,o){return n(`${e}/findOneAndUpdate`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async findOneAndReplace(t,r,o){return n(`${e}/findOneAndReplace`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async deleteOne(t){return n(`${e}/deleteOne`,{method:"POST",body:JSON.stringify({filter:t})})},async deleteMany(t){return n(`${e}/deleteMany`,{method:"POST",body:JSON.stringify({filter:t})})},async findOneAndDelete(t,r){return n(`${e}/findOneAndDelete`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async aggregate(t,r){return n(`${e}/aggregate`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})})},async aggregateCursor(t,r){let o=await n(`${e}/aggregate/cursor`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})});return V(o.cursorId,o.batch,n,s)},async createIndex(t,r){return (await n(`${e}/indexes`,{method:"POST",body:JSON.stringify({keys:t,options:r})})).indexName},async dropIndex(t){await n(`${e}/indexes/${encodeURIComponent(t)}`,{method:"DELETE"});},async listIndexes(){return n(`${e}/indexes`)},async bulkWrite(t,r){return n(`${e}/bulkWrite`,{method:"POST",body:JSON.stringify({operations:t,options:r})})}}}function de(s){let n=p(s);return {collection(e){return ke(e,n)},async listCollections(){return n("/mongodb/collections")},async createCollection(e,t){await n("/mongodb/collections",{method:"POST",body:JSON.stringify({name:e,options:t})});},async dropCollection(e){await n(`/mongodb/collections/${encodeURIComponent(e)}`,{method:"DELETE"});},async renameCollection(e,t){await n(`/mongodb/collections/${encodeURIComponent(e)}/rename`,{method:"POST",body:JSON.stringify({newName:t})});},async command(e){return n("/mongodb/command",{method:"POST",body:JSON.stringify(e)})}}}function ge(s){let n=p(s);return {async chat(e){return n("/ai/copilot/chat",{method:"POST",body:JSON.stringify(e),timeout:12e4})},getStreamUrl(){return `${s.baseUrl}/ai/copilot/chat/stream`},async getModels(e){return n(`/ai/copilot/models/${encodeURIComponent(e)}`)},async getCreditStatus(e){return n(`/ai/copilot/credit-status/${encodeURIComponent(e)}`)},async listSessions(e){return n(`/ai/copilot/sessions/${encodeURIComponent(e)}`)},async getSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`)},async updateSession(e,t){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"DELETE"})},async executePlan(e){return n("/ai/copilot/execute",{method:"POST",body:JSON.stringify(e),timeout:18e4})},async submitFeedback(e){return n("/ai/copilot/feedback",{method:"POST",body:JSON.stringify(e)})},async getClassificationStats(){return n("/ai/copilot/stats")},async getUsage(e){return n(`/ai/copilot/usage-org/${encodeURIComponent(e)}`)}}}function he(s,n,e,t){let r=n.type||"public",o="unsubscribed",a=new Map,c=[],i={},l=null,u=null,y=new Set,I=new Set,S=new Set,k=d=>{if(d.event){let P=a.get(d.event);P&&P.forEach(R=>R(d.payload));}},C=d=>{i=d.state||{},y.forEach(P=>P(i));},b=d=>{let P=d.key||"",R=d.currentPresences||[],g=d.joinedPresences||[],m=d.leftPresences||[];g.length>0&&(i[P]=R,I.forEach(f=>f(P,R,g))),m.length>0&&(R.length===0?delete i[P]:i[P]=R,S.forEach(f=>f(P,R,m))),y.forEach(f=>f(i));},T=d=>{let P={type:"db_change",projectId:d.projectId||"",schema:d.schema||"",table:d.table||"",operation:d.op,new:d.record,old:d.old_record,timestamp:d.ts||new Date().toISOString(),partial:d.partial};c.forEach(({options:R,handler:g})=>{if(R.table===P.table){let m=R.event||"*";(m==="*"||(Array.isArray(m)?m.includes(P.operation):m===P.operation))&&g(P);}});},v={get name(){return s},get type(){return r},get status(){return o},_handleMessage:d=>{switch(d.type){case "broadcast":k(d);break;case "presence_state":C(d);break;case "presence":b(d);break;case "db_change":T(d);break;case "subscribed":o="subscribed";break;case "error":o="error";break}},onDbChange(d,P){return c.push({options:d,handler:P}),o==="subscribed"&&e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}}),v},on(d,P){return a.has(d)||a.set(d,new Set),a.get(d).add(P),v},off(d,P){return P?a.get(d)?.delete(P):a.delete(d),v},async broadcast(d){if(o!=="subscribed")throw new Error("Channel must be subscribed before broadcasting");e({type:"broadcast",channel:s,event:d.event,payload:d.payload,includeSelf:d.includeSelf});},presence:{async track(d){if(r!=="presence")throw new Error("Presence tracking is only available on presence channels");l=d.key||t()||"anonymous",u=d.state,e({type:"presence_track",channel:s,key:l,state:u});},async update(d){if(!u)throw new Error("Must call track() before update()");u={...u,...d},e({type:"presence_update",channel:s,key:l??void 0,state:u});},async untrack(){l&&(e({type:"presence_untrack",channel:s,key:l}),l=null,u=null);},state(){return {...i}},onSync(d){return y.add(d),v},onJoin(d){return I.add(d),v},onLeave(d){return S.add(d),v}},async subscribe(){return o==="subscribed"||(o="subscribing",e({type:"subscribe",channel:s}),c.forEach(({options:d})=>{e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}});}),n.presenceState&&r==="presence"&&await v.presence.track({state:n.presenceState})),v},async unsubscribe(){o!=="unsubscribed"&&(l&&await v.presence.untrack(),e({type:"unsubscribe",channel:s}),o="unsubscribed",i={},a.clear(),c.length=0);}};return v}function ue(s,n){let{wsUrl:e=s.baseUrl.replace(/^http/,"ws")+"/realtime/ws",autoReconnect:t=true,reconnectDelay:r=1e3,maxReconnectAttempts:o=10}=n??{},a=null,c="disconnected",i=null,l=null,u=0,y=null,I=null,S=new Map,k=new Map,C=new Set,b={connect:new Set,disconnect:new Set,error:new Set,reconnect:new Set},T=g=>{b[g].forEach(m=>m());},E=g=>{let m=`table:${g.table}`;if(g.filter){let A=(Array.isArray(g.filter)?g.filter:[g.filter]).map(w=>`${w.field}${w.operator||"eq"}${w.value}`).join("&");m+=`?${A}`;}return m},v=g=>{a?.readyState===WebSocket.OPEN&&a.send(JSON.stringify(g));},d=g=>{if(g.channel){let m=S.get(g.channel);if(m){m._handleMessage(g);return}}switch(g.type){case "db_change":{let m={type:"db_change",projectId:g.projectId??"",schema:g.schema??"",table:g.table??"",operation:g.op,new:g.record,old:g.old_record,timestamp:g.ts??new Date().toISOString(),partial:g.partial},f=`table:${g.table}`;k.forEach((A,w)=>{(w===f||w.startsWith(f+"?"))&&A.forEach(B=>B(m));});break}case "presence":{let m={type:"presence",event:g.event,key:g.key||g.connectionId||"",connectionId:g.connectionId??"",projectId:g.projectId??"",currentPresences:g.currentPresences||[],leftPresences:g.leftPresences||[],joinedPresences:g.joinedPresences||[]};C.forEach(f=>f(m));break}case "welcome":i=g.connectionId||null;break;case "error":{console.error("[vaif/realtime] Server error:",g.message),T("error");break}}},P=()=>new Promise((g,m)=>{let f=new URLSearchParams;s.apiKey&&f.set(s.apiKeyHeader,s.apiKey),l&&f.set("token",l);let A=f.toString(),w=A?`${e}?${A}`:e;try{a=new WebSocket(w);}catch{m(new x("Failed to create WebSocket connection"));return}let B=()=>{c="connected",u=0,T("connect"),S.forEach(M=>{(M.status==="subscribed"||M.status==="subscribing")&&M.subscribe();}),k.forEach((M,N)=>{v({type:"subscribe",channel:N});}),I=setInterval(()=>{v({type:"ping"});},3e4),g();},pe=M=>{try{let N=JSON.parse(M.data);d(N);}catch{}},me=()=>{if(c="disconnected",i=null,a=null,I&&(clearInterval(I),I=null),T("disconnect"),t&&u<o){c="reconnecting";let M=r*Math.pow(2,u);y=setTimeout(()=>{u++,T("reconnect"),P().catch(()=>{});},Math.min(M,3e4));}},ye=()=>{T("error"),m(new x("WebSocket connection error"));};a.addEventListener("open",B),a.addEventListener("message",pe),a.addEventListener("close",me),a.addEventListener("error",ye);}),R=()=>{y&&(clearTimeout(y),y=null),I&&(clearInterval(I),I=null),u=o;};return {channel(g,m={}){let f=S.get(g);if(f)return f;let A=he(g,m,v,()=>i);return S.set(g,A),A},async removeChannel(g){let m=S.get(g.name);m&&(await m.unsubscribe(),S.delete(g.name));},getChannels(){return Array.from(S.values())},subscribe(g,m){let f=E(g);return k.has(f)||k.set(f,new Set),k.get(f).add(m),a?.readyState===WebSocket.OPEN&&v({type:"subscribe",channel:f}),()=>{let A=k.get(f);A&&(A.delete(m),A.size===0&&(k.delete(f),a?.readyState===WebSocket.OPEN&&v({type:"unsubscribe",channel:f})));}},subscribeToPresence(g){return C.add(g),()=>{C.delete(g);}},async connect(){if(c!=="connected"){if(!s.apiKey)throw new D("API key is required for realtime connections");c="connecting",await P();}},disconnect(){R(),S.forEach(g=>{g.unsubscribe();}),S.clear(),a&&(a.close(),a=null),c="disconnected",i=null;},get isConnected(){return c==="connected"},get connectionState(){return c},get connectionId(){return i},on(g,m){b[g].add(m);},off(g,m){b[g].delete(m);},setAuth(g){l=g;}}}var j={apiKeyHeader:"x-vaif-key",timeout:3e4,retry:{maxRetries:3,retryDelay:1e3,retryOn:[429,500,502,503,504]}};function Se(s){return {baseUrl:s.baseUrl.replace(/\/$/,""),apiKey:s.apiKey,apiKeyHeader:s.apiKeyHeader??j.apiKeyHeader,accessToken:s.accessToken,fetch:s.fetch??globalThis.fetch.bind(globalThis),timeout:s.timeout??j.timeout,retry:{maxRetries:s.retry?.maxRetries??j.retry.maxRetries,retryDelay:s.retry?.retryDelay??j.retry.retryDelay,retryOn:s.retry?.retryOn??[...j.retry.retryOn]}}}function ve(s){let n=Se(s),e=q(n),t=J(n),r=K(n),o=G(n),a=_(n),c=H(n),i=z(n),l=Q(n),u=X(n),y=Z(n),I=Y(n),S=ee(n),k=te(n),C=ne(n),b=re(n),T=oe(n),E=se(n),v=ie(n),d=ae(n),P=le(n),R=ce(n),g=de(n),m=ge(n);return {from:e.from,auth:t,functions:r,storage:o,projects:a,orgs:c,schema:i,secrets:l,deployments:u,realtimeMonitoring:y,storageDashboard:I,integrations:S,billing:k,admin:C,flags:b,security:T,ai:E,bootstrap:v,templates:d,oauth:P,docs:R,mongodb:g,copilot:m,realtime:f=>ue(n,f)}}Object.defineProperty(exports,"AuthError",{enumerable:true,get:function(){return auth.AuthError}});Object.defineProperty(exports,"InvalidCredentialsError",{enumerable:true,get:function(){return auth.InvalidCredentialsError}});Object.defineProperty(exports,"SessionExpiredError",{enumerable:true,get:function(){return auth.SessionExpiredError}});Object.defineProperty(exports,"SessionStorage",{enumerable:true,get:function(){return auth.SessionStorage}});Object.defineProperty(exports,"VaifAuthClient",{enumerable:true,get:function(){return auth.VaifAuthClient}});Object.defineProperty(exports,"authLocalStorage",{enumerable:true,get:function(){return auth.localStorage}});Object.defineProperty(exports,"authSessionStorage",{enumerable:true,get:function(){return auth.sessionStorage}});Object.defineProperty(exports,"cookieStorage",{enumerable:true,get:function(){return auth.cookieStorage}});Object.defineProperty(exports,"createAuthClient",{enumerable:true,get:function(){return auth.createAuthClient}});Object.defineProperty(exports,"getDefaultStorage",{enumerable:true,get:function(){return auth.getDefaultStorage}});Object.defineProperty(exports,"isBrowser",{enumerable:true,get:function(){return auth.isBrowser}});Object.defineProperty(exports,"isMFAChallenge",{enumerable:true,get:function(){return auth.isMFAChallenge}});Object.defineProperty(exports,"memoryStorage",{enumerable:true,get:function(){return auth.memoryStorage}});exports.VaifAuthError=D;exports.VaifError=O;exports.VaifNetworkError=x;exports.VaifNotFoundError=F;exports.VaifRateLimitError=$;exports.VaifValidationError=U;exports.createVaifClient=ve;exports.isVaifError=be;
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- export{AuthError,InvalidCredentialsError,SessionExpiredError,SessionStorage,VaifAuthClient,localStorage as authLocalStorage,sessionStorage as authSessionStorage,cookieStorage,createAuthClient,getDefaultStorage,isBrowser,isMFAChallenge,memoryStorage}from'@vaiftech/auth';var O=class s extends Error{constructor(n,e){super(n),this.name="VaifError",this.code=e.code,this.statusCode=e.statusCode,this.requestId=e.requestId,this.details=e.details;let t=Error;t.captureStackTrace&&t.captureStackTrace(this,s);}toJSON(){return {name:this.name,message:this.message,code:this.code,statusCode:this.statusCode,requestId:this.requestId,details:this.details}}},D=class extends O{constructor(n,e){super(n,{code:e?.code??"AUTH_ERROR",statusCode:e?.statusCode??401,requestId:e?.requestId}),this.name="VaifAuthError";}},U=class extends O{constructor(n,e){super(n,{code:"VALIDATION_ERROR",statusCode:400,requestId:e?.requestId,details:e?.details??e?.fieldErrors}),this.name="VaifValidationError",this.fieldErrors=e?.fieldErrors;}},x=class extends O{constructor(n,e){super(n,{code:"NETWORK_ERROR"}),this.name="VaifNetworkError",this.cause=e;}},$=class extends O{constructor(n,e){super(n,{code:"RATE_LIMITED",statusCode:429}),this.name="VaifRateLimitError",this.retryAfter=e;}},F=class extends O{constructor(n,e){super(n,{code:"NOT_FOUND",statusCode:404,requestId:e}),this.name="VaifNotFoundError";}};function be(s){return s instanceof O}async function fe(s){let n;try{n=await s.json();}catch{}let e=n?.message??n?.error??s.statusText??"Request failed",t=n?.requestId;switch(s.status){case 400:return new U(e,{details:n?.details,requestId:t});case 401:return new D(e,{code:"UNAUTHORIZED",statusCode:401,requestId:t});case 403:return new D(e,{code:"FORBIDDEN",statusCode:403,requestId:t});case 404:return new F(e,t);case 429:{let r=s.headers.get("Retry-After"),o=r?parseInt(r,10):void 0;return new $(e,o)}default:return new O(e,{code:n?.error??"HTTP_ERROR",statusCode:s.status,requestId:t,details:n?.details})}}async function Pe(s,n){let{timeout:e=3e4,fetchFn:t,...r}=n,o=new AbortController,a=setTimeout(()=>o.abort(),e);try{let c=await t(s,{...r,signal:o.signal});if(clearTimeout(a),!c.ok)throw await fe(c);if(c.status===204)return;let i=await c.text();return i?JSON.parse(i):void 0}catch(c){throw clearTimeout(a),c instanceof O?c:c instanceof Error&&c.name==="AbortError"?new x("Request timed out"):c instanceof Error?new x(c.message,c):new x("Network request failed")}}function p(s){let{baseUrl:n,apiKey:e,apiKeyHeader:t,accessToken:r,fetch:o,timeout:a}=s;return async function(i,l={}){let u=`${n}${i}`,y={"Content-Type":"application/json",...l.headers??{}};if(e&&(y[t]=e),r){let I=typeof r=="function"?await r():r;y.Authorization=`Bearer ${I}`;}return Pe(u,{...l,headers:y,timeout:l.timeout??a,fetchFn:o})}}function h(s){let n=new URLSearchParams;for(let[t,r]of Object.entries(s))r!==void 0&&n.set(t,String(r));let e=n.toString();return e?`?${e}`:""}function Ie(s){return JSON.stringify(s)}function L(s,n,e={}){let t={...e},r=()=>{let i={};if(t.limit!==void 0&&(i.limit=t.limit),t.offset!==void 0&&(i.offset=t.offset),t.where&&(i.where=Ie(t.where)),t.orderBy){let l=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];i.orderBy=JSON.stringify(l);}return t.select&&t.select.length>0&&(i.select=t.select.join(",")),t.include&&t.include.length>0&&(i.include=JSON.stringify(t.include)),t.distinct&&t.distinct.length>0&&(i.distinct=t.distinct.join(",")),i},o=()=>h(r()),a=i=>L(s,n,{...t,...i}),c={async list(i){i&&(t={...t,...i});let l=o();return n(`/generated/${s}${l}`)},async get(i){let l={};t.select&&t.select.length>0&&(l.select=t.select.join(",")),t.include&&t.include.length>0&&(l.include=JSON.stringify(t.include));let u=h(l);return n(`/generated/${s}/${encodeURIComponent(i)}${u}`)},async first(){let i=await c.limit(1).list();return i.data.length>0?i.data[0]:null},async firstOrFail(){let i=await c.first();if(!i)throw new Error(`No record found in table '${s}' matching the query`);return i},async create(i){return n(`/generated/${s}`,{method:"POST",body:JSON.stringify(i)})},async update(i,l){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"PATCH",body:JSON.stringify(l)})},async delete(i){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"DELETE"})},async createMany(i,l){return n(`/generated/${s}/batch`,{method:"POST",body:JSON.stringify({records:i,skipOnConflict:l?.skipOnConflict,returnRecords:l?.returnRecords})})},async updateMany(i,l){return n(`/generated/${s}/batch`,{method:"PATCH",body:JSON.stringify({data:i,where:t.where,returnRecords:l?.returnRecords})})},async deleteMany(){return n(`/generated/${s}/batch`,{method:"DELETE",body:JSON.stringify({where:t.where})})},async upsert(i,l){return n(`/generated/${s}/upsert`,{method:"POST",body:JSON.stringify({data:i,conflictFields:l.conflictFields,updateFields:l.updateFields})})},async count(){let i=r(),l=h(i);return (await n(`/generated/${s}/count${l}`)).count},async sum(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/sum${u}`)).sum},async avg(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/avg${u}`)).avg},async min(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/min${u}`)).min},async max(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/max${u}`)).max},async aggregate(i,l){return n(`/generated/${s}/aggregate`,{method:"POST",body:JSON.stringify({aggregates:i,where:l?.where||t.where,groupBy:l?.groupBy,having:l?.having})})},async paginate(i){let l=i.page||1,u=i.pageSize||20,y=(l-1)*u,I=r();I.limit=u,I.offset=y,I.includeCount=true;let S=h(I),k=await n(`/generated/${s}${S}`),C=k.total||k.data.length,b=Math.ceil(C/u);return {data:k.data,pageInfo:{total:C,page:l,pageSize:u,pageCount:b,hasNextPage:l<b,hasPrevPage:l>1}}},async cursorPaginate(i){let l=r();l.limit=i.limit||20,i.cursor&&(l.cursor=i.cursor);let u=h(l),y=await n(`/generated/${s}/cursor${u}`);return {data:y.data,nextCursor:y.nextCursor,prevCursor:y.prevCursor,hasMore:y.hasMore}},where(i){if(t.where){let l=t.where;return a({where:{AND:[...Array.isArray(l)?l:[l],i]}})}return a({where:i})},orderBy(i,l="asc"){let u={field:i,direction:l};if(t.orderBy){let y=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];return a({orderBy:[...y,u]})}return a({orderBy:u})},select(...i){return a({select:i})},limit(i){return a({limit:i})},offset(i){return a({offset:i})},include(i){let l=t.include||[];return a({include:[...l,i]})},distinct(...i){return a({distinct:i})}};return c}function q(s){let n=p(s);return {from(e){return L(e,n)},async raw(e,t){return n("/generated/raw",{method:"POST",body:JSON.stringify({query:e,params:t})})},async transaction(e,t){return n("/generated/transaction",{method:"POST",body:JSON.stringify({operations:e,isolationLevel:t?.isolationLevel,timeout:t?.timeout})})},async withTransaction(e,t){let o=(await n("/generated/transaction/start",{method:"POST",body:JSON.stringify({isolationLevel:t?.isolationLevel,timeout:t?.timeout})})).transactionId,a=(i,l)=>{let u=new Headers(l?.headers);return u.set("X-Transaction-Id",o),n(i,{...l,headers:u})},c={from(i){return L(i,a)},async raw(i,l){return a("/generated/raw",{method:"POST",body:JSON.stringify({query:i,params:l})})},async transaction(){throw new Error("Nested transactions are not supported")},async withTransaction(){throw new Error("Nested transactions are not supported")}};try{let i=await e(c);return await n("/generated/transaction/commit",{method:"POST",body:JSON.stringify({transactionId:o})}),i}catch(i){throw await n("/generated/transaction/rollback",{method:"POST",body:JSON.stringify({transactionId:o})}).catch(()=>{}),i}}}}function J(s){let n=p(s);return {async signUp(e,t,r){return n("/auth/signup",{method:"POST",body:JSON.stringify({email:e,password:t,name:r?.name,phone:r?.phone,metadata:r?.metadata,redirectUrl:r?.redirectUrl})})},async login(e,t,r){return n("/auth/login",{method:"POST",body:JSON.stringify({email:e,password:t,mfaCode:r?.mfaCode,rememberMe:r?.rememberMe})})},async logout(){await n("/auth/logout",{method:"POST"});},async logoutAll(){await n("/auth/logout-all",{method:"POST"});},async getUser(){return (await n("/auth/me")).user},async updateProfile(e){return (await n("/users/me",{method:"PATCH",body:JSON.stringify(e)})).user},async changePassword(e){return n("/users/me/change-password",{method:"POST",body:JSON.stringify(e)})},async requestPasswordReset(e){return n("/auth/forgot-password",{method:"POST",body:JSON.stringify(e)})},async confirmPasswordReset(e){return n("/auth/reset-password",{method:"POST",body:JSON.stringify(e)})},async requestEmailVerification(e){return n("/auth/verify-email/send",{method:"POST",body:JSON.stringify(e||{})})},async confirmEmailVerification(e){return n("/auth/verify-email/confirm",{method:"POST",body:JSON.stringify(e)})},async getOAuthSignInUrl(e){return n("/auth/oauth/authorize",{method:"POST",body:JSON.stringify(e)})},async handleOAuthCallback(e){return n("/auth/oauth/callback",{method:"POST",body:JSON.stringify(e)})},async linkOAuthProvider(e){return n("/auth/oauth/link",{method:"POST",body:JSON.stringify(e)})},async unlinkOAuthProvider(e){return n(`/auth/oauth/unlink/${e}`,{method:"POST"})},async listLinkedProviders(){return n("/auth/oauth/providers")},async requestMagicLink(e){return n("/auth/magic-link/send",{method:"POST",body:JSON.stringify(e)})},async verifyMagicLink(e){return n("/auth/magic-link/verify",{method:"POST",body:JSON.stringify(e)})},async requestPhoneVerification(e){return n("/auth/phone/send",{method:"POST",body:JSON.stringify(e)})},async confirmPhoneVerification(e){return n("/auth/phone/verify",{method:"POST",body:JSON.stringify(e)})},async setupMFA(e){return n("/auth/mfa/setup",{method:"POST",body:JSON.stringify({method:e})})},async enableMFA(e){return n("/auth/mfa/enable",{method:"POST",body:JSON.stringify({code:e})})},async disableMFA(e){return n("/auth/mfa/disable",{method:"POST",body:JSON.stringify({code:e})})},async verifyMFA(e,t){return n("/auth/mfa/verify",{method:"POST",body:JSON.stringify({mfaToken:e,code:t})})},async regenerateBackupCodes(){return n("/auth/mfa/backup-codes",{method:"POST"})},async refreshToken(e){return n("/auth/refresh",{method:"POST",body:JSON.stringify({refreshToken:e})})},async listSessions(){return n("/auth/sessions")},async revokeSession(e){return n(`/auth/sessions/${e}`,{method:"DELETE"})},async revokeOtherSessions(){return n("/auth/sessions/revoke-others",{method:"POST"})}}}function W(s){return new Promise(n=>setTimeout(n,s))}function K(s){let n=p(s);async function e(t,r,o){let a=o?.retry||{},c=a.maxRetries??0,i=a.initialDelay??1e3,l=a.maxDelay??3e4,u=a.backoffMultiplier??2,y=a.retryOnStatus??[429,500,502,503,504],I=a.retryOnNetworkError??true,S=null,k=i;for(let C=0;C<=c;C++)try{let b={};o?.version!==void 0&&(b.version=o.version),o?.includeLogs&&(b.includeLogs=!0);let T=h(b),E=await n(`/functions/${t}/invoke${T}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers});if(y.includes(E.status)&&C<c){S=new Error(`Function returned status ${E.status}`),await W(k),k=Math.min(k*u,l);continue}return E}catch(b){S=b;let T=b instanceof TypeError||b.message?.includes("network")||b.message?.includes("fetch");if(I&&T&&C<c){await W(k),k=Math.min(k*u,l);continue}throw b}throw S||new Error("Function invocation failed after retries")}return {invoke:e,async invokeByName(t,r,o){let a={};o?.version!==void 0&&(a.version=o.version),o?.includeLogs&&(a.includeLogs=true);let c=h(a);return n(`/functions/name/${encodeURIComponent(t)}/invoke${c}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers})},async batchInvoke(t,r){let a=(await Promise.allSettled(t.map(c=>this.invoke(c.functionId,c.input,r)))).map((c,i)=>c.status==="fulfilled"?{functionId:t[i].functionId,success:true,result:c.value}:{functionId:t[i].functionId,success:false,error:c.reason?.message||"Unknown error"});return {results:a,successCount:a.filter(c=>c.success).length,errorCount:a.filter(c=>!c.success).length}},rpc(t,r){let o=this,a=async(c,i)=>{let l={...r,...i};return (await e(t,{body:c},l)).data};return Object.defineProperty(a,"id",{value:t,writable:false}),a.getInfo=()=>o.get(t),a.getInvocations=c=>o.getInvocations({...c,functionId:t}),a},async list(t){let r={envId:t.envId,enabled:t.enabled,limit:t.limit,offset:t.offset},o=h(r);return n(`/functions/project/${t.projectId}${o}`)},async get(t){return n(`/functions/${t}`)},async getByName(t,r){return n(`/functions/project/${r}/name/${encodeURIComponent(t)}`)},async create(t){return n("/functions",{method:"POST",body:JSON.stringify(t)})},async update(t,r){return n(`/functions/${t}`,{method:"PATCH",body:JSON.stringify(r)})},async delete(t){return n(`/functions/${t}`,{method:"DELETE"})},async enable(t){return this.update(t,{enabled:true})},async disable(t){return this.update(t,{enabled:false})},async deploy(t,r,o){return n(`/functions/${t}/deploy`,{method:"POST",body:JSON.stringify({sourceCode:r,createVersion:o?.createVersion,versionDescription:o?.versionDescription,envVars:o?.envVars,secrets:o?.secrets})})},async getSource(t,r){let o=r!==void 0?`?version=${r}`:"";return n(`/functions/${t}/source${o}`)},async listVersions(t){return (await n(`/functions/${t}/versions`)).versions},async rollback(t,r){return n(`/functions/${t}/rollback`,{method:"POST",body:JSON.stringify({version:r})})},async getEnvVars(t){return (await n(`/functions/${t}/env`)).envVars},async setEnvVars(t,r){return n(`/functions/${t}/env`,{method:"PUT",body:JSON.stringify({envVars:r})})},async deleteEnvVar(t,r){return n(`/functions/${t}/env/${encodeURIComponent(r)}`,{method:"DELETE"})},async bindSecrets(t,r){return n(`/functions/${t}/secrets`,{method:"PUT",body:JSON.stringify({secrets:r})})},async setSchedule(t,r){return n(`/functions/${t}/schedule`,{method:"PUT",body:JSON.stringify(r)})},async removeSchedule(t){return n(`/functions/${t}/schedule`,{method:"DELETE"})},async getInvocations(t){let r={functionId:t.functionId,projectId:t.projectId,status:t.status,since:t.since,until:t.until,limit:t.limit,offset:t.offset},o=h(r);return (await n(`/functions/invocations${o}`)).invocations},async getInvocation(t){return n(`/functions/invocations/${t}`)},async getLogs(t,r){let o={since:r?.since,until:r?.until,level:r?.level,limit:r?.limit},a=h(o);return (await n(`/functions/${t}/logs${a}`)).logs}}}function G(s){let n=p(s),e="default";return {async getUploadUrl(t,r){return n("/storage/upload-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,sizeBytes:r?.sizeBytes,metadata:r?.metadata,isPublic:r?.isPublic,cacheControl:r?.cacheControl,contentDisposition:r?.contentDisposition,upsert:r?.upsert})})},async getDownloadUrl(t,r){return n("/storage/download-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,expiresIn:r?.expiresIn,download:r?.download,transform:r?.transform})})},async createSignedUrl(t,r=3600,o){return (await this.getDownloadUrl(t,{...o,expiresIn:r})).url},async createSignedUrls(t,r=3600,o){return await Promise.all(t.map(async c=>({key:c,url:await this.createSignedUrl(c,r,o)})))},async upload(t,r,o){let a=r instanceof Blob?r:new Blob([r]),c=a.size,i=o?.contentType||(r instanceof File?r.type:void 0)||"application/octet-stream",l=await this.getUploadUrl(t,{...o,contentType:i,sizeBytes:c}),u=await s.fetch(l.url,{method:"PUT",body:a,headers:{"Content-Type":i,...o?.cacheControl&&{"Cache-Control":o.cacheControl},...o?.contentDisposition&&{"Content-Disposition":o.contentDisposition}}});if(!u.ok)throw new Error(`Upload failed: ${u.statusText}`);let y=o?.bucket||e,I=l.url.split("?")[0];return {ok:true,key:t,bucket:y,url:I,publicUrl:o?.isPublic?this.getPublicUrl(t,{bucket:y}):void 0,size:c,contentType:i}},async uploadFromUrl(t,r,o){return n("/storage/upload-from-url",{method:"POST",body:JSON.stringify({key:t,url:r,bucket:o?.bucket||e,contentType:o?.contentType,metadata:o?.metadata,isPublic:o?.isPublic,timeout:o?.timeout})})},async download(t,r){let o=await this.getDownloadUrl(t,r),a=await s.fetch(o.url);if(!a.ok)throw new Error(`Download failed: ${a.statusText}`);return a.blob()},async list(t){let r={bucket:t?.bucket||e,prefix:t?.prefix,delimiter:t?.delimiter,limit:t?.limit,cursor:t?.cursor,includeUrls:t?.includeUrls},o=h(r);return n(`/storage/files${o}`)},async getMetadata(t,r){let o=r?.bucket||e;return n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}/metadata`)},async updateMetadata(t,r,o){let a=o?.bucket||e;return n(`/storage/files/${encodeURIComponent(a)}/${encodeURIComponent(t)}/metadata`,{method:"PATCH",body:JSON.stringify(r)})},async exists(t,r){try{return await this.getMetadata(t,r),!0}catch{return false}},async copy(t,r,o){return n("/storage/files/copy",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async move(t,r,o){return n("/storage/files/move",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async delete(t,r){let o=r?.bucket||e;await n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}`,{method:"DELETE"});},async deleteMany(t,r){return n("/storage/files/delete-batch",{method:"POST",body:JSON.stringify({keys:t,bucket:r?.bucket||e})})},getPublicUrl(t,r){let o=r?.bucket||e;return `${s.baseUrl.replace("/api","")}/storage/${encodeURIComponent(o)}/${encodeURIComponent(t)}`},async createBucket(t,r){return n("/storage/buckets",{method:"POST",body:JSON.stringify({name:t,isPublic:r?.isPublic,allowedMimeTypes:r?.allowedMimeTypes,maxFileSize:r?.maxFileSize,fileSizeLimit:r?.fileSizeLimit})})},async getBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}`)},async updateBucket(t,r){return n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})},async listBuckets(){return (await n("/storage/buckets")).buckets},async deleteBucket(t){await n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"DELETE"});},async emptyBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}/empty`,{method:"POST"})},async createMultipartUpload(t,r){return n("/storage/multipart/create",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,metadata:r?.metadata,partSize:r?.partSize})})},async uploadPart(t,r,o){let a=o instanceof Blob?o:new Blob([o]),{url:c}=await n(`/storage/multipart/${t}/part-url`,{method:"POST",body:JSON.stringify({partNumber:r})}),i=await s.fetch(c,{method:"PUT",body:a});if(!i.ok)throw new Error(`Part upload failed: ${i.statusText}`);let l=i.headers.get("etag")||"";return {partNumber:r,etag:l}},async completeMultipartUpload(t,r){return n(`/storage/multipart/${t}/complete`,{method:"POST",body:JSON.stringify({parts:r})})},async abortMultipartUpload(t){await n(`/storage/multipart/${t}/abort`,{method:"POST"});}}}function _(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.orgId&&t.set("orgId",e.orgId);let r=t.toString();return n(`/projects${r?`?${r}`:""}`)},async get(e){return n(`/projects/${e}`)},async create(e){return n("/projects",{method:"POST",body:JSON.stringify(e)})},async getApiKeys(e){return n(`/projects/${e}/api-keys`)},async createApiKey(e,t){return n(`/projects/${e}/api-keys`,{method:"POST",body:JSON.stringify(t??{})})},async revokeApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/revoke`,{method:"POST"})},async rotateApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/rotate`,{method:"POST"})},async setCustomDomain(e,t,r){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:r})})},async getDomainVerificationInstructions(e,t){return n(`/projects/${e}/environments/${t}/domain-verification`)},async verifyDomainTxt(e,t){return n(`/projects/${e}/environments/${t}/verify-domain`,{method:"POST"})},async verifyDomainCname(e,t){return n(`/projects/${e}/environments/${t}/verify-cname`,{method:"POST"})},async getDomainStatus(e,t){return n(`/projects/${e}/environments/${t}/domain-status`)},async provisionSsl(e,t){return n(`/projects/${e}/environments/${t}/provision-ssl`,{method:"POST"})},async removeCustomDomain(e,t){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:null})})},async listApiKeys(e){return (await n(`/projects/${e}/api-keys`)).keys}}}function H(s){let n=p(s);return {async list(){return n("/orgs")},async create(e){return n("/orgs",{method:"POST",body:JSON.stringify(e)})},async getProfile(e){return (await n(`/orgs/${e}/profile`)).profile||{}},async updateProfile(e,t){return (await n(`/orgs/${e}/profile`,{method:"PATCH",body:JSON.stringify(t)})).profile},async listBillingContacts(e){return (await n(`/orgs/${e}/billing-contacts`)).contacts},async addBillingContact(e,t){return n(`/orgs/${e}/billing-contacts`,{method:"POST",body:JSON.stringify(t)})},async removeBillingContact(e,t){return n(`/orgs/${e}/billing-contacts/${t}`,{method:"DELETE"})},async listMembers(e){return (await n(`/orgs/${e}/members`)).members},async inviteMember(e,t){return n(`/orgs/${e}/members/invite`,{method:"POST",body:JSON.stringify(t)})},async listInvites(e){return (await n(`/orgs/${e}/invites`)).invites},async cancelInvite(e,t){return n(`/orgs/${e}/invites/${t}`,{method:"DELETE"})},async removeMember(e,t){return n(`/orgs/${e}/members/${t}`,{method:"DELETE"})},async updateMemberRole(e,t,r){return n(`/orgs/${e}/members/${t}/role`,{method:"PATCH",body:JSON.stringify({role:r})})},async getMyMembership(e){try{return (await n(`/orgs/${e}/membership`)).membership}catch{return null}}}}function z(s){let n=p(s);return {async preview(e){return n("/schema-engine/preview",{method:"POST",body:JSON.stringify(e)})},async apply(e){return n("/schema-engine/apply",{method:"POST",body:JSON.stringify(e)})},async getMigrations(e,t){let r=t?`/schema-engine/migrations/project/${e}?limit=${t}`:`/schema-engine/migrations/project/${e}`;return n(r)},async saveSchema(e){return n("/schemas/",{method:"POST",body:JSON.stringify(e)})},async getSchemas(e){return n(`/schemas/project/${e}`)}}}function Q(s){let n=p(s);return {async create(e){return n("/functions/secrets",{method:"POST",body:JSON.stringify(e)})},async list(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/functions/secrets/project/${e}${o?`?${o}`:""}`;return n(a)},async reveal(e){return n(`/functions/secrets/${e}/value`)},async update(e,t){return n(`/functions/secrets/${e}`,{method:"PUT",body:JSON.stringify({value:t})})},async delete(e){return n(`/functions/secrets/${e}`,{method:"DELETE"})}}}function X(s){let n=p(s);return {async list(e,t){let r=new URLSearchParams;t&&r.set("env",t);let o=r.toString(),a=`/deployments/project/${e}${o?`?${o}`:""}`;return (await n(a)).deployments},async get(e){let t=await n(`/deployments/${e}`);return {...t.deployment,steps:t.steps}},async getSteps(e){return (await n(`/deployments/${e}/steps`)).steps},async promote(e){let t={projectId:e.projectId,fromEnv:e.sourceEnv,toEnv:e.targetEnv},r=await n("/deployments/promote",{method:"POST",body:JSON.stringify(t)}),o=await n(`/deployments/${r.deploymentId}`);return {deployment:{...o.deployment,steps:o.steps}}},async rollback(e){return n(`/deployments/${e}/rollback`,{method:"POST"})},async listTokens(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/deployments/tokens/project/${encodeURIComponent(e)}${o?`?${o}`:""}`;return (await n(a)).tokens},async createToken(e){return n("/deployments/tokens",{method:"POST",body:JSON.stringify(e)})},async revokeToken(e){return n(`/deployments/tokens/${encodeURIComponent(e)}/revoke`,{method:"POST"})}}}function Z(s){let n=p(s);return {async getStats(e){return n(`/realtime/stats/project/${e}`)},async getConnections(e){return (await n(`/realtime/connections/project/${e}`)).connections},async getSubscriptions(e){return (await n(`/realtime/subscriptions/project/${e}`)).subscriptions},async getEvents(e,t){let r=new URLSearchParams;t&&r.set("limit",String(t));let o=r.toString(),a=`/realtime/events/project/${e}${o?`?${o}`:""}`;return (await n(a)).events},async getStatus(e){return n(`/realtime/status/project/${e}`)},async install(e){return n("/realtime/install",{method:"POST",body:JSON.stringify(e)})},async enableAll(e){return n("/realtime/enable-all",{method:"POST",body:JSON.stringify(e)})}}}function Y(s){let n=p(s);return {async listBuckets(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/buckets/project/${e}${o?`?${o}`:""}`;return (await n(a)).buckets},async getBucket(e){return (await n(`/buckets/${e}`)).bucket},async createBucket(e){return (await n("/buckets",{method:"POST",body:JSON.stringify(e)})).bucket},async updateBucket(e,t){return (await n(`/buckets/${e}`,{method:"PUT",body:JSON.stringify(t)})).bucket},async deleteBucket(e){return n(`/buckets/${e}`,{method:"DELETE"})},async listFiles(e,t){let r=new URLSearchParams;t?.prefix&&r.set("prefix",t.prefix),t?.maxKeys&&r.set("maxKeys",String(t.maxKeys)),t?.continuationToken&&r.set("continuationToken",t.continuationToken);let o=r.toString(),a=`/buckets/${e}/files${o?`?${o}`:""}`;return n(a)},async deleteFile(e,t){return n(`/buckets/${e}/files?key=${encodeURIComponent(t)}`,{method:"DELETE"})},async getSignedUrl(e,t,r){return n(`/buckets/${e}/signed-url`,{method:"POST",body:JSON.stringify({key:t,expiresIn:r})})},async getUploadUrl(e,t,r){return n(`/buckets/${e}/upload-url`,{method:"POST",body:JSON.stringify({key:t,...r})})},async uploadFile(e,t,r,o){let a=o?.prefix?`${o.prefix}${t}`:t,c=o?.contentType??(r instanceof Blob?r.type:"application/octet-stream"),i=new URLSearchParams;return i.set("key",a),c&&i.set("contentType",c),n(`/buckets/${e}/upload?${i.toString()}`,{method:"POST",body:r,headers:{"Content-Type":c||"application/octet-stream"}})}}}function ee(s){let n=p(s);return {async list(e,t){let r={type:t?.type,enabled:t?.enabled},o=h(r);return (await n(`/integrations/subscriptions/project/${e}${o}`)).subscriptions},async get(e){return n(`/integrations/subscriptions/${e}`)},async create(e){return (await n("/integrations/subscriptions",{method:"POST",body:JSON.stringify(e)})).subscription},async update(e,t){return (await n(`/integrations/subscriptions/${e}`,{method:"PATCH",body:JSON.stringify(t)})).subscription},async delete(e){return n(`/integrations/subscriptions/${e}`,{method:"DELETE"})},async enable(e){return this.update(e,{enabled:true})},async disable(e){return this.update(e,{enabled:false})},async test(e){return n(`/integrations/subscriptions/${e}/test`,{method:"POST"})},async publish(e){return n("/integrations/events/publish",{method:"POST",body:JSON.stringify(e)})},async publishBatch(e){return (await n("/integrations/events/publish-batch",{method:"POST",body:JSON.stringify({events:e})})).results},async listEvents(e){let t={envId:e.envId,source:e.source,name:e.name,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/events/project/${e.projectId}${r}`)).events},async getEvent(e){return n(`/integrations/events/${e}`)},async getDeliveries(e){let t={subscriptionId:e.subscriptionId,eventId:e.eventId,status:e.status,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/deliveries${r}`)).deliveries},async getDelivery(e){return n(`/integrations/deliveries/${e}`)},async retryDelivery(e){return n(`/integrations/deliveries/${e}/retry`,{method:"POST"})},async retryAllFailed(e){return n(`/integrations/subscriptions/${e}/retry-failed`,{method:"POST"})},async getDlq(e,t){let r={limit:t?.limit,offset:t?.offset},o=h(r);return (await n(`/integrations/dlq/project/${e}${o}`)).deliveries},async purgeDlq(e,t){return n(`/integrations/dlq/project/${e}/purge`,{method:"POST",body:JSON.stringify({olderThan:t.olderThan})})},async replayDlq(e,t){return n(`/integrations/dlq/project/${e}/replay`,{method:"POST",body:JSON.stringify(t)})},verifySignature(e){let t=e.tolerance??300;try{let r=e.signature.split(","),o=r.find(b=>b.startsWith("t=")),a=r.find(b=>b.startsWith("v1="));if(!o||!a)return !1;let c=parseInt(o.slice(2),10),i=a.slice(3),l=Math.floor(Date.now()/1e3);if(Math.abs(l-c)>t)return !1;let u=`${c}.${e.payload}`,y=new TextEncoder,I=y.encode(e.secret),S=y.encode(u),k=Array.from(I).concat(Array.from(S)).reduce((b,T)=>b+T,0).toString(16);if(i.length!==k.length)return !1;let C=0;for(let b=0;b<i.length;b++)C|=i.charCodeAt(b)^k.charCodeAt(b);return C===0}catch{return false}},generateSecret(){let e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",t="whsec_";for(let r=0;r<32;r++)t+=e.charAt(Math.floor(Math.random()*e.length));return t}}}function te(s){let n=p(s);return {async getSummary(e){return n(`/billing/org/${e}/summary`)},async getEntitlements(e){return n(`/entitlements/org/${e}`)},async checkEntitlement(e,t){return n(`/entitlements/org/${e}/check`,{method:"POST",body:JSON.stringify(t)})},async getPlans(){return (await n("/pricing/plans")).plans},async createCheckout(e){return n("/billing/checkout",{method:"POST",body:JSON.stringify(e)})},async verifyCheckoutSession(e){return n(`/billing/checkout/verify/${e}`)},async openPortal(e){return n(`/billing/org/${e.orgId}/portal`,{method:"POST",body:JSON.stringify({returnUrl:e.returnUrl})})},async getAIUsageSummary(e){return n(`/ai-usage/org/${e}/summary`)},async getAIUsageHistory(e,t=30){return n(`/ai-usage/org/${e}/history?days=${t}`)},async getAIUsageBreakdown(e){return n(`/ai-usage/org/${e}/breakdown`)},async getRecentAIRequests(e,t=50,r=0){return n(`/ai-usage/org/${e}/recent?limit=${t}&offset=${r}`)}}}function ne(s){let n=p(s);return {async getOverview(){return n("/admin/overview")},async listUsers(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/users${r?`?${r}`:""}`)},async getUser(e){return n(`/admin/users/${e}`)},async updateUserStatus(e,t){return n(`/admin/users/${e}/status`,{method:"PATCH",body:JSON.stringify({status:t})})},async updateUserAdmin(e,t){return n(`/admin/users/${e}/admin`,{method:"PATCH",body:JSON.stringify({isAdmin:t})})},async listOrganizations(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.plan&&t.set("plan",e.plan),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/organizations${r?`?${r}`:""}`)},async getOrganization(e){return n(`/admin/organizations/${e}`)},async updateOrganization(e,t){return n(`/admin/organizations/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listProjects(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.orgId&&t.set("orgId",e.orgId),e?.region&&t.set("region",e.region),e?.tenancy&&t.set("tenancy",e.tenancy),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/projects${r?`?${r}`:""}`)},async getProject(e){return n(`/admin/projects/${e}`)},async updateProject(e,t){return n(`/admin/projects/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getProjectResources(e){return n(`/admin/resources/project/${e}`)},async setDedicatedDb(e){return n(`/admin/resources/project/${e.projectId}/db`,{method:"POST",body:JSON.stringify({connectionString:e.connectionString})})},async listIncidents(e="open"){return (await n(`/admin/incidents?status=${e}`)).incidents},async createIncident(e){return n("/admin/incidents",{method:"POST",body:JSON.stringify(e)})},async acknowledgeIncident(e){return n(`/admin/incidents/${e}/ack`,{method:"POST"})},async resolveIncident(e){return n(`/admin/incidents/${e}/resolve`,{method:"POST"})},async listRegions(){return n("/admin/regions")},async updateRegion(e,t){return n(`/admin/regions/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getHealthComponents(){return n("/admin/health/components")},async updateHealthComponent(e,t){return n(`/admin/health/components/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listQueues(){return n("/admin/queues")},async listDlqMessages(e){let t=new URLSearchParams;e?.queue&&t.set("queue",e.queue),e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/dlq${r?`?${r}`:""}`)},async retryDlqMessage(e){return n(`/admin/dlq/${e}/retry`,{method:"POST"})},async archiveDlqMessage(e){return n(`/admin/dlq/${e}`,{method:"DELETE"})},async listFeatureFlags(){return (await n("/flags")).flags},async createFeatureFlag(e,t){return n("/flags",{method:"POST",body:JSON.stringify({key:e,enabled:t})})},async updateFeatureFlag(e,t){return n(`/flags/${e}`,{method:"PUT",body:JSON.stringify({enabled:t})})},async deleteFeatureFlag(e){return n(`/flags/${e}`,{method:"DELETE"})},async listAdmins(){return (await n("/admin/admins")).admins||[]},async addAdmin(e,t,r){return n("/admin/admins",{method:"POST",body:JSON.stringify({userId:e,role:t,notes:r})})},async updateAdmin(e,t){return n(`/admin/admins/${e}`,{method:"PUT",body:JSON.stringify(t)})},async removeAdmin(e){return n(`/admin/admins/${e}`,{method:"DELETE"})},async getSettings(e){let t=e?`?category=${e}`:"";return n(`/admin/settings${t}`)},async updateSetting(e,t){return n(`/admin/settings/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify({value:t})})},async listAIModels(){return n("/admin/ai/models")},async getAIModel(e){return n(`/admin/ai/models/${e}`)},async createAIModel(e){return n("/admin/ai/models",{method:"POST",body:JSON.stringify(e)})},async updateAIModel(e,t){return n(`/admin/ai/models/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteAIModel(e){return n(`/admin/ai/models/${e}`,{method:"DELETE"})},async toggleAIModel(e,t,r){return n(`/admin/ai/models/${e}/toggle`,{method:"POST",body:JSON.stringify({enabled:t,disabledMessage:r})})},async listAISessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/workspace/sessions${r?`?${r}`:""}`)},async getAISession(e){return n(`/admin/ai/workspace/sessions/${e}`)},async deleteAISession(e){return n(`/admin/ai/workspace/sessions/${e}`,{method:"DELETE"})},async listGeneratedBackends(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/backends${r?`?${r}`:""}`)},async getGeneratedBackend(e){return n(`/admin/ai/backends/${e}`)},async deleteGeneratedBackend(e){return n(`/admin/ai/backends/${e}`,{method:"DELETE"})},async listPromptTemplates(e){let t=new URLSearchParams;e?.category&&t.set("category",e.category),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/prompt-templates${r?`?${r}`:""}`)},async createPromptTemplate(e){return n("/admin/ai/prompt-templates",{method:"POST",body:JSON.stringify(e)})},async updatePromptTemplate(e,t){return n(`/admin/ai/prompt-templates/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deletePromptTemplate(e){return n(`/admin/ai/prompt-templates/${e}`,{method:"DELETE"})},async listContextSnapshots(e){let t=new URLSearchParams;e?.projectId&&t.set("projectId",e.projectId),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/context-snapshots${r?`?${r}`:""}`)},async invalidateContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}/invalidate`,{method:"POST"})},async deleteContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}`,{method:"DELETE"})},async getCopilotOverview(){return n("/admin/copilot/overview")},async listCopilotSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/sessions${r?`?${r}`:""}`)},async getCopilotSession(e){return n(`/admin/copilot/sessions/${e}`)},async deleteCopilotSession(e){return n(`/admin/copilot/sessions/${e}`,{method:"DELETE"})},async listCopilotMemories(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.projectId&&t.set("projectId",e.projectId),e?.memoryType&&t.set("memoryType",e.memoryType),e?.importance&&t.set("importance",e.importance),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/memories${r?`?${r}`:""}`)},async getCopilotMemoryStats(){return n("/admin/copilot/memories/stats")},async getCopilotMemory(e){return n(`/admin/copilot/memories/${e}`)},async updateCopilotMemory(e,t){return n(`/admin/copilot/memories/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteCopilotMemory(e){return n(`/admin/copilot/memories/${e}`,{method:"DELETE"})},async cleanupExpiredMemories(){return n("/admin/copilot/memories/cleanup",{method:"POST"})},async exportTrainingData(e){let t=new URLSearchParams;e?.format&&t.set("format",e.format),e?.dataType&&t.set("dataType",e.dataType),e?.minConfidence!==void 0&&t.set("minConfidence",String(e.minConfidence)),e?.limit&&t.set("limit",String(e.limit)),e?.includeExecuted!==void 0&&t.set("includeExecuted",String(e.includeExecuted)),e?.includeSuccessful!==void 0&&t.set("includeSuccessful",String(e.includeSuccessful));let r=t.toString();return n(`/admin/copilot/training-data/export${r?`?${r}`:""}`)},async getTrainingDataStats(){return n("/admin/copilot/training-data/stats")},async listErrors(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.path&&t.set("path",e.path),e?.errorCode&&t.set("errorCode",e.errorCode),e?.status&&t.set("status",e.status),e?.environment&&t.set("environment",e.environment),e?.startDate&&t.set("startDate",e.startDate),e?.endDate&&t.set("endDate",e.endDate),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/errors${r?`?${r}`:""}`)},async getErrorStats(){return n("/admin/errors/stats")},async getError(e){return n(`/admin/errors/${e}`)},async resolveError(e,t){return n(`/admin/errors/${e}/resolve`,{method:"PUT",body:JSON.stringify({notes:t})})},async deleteError(e){return n(`/admin/errors/${e}`,{method:"DELETE"})},async bulkDeleteErrors(e){let t=e?`?olderThanDays=${e}`:"";return n(`/admin/errors${t}`,{method:"DELETE"})},async getAIWorkspaceOverview(){return n("/admin/ai-workspace/overview")},async listAIWorkspaceSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.taskType&&t.set("taskType",e.taskType),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai-workspace/sessions${r?`?${r}`:""}`)},async getAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`)},async deleteAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`,{method:"DELETE"})}}}function re(s){let n=p(s);return {async list(){return (await n("/flags")).flags},async create(e){return n("/flags",{method:"POST",body:JSON.stringify(e)})},async update(e,t){return n(`/flags/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify(t)})},async delete(e){return n(`/flags/${encodeURIComponent(e)}`,{method:"DELETE"})}}}function oe(s){let n=p(s);return {async getOverview(e){return (await n(`/security/overview/${encodeURIComponent(e)}`)).overview},async getAuditLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.offset&&r.set("offset",String(t.offset));let o=r.toString(),a=`/security/audit/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async listEnvVars(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/projects/${encodeURIComponent(e)}/env-vars${o?`?${o}`:""}`;return (await n(a)).envVars},async createEnvVar(e,t){return (await n(`/projects/${encodeURIComponent(e)}/env-vars`,{method:"POST",body:JSON.stringify(t)})).envVar},async updateEnvVar(e,t,r){return (await n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})).envVar},async deleteEnvVar(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"DELETE"})},async getEnvVarValue(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}/value`)}}}function se(s){let n=p(s);return {async generatePlan(e){return n("/ai/plan",{method:"POST",body:JSON.stringify({projectId:e.projectId,prompt:e.prompt,context:e.context,taskType:e.taskType,mode:e.mode})})},async explainPlan(e){return n("/ai/explain",{method:"POST",body:JSON.stringify({plan:e.plan,projectId:e.projectId,taskType:e.taskType,mode:e.mode})})},async getOrgSettings(e){return n(`/ai/settings/org/${encodeURIComponent(e)}`)},async updateOrgSettings(e,t){return n(`/ai/settings/org/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getProjectOverrides(e){return n(`/ai/settings/project/${encodeURIComponent(e)}`)},async updateProjectOverrides(e,t){return n(`/ai/settings/project/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getUsage(e,t){let r=new URLSearchParams;t&&r.set("month",t);let o=r.toString(),a=`/ai/usage/org/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async getBudgetStatus(e){let[t,r]=await Promise.all([this.getOrgSettings(e),this.getUsage(e)]),o=t?.monthlyBudgetCents??1e4,a=r.costCents,c=Math.max(0,o-a),i=o>0?Math.round(a/o*100):0;return {spent:a,budget:o,remaining:c,hardStop:t?.hardStopEnabled??false,percentUsed:i}},async generateFunction(e){return n("/ai/generate-function",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,inputSchema:e.inputSchema,outputSchema:e.outputSchema,language:e.language??"typescript",mode:e.mode})})},async generateEndpoint(e){return n("/ai/generate-endpoint",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,method:e.method??"GET",authRequired:e.authRequired??true,mode:e.mode})})},async exportCode(e){return n("/ai/export-code",{method:"POST",body:JSON.stringify({projectId:e.projectId,targetLanguage:e.targetLanguage,includeSchema:e.includeSchema??true,includeFunctions:e.includeFunctions??true,includeEndpoints:e.includeEndpoints??true})})},async createConversation(e,t){return n("/ai/conversations",{method:"POST",body:JSON.stringify({projectId:e,title:t?.title,context:t?.context})})},async sendMessage(e,t){return n(`/ai/conversations/${encodeURIComponent(e)}/messages`,{method:"POST",body:JSON.stringify({content:t.content,taskType:t.taskType})})},async getConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`)},async listConversations(e){return (await n(`/ai/conversations/project/${encodeURIComponent(e)}`)).conversations},async deleteConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`,{method:"DELETE"})},async getAvailableModels(){return n("/ai/models/available")},async getModel(e){return n(`/ai/models/${encodeURIComponent(e)}`)},async getProjectContext(e){return n(`/ai/context/${encodeURIComponent(e)}`)},async estimateTokens(e,t){return n("/ai/context/estimate",{method:"POST",body:JSON.stringify({prompt:e,projectId:t})})},async analyzeForClarification(e){return n("/ai/clarify",{method:"POST",body:JSON.stringify(e)})},async getSuggestions(e){return n("/ai/suggestions",{method:"POST",body:JSON.stringify(e)})},workspace:{async create(e){return n("/ai/workspace/create",{method:"POST",body:JSON.stringify(e)})},async get(e){return n(`/ai/workspace/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/workspace/list/${encodeURIComponent(e)}`)},async submitPrompt(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/prompt`,{method:"POST",body:JSON.stringify(t),timeout:12e4})},async submitClarification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/clarify`,{method:"POST",body:JSON.stringify({responses:t}),timeout:9e4})},async generate(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/generate`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitModification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/modify`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitFeedback(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/feedback`,{method:"POST",body:JSON.stringify(t)})}},backends:{async get(e){return n(`/ai/backends/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/backends/list/${encodeURIComponent(e)}`)},async delete(e){return n(`/ai/backends/${encodeURIComponent(e)}`,{method:"DELETE"})},async deploy(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy`,{method:"POST",body:JSON.stringify(t)})},async apply(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/apply`,{method:"POST",body:JSON.stringify(t)})},async deployLive(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy-live`,{method:"POST",body:JSON.stringify(t),timeout:3e5})},async getDeployments(e){return n(`/ai/backends/${encodeURIComponent(e)}/deployments`)}},deployments:{async getLimits(e){return n(`/ai/deployments/limits/${encodeURIComponent(e)}`)},async getStatus(e){return n(`/ai/deployments/${encodeURIComponent(e)}/status`)},async getLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.severity&&r.set("severity",t.severity);let o=r.toString();return n(`/ai/deployments/${encodeURIComponent(e)}/logs${o?`?${o}`:""}`)},async terminate(e){return n(`/ai/deployments/${encodeURIComponent(e)}`,{method:"DELETE"})},async redeploy(e){return n(`/ai/deployments/${encodeURIComponent(e)}/redeploy`,{method:"POST",timeout:3e5})}},async getUserOrganizations(){return n("/ai/user/organizations")},async getProjectLimits(e){return n(`/ai/org/${encodeURIComponent(e)}/project-limits`)},async createProjectWithSchema(e){return n("/ai/schema/create-project",{method:"POST",body:JSON.stringify(e)})}}}function ie(s){let n=p(s);return {async load(){return n("/bootstrap")}}}function ae(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.visibility&&t.set("visibility",e.visibility),e?.category&&t.set("category",e.category),e?.orgId&&t.set("orgId",e.orgId);let r=t.toString(),o=`/templates${r?`?${r}`:""}`;return (await n(o)).templates},async get(e){return n(`/templates/${e}`)},async previewInstall(e){return n("/templates/install/preview",{method:"POST",body:JSON.stringify(e)})},async applyInstall(e){return n("/templates/install/apply",{method:"POST",body:JSON.stringify(e)})},async rollback(e){return n(`/templates/install/${e}/rollback`,{method:"POST"})},async createProject(e){return n("/templates/create-project",{method:"POST",body:JSON.stringify(e)})}}}function le(s){let n=p(s);return {async list(e){return (await n(`/oauth/org/${e}`)).connections},async configure(e,t){return n(`/oauth/org/${e}/configure`,{method:"POST",body:JSON.stringify(t)})},async enable(e){return n(`/oauth/connections/${e}/enable`,{method:"POST"})},async disable(e){return n(`/oauth/connections/${e}/disable`,{method:"POST"})},async delete(e){return n(`/oauth/connections/${e}`,{method:"DELETE"})}}}function ce(s){let n=p(s);return {async listPages(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/pages${t}`)).pages},async getPage(e){return (await n(`/docs/pages/${encodeURIComponent(e)}`)).page},async createPage(e){return (await n("/docs/pages",{method:"POST",body:JSON.stringify(e)})).page},async updatePage(e,t){return (await n(`/docs/pages/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).page},async deletePage(e){return n(`/docs/pages/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdks(){return (await n("/docs/sdks")).sdks},async getSdk(e){return (await n(`/docs/sdks/${encodeURIComponent(e)}`)).sdk},async createSdk(e){return (await n("/docs/sdks",{method:"POST",body:JSON.stringify(e)})).sdk},async updateSdk(e,t){return (await n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).sdk},async deleteSdk(e){return n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdkExamples(e,t){let r=t?`?topic=${encodeURIComponent(t)}`:"";return (await n(`/docs/sdks/${encodeURIComponent(e)}/examples${r}`)).examples},async createSdkExample(e){return (await n("/docs/sdk-examples",{method:"POST",body:JSON.stringify(e)})).example},async deleteSdkExample(e){return n(`/docs/sdk-examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listEndpoints(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/api-endpoints${t}`)).endpoints},async getEndpoint(e){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`)).endpoint},async createEndpoint(e){return (await n("/docs/api-endpoints",{method:"POST",body:JSON.stringify(e)})).endpoint},async updateEndpoint(e,t){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).endpoint},async deleteEndpoint(e){return n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"DELETE"})},async listExamples(e){let t=e!==void 0?`?featured=${e}`:"";return (await n(`/docs/examples${t}`)).examples},async getExample(e){return (await n(`/docs/examples/${encodeURIComponent(e)}`)).example},async createExample(e){return (await n("/docs/examples",{method:"POST",body:JSON.stringify(e)})).example},async updateExample(e,t){return (await n(`/docs/examples/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).example},async deleteExample(e){return n(`/docs/examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listChangelog(){return (await n("/docs/changelog")).entries},async getChangelogEntry(e){return (await n(`/docs/changelog/${encodeURIComponent(e)}`)).entry},async createChangelogEntry(e){return (await n("/docs/changelog",{method:"POST",body:JSON.stringify(e)})).entry},async updateChangelogEntry(e,t){return (await n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).entry},async deleteChangelogEntry(e){return n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"DELETE"})},async search(e){return (await n(`/docs/search?q=${encodeURIComponent(e)}`)).results}}}function V(s,n,e,t){let r=[...n],o=0,a=false,c=false,i=async()=>{if(c||a)return;let l=await e(`/mongodb/${t}/cursor/${s}/next`,{method:"POST"});r=l.batch,o=0,a=l.exhausted;};return {id:s,async hasNext(){return c?false:o<r.length?true:a?false:(await i(),r.length>0)},async next(){return c?null:o<r.length?r[o++]:a||(await i(),r.length===0)?null:r[o++]},async toArray(){if(c)return [];let l=[];for(;o<r.length;)l.push(r[o++]);for(;!a;)await i(),l.push(...r),o=r.length;return l},async forEach(l){if(!c){for(;o<r.length;)await l(r[o++]);for(;!a;){await i();for(let u of r)await l(u);o=r.length;}}},map(l){let u=r.slice(o).map(l);return V(s,u,e,t)},async close(){if(!c){c=true;try{await e(`/mongodb/${t}/cursor/${s}/close`,{method:"POST"});}catch{}}},isClosed(){return c}}}function ke(s,n){let e=`/mongodb/${encodeURIComponent(s)}`;return {collectionName:s,async find(t,r){return n(`${e}/find`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findCursor(t,r){let o=await n(`${e}/find/cursor`,{method:"POST",body:JSON.stringify({filter:t,options:r})});return V(o.cursorId,o.batch,n,s)},async findOne(t,r){return n(`${e}/findOne`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findById(t,r){return n(`${e}/findById/${encodeURIComponent(t)}`,{method:"GET",...r&&{body:JSON.stringify({options:r})}})},async countDocuments(t){return (await n(`${e}/count`,{method:"POST",body:JSON.stringify({filter:t})})).count},async estimatedDocumentCount(){return (await n(`${e}/estimatedCount`)).count},async distinct(t,r){return n(`${e}/distinct`,{method:"POST",body:JSON.stringify({field:t,...r})})},async insertOne(t){return n(`${e}/insertOne`,{method:"POST",body:JSON.stringify({document:t})})},async insertMany(t,r){return n(`${e}/insertMany`,{method:"POST",body:JSON.stringify({documents:t,options:r})})},async updateOne(t,r,o){return n(`${e}/updateOne`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async updateMany(t,r,o){return n(`${e}/updateMany`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async replaceOne(t,r,o){return n(`${e}/replaceOne`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async findOneAndUpdate(t,r,o){return n(`${e}/findOneAndUpdate`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async findOneAndReplace(t,r,o){return n(`${e}/findOneAndReplace`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async deleteOne(t){return n(`${e}/deleteOne`,{method:"POST",body:JSON.stringify({filter:t})})},async deleteMany(t){return n(`${e}/deleteMany`,{method:"POST",body:JSON.stringify({filter:t})})},async findOneAndDelete(t,r){return n(`${e}/findOneAndDelete`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async aggregate(t,r){return n(`${e}/aggregate`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})})},async aggregateCursor(t,r){let o=await n(`${e}/aggregate/cursor`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})});return V(o.cursorId,o.batch,n,s)},async createIndex(t,r){return (await n(`${e}/indexes`,{method:"POST",body:JSON.stringify({keys:t,options:r})})).indexName},async dropIndex(t){await n(`${e}/indexes/${encodeURIComponent(t)}`,{method:"DELETE"});},async listIndexes(){return n(`${e}/indexes`)},async bulkWrite(t,r){return n(`${e}/bulkWrite`,{method:"POST",body:JSON.stringify({operations:t,options:r})})}}}function de(s){let n=p(s);return {collection(e){return ke(e,n)},async listCollections(){return n("/mongodb/collections")},async createCollection(e,t){await n("/mongodb/collections",{method:"POST",body:JSON.stringify({name:e,options:t})});},async dropCollection(e){await n(`/mongodb/collections/${encodeURIComponent(e)}`,{method:"DELETE"});},async renameCollection(e,t){await n(`/mongodb/collections/${encodeURIComponent(e)}/rename`,{method:"POST",body:JSON.stringify({newName:t})});},async command(e){return n("/mongodb/command",{method:"POST",body:JSON.stringify(e)})}}}function ge(s){let n=p(s);return {async chat(e){return n("/ai/copilot/chat",{method:"POST",body:JSON.stringify(e),timeout:12e4})},async listSessions(e){return n(`/ai/copilot/sessions/${encodeURIComponent(e)}`)},async getSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`)},async updateSession(e,t){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"DELETE"})},async executePlan(e){return n("/ai/copilot/execute",{method:"POST",body:JSON.stringify(e),timeout:18e4})},async submitFeedback(e){return n("/ai/copilot/feedback",{method:"POST",body:JSON.stringify(e)})},async getClassificationStats(){return n("/ai/copilot/stats")}}}function he(s,n,e,t){let r=n.type||"public",o="unsubscribed",a=new Map,c=[],i={},l=null,u=null,y=new Set,I=new Set,S=new Set,k=d=>{if(d.event){let P=a.get(d.event);P&&P.forEach(A=>A(d.payload));}},C=d=>{i=d.state||{},y.forEach(P=>P(i));},b=d=>{let P=d.key||"",A=d.currentPresences||[],g=d.joinedPresences||[],m=d.leftPresences||[];g.length>0&&(i[P]=A,I.forEach(f=>f(P,A,g))),m.length>0&&(A.length===0?delete i[P]:i[P]=A,S.forEach(f=>f(P,A,m))),y.forEach(f=>f(i));},T=d=>{let P={type:"db_change",projectId:d.projectId||"",schema:d.schema||"",table:d.table||"",operation:d.op,new:d.record,old:d.old_record,timestamp:d.ts||new Date().toISOString(),partial:d.partial};c.forEach(({options:A,handler:g})=>{if(A.table===P.table){let m=A.event||"*";(m==="*"||(Array.isArray(m)?m.includes(P.operation):m===P.operation))&&g(P);}});},v={get name(){return s},get type(){return r},get status(){return o},_handleMessage:d=>{switch(d.type){case "broadcast":k(d);break;case "presence_state":C(d);break;case "presence":b(d);break;case "db_change":T(d);break;case "subscribed":o="subscribed";break;case "error":o="error";break}},onDbChange(d,P){return c.push({options:d,handler:P}),o==="subscribed"&&e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}}),v},on(d,P){return a.has(d)||a.set(d,new Set),a.get(d).add(P),v},off(d,P){return P?a.get(d)?.delete(P):a.delete(d),v},async broadcast(d){if(o!=="subscribed")throw new Error("Channel must be subscribed before broadcasting");e({type:"broadcast",channel:s,event:d.event,payload:d.payload,includeSelf:d.includeSelf});},presence:{async track(d){if(r!=="presence")throw new Error("Presence tracking is only available on presence channels");l=d.key||t()||"anonymous",u=d.state,e({type:"presence_track",channel:s,key:l,state:u});},async update(d){if(!u)throw new Error("Must call track() before update()");u={...u,...d},e({type:"presence_update",channel:s,key:l??void 0,state:u});},async untrack(){l&&(e({type:"presence_untrack",channel:s,key:l}),l=null,u=null);},state(){return {...i}},onSync(d){return y.add(d),v},onJoin(d){return I.add(d),v},onLeave(d){return S.add(d),v}},async subscribe(){return o==="subscribed"||(o="subscribing",e({type:"subscribe",channel:s}),c.forEach(({options:d})=>{e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}});}),n.presenceState&&r==="presence"&&await v.presence.track({state:n.presenceState})),v},async unsubscribe(){o!=="unsubscribed"&&(l&&await v.presence.untrack(),e({type:"unsubscribe",channel:s}),o="unsubscribed",i={},a.clear(),c.length=0);}};return v}function ue(s,n){let{wsUrl:e=s.baseUrl.replace(/^http/,"ws")+"/realtime/ws",autoReconnect:t=true,reconnectDelay:r=1e3,maxReconnectAttempts:o=10}=n??{},a=null,c="disconnected",i=null,l=null,u=0,y=null,I=null,S=new Map,k=new Map,C=new Set,b={connect:new Set,disconnect:new Set,error:new Set,reconnect:new Set},T=g=>{b[g].forEach(m=>m());},E=g=>{let m=`table:${g.table}`;if(g.filter){let R=(Array.isArray(g.filter)?g.filter:[g.filter]).map(w=>`${w.field}${w.operator||"eq"}${w.value}`).join("&");m+=`?${R}`;}return m},v=g=>{a?.readyState===WebSocket.OPEN&&a.send(JSON.stringify(g));},d=g=>{if(g.channel){let m=S.get(g.channel);if(m){m._handleMessage(g);return}}switch(g.type){case "db_change":{let m={type:"db_change",projectId:g.projectId??"",schema:g.schema??"",table:g.table??"",operation:g.op,new:g.record,old:g.old_record,timestamp:g.ts??new Date().toISOString(),partial:g.partial},f=`table:${g.table}`;k.forEach((R,w)=>{(w===f||w.startsWith(f+"?"))&&R.forEach(B=>B(m));});break}case "presence":{let m={type:"presence",event:g.event,key:g.key||g.connectionId||"",connectionId:g.connectionId??"",projectId:g.projectId??"",currentPresences:g.currentPresences||[],leftPresences:g.leftPresences||[],joinedPresences:g.joinedPresences||[]};C.forEach(f=>f(m));break}case "welcome":i=g.connectionId||null;break;case "error":{console.error("[vaif/realtime] Server error:",g.message),T("error");break}}},P=()=>new Promise((g,m)=>{let f=new URLSearchParams;s.apiKey&&f.set(s.apiKeyHeader,s.apiKey),l&&f.set("token",l);let R=f.toString(),w=R?`${e}?${R}`:e;try{a=new WebSocket(w);}catch{m(new x("Failed to create WebSocket connection"));return}let B=()=>{c="connected",u=0,T("connect"),S.forEach(M=>{(M.status==="subscribed"||M.status==="subscribing")&&M.subscribe();}),k.forEach((M,N)=>{v({type:"subscribe",channel:N});}),I=setInterval(()=>{v({type:"ping"});},3e4),g();},pe=M=>{try{let N=JSON.parse(M.data);d(N);}catch{}},me=()=>{if(c="disconnected",i=null,a=null,I&&(clearInterval(I),I=null),T("disconnect"),t&&u<o){c="reconnecting";let M=r*Math.pow(2,u);y=setTimeout(()=>{u++,T("reconnect"),P().catch(()=>{});},Math.min(M,3e4));}},ye=()=>{T("error"),m(new x("WebSocket connection error"));};a.addEventListener("open",B),a.addEventListener("message",pe),a.addEventListener("close",me),a.addEventListener("error",ye);}),A=()=>{y&&(clearTimeout(y),y=null),I&&(clearInterval(I),I=null),u=o;};return {channel(g,m={}){let f=S.get(g);if(f)return f;let R=he(g,m,v,()=>i);return S.set(g,R),R},async removeChannel(g){let m=S.get(g.name);m&&(await m.unsubscribe(),S.delete(g.name));},getChannels(){return Array.from(S.values())},subscribe(g,m){let f=E(g);return k.has(f)||k.set(f,new Set),k.get(f).add(m),a?.readyState===WebSocket.OPEN&&v({type:"subscribe",channel:f}),()=>{let R=k.get(f);R&&(R.delete(m),R.size===0&&(k.delete(f),a?.readyState===WebSocket.OPEN&&v({type:"unsubscribe",channel:f})));}},subscribeToPresence(g){return C.add(g),()=>{C.delete(g);}},async connect(){if(c!=="connected"){if(!s.apiKey)throw new D("API key is required for realtime connections");c="connecting",await P();}},disconnect(){A(),S.forEach(g=>{g.unsubscribe();}),S.clear(),a&&(a.close(),a=null),c="disconnected",i=null;},get isConnected(){return c==="connected"},get connectionState(){return c},get connectionId(){return i},on(g,m){b[g].add(m);},off(g,m){b[g].delete(m);},setAuth(g){l=g;}}}var j={apiKeyHeader:"x-vaif-key",timeout:3e4,retry:{maxRetries:3,retryDelay:1e3,retryOn:[429,500,502,503,504]}};function Se(s){return {baseUrl:s.baseUrl.replace(/\/$/,""),apiKey:s.apiKey,apiKeyHeader:s.apiKeyHeader??j.apiKeyHeader,accessToken:s.accessToken,fetch:s.fetch??globalThis.fetch.bind(globalThis),timeout:s.timeout??j.timeout,retry:{maxRetries:s.retry?.maxRetries??j.retry.maxRetries,retryDelay:s.retry?.retryDelay??j.retry.retryDelay,retryOn:s.retry?.retryOn??[...j.retry.retryOn]}}}function ve(s){let n=Se(s),e=q(n),t=J(n),r=K(n),o=G(n),a=_(n),c=H(n),i=z(n),l=Q(n),u=X(n),y=Z(n),I=Y(n),S=ee(n),k=te(n),C=ne(n),b=re(n),T=oe(n),E=se(n),v=ie(n),d=ae(n),P=le(n),A=ce(n),g=de(n),m=ge(n);return {from:e.from,auth:t,functions:r,storage:o,projects:a,orgs:c,schema:i,secrets:l,deployments:u,realtimeMonitoring:y,storageDashboard:I,integrations:S,billing:k,admin:C,flags:b,security:T,ai:E,bootstrap:v,templates:d,oauth:P,docs:A,mongodb:g,copilot:m,realtime:f=>ue(n,f)}}export{D as VaifAuthError,O as VaifError,x as VaifNetworkError,F as VaifNotFoundError,$ as VaifRateLimitError,U as VaifValidationError,ve as createVaifClient,be as isVaifError};
1
+ export{AuthError,InvalidCredentialsError,SessionExpiredError,SessionStorage,VaifAuthClient,localStorage as authLocalStorage,sessionStorage as authSessionStorage,cookieStorage,createAuthClient,getDefaultStorage,isBrowser,isMFAChallenge,memoryStorage}from'@vaiftech/auth';var O=class s extends Error{constructor(n,e){super(n),this.name="VaifError",this.code=e.code,this.statusCode=e.statusCode,this.requestId=e.requestId,this.details=e.details;let t=Error;t.captureStackTrace&&t.captureStackTrace(this,s);}toJSON(){return {name:this.name,message:this.message,code:this.code,statusCode:this.statusCode,requestId:this.requestId,details:this.details}}},D=class extends O{constructor(n,e){super(n,{code:e?.code??"AUTH_ERROR",statusCode:e?.statusCode??401,requestId:e?.requestId}),this.name="VaifAuthError";}},U=class extends O{constructor(n,e){super(n,{code:"VALIDATION_ERROR",statusCode:400,requestId:e?.requestId,details:e?.details??e?.fieldErrors}),this.name="VaifValidationError",this.fieldErrors=e?.fieldErrors;}},x=class extends O{constructor(n,e){super(n,{code:"NETWORK_ERROR"}),this.name="VaifNetworkError",this.cause=e;}},$=class extends O{constructor(n,e){super(n,{code:"RATE_LIMITED",statusCode:429}),this.name="VaifRateLimitError",this.retryAfter=e;}},F=class extends O{constructor(n,e){super(n,{code:"NOT_FOUND",statusCode:404,requestId:e}),this.name="VaifNotFoundError";}};function be(s){return s instanceof O}async function fe(s){let n;try{n=await s.json();}catch{}let e=n?.message??n?.error??s.statusText??"Request failed",t=n?.requestId;switch(s.status){case 400:return new U(e,{details:n?.details,requestId:t});case 401:return new D(e,{code:"UNAUTHORIZED",statusCode:401,requestId:t});case 403:return new D(e,{code:"FORBIDDEN",statusCode:403,requestId:t});case 404:return new F(e,t);case 429:{let r=s.headers.get("Retry-After"),o=r?parseInt(r,10):void 0;return new $(e,o)}default:return new O(e,{code:n?.error??"HTTP_ERROR",statusCode:s.status,requestId:t,details:n?.details})}}async function Pe(s,n){let{timeout:e=3e4,fetchFn:t,...r}=n,o=new AbortController,a=setTimeout(()=>o.abort(),e);try{let c=await t(s,{...r,signal:o.signal});if(clearTimeout(a),!c.ok)throw await fe(c);if(c.status===204)return;let i=await c.text();return i?JSON.parse(i):void 0}catch(c){throw clearTimeout(a),c instanceof O?c:c instanceof Error&&c.name==="AbortError"?new x("Request timed out"):c instanceof Error?new x(c.message,c):new x("Network request failed")}}function p(s){let{baseUrl:n,apiKey:e,apiKeyHeader:t,accessToken:r,fetch:o,timeout:a}=s;return async function(i,l={}){let u=`${n}${i}`,y={"Content-Type":"application/json",...l.headers??{}};if(e&&(y[t]=e),r){let I=typeof r=="function"?await r():r;y.Authorization=`Bearer ${I}`;}return Pe(u,{...l,headers:y,timeout:l.timeout??a,fetchFn:o})}}function h(s){let n=new URLSearchParams;for(let[t,r]of Object.entries(s))r!==void 0&&n.set(t,String(r));let e=n.toString();return e?`?${e}`:""}function Ie(s){return JSON.stringify(s)}function L(s,n,e={}){let t={...e},r=()=>{let i={};if(t.limit!==void 0&&(i.limit=t.limit),t.offset!==void 0&&(i.offset=t.offset),t.where&&(i.where=Ie(t.where)),t.orderBy){let l=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];i.orderBy=JSON.stringify(l);}return t.select&&t.select.length>0&&(i.select=t.select.join(",")),t.include&&t.include.length>0&&(i.include=JSON.stringify(t.include)),t.distinct&&t.distinct.length>0&&(i.distinct=t.distinct.join(",")),i},o=()=>h(r()),a=i=>L(s,n,{...t,...i}),c={async list(i){i&&(t={...t,...i});let l=o();return n(`/generated/${s}${l}`)},async get(i){let l={};t.select&&t.select.length>0&&(l.select=t.select.join(",")),t.include&&t.include.length>0&&(l.include=JSON.stringify(t.include));let u=h(l);return n(`/generated/${s}/${encodeURIComponent(i)}${u}`)},async first(){let i=await c.limit(1).list();return i.data.length>0?i.data[0]:null},async firstOrFail(){let i=await c.first();if(!i)throw new Error(`No record found in table '${s}' matching the query`);return i},async create(i){return n(`/generated/${s}`,{method:"POST",body:JSON.stringify(i)})},async update(i,l){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"PATCH",body:JSON.stringify(l)})},async delete(i){return n(`/generated/${s}/${encodeURIComponent(i)}`,{method:"DELETE"})},async createMany(i,l){return n(`/generated/${s}/batch`,{method:"POST",body:JSON.stringify({records:i,skipOnConflict:l?.skipOnConflict,returnRecords:l?.returnRecords})})},async updateMany(i,l){return n(`/generated/${s}/batch`,{method:"PATCH",body:JSON.stringify({data:i,where:t.where,returnRecords:l?.returnRecords})})},async deleteMany(){return n(`/generated/${s}/batch`,{method:"DELETE",body:JSON.stringify({where:t.where})})},async upsert(i,l){return n(`/generated/${s}/upsert`,{method:"POST",body:JSON.stringify({data:i,conflictFields:l.conflictFields,updateFields:l.updateFields})})},async count(){let i=r(),l=h(i);return (await n(`/generated/${s}/count${l}`)).count},async sum(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/sum${u}`)).sum},async avg(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/avg${u}`)).avg},async min(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/min${u}`)).min},async max(i){let l=r(),u=h({...l,field:i});return (await n(`/generated/${s}/max${u}`)).max},async aggregate(i,l){return n(`/generated/${s}/aggregate`,{method:"POST",body:JSON.stringify({aggregates:i,where:l?.where||t.where,groupBy:l?.groupBy,having:l?.having})})},async paginate(i){let l=i.page||1,u=i.pageSize||20,y=(l-1)*u,I=r();I.limit=u,I.offset=y,I.includeCount=true;let S=h(I),k=await n(`/generated/${s}${S}`),C=k.total||k.data.length,b=Math.ceil(C/u);return {data:k.data,pageInfo:{total:C,page:l,pageSize:u,pageCount:b,hasNextPage:l<b,hasPrevPage:l>1}}},async cursorPaginate(i){let l=r();l.limit=i.limit||20,i.cursor&&(l.cursor=i.cursor);let u=h(l),y=await n(`/generated/${s}/cursor${u}`);return {data:y.data,nextCursor:y.nextCursor,prevCursor:y.prevCursor,hasMore:y.hasMore}},where(i){if(t.where){let l=t.where;return a({where:{AND:[...Array.isArray(l)?l:[l],i]}})}return a({where:i})},orderBy(i,l="asc"){let u={field:i,direction:l};if(t.orderBy){let y=Array.isArray(t.orderBy)?t.orderBy:[t.orderBy];return a({orderBy:[...y,u]})}return a({orderBy:u})},select(...i){return a({select:i})},limit(i){return a({limit:i})},offset(i){return a({offset:i})},include(i){let l=t.include||[];return a({include:[...l,i]})},distinct(...i){return a({distinct:i})}};return c}function q(s){let n=p(s);return {from(e){return L(e,n)},async raw(e,t){return n("/generated/raw",{method:"POST",body:JSON.stringify({query:e,params:t})})},async transaction(e,t){return n("/generated/transaction",{method:"POST",body:JSON.stringify({operations:e,isolationLevel:t?.isolationLevel,timeout:t?.timeout})})},async withTransaction(e,t){let o=(await n("/generated/transaction/start",{method:"POST",body:JSON.stringify({isolationLevel:t?.isolationLevel,timeout:t?.timeout})})).transactionId,a=(i,l)=>{let u=new Headers(l?.headers);return u.set("X-Transaction-Id",o),n(i,{...l,headers:u})},c={from(i){return L(i,a)},async raw(i,l){return a("/generated/raw",{method:"POST",body:JSON.stringify({query:i,params:l})})},async transaction(){throw new Error("Nested transactions are not supported")},async withTransaction(){throw new Error("Nested transactions are not supported")}};try{let i=await e(c);return await n("/generated/transaction/commit",{method:"POST",body:JSON.stringify({transactionId:o})}),i}catch(i){throw await n("/generated/transaction/rollback",{method:"POST",body:JSON.stringify({transactionId:o})}).catch(()=>{}),i}}}}function J(s){let n=p(s);return {async signUp(e,t,r){return n("/auth/signup",{method:"POST",body:JSON.stringify({email:e,password:t,name:r?.name,phone:r?.phone,metadata:r?.metadata,redirectUrl:r?.redirectUrl})})},async login(e,t,r){return n("/auth/login",{method:"POST",body:JSON.stringify({email:e,password:t,mfaCode:r?.mfaCode,rememberMe:r?.rememberMe})})},async logout(){await n("/auth/logout",{method:"POST"});},async logoutAll(){await n("/auth/logout-all",{method:"POST"});},async getUser(){return (await n("/auth/me")).user},async updateProfile(e){return (await n("/users/me",{method:"PATCH",body:JSON.stringify(e)})).user},async changePassword(e){return n("/users/me/change-password",{method:"POST",body:JSON.stringify(e)})},async requestPasswordReset(e){return n("/auth/forgot-password",{method:"POST",body:JSON.stringify(e)})},async confirmPasswordReset(e){return n("/auth/reset-password",{method:"POST",body:JSON.stringify(e)})},async requestEmailVerification(e){return n("/auth/verify-email/send",{method:"POST",body:JSON.stringify(e||{})})},async confirmEmailVerification(e){return n("/auth/verify-email/confirm",{method:"POST",body:JSON.stringify(e)})},async getOAuthSignInUrl(e){return n("/auth/oauth/authorize",{method:"POST",body:JSON.stringify(e)})},async handleOAuthCallback(e){return n("/auth/oauth/callback",{method:"POST",body:JSON.stringify(e)})},async linkOAuthProvider(e){return n("/auth/oauth/link",{method:"POST",body:JSON.stringify(e)})},async unlinkOAuthProvider(e){return n(`/auth/oauth/unlink/${e}`,{method:"POST"})},async listLinkedProviders(){return n("/auth/oauth/providers")},async requestMagicLink(e){return n("/auth/magic-link/send",{method:"POST",body:JSON.stringify(e)})},async verifyMagicLink(e){return n("/auth/magic-link/verify",{method:"POST",body:JSON.stringify(e)})},async requestPhoneVerification(e){return n("/auth/phone/send",{method:"POST",body:JSON.stringify(e)})},async confirmPhoneVerification(e){return n("/auth/phone/verify",{method:"POST",body:JSON.stringify(e)})},async setupMFA(e){return n("/auth/mfa/setup",{method:"POST",body:JSON.stringify({method:e})})},async enableMFA(e){return n("/auth/mfa/enable",{method:"POST",body:JSON.stringify({code:e})})},async disableMFA(e){return n("/auth/mfa/disable",{method:"POST",body:JSON.stringify({code:e})})},async verifyMFA(e,t){return n("/auth/mfa/verify",{method:"POST",body:JSON.stringify({mfaToken:e,code:t})})},async regenerateBackupCodes(){return n("/auth/mfa/backup-codes",{method:"POST"})},async refreshToken(e){return n("/auth/refresh",{method:"POST",body:JSON.stringify({refreshToken:e})})},async listSessions(){return n("/auth/sessions")},async revokeSession(e){return n(`/auth/sessions/${e}`,{method:"DELETE"})},async revokeOtherSessions(){return n("/auth/sessions/revoke-others",{method:"POST"})}}}function W(s){return new Promise(n=>setTimeout(n,s))}function K(s){let n=p(s);async function e(t,r,o){let a=o?.retry||{},c=a.maxRetries??0,i=a.initialDelay??1e3,l=a.maxDelay??3e4,u=a.backoffMultiplier??2,y=a.retryOnStatus??[429,500,502,503,504],I=a.retryOnNetworkError??true,S=null,k=i;for(let C=0;C<=c;C++)try{let b={};o?.version!==void 0&&(b.version=o.version),o?.includeLogs&&(b.includeLogs=!0);let T=h(b),E=await n(`/functions/${t}/invoke${T}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers});if(y.includes(E.status)&&C<c){S=new Error(`Function returned status ${E.status}`),await W(k),k=Math.min(k*u,l);continue}return E}catch(b){S=b;let T=b instanceof TypeError||b.message?.includes("network")||b.message?.includes("fetch");if(I&&T&&C<c){await W(k),k=Math.min(k*u,l);continue}throw b}throw S||new Error("Function invocation failed after retries")}return {invoke:e,async invokeByName(t,r,o){let a={};o?.version!==void 0&&(a.version=o.version),o?.includeLogs&&(a.includeLogs=true);let c=h(a);return n(`/functions/name/${encodeURIComponent(t)}/invoke${c}`,{method:"POST",body:JSON.stringify(r??{}),headers:o?.headers})},async batchInvoke(t,r){let a=(await Promise.allSettled(t.map(c=>this.invoke(c.functionId,c.input,r)))).map((c,i)=>c.status==="fulfilled"?{functionId:t[i].functionId,success:true,result:c.value}:{functionId:t[i].functionId,success:false,error:c.reason?.message||"Unknown error"});return {results:a,successCount:a.filter(c=>c.success).length,errorCount:a.filter(c=>!c.success).length}},rpc(t,r){let o=this,a=async(c,i)=>{let l={...r,...i};return (await e(t,{body:c},l)).data};return Object.defineProperty(a,"id",{value:t,writable:false}),a.getInfo=()=>o.get(t),a.getInvocations=c=>o.getInvocations({...c,functionId:t}),a},async list(t){let r={envId:t.envId,enabled:t.enabled,limit:t.limit,offset:t.offset},o=h(r);return n(`/functions/project/${t.projectId}${o}`)},async get(t){return n(`/functions/${t}`)},async getByName(t,r){return n(`/functions/project/${r}/name/${encodeURIComponent(t)}`)},async create(t){return n("/functions",{method:"POST",body:JSON.stringify(t)})},async update(t,r){return n(`/functions/${t}`,{method:"PATCH",body:JSON.stringify(r)})},async delete(t){return n(`/functions/${t}`,{method:"DELETE"})},async enable(t){return this.update(t,{enabled:true})},async disable(t){return this.update(t,{enabled:false})},async deploy(t,r,o){return n(`/functions/${t}/deploy`,{method:"POST",body:JSON.stringify({sourceCode:r,createVersion:o?.createVersion,versionDescription:o?.versionDescription,envVars:o?.envVars,secrets:o?.secrets})})},async getSource(t,r){let o=r!==void 0?`?version=${r}`:"";return n(`/functions/${t}/source${o}`)},async listVersions(t){return (await n(`/functions/${t}/versions`)).versions},async rollback(t,r){return n(`/functions/${t}/rollback`,{method:"POST",body:JSON.stringify({version:r})})},async getEnvVars(t){return (await n(`/functions/${t}/env`)).envVars},async setEnvVars(t,r){return n(`/functions/${t}/env`,{method:"PUT",body:JSON.stringify({envVars:r})})},async deleteEnvVar(t,r){return n(`/functions/${t}/env/${encodeURIComponent(r)}`,{method:"DELETE"})},async bindSecrets(t,r){return n(`/functions/${t}/secrets`,{method:"PUT",body:JSON.stringify({secrets:r})})},async setSchedule(t,r){return n(`/functions/${t}/schedule`,{method:"PUT",body:JSON.stringify(r)})},async removeSchedule(t){return n(`/functions/${t}/schedule`,{method:"DELETE"})},async getInvocations(t){let r={functionId:t.functionId,projectId:t.projectId,status:t.status,since:t.since,until:t.until,limit:t.limit,offset:t.offset},o=h(r);return (await n(`/functions/invocations${o}`)).invocations},async getInvocation(t){return n(`/functions/invocations/${t}`)},async getLogs(t,r){let o={since:r?.since,until:r?.until,level:r?.level,limit:r?.limit},a=h(o);return (await n(`/functions/${t}/logs${a}`)).logs}}}function G(s){let n=p(s),e="default";return {async getUploadUrl(t,r){return n("/storage/upload-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,sizeBytes:r?.sizeBytes,metadata:r?.metadata,isPublic:r?.isPublic,cacheControl:r?.cacheControl,contentDisposition:r?.contentDisposition,upsert:r?.upsert})})},async getDownloadUrl(t,r){return n("/storage/download-url",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,expiresIn:r?.expiresIn,download:r?.download,transform:r?.transform})})},async createSignedUrl(t,r=3600,o){return (await this.getDownloadUrl(t,{...o,expiresIn:r})).url},async createSignedUrls(t,r=3600,o){return await Promise.all(t.map(async c=>({key:c,url:await this.createSignedUrl(c,r,o)})))},async upload(t,r,o){let a=r instanceof Blob?r:new Blob([r]),c=a.size,i=o?.contentType||(r instanceof File?r.type:void 0)||"application/octet-stream",l=await this.getUploadUrl(t,{...o,contentType:i,sizeBytes:c}),u=await s.fetch(l.url,{method:"PUT",body:a,headers:{"Content-Type":i,...o?.cacheControl&&{"Cache-Control":o.cacheControl},...o?.contentDisposition&&{"Content-Disposition":o.contentDisposition}}});if(!u.ok)throw new Error(`Upload failed: ${u.statusText}`);let y=o?.bucket||e,I=l.url.split("?")[0];return {ok:true,key:t,bucket:y,url:I,publicUrl:o?.isPublic?this.getPublicUrl(t,{bucket:y}):void 0,size:c,contentType:i}},async uploadFromUrl(t,r,o){return n("/storage/upload-from-url",{method:"POST",body:JSON.stringify({key:t,url:r,bucket:o?.bucket||e,contentType:o?.contentType,metadata:o?.metadata,isPublic:o?.isPublic,timeout:o?.timeout})})},async download(t,r){let o=await this.getDownloadUrl(t,r),a=await s.fetch(o.url);if(!a.ok)throw new Error(`Download failed: ${a.statusText}`);return a.blob()},async list(t){let r={bucket:t?.bucket||e,prefix:t?.prefix,delimiter:t?.delimiter,limit:t?.limit,cursor:t?.cursor,includeUrls:t?.includeUrls},o=h(r);return n(`/storage/files${o}`)},async getMetadata(t,r){let o=r?.bucket||e;return n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}/metadata`)},async updateMetadata(t,r,o){let a=o?.bucket||e;return n(`/storage/files/${encodeURIComponent(a)}/${encodeURIComponent(t)}/metadata`,{method:"PATCH",body:JSON.stringify(r)})},async exists(t,r){try{return await this.getMetadata(t,r),!0}catch{return false}},async copy(t,r,o){return n("/storage/files/copy",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async move(t,r,o){return n("/storage/files/move",{method:"POST",body:JSON.stringify({sourceKey:t,sourceBucket:o?.sourceBucket||e,destinationKey:r,destinationBucket:o?.destinationBucket||o?.sourceBucket||e,metadata:o?.metadata})})},async delete(t,r){let o=r?.bucket||e;await n(`/storage/files/${encodeURIComponent(o)}/${encodeURIComponent(t)}`,{method:"DELETE"});},async deleteMany(t,r){return n("/storage/files/delete-batch",{method:"POST",body:JSON.stringify({keys:t,bucket:r?.bucket||e})})},getPublicUrl(t,r){let o=r?.bucket||e;return `${s.baseUrl.replace("/api","")}/storage/${encodeURIComponent(o)}/${encodeURIComponent(t)}`},async createBucket(t,r){return n("/storage/buckets",{method:"POST",body:JSON.stringify({name:t,isPublic:r?.isPublic,allowedMimeTypes:r?.allowedMimeTypes,maxFileSize:r?.maxFileSize,fileSizeLimit:r?.fileSizeLimit})})},async getBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}`)},async updateBucket(t,r){return n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})},async listBuckets(){return (await n("/storage/buckets")).buckets},async deleteBucket(t){await n(`/storage/buckets/${encodeURIComponent(t)}`,{method:"DELETE"});},async emptyBucket(t){return n(`/storage/buckets/${encodeURIComponent(t)}/empty`,{method:"POST"})},async createMultipartUpload(t,r){return n("/storage/multipart/create",{method:"POST",body:JSON.stringify({key:t,bucket:r?.bucket||e,contentType:r?.contentType,metadata:r?.metadata,partSize:r?.partSize})})},async uploadPart(t,r,o){let a=o instanceof Blob?o:new Blob([o]),{url:c}=await n(`/storage/multipart/${t}/part-url`,{method:"POST",body:JSON.stringify({partNumber:r})}),i=await s.fetch(c,{method:"PUT",body:a});if(!i.ok)throw new Error(`Part upload failed: ${i.statusText}`);let l=i.headers.get("etag")||"";return {partNumber:r,etag:l}},async completeMultipartUpload(t,r){return n(`/storage/multipart/${t}/complete`,{method:"POST",body:JSON.stringify({parts:r})})},async abortMultipartUpload(t){await n(`/storage/multipart/${t}/abort`,{method:"POST"});}}}function _(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.orgId&&t.set("orgId",e.orgId);let r=t.toString();return n(`/projects${r?`?${r}`:""}`)},async get(e){return n(`/projects/${e}`)},async create(e){return n("/projects",{method:"POST",body:JSON.stringify(e)})},async getApiKeys(e){return n(`/projects/${e}/api-keys`)},async createApiKey(e,t){return n(`/projects/${e}/api-keys`,{method:"POST",body:JSON.stringify(t??{})})},async revokeApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/revoke`,{method:"POST"})},async rotateApiKey(e,t){return n(`/projects/${e}/api-keys/${t}/rotate`,{method:"POST"})},async setCustomDomain(e,t,r){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:r})})},async getDomainVerificationInstructions(e,t){return n(`/projects/${e}/environments/${t}/domain-verification`)},async verifyDomainTxt(e,t){return n(`/projects/${e}/environments/${t}/verify-domain`,{method:"POST"})},async verifyDomainCname(e,t){return n(`/projects/${e}/environments/${t}/verify-cname`,{method:"POST"})},async getDomainStatus(e,t){return n(`/projects/${e}/environments/${t}/domain-status`)},async provisionSsl(e,t){return n(`/projects/${e}/environments/${t}/provision-ssl`,{method:"POST"})},async removeCustomDomain(e,t){return n(`/projects/${e}/environments/${t}`,{method:"PATCH",body:JSON.stringify({customDomain:null})})},async listApiKeys(e){return (await n(`/projects/${e}/api-keys`)).keys}}}function H(s){let n=p(s);return {async list(){return n("/orgs")},async create(e){return n("/orgs",{method:"POST",body:JSON.stringify(e)})},async getProfile(e){return (await n(`/orgs/${e}/profile`)).profile||{}},async updateProfile(e,t){return (await n(`/orgs/${e}/profile`,{method:"PATCH",body:JSON.stringify(t)})).profile},async listBillingContacts(e){return (await n(`/orgs/${e}/billing-contacts`)).contacts},async addBillingContact(e,t){return n(`/orgs/${e}/billing-contacts`,{method:"POST",body:JSON.stringify(t)})},async removeBillingContact(e,t){return n(`/orgs/${e}/billing-contacts/${t}`,{method:"DELETE"})},async listMembers(e){return (await n(`/orgs/${e}/members`)).members},async inviteMember(e,t){return n(`/orgs/${e}/members/invite`,{method:"POST",body:JSON.stringify(t)})},async listInvites(e){return (await n(`/orgs/${e}/invites`)).invites},async cancelInvite(e,t){return n(`/orgs/${e}/invites/${t}`,{method:"DELETE"})},async removeMember(e,t){return n(`/orgs/${e}/members/${t}`,{method:"DELETE"})},async updateMemberRole(e,t,r){return n(`/orgs/${e}/members/${t}/role`,{method:"PATCH",body:JSON.stringify({role:r})})},async getMyMembership(e){try{return (await n(`/orgs/${e}/membership`)).membership}catch{return null}}}}function z(s){let n=p(s);return {async preview(e){return n("/schema-engine/preview",{method:"POST",body:JSON.stringify(e)})},async apply(e){return n("/schema-engine/apply",{method:"POST",body:JSON.stringify(e)})},async getMigrations(e,t){let r=t?`/schema-engine/migrations/project/${e}?limit=${t}`:`/schema-engine/migrations/project/${e}`;return n(r)},async saveSchema(e){return n("/schemas/",{method:"POST",body:JSON.stringify(e)})},async getSchemas(e){return n(`/schemas/project/${e}`)}}}function Q(s){let n=p(s);return {async create(e){return n("/functions/secrets",{method:"POST",body:JSON.stringify(e)})},async list(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/functions/secrets/project/${e}${o?`?${o}`:""}`;return n(a)},async reveal(e){return n(`/functions/secrets/${e}/value`)},async update(e,t){return n(`/functions/secrets/${e}`,{method:"PUT",body:JSON.stringify({value:t})})},async delete(e){return n(`/functions/secrets/${e}`,{method:"DELETE"})}}}function X(s){let n=p(s);return {async list(e,t){let r=new URLSearchParams;t&&r.set("env",t);let o=r.toString(),a=`/deployments/project/${e}${o?`?${o}`:""}`;return (await n(a)).deployments},async get(e){let t=await n(`/deployments/${e}`);return {...t.deployment,steps:t.steps}},async getSteps(e){return (await n(`/deployments/${e}/steps`)).steps},async promote(e){let t={projectId:e.projectId,fromEnv:e.sourceEnv,toEnv:e.targetEnv},r=await n("/deployments/promote",{method:"POST",body:JSON.stringify(t)}),o=await n(`/deployments/${r.deploymentId}`);return {deployment:{...o.deployment,steps:o.steps}}},async rollback(e){return n(`/deployments/${e}/rollback`,{method:"POST"})},async listTokens(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/deployments/tokens/project/${encodeURIComponent(e)}${o?`?${o}`:""}`;return (await n(a)).tokens},async createToken(e){return n("/deployments/tokens",{method:"POST",body:JSON.stringify(e)})},async revokeToken(e){return n(`/deployments/tokens/${encodeURIComponent(e)}/revoke`,{method:"POST"})}}}function Z(s){let n=p(s);return {async getStats(e){return n(`/realtime/stats/project/${e}`)},async getConnections(e){return (await n(`/realtime/connections/project/${e}`)).connections},async getSubscriptions(e){return (await n(`/realtime/subscriptions/project/${e}`)).subscriptions},async getEvents(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.source&&t.source!=="all"&&r.set("source",t.source),t?.level&&t.level!=="all"&&r.set("level",t.level);let o=r.toString(),a=`/realtime/events/project/${e}${o?`?${o}`:""}`;return (await n(a)).events},async getStatus(e){return n(`/realtime/status/project/${e}`)},async install(e){return n("/realtime/install",{method:"POST",body:JSON.stringify(e)})},async enableAll(e){return n("/realtime/enable-all",{method:"POST",body:JSON.stringify(e)})}}}function Y(s){let n=p(s);return {async listBuckets(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/buckets/project/${e}${o?`?${o}`:""}`;return (await n(a)).buckets},async getBucket(e){return (await n(`/buckets/${e}`)).bucket},async createBucket(e){return (await n("/buckets",{method:"POST",body:JSON.stringify(e)})).bucket},async updateBucket(e,t){return (await n(`/buckets/${e}`,{method:"PUT",body:JSON.stringify(t)})).bucket},async deleteBucket(e){return n(`/buckets/${e}`,{method:"DELETE"})},async listFiles(e,t){let r=new URLSearchParams;t?.prefix&&r.set("prefix",t.prefix),t?.maxKeys&&r.set("maxKeys",String(t.maxKeys)),t?.continuationToken&&r.set("continuationToken",t.continuationToken);let o=r.toString(),a=`/buckets/${e}/files${o?`?${o}`:""}`;return n(a)},async deleteFile(e,t){return n(`/buckets/${e}/files?key=${encodeURIComponent(t)}`,{method:"DELETE"})},async getSignedUrl(e,t,r){return n(`/buckets/${e}/signed-url`,{method:"POST",body:JSON.stringify({key:t,expiresIn:r})})},async getUploadUrl(e,t,r){return n(`/buckets/${e}/upload-url`,{method:"POST",body:JSON.stringify({key:t,...r})})},async uploadFile(e,t,r,o){let a=o?.prefix?`${o.prefix}${t}`:t,c=o?.contentType??(r instanceof Blob?r.type:"application/octet-stream"),i=new URLSearchParams;return i.set("key",a),c&&i.set("contentType",c),n(`/buckets/${e}/upload?${i.toString()}`,{method:"POST",body:r,headers:{"Content-Type":c||"application/octet-stream"}})}}}function ee(s){let n=p(s);return {async list(e,t){let r={type:t?.type,enabled:t?.enabled},o=h(r);return (await n(`/integrations/subscriptions/project/${e}${o}`)).subscriptions},async get(e){return n(`/integrations/subscriptions/${e}`)},async create(e){return (await n("/integrations/subscriptions",{method:"POST",body:JSON.stringify(e)})).subscription},async update(e,t){return (await n(`/integrations/subscriptions/${e}`,{method:"PATCH",body:JSON.stringify(t)})).subscription},async delete(e){return n(`/integrations/subscriptions/${e}`,{method:"DELETE"})},async enable(e){return this.update(e,{enabled:true})},async disable(e){return this.update(e,{enabled:false})},async test(e){return n(`/integrations/subscriptions/${e}/test`,{method:"POST"})},async publish(e){return n("/integrations/events/publish",{method:"POST",body:JSON.stringify(e)})},async publishBatch(e){return (await n("/integrations/events/publish-batch",{method:"POST",body:JSON.stringify({events:e})})).results},async listEvents(e){let t={envId:e.envId,source:e.source,name:e.name,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/events/project/${e.projectId}${r}`)).events},async getEvent(e){return n(`/integrations/events/${e}`)},async getDeliveries(e){let t={subscriptionId:e.subscriptionId,eventId:e.eventId,status:e.status,since:e.since,until:e.until,limit:e.limit,offset:e.offset},r=h(t);return (await n(`/integrations/deliveries${r}`)).deliveries},async getDelivery(e){return n(`/integrations/deliveries/${e}`)},async retryDelivery(e){return n(`/integrations/deliveries/${e}/retry`,{method:"POST"})},async retryAllFailed(e){return n(`/integrations/subscriptions/${e}/retry-failed`,{method:"POST"})},async getDlq(e,t){let r={limit:t?.limit,offset:t?.offset},o=h(r);return (await n(`/integrations/dlq/project/${e}${o}`)).deliveries},async purgeDlq(e,t){return n(`/integrations/dlq/project/${e}/purge`,{method:"POST",body:JSON.stringify({olderThan:t.olderThan})})},async replayDlq(e,t){return n(`/integrations/dlq/project/${e}/replay`,{method:"POST",body:JSON.stringify(t)})},verifySignature(e){let t=e.tolerance??300;try{let r=e.signature.split(","),o=r.find(b=>b.startsWith("t=")),a=r.find(b=>b.startsWith("v1="));if(!o||!a)return !1;let c=parseInt(o.slice(2),10),i=a.slice(3),l=Math.floor(Date.now()/1e3);if(Math.abs(l-c)>t)return !1;let u=`${c}.${e.payload}`,y=new TextEncoder,I=y.encode(e.secret),S=y.encode(u),k=Array.from(I).concat(Array.from(S)).reduce((b,T)=>b+T,0).toString(16);if(i.length!==k.length)return !1;let C=0;for(let b=0;b<i.length;b++)C|=i.charCodeAt(b)^k.charCodeAt(b);return C===0}catch{return false}},generateSecret(){let e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",t="whsec_";for(let r=0;r<32;r++)t+=e.charAt(Math.floor(Math.random()*e.length));return t}}}function te(s){let n=p(s);return {async getSummary(e){return n(`/billing/org/${e}/summary`)},async getEntitlements(e){return n(`/entitlements/org/${e}`)},async checkEntitlement(e,t){return n(`/entitlements/org/${e}/check`,{method:"POST",body:JSON.stringify(t)})},async getPlans(){return (await n("/pricing/plans")).plans},async createCheckout(e){return n("/billing/checkout",{method:"POST",body:JSON.stringify(e)})},async verifyCheckoutSession(e){return n(`/billing/checkout/verify/${e}`)},async openPortal(e){return n(`/billing/org/${e.orgId}/portal`,{method:"POST",body:JSON.stringify({returnUrl:e.returnUrl})})},async getAIUsageSummary(e){return n(`/ai-usage/org/${e}/summary`)},async getAIUsageHistory(e,t=30){return n(`/ai-usage/org/${e}/history?days=${t}`)},async getAIUsageBreakdown(e){return n(`/ai-usage/org/${e}/breakdown`)},async getRecentAIRequests(e,t=50,r=0){return n(`/ai-usage/org/${e}/recent?limit=${t}&offset=${r}`)}}}function ne(s){let n=p(s);return {async getOverview(){return n("/admin/overview")},async listUsers(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/users${r?`?${r}`:""}`)},async getUser(e){return n(`/admin/users/${e}`)},async updateUserStatus(e,t){return n(`/admin/users/${e}/status`,{method:"PATCH",body:JSON.stringify({status:t})})},async updateUserAdmin(e,t){return n(`/admin/users/${e}/admin`,{method:"PATCH",body:JSON.stringify({isAdmin:t})})},async listOrganizations(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.plan&&t.set("plan",e.plan),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/organizations${r?`?${r}`:""}`)},async getOrganization(e){return n(`/admin/organizations/${e}`)},async updateOrganization(e,t){return n(`/admin/organizations/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listProjects(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.orgId&&t.set("orgId",e.orgId),e?.region&&t.set("region",e.region),e?.tenancy&&t.set("tenancy",e.tenancy),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/projects${r?`?${r}`:""}`)},async getProject(e){return n(`/admin/projects/${e}`)},async updateProject(e,t){return n(`/admin/projects/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getProjectResources(e){return n(`/admin/resources/project/${e}`)},async setDedicatedDb(e){return n(`/admin/resources/project/${e.projectId}/db`,{method:"POST",body:JSON.stringify({connectionString:e.connectionString})})},async listIncidents(e="open"){return (await n(`/admin/incidents?status=${e}`)).incidents},async createIncident(e){return n("/admin/incidents",{method:"POST",body:JSON.stringify(e)})},async acknowledgeIncident(e){return n(`/admin/incidents/${e}/ack`,{method:"POST"})},async resolveIncident(e){return n(`/admin/incidents/${e}/resolve`,{method:"POST"})},async listRegions(){return n("/admin/regions")},async updateRegion(e,t){return n(`/admin/regions/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async getHealthComponents(){return n("/admin/health/components")},async updateHealthComponent(e,t){return n(`/admin/health/components/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async listQueues(){return n("/admin/queues")},async listDlqMessages(e){let t=new URLSearchParams;e?.queue&&t.set("queue",e.queue),e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/dlq${r?`?${r}`:""}`)},async retryDlqMessage(e){return n(`/admin/dlq/${e}/retry`,{method:"POST"})},async archiveDlqMessage(e){return n(`/admin/dlq/${e}`,{method:"DELETE"})},async listFeatureFlags(){return (await n("/flags")).flags},async createFeatureFlag(e,t){return n("/flags",{method:"POST",body:JSON.stringify({key:e,enabled:t})})},async updateFeatureFlag(e,t){return n(`/flags/${e}`,{method:"PUT",body:JSON.stringify({enabled:t})})},async deleteFeatureFlag(e){return n(`/flags/${e}`,{method:"DELETE"})},async listAdmins(){return (await n("/admin/admins")).admins||[]},async addAdmin(e,t,r){return n("/admin/admins",{method:"POST",body:JSON.stringify({userId:e,role:t,notes:r})})},async updateAdmin(e,t){return n(`/admin/admins/${e}`,{method:"PUT",body:JSON.stringify(t)})},async removeAdmin(e){return n(`/admin/admins/${e}`,{method:"DELETE"})},async getSettings(e){let t=e?`?category=${e}`:"";return n(`/admin/settings${t}`)},async updateSetting(e,t){return n(`/admin/settings/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify({value:t})})},async listAIModels(){return n("/admin/ai/models")},async getAIModel(e){return n(`/admin/ai/models/${e}`)},async createAIModel(e){return n("/admin/ai/models",{method:"POST",body:JSON.stringify(e)})},async updateAIModel(e,t){return n(`/admin/ai/models/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteAIModel(e){return n(`/admin/ai/models/${e}`,{method:"DELETE"})},async toggleAIModel(e,t,r){return n(`/admin/ai/models/${e}/toggle`,{method:"POST",body:JSON.stringify({enabled:t,disabledMessage:r})})},async listAISessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/workspace/sessions${r?`?${r}`:""}`)},async getAISession(e){return n(`/admin/ai/workspace/sessions/${e}`)},async deleteAISession(e){return n(`/admin/ai/workspace/sessions/${e}`,{method:"DELETE"})},async listGeneratedBackends(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/backends${r?`?${r}`:""}`)},async getGeneratedBackend(e){return n(`/admin/ai/backends/${e}`)},async deleteGeneratedBackend(e){return n(`/admin/ai/backends/${e}`,{method:"DELETE"})},async listPromptTemplates(e){let t=new URLSearchParams;e?.category&&t.set("category",e.category),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/prompt-templates${r?`?${r}`:""}`)},async createPromptTemplate(e){return n("/admin/ai/prompt-templates",{method:"POST",body:JSON.stringify(e)})},async updatePromptTemplate(e,t){return n(`/admin/ai/prompt-templates/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deletePromptTemplate(e){return n(`/admin/ai/prompt-templates/${e}`,{method:"DELETE"})},async listContextSnapshots(e){let t=new URLSearchParams;e?.projectId&&t.set("projectId",e.projectId),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai/context-snapshots${r?`?${r}`:""}`)},async invalidateContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}/invalidate`,{method:"POST"})},async deleteContextSnapshot(e){return n(`/admin/ai/context-snapshots/${e}`,{method:"DELETE"})},async getCopilotOverview(){return n("/admin/copilot/overview")},async listCopilotSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/sessions${r?`?${r}`:""}`)},async getCopilotSession(e){return n(`/admin/copilot/sessions/${e}`)},async deleteCopilotSession(e){return n(`/admin/copilot/sessions/${e}`,{method:"DELETE"})},async listCopilotMemories(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.projectId&&t.set("projectId",e.projectId),e?.memoryType&&t.set("memoryType",e.memoryType),e?.importance&&t.set("importance",e.importance),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/copilot/memories${r?`?${r}`:""}`)},async getCopilotMemoryStats(){return n("/admin/copilot/memories/stats")},async getCopilotMemory(e){return n(`/admin/copilot/memories/${e}`)},async updateCopilotMemory(e,t){return n(`/admin/copilot/memories/${e}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteCopilotMemory(e){return n(`/admin/copilot/memories/${e}`,{method:"DELETE"})},async cleanupExpiredMemories(){return n("/admin/copilot/memories/cleanup",{method:"POST"})},async exportTrainingData(e){let t=new URLSearchParams;e?.format&&t.set("format",e.format),e?.dataType&&t.set("dataType",e.dataType),e?.minConfidence!==void 0&&t.set("minConfidence",String(e.minConfidence)),e?.limit&&t.set("limit",String(e.limit)),e?.includeExecuted!==void 0&&t.set("includeExecuted",String(e.includeExecuted)),e?.includeSuccessful!==void 0&&t.set("includeSuccessful",String(e.includeSuccessful));let r=t.toString();return n(`/admin/copilot/training-data/export${r?`?${r}`:""}`)},async getTrainingDataStats(){return n("/admin/copilot/training-data/stats")},async listErrors(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.path&&t.set("path",e.path),e?.errorCode&&t.set("errorCode",e.errorCode),e?.status&&t.set("status",e.status),e?.environment&&t.set("environment",e.environment),e?.startDate&&t.set("startDate",e.startDate),e?.endDate&&t.set("endDate",e.endDate),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/errors${r?`?${r}`:""}`)},async getErrorStats(){return n("/admin/errors/stats")},async getError(e){return n(`/admin/errors/${e}`)},async resolveError(e,t){return n(`/admin/errors/${e}/resolve`,{method:"PUT",body:JSON.stringify({notes:t})})},async deleteError(e){return n(`/admin/errors/${e}`,{method:"DELETE"})},async bulkDeleteErrors(e){let t=e?`?olderThanDays=${e}`:"";return n(`/admin/errors${t}`,{method:"DELETE"})},async getAIWorkspaceOverview(){return n("/admin/ai-workspace/overview")},async listAIWorkspaceSessions(e){let t=new URLSearchParams;e?.search&&t.set("search",e.search),e?.status&&t.set("status",e.status),e?.taskType&&t.set("taskType",e.taskType),e?.limit&&t.set("limit",String(e.limit)),e?.offset&&t.set("offset",String(e.offset));let r=t.toString();return n(`/admin/ai-workspace/sessions${r?`?${r}`:""}`)},async getAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`)},async deleteAIWorkspaceSession(e){return n(`/admin/ai-workspace/sessions/${e}`,{method:"DELETE"})}}}function re(s){let n=p(s);return {async list(){return (await n("/flags")).flags},async create(e){return n("/flags",{method:"POST",body:JSON.stringify(e)})},async update(e,t){return n(`/flags/${encodeURIComponent(e)}`,{method:"PUT",body:JSON.stringify(t)})},async delete(e){return n(`/flags/${encodeURIComponent(e)}`,{method:"DELETE"})}}}function oe(s){let n=p(s);return {async getOverview(e){return (await n(`/security/overview/${encodeURIComponent(e)}`)).overview},async getAuditLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.offset&&r.set("offset",String(t.offset));let o=r.toString(),a=`/security/audit/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async listEnvVars(e,t){let r=new URLSearchParams;t&&r.set("envId",t);let o=r.toString(),a=`/projects/${encodeURIComponent(e)}/env-vars${o?`?${o}`:""}`;return (await n(a)).envVars},async createEnvVar(e,t){return (await n(`/projects/${encodeURIComponent(e)}/env-vars`,{method:"POST",body:JSON.stringify(t)})).envVar},async updateEnvVar(e,t,r){return (await n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"PATCH",body:JSON.stringify(r)})).envVar},async deleteEnvVar(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}`,{method:"DELETE"})},async getEnvVarValue(e,t){return n(`/projects/${encodeURIComponent(e)}/env-vars/${encodeURIComponent(t)}/value`)}}}function se(s){let n=p(s);return {async generatePlan(e){return n("/ai/plan",{method:"POST",body:JSON.stringify({projectId:e.projectId,prompt:e.prompt,context:e.context,taskType:e.taskType,mode:e.mode})})},async explainPlan(e){return n("/ai/explain",{method:"POST",body:JSON.stringify({plan:e.plan,projectId:e.projectId,taskType:e.taskType,mode:e.mode})})},async getOrgSettings(e){return n(`/ai/settings/org/${encodeURIComponent(e)}`)},async updateOrgSettings(e,t){return n(`/ai/settings/org/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getProjectOverrides(e){return n(`/ai/settings/project/${encodeURIComponent(e)}`)},async updateProjectOverrides(e,t){return n(`/ai/settings/project/${encodeURIComponent(e)}`,{method:"POST",body:JSON.stringify(t)})},async getUsage(e,t){let r=new URLSearchParams;t&&r.set("month",t);let o=r.toString(),a=`/ai/usage/org/${encodeURIComponent(e)}${o?`?${o}`:""}`;return n(a)},async getBudgetStatus(e){let[t,r]=await Promise.all([this.getOrgSettings(e),this.getUsage(e)]),o=t?.monthlyBudgetCents??1e4,a=r.costCents,c=Math.max(0,o-a),i=o>0?Math.round(a/o*100):0;return {spent:a,budget:o,remaining:c,hardStop:t?.hardStopEnabled??false,percentUsed:i}},async generateFunction(e){return n("/ai/generate-function",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,inputSchema:e.inputSchema,outputSchema:e.outputSchema,language:e.language??"typescript",mode:e.mode})})},async generateEndpoint(e){return n("/ai/generate-endpoint",{method:"POST",body:JSON.stringify({projectId:e.projectId,description:e.description,method:e.method??"GET",authRequired:e.authRequired??true,mode:e.mode})})},async exportCode(e){return n("/ai/export-code",{method:"POST",body:JSON.stringify({projectId:e.projectId,targetLanguage:e.targetLanguage,includeSchema:e.includeSchema??true,includeFunctions:e.includeFunctions??true,includeEndpoints:e.includeEndpoints??true})})},async createConversation(e,t){return n("/ai/conversations",{method:"POST",body:JSON.stringify({projectId:e,title:t?.title,context:t?.context})})},async sendMessage(e,t){return n(`/ai/conversations/${encodeURIComponent(e)}/messages`,{method:"POST",body:JSON.stringify({content:t.content,taskType:t.taskType})})},async getConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`)},async listConversations(e){return (await n(`/ai/conversations/project/${encodeURIComponent(e)}`)).conversations},async deleteConversation(e){return n(`/ai/conversations/${encodeURIComponent(e)}`,{method:"DELETE"})},async getAvailableModels(){return n("/ai/models/available")},async getModel(e){return n(`/ai/models/${encodeURIComponent(e)}`)},async getProjectContext(e){return n(`/ai/context/${encodeURIComponent(e)}`)},async estimateTokens(e,t){return n("/ai/context/estimate",{method:"POST",body:JSON.stringify({prompt:e,projectId:t})})},async analyzeForClarification(e){return n("/ai/clarify",{method:"POST",body:JSON.stringify(e)})},async getSuggestions(e){return n("/ai/suggestions",{method:"POST",body:JSON.stringify(e)})},workspace:{async create(e){return n("/ai/workspace/create",{method:"POST",body:JSON.stringify(e)})},async get(e){return n(`/ai/workspace/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/workspace/list/${encodeURIComponent(e)}`)},async submitPrompt(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/prompt`,{method:"POST",body:JSON.stringify(t),timeout:12e4})},async submitClarification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/clarify`,{method:"POST",body:JSON.stringify({responses:t}),timeout:9e4})},async generate(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/generate`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitModification(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/modify`,{method:"POST",body:JSON.stringify(t),timeout:18e4})},async submitFeedback(e,t){return n(`/ai/workspace/${encodeURIComponent(e)}/feedback`,{method:"POST",body:JSON.stringify(t)})}},backends:{async get(e){return n(`/ai/backends/${encodeURIComponent(e)}`)},async list(e){return n(`/ai/backends/list/${encodeURIComponent(e)}`)},async delete(e){return n(`/ai/backends/${encodeURIComponent(e)}`,{method:"DELETE"})},async deploy(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy`,{method:"POST",body:JSON.stringify(t)})},async apply(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/apply`,{method:"POST",body:JSON.stringify(t)})},async deployLive(e,t){return n(`/ai/backends/${encodeURIComponent(e)}/deploy-live`,{method:"POST",body:JSON.stringify(t),timeout:3e5})},async getDeployments(e){return n(`/ai/backends/${encodeURIComponent(e)}/deployments`)}},deployments:{async getLimits(e){return n(`/ai/deployments/limits/${encodeURIComponent(e)}`)},async getStatus(e){return n(`/ai/deployments/${encodeURIComponent(e)}/status`)},async getLogs(e,t){let r=new URLSearchParams;t?.limit&&r.set("limit",String(t.limit)),t?.severity&&r.set("severity",t.severity);let o=r.toString();return n(`/ai/deployments/${encodeURIComponent(e)}/logs${o?`?${o}`:""}`)},async terminate(e){return n(`/ai/deployments/${encodeURIComponent(e)}`,{method:"DELETE"})},async redeploy(e){return n(`/ai/deployments/${encodeURIComponent(e)}/redeploy`,{method:"POST",timeout:3e5})}},async getUserOrganizations(){return n("/ai/user/organizations")},async getProjectLimits(e){return n(`/ai/org/${encodeURIComponent(e)}/project-limits`)},async createProjectWithSchema(e){return n("/ai/schema/create-project",{method:"POST",body:JSON.stringify(e)})}}}function ie(s){let n=p(s);return {async load(){return n("/bootstrap")}}}function ae(s){let n=p(s);return {async list(e){let t=new URLSearchParams;e?.visibility&&t.set("visibility",e.visibility),e?.category&&t.set("category",e.category),e?.orgId&&t.set("orgId",e.orgId);let r=t.toString(),o=`/templates${r?`?${r}`:""}`;return (await n(o)).templates},async get(e){return n(`/templates/${e}`)},async previewInstall(e){return n("/templates/install/preview",{method:"POST",body:JSON.stringify(e)})},async applyInstall(e){return n("/templates/install/apply",{method:"POST",body:JSON.stringify(e)})},async rollback(e){return n(`/templates/install/${e}/rollback`,{method:"POST"})},async createProject(e){return n("/templates/create-project",{method:"POST",body:JSON.stringify(e)})}}}function le(s){let n=p(s);return {async list(e){return (await n(`/oauth/org/${e}`)).connections},async configure(e,t){return n(`/oauth/org/${e}/configure`,{method:"POST",body:JSON.stringify(t)})},async enable(e){return n(`/oauth/connections/${e}/enable`,{method:"POST"})},async disable(e){return n(`/oauth/connections/${e}/disable`,{method:"POST"})},async delete(e){return n(`/oauth/connections/${e}`,{method:"DELETE"})}}}function ce(s){let n=p(s);return {async listPages(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/pages${t}`)).pages},async getPage(e){return (await n(`/docs/pages/${encodeURIComponent(e)}`)).page},async createPage(e){return (await n("/docs/pages",{method:"POST",body:JSON.stringify(e)})).page},async updatePage(e,t){return (await n(`/docs/pages/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).page},async deletePage(e){return n(`/docs/pages/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdks(){return (await n("/docs/sdks")).sdks},async getSdk(e){return (await n(`/docs/sdks/${encodeURIComponent(e)}`)).sdk},async createSdk(e){return (await n("/docs/sdks",{method:"POST",body:JSON.stringify(e)})).sdk},async updateSdk(e,t){return (await n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).sdk},async deleteSdk(e){return n(`/docs/sdks/${encodeURIComponent(e)}`,{method:"DELETE"})},async listSdkExamples(e,t){let r=t?`?topic=${encodeURIComponent(t)}`:"";return (await n(`/docs/sdks/${encodeURIComponent(e)}/examples${r}`)).examples},async createSdkExample(e){return (await n("/docs/sdk-examples",{method:"POST",body:JSON.stringify(e)})).example},async deleteSdkExample(e){return n(`/docs/sdk-examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listEndpoints(e){let t=e?`?category=${encodeURIComponent(e)}`:"";return (await n(`/docs/api-endpoints${t}`)).endpoints},async getEndpoint(e){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`)).endpoint},async createEndpoint(e){return (await n("/docs/api-endpoints",{method:"POST",body:JSON.stringify(e)})).endpoint},async updateEndpoint(e,t){return (await n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).endpoint},async deleteEndpoint(e){return n(`/docs/api-endpoints/${encodeURIComponent(e)}`,{method:"DELETE"})},async listExamples(e){let t=e!==void 0?`?featured=${e}`:"";return (await n(`/docs/examples${t}`)).examples},async getExample(e){return (await n(`/docs/examples/${encodeURIComponent(e)}`)).example},async createExample(e){return (await n("/docs/examples",{method:"POST",body:JSON.stringify(e)})).example},async updateExample(e,t){return (await n(`/docs/examples/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).example},async deleteExample(e){return n(`/docs/examples/${encodeURIComponent(e)}`,{method:"DELETE"})},async listChangelog(){return (await n("/docs/changelog")).entries},async getChangelogEntry(e){return (await n(`/docs/changelog/${encodeURIComponent(e)}`)).entry},async createChangelogEntry(e){return (await n("/docs/changelog",{method:"POST",body:JSON.stringify(e)})).entry},async updateChangelogEntry(e,t){return (await n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})).entry},async deleteChangelogEntry(e){return n(`/docs/changelog/${encodeURIComponent(e)}`,{method:"DELETE"})},async search(e){return (await n(`/docs/search?q=${encodeURIComponent(e)}`)).results}}}function V(s,n,e,t){let r=[...n],o=0,a=false,c=false,i=async()=>{if(c||a)return;let l=await e(`/mongodb/${t}/cursor/${s}/next`,{method:"POST"});r=l.batch,o=0,a=l.exhausted;};return {id:s,async hasNext(){return c?false:o<r.length?true:a?false:(await i(),r.length>0)},async next(){return c?null:o<r.length?r[o++]:a||(await i(),r.length===0)?null:r[o++]},async toArray(){if(c)return [];let l=[];for(;o<r.length;)l.push(r[o++]);for(;!a;)await i(),l.push(...r),o=r.length;return l},async forEach(l){if(!c){for(;o<r.length;)await l(r[o++]);for(;!a;){await i();for(let u of r)await l(u);o=r.length;}}},map(l){let u=r.slice(o).map(l);return V(s,u,e,t)},async close(){if(!c){c=true;try{await e(`/mongodb/${t}/cursor/${s}/close`,{method:"POST"});}catch{}}},isClosed(){return c}}}function ke(s,n){let e=`/mongodb/${encodeURIComponent(s)}`;return {collectionName:s,async find(t,r){return n(`${e}/find`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findCursor(t,r){let o=await n(`${e}/find/cursor`,{method:"POST",body:JSON.stringify({filter:t,options:r})});return V(o.cursorId,o.batch,n,s)},async findOne(t,r){return n(`${e}/findOne`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async findById(t,r){return n(`${e}/findById/${encodeURIComponent(t)}`,{method:"GET",...r&&{body:JSON.stringify({options:r})}})},async countDocuments(t){return (await n(`${e}/count`,{method:"POST",body:JSON.stringify({filter:t})})).count},async estimatedDocumentCount(){return (await n(`${e}/estimatedCount`)).count},async distinct(t,r){return n(`${e}/distinct`,{method:"POST",body:JSON.stringify({field:t,...r})})},async insertOne(t){return n(`${e}/insertOne`,{method:"POST",body:JSON.stringify({document:t})})},async insertMany(t,r){return n(`${e}/insertMany`,{method:"POST",body:JSON.stringify({documents:t,options:r})})},async updateOne(t,r,o){return n(`${e}/updateOne`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async updateMany(t,r,o){return n(`${e}/updateMany`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async replaceOne(t,r,o){return n(`${e}/replaceOne`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async findOneAndUpdate(t,r,o){return n(`${e}/findOneAndUpdate`,{method:"POST",body:JSON.stringify({filter:t,update:r,options:o})})},async findOneAndReplace(t,r,o){return n(`${e}/findOneAndReplace`,{method:"POST",body:JSON.stringify({filter:t,replacement:r,options:o})})},async deleteOne(t){return n(`${e}/deleteOne`,{method:"POST",body:JSON.stringify({filter:t})})},async deleteMany(t){return n(`${e}/deleteMany`,{method:"POST",body:JSON.stringify({filter:t})})},async findOneAndDelete(t,r){return n(`${e}/findOneAndDelete`,{method:"POST",body:JSON.stringify({filter:t,options:r})})},async aggregate(t,r){return n(`${e}/aggregate`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})})},async aggregateCursor(t,r){let o=await n(`${e}/aggregate/cursor`,{method:"POST",body:JSON.stringify({pipeline:t,options:r})});return V(o.cursorId,o.batch,n,s)},async createIndex(t,r){return (await n(`${e}/indexes`,{method:"POST",body:JSON.stringify({keys:t,options:r})})).indexName},async dropIndex(t){await n(`${e}/indexes/${encodeURIComponent(t)}`,{method:"DELETE"});},async listIndexes(){return n(`${e}/indexes`)},async bulkWrite(t,r){return n(`${e}/bulkWrite`,{method:"POST",body:JSON.stringify({operations:t,options:r})})}}}function de(s){let n=p(s);return {collection(e){return ke(e,n)},async listCollections(){return n("/mongodb/collections")},async createCollection(e,t){await n("/mongodb/collections",{method:"POST",body:JSON.stringify({name:e,options:t})});},async dropCollection(e){await n(`/mongodb/collections/${encodeURIComponent(e)}`,{method:"DELETE"});},async renameCollection(e,t){await n(`/mongodb/collections/${encodeURIComponent(e)}/rename`,{method:"POST",body:JSON.stringify({newName:t})});},async command(e){return n("/mongodb/command",{method:"POST",body:JSON.stringify(e)})}}}function ge(s){let n=p(s);return {async chat(e){return n("/ai/copilot/chat",{method:"POST",body:JSON.stringify(e),timeout:12e4})},getStreamUrl(){return `${s.baseUrl}/ai/copilot/chat/stream`},async getModels(e){return n(`/ai/copilot/models/${encodeURIComponent(e)}`)},async getCreditStatus(e){return n(`/ai/copilot/credit-status/${encodeURIComponent(e)}`)},async listSessions(e){return n(`/ai/copilot/sessions/${encodeURIComponent(e)}`)},async getSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`)},async updateSession(e,t){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"PATCH",body:JSON.stringify(t)})},async deleteSession(e){return n(`/ai/copilot/session/${encodeURIComponent(e)}`,{method:"DELETE"})},async executePlan(e){return n("/ai/copilot/execute",{method:"POST",body:JSON.stringify(e),timeout:18e4})},async submitFeedback(e){return n("/ai/copilot/feedback",{method:"POST",body:JSON.stringify(e)})},async getClassificationStats(){return n("/ai/copilot/stats")},async getUsage(e){return n(`/ai/copilot/usage-org/${encodeURIComponent(e)}`)}}}function he(s,n,e,t){let r=n.type||"public",o="unsubscribed",a=new Map,c=[],i={},l=null,u=null,y=new Set,I=new Set,S=new Set,k=d=>{if(d.event){let P=a.get(d.event);P&&P.forEach(R=>R(d.payload));}},C=d=>{i=d.state||{},y.forEach(P=>P(i));},b=d=>{let P=d.key||"",R=d.currentPresences||[],g=d.joinedPresences||[],m=d.leftPresences||[];g.length>0&&(i[P]=R,I.forEach(f=>f(P,R,g))),m.length>0&&(R.length===0?delete i[P]:i[P]=R,S.forEach(f=>f(P,R,m))),y.forEach(f=>f(i));},T=d=>{let P={type:"db_change",projectId:d.projectId||"",schema:d.schema||"",table:d.table||"",operation:d.op,new:d.record,old:d.old_record,timestamp:d.ts||new Date().toISOString(),partial:d.partial};c.forEach(({options:R,handler:g})=>{if(R.table===P.table){let m=R.event||"*";(m==="*"||(Array.isArray(m)?m.includes(P.operation):m===P.operation))&&g(P);}});},v={get name(){return s},get type(){return r},get status(){return o},_handleMessage:d=>{switch(d.type){case "broadcast":k(d);break;case "presence_state":C(d);break;case "presence":b(d);break;case "db_change":T(d);break;case "subscribed":o="subscribed";break;case "error":o="error";break}},onDbChange(d,P){return c.push({options:d,handler:P}),o==="subscribed"&&e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}}),v},on(d,P){return a.has(d)||a.set(d,new Set),a.get(d).add(P),v},off(d,P){return P?a.get(d)?.delete(P):a.delete(d),v},async broadcast(d){if(o!=="subscribed")throw new Error("Channel must be subscribed before broadcasting");e({type:"broadcast",channel:s,event:d.event,payload:d.payload,includeSelf:d.includeSelf});},presence:{async track(d){if(r!=="presence")throw new Error("Presence tracking is only available on presence channels");l=d.key||t()||"anonymous",u=d.state,e({type:"presence_track",channel:s,key:l,state:u});},async update(d){if(!u)throw new Error("Must call track() before update()");u={...u,...d},e({type:"presence_update",channel:s,key:l??void 0,state:u});},async untrack(){l&&(e({type:"presence_untrack",channel:s,key:l}),l=null,u=null);},state(){return {...i}},onSync(d){return y.add(d),v},onJoin(d){return I.add(d),v},onLeave(d){return S.add(d),v}},async subscribe(){return o==="subscribed"||(o="subscribing",e({type:"subscribe",channel:s}),c.forEach(({options:d})=>{e({type:"subscribe",channel:s,options:{table:d.table,filter:d.filter,event:d.event,columns:d.columns}});}),n.presenceState&&r==="presence"&&await v.presence.track({state:n.presenceState})),v},async unsubscribe(){o!=="unsubscribed"&&(l&&await v.presence.untrack(),e({type:"unsubscribe",channel:s}),o="unsubscribed",i={},a.clear(),c.length=0);}};return v}function ue(s,n){let{wsUrl:e=s.baseUrl.replace(/^http/,"ws")+"/realtime/ws",autoReconnect:t=true,reconnectDelay:r=1e3,maxReconnectAttempts:o=10}=n??{},a=null,c="disconnected",i=null,l=null,u=0,y=null,I=null,S=new Map,k=new Map,C=new Set,b={connect:new Set,disconnect:new Set,error:new Set,reconnect:new Set},T=g=>{b[g].forEach(m=>m());},E=g=>{let m=`table:${g.table}`;if(g.filter){let A=(Array.isArray(g.filter)?g.filter:[g.filter]).map(w=>`${w.field}${w.operator||"eq"}${w.value}`).join("&");m+=`?${A}`;}return m},v=g=>{a?.readyState===WebSocket.OPEN&&a.send(JSON.stringify(g));},d=g=>{if(g.channel){let m=S.get(g.channel);if(m){m._handleMessage(g);return}}switch(g.type){case "db_change":{let m={type:"db_change",projectId:g.projectId??"",schema:g.schema??"",table:g.table??"",operation:g.op,new:g.record,old:g.old_record,timestamp:g.ts??new Date().toISOString(),partial:g.partial},f=`table:${g.table}`;k.forEach((A,w)=>{(w===f||w.startsWith(f+"?"))&&A.forEach(B=>B(m));});break}case "presence":{let m={type:"presence",event:g.event,key:g.key||g.connectionId||"",connectionId:g.connectionId??"",projectId:g.projectId??"",currentPresences:g.currentPresences||[],leftPresences:g.leftPresences||[],joinedPresences:g.joinedPresences||[]};C.forEach(f=>f(m));break}case "welcome":i=g.connectionId||null;break;case "error":{console.error("[vaif/realtime] Server error:",g.message),T("error");break}}},P=()=>new Promise((g,m)=>{let f=new URLSearchParams;s.apiKey&&f.set(s.apiKeyHeader,s.apiKey),l&&f.set("token",l);let A=f.toString(),w=A?`${e}?${A}`:e;try{a=new WebSocket(w);}catch{m(new x("Failed to create WebSocket connection"));return}let B=()=>{c="connected",u=0,T("connect"),S.forEach(M=>{(M.status==="subscribed"||M.status==="subscribing")&&M.subscribe();}),k.forEach((M,N)=>{v({type:"subscribe",channel:N});}),I=setInterval(()=>{v({type:"ping"});},3e4),g();},pe=M=>{try{let N=JSON.parse(M.data);d(N);}catch{}},me=()=>{if(c="disconnected",i=null,a=null,I&&(clearInterval(I),I=null),T("disconnect"),t&&u<o){c="reconnecting";let M=r*Math.pow(2,u);y=setTimeout(()=>{u++,T("reconnect"),P().catch(()=>{});},Math.min(M,3e4));}},ye=()=>{T("error"),m(new x("WebSocket connection error"));};a.addEventListener("open",B),a.addEventListener("message",pe),a.addEventListener("close",me),a.addEventListener("error",ye);}),R=()=>{y&&(clearTimeout(y),y=null),I&&(clearInterval(I),I=null),u=o;};return {channel(g,m={}){let f=S.get(g);if(f)return f;let A=he(g,m,v,()=>i);return S.set(g,A),A},async removeChannel(g){let m=S.get(g.name);m&&(await m.unsubscribe(),S.delete(g.name));},getChannels(){return Array.from(S.values())},subscribe(g,m){let f=E(g);return k.has(f)||k.set(f,new Set),k.get(f).add(m),a?.readyState===WebSocket.OPEN&&v({type:"subscribe",channel:f}),()=>{let A=k.get(f);A&&(A.delete(m),A.size===0&&(k.delete(f),a?.readyState===WebSocket.OPEN&&v({type:"unsubscribe",channel:f})));}},subscribeToPresence(g){return C.add(g),()=>{C.delete(g);}},async connect(){if(c!=="connected"){if(!s.apiKey)throw new D("API key is required for realtime connections");c="connecting",await P();}},disconnect(){R(),S.forEach(g=>{g.unsubscribe();}),S.clear(),a&&(a.close(),a=null),c="disconnected",i=null;},get isConnected(){return c==="connected"},get connectionState(){return c},get connectionId(){return i},on(g,m){b[g].add(m);},off(g,m){b[g].delete(m);},setAuth(g){l=g;}}}var j={apiKeyHeader:"x-vaif-key",timeout:3e4,retry:{maxRetries:3,retryDelay:1e3,retryOn:[429,500,502,503,504]}};function Se(s){return {baseUrl:s.baseUrl.replace(/\/$/,""),apiKey:s.apiKey,apiKeyHeader:s.apiKeyHeader??j.apiKeyHeader,accessToken:s.accessToken,fetch:s.fetch??globalThis.fetch.bind(globalThis),timeout:s.timeout??j.timeout,retry:{maxRetries:s.retry?.maxRetries??j.retry.maxRetries,retryDelay:s.retry?.retryDelay??j.retry.retryDelay,retryOn:s.retry?.retryOn??[...j.retry.retryOn]}}}function ve(s){let n=Se(s),e=q(n),t=J(n),r=K(n),o=G(n),a=_(n),c=H(n),i=z(n),l=Q(n),u=X(n),y=Z(n),I=Y(n),S=ee(n),k=te(n),C=ne(n),b=re(n),T=oe(n),E=se(n),v=ie(n),d=ae(n),P=le(n),R=ce(n),g=de(n),m=ge(n);return {from:e.from,auth:t,functions:r,storage:o,projects:a,orgs:c,schema:i,secrets:l,deployments:u,realtimeMonitoring:y,storageDashboard:I,integrations:S,billing:k,admin:C,flags:b,security:T,ai:E,bootstrap:v,templates:d,oauth:P,docs:R,mongodb:g,copilot:m,realtime:f=>ue(n,f)}}export{D as VaifAuthError,O as VaifError,x as VaifNetworkError,F as VaifNotFoundError,$ as VaifRateLimitError,U as VaifValidationError,ve as createVaifClient,be as isVaifError};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vaiftech/client",
3
- "version": "1.0.12",
3
+ "version": "1.0.13",
4
4
  "description": "TypeScript SDK for VAIF Studio BaaS",
5
5
  "main": "dist/index.js",
6
6
  "module": "dist/index.mjs",
@@ -23,7 +23,7 @@
23
23
  "test": "vitest run"
24
24
  },
25
25
  "dependencies": {
26
- "@vaiftech/auth": "workspace:*"
26
+ "@vaiftech/auth": "^1.0.4"
27
27
  },
28
28
  "devDependencies": {
29
29
  "tsup": "^8.0.0",