@shipstatic/ship 0.8.5 → 0.8.6

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/README.md CHANGED
@@ -1,6 +1,6 @@
1
1
  # @shipstatic/ship
2
2
 
3
- Universal SDK and CLI for deploying static files to ShipStatic.
3
+ Universal SDK and CLI for deploying static sites to ShipStatic. No account required — deploy instantly, claim later.
4
4
 
5
5
  ## Installation
6
6
 
@@ -15,7 +15,7 @@ npm install @shipstatic/ship
15
15
  ## CLI Usage
16
16
 
17
17
  ```bash
18
- # Deploy a directory
18
+ # Deploy no account needed, site is live instantly
19
19
  ship ./dist
20
20
 
21
21
  # Deploy with labels
@@ -25,6 +25,8 @@ ship ./dist --label production --label v1.0.0
25
25
  ship ./dist -q | ship domains set www.example.com
26
26
  ```
27
27
 
28
+ Without credentials, deployments are public (3-day TTL) with a claim URL. Configure an API key for permanent deployments: `ship config`
29
+
28
30
  ### Composability
29
31
 
30
32
  The `-q` flag outputs only the resource identifier — perfect for piping and scripting:
@@ -107,27 +109,22 @@ ship completion uninstall
107
109
  ```javascript
108
110
  import Ship from '@shipstatic/ship';
109
111
 
110
- const ship = new Ship({
111
- apiKey: 'ship-your-api-key'
112
- });
113
-
114
- // Deploy (shortcut)
112
+ // Deploy no credentials needed
113
+ const ship = new Ship();
115
114
  const deployment = await ship.deploy('./dist');
116
- console.log(`Deployed: https://${deployment.deployment}`);
115
+ console.log(`Live: https://${deployment.deployment}`);
116
+ console.log(`Claim: ${deployment.claim}`); // User visits to keep permanently
117
117
 
118
- // Deploy with options
119
- const deployment = await ship.deployments.upload('./dist', {
118
+ // With an API key — deployments are permanent
119
+ const ship = new Ship({ apiKey: 'ship-your-api-key' });
120
+ const deployment = await ship.deploy('./dist', {
120
121
  labels: ['production', 'v1.0'],
121
122
  onProgress: ({ percent }) => console.log(`${percent}%`)
122
123
  });
123
124
 
124
- // Manage domains
125
+ // Manage domains (requires API key)
125
126
  await ship.domains.set('www.example.com', { deployment: deployment.deployment });
126
127
  await ship.domains.list();
127
-
128
- // Update labels
129
- await ship.deployments.set(deployment.deployment, { labels: ['production', 'v1.0'] });
130
- await ship.domains.set('www.example.com', { labels: ['live'] });
131
128
  ```
132
129
 
133
130
  ## Browser Usage
@@ -149,6 +146,8 @@ const deployment = await ship.deploy([
149
146
 
150
147
  ## Authentication
151
148
 
149
+ Deploying works without credentials. For permanent deployments and account features:
150
+
152
151
  ```javascript
153
152
  // API key (persistent access)
154
153
  const ship = new Ship({
package/SKILL.md CHANGED
@@ -4,11 +4,8 @@ description: Static hosting via ShipStatic. Use when the user wants to deploy a
4
4
  metadata:
5
5
  openclaw:
6
6
  requires:
7
- env:
8
- - SHIP_API_KEY
9
7
  bins:
10
8
  - ship
11
- primaryEnv: SHIP_API_KEY
12
9
  emoji: "🚀"
13
10
  homepage: https://github.com/shipstatic/ship
14
11
  install:
@@ -17,7 +14,24 @@ metadata:
17
14
  bins: [ship]
18
15
  ---
19
16
 
20
- ## Authenticate
17
+ ## Deploy
18
+
19
+ No account needed. Just deploy:
20
+
21
+ ```bash
22
+ ship ./dist # Site is live instantly
23
+ ship ./dist --json # Parse: {"deployment": "...", "claim": "https://..."}
24
+ ship ./dist -q # Outputs only: happy-cat-abc1234.shipstatic.com
25
+ ship ./dist --label v1.0 --label latest # Labels (repeatable)
26
+ ```
27
+
28
+ Without credentials, the site is live instantly and expires in 3 days. The output includes a claim URL — always show both the deployment URL and the claim URL to the user so they can keep the site permanently.
29
+
30
+ Deployment IDs are their permanent URLs: `word-word-hash.shipstatic.com`. Always use the full ID (including `.shipstatic.com`) as the argument to other commands.
31
+
32
+ ## API Key (optional)
33
+
34
+ For permanent deployments and full account access:
21
35
 
22
36
  ```bash
23
37
  ship config # Interactive — saves to ~/.shiprc
@@ -25,7 +39,7 @@ ship --api-key <key> ... # Per-command
25
39
  export SHIP_API_KEY=<key> # Environment variable
26
40
  ```
27
41
 
28
- Get an API key at https://my.shipstatic.com/settings
42
+ Create a free API key at https://my.shipstatic.com/api-key
29
43
 
30
44
  ## Output Modes
31
45
 
@@ -170,7 +184,7 @@ ship tokens remove <token> # Delete token
170
184
 
171
185
  | Error | Meaning | Action |
172
186
  |-------|---------|--------|
173
- | `authentication required` | No credentials | Use `--api-key`, `--deploy-token`, or `ship config` |
187
+ | `too many requests` | Public deploy rate limited | Wait and retry, or use `ship config` to set an API key |
174
188
  | `authentication failed` | Invalid credentials | Check key/token validity |
175
189
  | `not found` | Resource doesn't exist | Verify the ID/name |
176
190
  | `path does not exist` | Deploy path invalid | Check the file/directory path |
package/dist/browser.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import * as _shipstatic_types from '@shipstatic/types';
2
- import { DeploymentUploadOptions, ProgressInfo, StaticFile, Domain, Deployment, DeploymentListResponse, DomainListResponse, DomainDnsResponse, DomainRecordsResponse, DomainValidateResponse, TokenCreateResponse, TokenListResponse, Account, ConfigResponse, ResolvedConfig, DeployInput, AccountResource, DeploymentResource, DomainResource, TokenResource, ValidatableFile, FileValidationResult } from '@shipstatic/types';
2
+ import { DeploymentUploadOptions, ProgressInfo, StaticFile, Domain, DeploymentCreateResponse, DeploymentListResponse, Deployment, DomainListResponse, DomainDnsResponse, DomainRecordsResponse, DomainValidateResponse, TokenCreateResponse, TokenListResponse, Account, ConfigResponse, ResolvedConfig, DeployInput, AccountResource, DeploymentResource, DomainResource, TokenResource, ValidatableFile, FileValidationResult } from '@shipstatic/types';
3
3
  export * from '@shipstatic/types';
4
4
  export { Account, AccountResource, DEFAULT_API, DeployInput, Deployment, DeploymentResource, Domain, DomainResource, ErrorType, FileValidationStatus as FILE_VALIDATION_STATUS, PingResponse, ResolvedConfig, ShipError, StaticFile, TokenResource } from '@shipstatic/types';
5
5
 
@@ -208,7 +208,7 @@ declare class ApiHttp extends SimpleEvents {
208
208
  private parseResponse;
209
209
  private handleResponseError;
210
210
  private handleFetchError;
211
- deploy(files: StaticFile[], options?: ApiDeployOptions): Promise<Deployment>;
211
+ deploy(files: StaticFile[], options?: ApiDeployOptions): Promise<DeploymentCreateResponse>;
212
212
  listDeployments(): Promise<DeploymentListResponse>;
213
213
  getDeployment(id: string): Promise<Deployment>;
214
214
  updateDeploymentLabels(id: string, labels: string[]): Promise<Deployment>;
@@ -230,6 +230,7 @@ declare class ApiHttp extends SimpleEvents {
230
230
  createToken(ttl?: number, labels?: string[]): Promise<TokenCreateResponse>;
231
231
  listTokens(): Promise<TokenListResponse>;
232
232
  removeToken(token: string): Promise<void>;
233
+ fetchAgentToken(): Promise<TokenCreateResponse>;
233
234
  getAccount(): Promise<Account>;
234
235
  getConfig(): Promise<ConfigResponse>;
235
236
  ping(): Promise<boolean>;
package/dist/browser.js CHANGED
@@ -1,2 +1,2 @@
1
- var ze=Object.create;var L=Object.defineProperty;var Ke=Object.getOwnPropertyDescriptor;var He=Object.getOwnPropertyNames;var Ve=Object.getPrototypeOf,je=Object.prototype.hasOwnProperty;var Ge=(i,r,e)=>r in i?L(i,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[r]=e;var R=(i,r)=>()=>(i&&(r=i(i=0)),r);var de=(i,r)=>()=>(r||i((r={exports:{}}).exports,r),r.exports),qe=(i,r)=>{for(var e in r)L(i,e,{get:r[e],enumerable:!0})},Ye=(i,r,e,a)=>{if(r&&typeof r=="object"||typeof r=="function")for(let u of He(r))!je.call(i,u)&&u!==e&&L(i,u,{get:()=>r[u],enumerable:!(a=Ke(r,u))||a.enumerable});return i};var Y=(i,r,e)=>(e=i!=null?ze(Ve(i)):{},Ye(r||!i||!i.__esModule?L(e,"default",{value:i,enumerable:!0}):e,i));var U=(i,r,e)=>Ge(i,typeof r!="symbol"?r+"":r,e);function Q(i){return i!==null&&typeof i=="object"&&"name"in i&&i.name==="ShipError"&&"status"in i}function B(i){let r=i.lastIndexOf(".");if(r===-1||r===i.length-1)return!1;let e=i.slice(r+1).toLowerCase();return Je.has(e)}function ge(i){return We.test(i)}function k(i){return i.replace(/\\/g,"/").split("/").filter(Boolean).some(e=>Xe.has(e))}function dt(i){if(!i.startsWith(I))throw m.validation(`API key must start with "${I}"`);if(i.length!==me)throw m.validation(`API key must be ${me} characters total (${I} + ${W} hex chars)`);let r=i.slice(I.length);if(!/^[a-f0-9]{64}$/i.test(r))throw m.validation(`API key must contain ${W} hexadecimal characters after "${I}" prefix`)}function mt(i){if(!i.startsWith(F))throw m.validation(`Deploy token must start with "${F}"`);if(i.length!==ye)throw m.validation(`Deploy token must be ${ye} characters total (${F} + ${X} hex chars)`);let r=i.slice(F.length);if(!/^[a-f0-9]{64}$/i.test(r))throw m.validation(`Deploy token must contain ${X} hexadecimal characters after "${F}" prefix`)}function yt(i){try{let r=new URL(i);if(!["http:","https:"].includes(r.protocol))throw m.validation("API URL must use http:// or https:// protocol");if(r.pathname!=="/"&&r.pathname!=="")throw m.validation("API URL must not contain a path");if(r.search||r.hash)throw m.validation("API URL must not contain query parameters or fragments")}catch(r){throw Q(r)?r:m.validation("API URL must be a valid URL")}}function gt(i){return/^[a-z]+-[a-z]+-[a-z0-9]{7}(\.[a-z0-9.-]+)?$/i.test(i)}function Ae(i,r){return i.endsWith(`.${r}`)}function At(i,r){return!Ae(i,r)}function Dt(i,r){return Ae(i,r)?i.slice(0,-(r.length+1)):null}function St(i){return`https://${i}`}function bt(i){return`https://${i}`}function wt(i){return!i||i.length===0?null:JSON.stringify(i)}function Rt(i){if(!i)return[];try{let r=JSON.parse(i);return Array.isArray(r)?r:[]}catch{return[]}}var pt,ut,ct,S,J,m,Je,We,Xe,I,W,me,ft,F,X,ye,ht,Z,M,E,Et,vt,w=R(()=>{"use strict";pt={PENDING:"pending",SUCCESS:"success",FAILED:"failed",DELETING:"deleting"},ut={PENDING:"pending",PARTIAL:"partial",SUCCESS:"success",PAUSED:"paused"},ct={FREE:"free",STANDARD:"standard",SPONSORED:"sponsored",ENTERPRISE:"enterprise",SUSPENDED:"suspended",TERMINATING:"terminating",TERMINATED:"terminated"};(function(i){i.Validation="validation_failed",i.NotFound="not_found",i.RateLimit="rate_limit_exceeded",i.Authentication="authentication_failed",i.Business="business_logic_error",i.Api="internal_server_error",i.Network="network_error",i.Cancelled="operation_cancelled",i.File="file_error",i.Config="config_error"})(S||(S={}));J={client:new Set([S.Business,S.Config,S.File,S.Validation]),network:new Set([S.Network]),auth:new Set([S.Authentication])},m=class i extends Error{constructor(e,a,u,f){super(a);U(this,"type");U(this,"status");U(this,"details");this.type=e,this.status=u,this.details=f,this.name="ShipError"}toResponse(){let e=this.type===S.Authentication&&this.details?.internal?void 0:this.details;return{error:this.type,message:this.message,status:this.status,details:e}}static fromResponse(e){return new i(e.error,e.message,e.status,e.details)}static validation(e,a){return new i(S.Validation,e,400,a)}static notFound(e,a){let u=a?`${e} ${a} not found`:`${e} not found`;return new i(S.NotFound,u,404)}static rateLimit(e="Too many requests"){return new i(S.RateLimit,e,429)}static authentication(e="Authentication required",a){return new i(S.Authentication,e,401,a)}static business(e,a=400){return new i(S.Business,e,a)}static network(e,a){return new i(S.Network,e,void 0,{cause:a})}static cancelled(e){return new i(S.Cancelled,e)}static file(e,a){return new i(S.File,e,void 0,{filePath:a})}static config(e,a){return new i(S.Config,e,void 0,a)}static api(e,a=500){return new i(S.Api,e,a)}static database(e,a=500){return new i(S.Api,e,a)}static storage(e,a=500){return new i(S.Api,e,a)}get filePath(){return this.details?.filePath}isClientError(){return J.client.has(this.type)}isNetworkError(){return J.network.has(this.type)}isAuthError(){return J.auth.has(this.type)}isValidationError(){return this.type===S.Validation}isFileError(){return this.type===S.File}isConfigError(){return this.type===S.Config}isType(e){return this.type===e}};Je=new Set(["exe","msi","dll","scr","bat","cmd","com","pif","app","deb","rpm","pkg","mpkg","dmg","iso","img","cab","cpl","chm","ps1","vbs","vbe","ws","wsf","wsc","wsh","reg","jar","jnlp","apk","crx","lnk","inf","hta"]);We=/[\x00-\x1f\x7f#?%\\<>"]/;Xe=new Set(["node_modules","package.json"]);I="ship-",W=64,me=I.length+W,ft=4,F="token-",X=64,ye=F.length+X,ht={JWT:"jwt",API_KEY:"apiKey",TOKEN:"token",WEBHOOK:"webhook",SYSTEM:"system"},Z="ship.json";M="https://api.shipstatic.com",E={PENDING:"pending",PROCESSING_ERROR:"processing_error",EXCLUDED:"excluded",VALIDATION_FAILED:"validation_failed",READY:"ready"};Et={MIN_LENGTH:3,MAX_LENGTH:25,MAX_COUNT:10,SEPARATORS:"._-"},vt=/^[a-z0-9]+(?:[._-][a-z0-9]+)*$/});function te(i){ee=i}function _(){if(ee===null)throw m.config("Platform configuration not initialized. The SDK must fetch configuration from the API before performing operations.");return ee}var ee,O=R(()=>{"use strict";w();ee=null});function Lt(i){ne=i}function Ze(){return typeof process<"u"&&process.versions&&process.versions.node?"node":typeof window<"u"||typeof self<"u"?"browser":"unknown"}function H(){return ne||Ze()}var ne,V=R(()=>{"use strict";ne=null});var ve=de((be,Ee)=>{"use strict";(function(i){if(typeof be=="object")Ee.exports=i();else if(typeof define=="function"&&define.amd)define(i);else{var r;try{r=window}catch{r=self}r.SparkMD5=i()}})(function(i){"use strict";var r=function(p,l){return p+l&4294967295},e=["0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"];function a(p,l,n,t,s,o){return l=r(r(l,p),r(t,o)),r(l<<s|l>>>32-s,n)}function u(p,l){var n=p[0],t=p[1],s=p[2],o=p[3];n+=(t&s|~t&o)+l[0]-680876936|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[1]-389564586|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[2]+606105819|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[3]-1044525330|0,t=(t<<22|t>>>10)+s|0,n+=(t&s|~t&o)+l[4]-176418897|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[5]+1200080426|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[6]-1473231341|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[7]-45705983|0,t=(t<<22|t>>>10)+s|0,n+=(t&s|~t&o)+l[8]+1770035416|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[9]-1958414417|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[10]-42063|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[11]-1990404162|0,t=(t<<22|t>>>10)+s|0,n+=(t&s|~t&o)+l[12]+1804603682|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[13]-40341101|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[14]-1502002290|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[15]+1236535329|0,t=(t<<22|t>>>10)+s|0,n+=(t&o|s&~o)+l[1]-165796510|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[6]-1069501632|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[11]+643717713|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[0]-373897302|0,t=(t<<20|t>>>12)+s|0,n+=(t&o|s&~o)+l[5]-701558691|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[10]+38016083|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[15]-660478335|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[4]-405537848|0,t=(t<<20|t>>>12)+s|0,n+=(t&o|s&~o)+l[9]+568446438|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[14]-1019803690|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[3]-187363961|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[8]+1163531501|0,t=(t<<20|t>>>12)+s|0,n+=(t&o|s&~o)+l[13]-1444681467|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[2]-51403784|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[7]+1735328473|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[12]-1926607734|0,t=(t<<20|t>>>12)+s|0,n+=(t^s^o)+l[5]-378558|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[8]-2022574463|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[11]+1839030562|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[14]-35309556|0,t=(t<<23|t>>>9)+s|0,n+=(t^s^o)+l[1]-1530992060|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[4]+1272893353|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[7]-155497632|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[10]-1094730640|0,t=(t<<23|t>>>9)+s|0,n+=(t^s^o)+l[13]+681279174|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[0]-358537222|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[3]-722521979|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[6]+76029189|0,t=(t<<23|t>>>9)+s|0,n+=(t^s^o)+l[9]-640364487|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[12]-421815835|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[15]+530742520|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[2]-995338651|0,t=(t<<23|t>>>9)+s|0,n+=(s^(t|~o))+l[0]-198630844|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[7]+1126891415|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[14]-1416354905|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[5]-57434055|0,t=(t<<21|t>>>11)+s|0,n+=(s^(t|~o))+l[12]+1700485571|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[3]-1894986606|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[10]-1051523|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[1]-2054922799|0,t=(t<<21|t>>>11)+s|0,n+=(s^(t|~o))+l[8]+1873313359|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[15]-30611744|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[6]-1560198380|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[13]+1309151649|0,t=(t<<21|t>>>11)+s|0,n+=(s^(t|~o))+l[4]-145523070|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[11]-1120210379|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[2]+718787259|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[9]-343485551|0,t=(t<<21|t>>>11)+s|0,p[0]=n+p[0]|0,p[1]=t+p[1]|0,p[2]=s+p[2]|0,p[3]=o+p[3]|0}function f(p){var l=[],n;for(n=0;n<64;n+=4)l[n>>2]=p.charCodeAt(n)+(p.charCodeAt(n+1)<<8)+(p.charCodeAt(n+2)<<16)+(p.charCodeAt(n+3)<<24);return l}function h(p){var l=[],n;for(n=0;n<64;n+=4)l[n>>2]=p[n]+(p[n+1]<<8)+(p[n+2]<<16)+(p[n+3]<<24);return l}function y(p){var l=p.length,n=[1732584193,-271733879,-1732584194,271733878],t,s,o,v,C,T;for(t=64;t<=l;t+=64)u(n,f(p.substring(t-64,t)));for(p=p.substring(t-64),s=p.length,o=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],t=0;t<s;t+=1)o[t>>2]|=p.charCodeAt(t)<<(t%4<<3);if(o[t>>2]|=128<<(t%4<<3),t>55)for(u(n,o),t=0;t<16;t+=1)o[t]=0;return v=l*8,v=v.toString(16).match(/(.*?)(.{0,8})$/),C=parseInt(v[2],16),T=parseInt(v[1],16)||0,o[14]=C,o[15]=T,u(n,o),n}function c(p){var l=p.length,n=[1732584193,-271733879,-1732584194,271733878],t,s,o,v,C,T;for(t=64;t<=l;t+=64)u(n,h(p.subarray(t-64,t)));for(p=t-64<l?p.subarray(t-64):new Uint8Array(0),s=p.length,o=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],t=0;t<s;t+=1)o[t>>2]|=p[t]<<(t%4<<3);if(o[t>>2]|=128<<(t%4<<3),t>55)for(u(n,o),t=0;t<16;t+=1)o[t]=0;return v=l*8,v=v.toString(16).match(/(.*?)(.{0,8})$/),C=parseInt(v[2],16),T=parseInt(v[1],16)||0,o[14]=C,o[15]=T,u(n,o),n}function g(p){var l="",n;for(n=0;n<4;n+=1)l+=e[p>>n*8+4&15]+e[p>>n*8&15];return l}function d(p){var l;for(l=0;l<p.length;l+=1)p[l]=g(p[l]);return p.join("")}d(y("hello"))!=="5d41402abc4b2a76b9719d911017c592"&&(r=function(p,l){var n=(p&65535)+(l&65535),t=(p>>16)+(l>>16)+(n>>16);return t<<16|n&65535}),typeof ArrayBuffer<"u"&&!ArrayBuffer.prototype.slice&&(function(){function p(l,n){return l=l|0||0,l<0?Math.max(l+n,0):Math.min(l,n)}ArrayBuffer.prototype.slice=function(l,n){var t=this.byteLength,s=p(l,t),o=t,v,C,T,he;return n!==i&&(o=p(n,t)),s>o?new ArrayBuffer(0):(v=o-s,C=new ArrayBuffer(v),T=new Uint8Array(C),he=new Uint8Array(this,s,v),T.set(he),C)}})();function A(p){return/[\u0080-\uFFFF]/.test(p)&&(p=unescape(encodeURIComponent(p))),p}function x(p,l){var n=p.length,t=new ArrayBuffer(n),s=new Uint8Array(t),o;for(o=0;o<n;o+=1)s[o]=p.charCodeAt(o);return l?s:t}function P(p){return String.fromCharCode.apply(null,new Uint8Array(p))}function Me(p,l,n){var t=new Uint8Array(p.byteLength+l.byteLength);return t.set(new Uint8Array(p)),t.set(new Uint8Array(l),p.byteLength),n?t:t.buffer}function N(p){var l=[],n=p.length,t;for(t=0;t<n-1;t+=2)l.push(parseInt(p.substr(t,2),16));return String.fromCharCode.apply(String,l)}function D(){this.reset()}return D.prototype.append=function(p){return this.appendBinary(A(p)),this},D.prototype.appendBinary=function(p){this._buff+=p,this._length+=p.length;var l=this._buff.length,n;for(n=64;n<=l;n+=64)u(this._hash,f(this._buff.substring(n-64,n)));return this._buff=this._buff.substring(n-64),this},D.prototype.end=function(p){var l=this._buff,n=l.length,t,s=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],o;for(t=0;t<n;t+=1)s[t>>2]|=l.charCodeAt(t)<<(t%4<<3);return this._finish(s,n),o=d(this._hash),p&&(o=N(o)),this.reset(),o},D.prototype.reset=function(){return this._buff="",this._length=0,this._hash=[1732584193,-271733879,-1732584194,271733878],this},D.prototype.getState=function(){return{buff:this._buff,length:this._length,hash:this._hash.slice()}},D.prototype.setState=function(p){return this._buff=p.buff,this._length=p.length,this._hash=p.hash,this},D.prototype.destroy=function(){delete this._hash,delete this._buff,delete this._length},D.prototype._finish=function(p,l){var n=l,t,s,o;if(p[n>>2]|=128<<(n%4<<3),n>55)for(u(this._hash,p),n=0;n<16;n+=1)p[n]=0;t=this._length*8,t=t.toString(16).match(/(.*?)(.{0,8})$/),s=parseInt(t[2],16),o=parseInt(t[1],16)||0,p[14]=s,p[15]=o,u(this._hash,p)},D.hash=function(p,l){return D.hashBinary(A(p),l)},D.hashBinary=function(p,l){var n=y(p),t=d(n);return l?N(t):t},D.ArrayBuffer=function(){this.reset()},D.ArrayBuffer.prototype.append=function(p){var l=Me(this._buff.buffer,p,!0),n=l.length,t;for(this._length+=p.byteLength,t=64;t<=n;t+=64)u(this._hash,h(l.subarray(t-64,t)));return this._buff=t-64<n?new Uint8Array(l.buffer.slice(t-64)):new Uint8Array(0),this},D.ArrayBuffer.prototype.end=function(p){var l=this._buff,n=l.length,t=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],s,o;for(s=0;s<n;s+=1)t[s>>2]|=l[s]<<(s%4<<3);return this._finish(t,n),o=d(this._hash),p&&(o=N(o)),this.reset(),o},D.ArrayBuffer.prototype.reset=function(){return this._buff=new Uint8Array(0),this._length=0,this._hash=[1732584193,-271733879,-1732584194,271733878],this},D.ArrayBuffer.prototype.getState=function(){var p=D.prototype.getState.call(this);return p.buff=P(p.buff),p},D.ArrayBuffer.prototype.setState=function(p){return p.buff=x(p.buff,!0),D.prototype.setState.call(this,p)},D.ArrayBuffer.prototype.destroy=D.prototype.destroy,D.ArrayBuffer.prototype._finish=D.prototype._finish,D.ArrayBuffer.hash=function(p,l){var n=c(new Uint8Array(p)),t=d(n);return l?N(t):t},D})});var re=de((Bt,we)=>{"use strict";we.exports={}});async function et(i){let r=(await Promise.resolve().then(()=>Y(ve(),1))).default;return new Promise((e,a)=>{let f=Math.ceil(i.size/2097152),h=0,y=new r.ArrayBuffer,c=new FileReader,g=()=>{let d=h*2097152,A=Math.min(d+2097152,i.size);c.readAsArrayBuffer(i.slice(d,A))};c.onload=d=>{let A=d.target?.result;if(!A){a(m.business("Failed to read file chunk"));return}y.append(A),h++,h<f?g():e({md5:y.end()})},c.onerror=()=>{a(m.business("Failed to calculate MD5: FileReader error"))},g()})}async function tt(i){let r=await Promise.resolve().then(()=>Y(re(),1));if(Buffer.isBuffer(i)){let a=r.createHash("md5");return a.update(i),{md5:a.digest("hex")}}let e=await Promise.resolve().then(()=>Y(re(),1));return new Promise((a,u)=>{let f=r.createHash("md5"),h=e.createReadStream(i);h.on("error",y=>u(m.business(`Failed to read file for MD5: ${y.message}`))),h.on("data",y=>f.update(y)),h.on("end",()=>a({md5:f.digest("hex")}))})}async function $(i){let r=H();if(r==="browser"){if(!(i instanceof Blob))throw m.business("Invalid input for browser MD5 calculation: Expected Blob or File.");return et(i)}if(r==="node"){if(!(Buffer.isBuffer(i)||typeof i=="string"))throw m.business("Invalid input for Node.js MD5 calculation: Expected Buffer or file path string.");return tt(i)}throw m.business("Unknown or unsupported execution environment for MD5 calculation.")}var j=R(()=>{"use strict";V();w()});function Pe(i){return it.test(i)}var rt,it,_e=R(()=>{"use strict";rt=["^npm-debug\\.log$","^\\..*\\.swp$","^\\.DS_Store$","^\\.AppleDouble$","^\\.LSOverride$","^Icon\\r$","^\\._.*","^\\.Spotlight-V100(?:$|\\/)","\\.Trashes","^__MACOSX$","~$","^Thumbs\\.db$","^ehthumbs\\.db$","^[Dd]esktop\\.ini$","@eaDir$"],it=new RegExp(rt.join("|"))});function Oe(i,r){if(!i||i.length===0)return[];if(!r?.allowUnbuilt&&i.find(a=>a&&k(a)))throw m.business("Unbuilt project detected \u2014 deploy your build output (dist/, build/, out/), not the project folder");return i.filter(e=>{if(!e)return!1;let a=e.replace(/\\/g,"/").split("/").filter(Boolean);if(a.length===0)return!0;let u=a[a.length-1];if(Pe(u))return!1;for(let h of a)if(h!==".well-known"&&(h.startsWith(".")||h.length>255))return!1;let f=a.slice(0,-1);for(let h of f)if(ot.some(y=>h.toLowerCase()===y.toLowerCase()))return!1;return!0})}var ot,ie=R(()=>{"use strict";_e();w();ot=["__MACOSX",".Trashes",".fseventsd",".Spotlight-V100"]});function q(i){return i.replace(/\\/g,"/").replace(/\/+/g,"/").replace(/^\/+/,"")}var $e=R(()=>{"use strict"});function Ne(i,r={}){if(r.flatten===!1)return i.map(a=>({path:q(a),name:oe(a)}));let e=st(i);return i.map(a=>{let u=q(a);if(e){let f=e.endsWith("/")?e:`${e}/`;u.startsWith(f)&&(u=u.substring(f.length))}return u||(u=oe(a)),{path:u,name:oe(a)}})}function st(i){if(!i.length)return"";let e=i.map(f=>q(f)).map(f=>f.split("/")),a=[],u=Math.min(...e.map(f=>f.length));for(let f=0;f<u-1;f++){let h=e[0][f];if(e.every(y=>y[f]===h))a.push(h);else break}return a.join("/")}function oe(i){return i.split(/[/\\]/).pop()||i}var se=R(()=>{"use strict";$e()});function ae(i,r=1){if(i===0)return"0 Bytes";let e=1024,a=["Bytes","KB","MB","GB"],u=Math.floor(Math.log(i)/Math.log(e));return parseFloat((i/Math.pow(e,u)).toFixed(r))+" "+a[u]}function le(i){if(ge(i))return{valid:!1,reason:"File name contains unsafe characters"};if(i.startsWith(" ")||i.endsWith(" "))return{valid:!1,reason:"File name cannot start/end with spaces"};if(i.endsWith("."))return{valid:!1,reason:"File name cannot end with dots"};let r=/^(CON|PRN|AUX|NUL|COM[1-9]|LPT[1-9])(\.|$)/i,e=i.split("/").pop()||i;return r.test(e)?{valid:!1,reason:"File name uses a reserved system name"}:i.includes("..")?{valid:!1,reason:"File name contains path traversal pattern"}:{valid:!0}}function hn(i,r){let e=[],a=[],u=[];if(i.length===0){let c={file:"(no files)",message:"At least one file must be provided"};return e.push(c),{files:[],validFiles:[],errors:e,warnings:[],canDeploy:!1}}for(let c of i)if(k(c.name))return e.push({file:c.name,message:"Unbuilt project detected \u2014 deploy your build output (dist/, build/, out/), not the project folder"}),{files:i.map(g=>({...g,status:E.VALIDATION_FAILED,statusMessage:"Unbuilt project detected"})),validFiles:[],errors:e,warnings:[],canDeploy:!1};if(i.length>r.maxFilesCount){let c={file:`(${i.length} files)`,message:`File count (${i.length}) exceeds limit of ${r.maxFilesCount}`};return e.push(c),{files:i.map(g=>({...g,status:E.VALIDATION_FAILED,statusMessage:c.message})),validFiles:[],errors:e,warnings:[],canDeploy:!1}}let f=0;for(let c of i){let g=E.READY,d="Ready for upload",A=c.name?le(c.name):{valid:!1,reason:"File name cannot be empty"};if(c.status===E.PROCESSING_ERROR)g=E.VALIDATION_FAILED,d=c.statusMessage||"File failed during processing",e.push({file:c.name,message:d});else if(c.size===0){g=E.EXCLUDED,d="File is empty (0 bytes) and cannot be deployed due to storage limitations",a.push({file:c.name,message:d}),u.push({...c,status:g,statusMessage:d});continue}else c.size<0?(g=E.VALIDATION_FAILED,d="File size must be positive",e.push({file:c.name,message:d})):!c.name||c.name.trim().length===0?(g=E.VALIDATION_FAILED,d="File name cannot be empty",e.push({file:c.name||"(empty)",message:d})):c.name.includes("\0")?(g=E.VALIDATION_FAILED,d="File name contains invalid characters (null byte)",e.push({file:c.name,message:d})):A.valid?B(c.name)?(g=E.VALIDATION_FAILED,d=`File extension not allowed: "${c.name}"`,e.push({file:c.name,message:d})):c.size>r.maxFileSize?(g=E.VALIDATION_FAILED,d=`File size (${ae(c.size)}) exceeds limit of ${ae(r.maxFileSize)}`,e.push({file:c.name,message:d})):(f+=c.size,f>r.maxTotalSize&&(g=E.VALIDATION_FAILED,d=`Total size would exceed limit of ${ae(r.maxTotalSize)}`,e.push({file:c.name,message:d}))):(g=E.VALIDATION_FAILED,d=A.reason||"Invalid file name",e.push({file:c.name,message:d}));u.push({...c,status:g,statusMessage:d})}e.length>0&&(u=u.map(c=>c.status===E.EXCLUDED?c:{...c,status:E.VALIDATION_FAILED,statusMessage:c.status===E.VALIDATION_FAILED?c.statusMessage:"Deployment failed due to validation errors in bundle"}));let h=e.length===0?u.filter(c=>c.status===E.READY):[],y=e.length===0;return{files:u,validFiles:h,errors:e,warnings:a,canDeploy:y}}function at(i){return i.filter(r=>r.status===E.READY)}function dn(i){return at(i).length>0}var pe=R(()=>{"use strict";w()});function Le(i,r){if(i.includes("\0")||i.includes("/../")||i.startsWith("../")||i.endsWith("/.."))throw m.business(`Security error: Unsafe file path "${i}" for file: ${r}`)}function Ue(i,r){let e=le(i);if(!e.valid)throw m.business(e.reason||"Invalid file name");if(B(i))throw m.business(`File extension not allowed: "${r}"`)}var ue=R(()=>{"use strict";w();pe()});var ke={};qe(ke,{processFilesForBrowser:()=>Be});async function Be(i,r={}){if(H()!=="browser")throw m.business("processFilesForBrowser can only be called in a browser environment.");let e=i.map(d=>d.webkitRelativePath||d.name),a=r.build||r.prerender,u=new Set(Oe(e,{allowUnbuilt:a})),f=[];for(let d=0;d<i.length;d++)u.has(e[d])&&f.push({file:i[d],rawPath:e[d]});if(f.length===0)return[];let h=Ne(f.map(d=>d.rawPath),{flatten:r.pathDetect!==!1});if(a){let d=[];for(let A=0;A<f.length;A++){let{file:x}=f[A];if(x.size===0)continue;let{md5:P}=await $(x);d.push({path:h[A].path,content:x,size:x.size,md5:P})}return d}let y=_(),c=[],g=0;for(let d=0;d<f.length;d++){let{file:A}=f[d],x=h[d].path;if(Le(x,A.name),A.size===0)continue;if(Ue(x,A.name),A.size>y.maxFileSize)throw m.business(`File ${A.name} is too large. Maximum allowed size is ${y.maxFileSize/(1024*1024)}MB.`);if(g+=A.size,g>y.maxTotalSize)throw m.business(`Total deploy size is too large. Maximum allowed is ${y.maxTotalSize/(1024*1024)}MB.`);let{md5:P}=await $(A);c.push({path:x,content:A,size:A.size,md5:P})}if(c.length>y.maxFilesCount)throw m.business(`Too many files to deploy. Maximum allowed is ${y.maxFilesCount} files.`);return c}var ce=R(()=>{"use strict";j();w();V();ie();se();ue();O()});w();var z=class{constructor(){this.handlers=new Map}on(r,e){this.handlers.has(r)||this.handlers.set(r,new Set),this.handlers.get(r).add(e)}off(r,e){let a=this.handlers.get(r);a&&(a.delete(e),a.size===0&&this.handlers.delete(r))}emit(r,...e){let a=this.handlers.get(r);if(!a)return;let u=Array.from(a);for(let f of u)try{f(...e)}catch(h){a.delete(f),r!=="error"&&setTimeout(()=>{h instanceof Error?this.emit("error",h,String(r)):this.emit("error",new Error(String(h)),String(r))},0)}}transfer(r){this.handlers.forEach((e,a)=>{e.forEach(u=>{r.on(a,u)})})}clear(){this.handlers.clear()}};var b={DEPLOYMENTS:"/deployments",DOMAINS:"/domains",TOKENS:"/tokens",ACCOUNT:"/account",CONFIG:"/config",PING:"/ping",SPA_CHECK:"/spa-check"},Qe=3e4,K=class extends z{constructor(e){super();this.globalHeaders={};this.apiUrl=e.apiUrl||M,this.getAuthHeadersCallback=e.getAuthHeaders,this.useCredentials=e.useCredentials??!1,this.timeout=e.timeout??Qe,this.createDeployBody=e.createDeployBody,this.deployEndpoint=e.deployEndpoint||b.DEPLOYMENTS}setGlobalHeaders(e){this.globalHeaders=e}transferEventsTo(e){this.transfer(e)}async executeRequest(e,a,u){let f=this.mergeHeaders(a.headers),{signal:h,cleanup:y}=this.createTimeoutSignal(a.signal),c={...a,headers:f,credentials:this.useCredentials&&!f.Authorization?"include":void 0,signal:h};this.emit("request",e,c);try{let g=await fetch(e,c);return y(),g.ok||await this.handleResponseError(g,u),this.emit("response",this.safeClone(g),e),{data:await this.parseResponse(this.safeClone(g)),status:g.status}}catch(g){y();let d=g instanceof Error?g:new Error(String(g));this.emit("error",d,e),this.handleFetchError(g,u)}}async request(e,a,u){let{data:f}=await this.executeRequest(e,a,u);return f}async requestWithStatus(e,a,u){return this.executeRequest(e,a,u)}mergeHeaders(e={}){return{...this.globalHeaders,...this.getAuthHeadersCallback(),...e}}createTimeoutSignal(e){let a=new AbortController,u=setTimeout(()=>a.abort(),this.timeout);if(e){let f=()=>a.abort();e.addEventListener("abort",f),e.aborted&&a.abort()}return{signal:a.signal,cleanup:()=>clearTimeout(u)}}safeClone(e){try{return e.clone()}catch{return e}}async parseResponse(e){if(!(e.headers.get("Content-Length")==="0"||e.status===204))return e.json()}async handleResponseError(e,a){let u={};try{if(e.headers.get("content-type")?.includes("application/json")){let y=await e.json();if(y&&typeof y=="object"){let c=y;typeof c.message=="string"&&(u.message=c.message),typeof c.error=="string"&&(u.error=c.error)}}else u={message:await e.text()}}catch{u={message:"Failed to parse error response"}}let f=u.message||u.error||`${a} failed`;throw e.status===401?m.authentication(f):m.api(f,e.status)}handleFetchError(e,a){throw Q(e)?e:e instanceof Error&&e.name==="AbortError"?m.cancelled(`${a} was cancelled`):e instanceof TypeError&&e.message.includes("fetch")?m.network(`${a} failed: ${e.message}`,e):e instanceof Error?m.business(`${a} failed: ${e.message}`):m.business(`${a} failed: Unknown error`)}async deploy(e,a={}){if(!e.length)throw m.business("No files to deploy");for(let c of e)if(!c.md5)throw m.file(`MD5 checksum missing for file: ${c.path}`,c.path);let u=a.build||a.prerender?{build:a.build,prerender:a.prerender}:void 0,{body:f,headers:h}=await this.createDeployBody(e,a.labels,a.via,u),y={};return a.deployToken?y.Authorization=`Bearer ${a.deployToken}`:a.apiKey&&(y.Authorization=`Bearer ${a.apiKey}`),a.caller&&(y["X-Caller"]=a.caller),this.request(`${a.apiUrl||this.apiUrl}${this.deployEndpoint}`,{method:"POST",body:f,headers:{...h,...y},signal:a.signal||null},"Deploy")}async listDeployments(){return this.request(`${this.apiUrl}${b.DEPLOYMENTS}`,{method:"GET"},"List deployments")}async getDeployment(e){return this.request(`${this.apiUrl}${b.DEPLOYMENTS}/${encodeURIComponent(e)}`,{method:"GET"},"Get deployment")}async updateDeploymentLabels(e,a){return this.request(`${this.apiUrl}${b.DEPLOYMENTS}/${encodeURIComponent(e)}`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({labels:a})},"Update deployment labels")}async removeDeployment(e){await this.request(`${this.apiUrl}${b.DEPLOYMENTS}/${encodeURIComponent(e)}`,{method:"DELETE"},"Remove deployment")}async setDomain(e,a,u){let f={};a&&(f.deployment=a),u!==void 0&&(f.labels=u);let{data:h,status:y}=await this.requestWithStatus(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(f)},"Set domain");return{...h,isCreate:y===201}}async listDomains(){return this.request(`${this.apiUrl}${b.DOMAINS}`,{method:"GET"},"List domains")}async getDomain(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}`,{method:"GET"},"Get domain")}async removeDomain(e){await this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}`,{method:"DELETE"},"Remove domain")}async verifyDomain(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/verify`,{method:"POST"},"Verify domain")}async getDomainDns(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/dns`,{method:"GET"},"Get domain DNS")}async getDomainRecords(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/records`,{method:"GET"},"Get domain records")}async getDomainShare(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/share`,{method:"GET"},"Get domain share")}async validateDomain(e){return this.request(`${this.apiUrl}${b.DOMAINS}/validate`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:e})},"Validate domain")}async createToken(e,a){let u={};return e!==void 0&&(u.ttl=e),a!==void 0&&(u.labels=a),this.request(`${this.apiUrl}${b.TOKENS}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(u)},"Create token")}async listTokens(){return this.request(`${this.apiUrl}${b.TOKENS}`,{method:"GET"},"List tokens")}async removeToken(e){await this.request(`${this.apiUrl}${b.TOKENS}/${encodeURIComponent(e)}`,{method:"DELETE"},"Remove token")}async getAccount(){return this.request(`${this.apiUrl}${b.ACCOUNT}`,{method:"GET"},"Get account")}async getConfig(){return this.request(`${this.apiUrl}${b.CONFIG}`,{method:"GET"},"Get config")}async ping(){return(await this.request(`${this.apiUrl}${b.PING}`,{method:"GET"},"Ping"))?.success||!1}async checkSPA(e,a={}){let u=e.find(g=>g.path==="index.html"||g.path==="/index.html");if(!u||u.size>100*1024)return!1;let f;if(typeof Buffer<"u"&&Buffer.isBuffer(u.content))f=u.content.toString("utf-8");else if(typeof Blob<"u"&&u.content instanceof Blob)f=await u.content.text();else if(typeof File<"u"&&u.content instanceof File)f=await u.content.text();else return!1;let h={"Content-Type":"application/json"};a.deployToken?h.Authorization=`Bearer ${a.deployToken}`:a.apiKey&&(h.Authorization=`Bearer ${a.apiKey}`);let y={files:e.map(g=>g.path),index:f};return(await this.request(`${this.apiUrl}${b.SPA_CHECK}`,{method:"POST",headers:h,body:JSON.stringify(y)},"SPA check")).isSPA}};w();O();w();w();function De(i={},r={}){let e={apiUrl:i.apiUrl||r.apiUrl||M,apiKey:i.apiKey!==void 0?i.apiKey:r.apiKey,deployToken:i.deployToken!==void 0?i.deployToken:r.deployToken},a={apiUrl:e.apiUrl};return e.apiKey!==void 0&&(a.apiKey=e.apiKey),e.deployToken!==void 0&&(a.deployToken=e.deployToken),a}function Se(i,r){let e={...i};return e.apiUrl===void 0&&r.apiUrl!==void 0&&(e.apiUrl=r.apiUrl),e.apiKey===void 0&&r.apiKey!==void 0&&(e.apiKey=r.apiKey),e.deployToken===void 0&&r.deployToken!==void 0&&(e.deployToken=r.deployToken),e.timeout===void 0&&r.timeout!==void 0&&(e.timeout=r.timeout),e.maxConcurrency===void 0&&r.maxConcurrency!==void 0&&(e.maxConcurrency=r.maxConcurrency),e.onProgress===void 0&&r.onProgress!==void 0&&(e.onProgress=r.onProgress),e.caller===void 0&&r.caller!==void 0&&(e.caller=r.caller),e}w();j();async function nt(){let r=JSON.stringify({rewrites:[{source:"/(.*)",destination:"/index.html"}]},null,2),e;typeof Buffer<"u"?e=Buffer.from(r,"utf-8"):e=new Blob([r],{type:"application/json"});let{md5:a}=await $(e);return{path:Z,content:e,size:r.length,md5:a}}async function Re(i,r,e){if(e.spaDetect===!1||e.build||e.prerender||i.some(a=>a.path===Z))return i;try{if(await r.checkSPA(i,e)){let u=await nt();return[...i,u]}}catch{}return i}function xe(i){let{getApi:r,ensureInit:e,processInput:a,clientDefaults:u,hasAuth:f}=i;return{upload:async(h,y={})=>{await e();let c=u?Se(y,u):y;if(f&&!f()&&!c.deployToken&&!c.apiKey)throw m.authentication("Authentication credentials are required for deployment. Please call setDeployToken() or setApiKey() first, or pass credentials in the deployment options.");if(!a)throw m.config("processInput function is not provided.");let g=r(),d=await a(h,c);return d=await Re(d,g,c),g.deploy(d,c)},list:async()=>(await e(),r().listDeployments()),get:async h=>(await e(),r().getDeployment(h)),set:async(h,y)=>(await e(),r().updateDeploymentLabels(h,y.labels)),remove:async h=>{await e(),await r().removeDeployment(h)}}}function Ce(i){let{getApi:r,ensureInit:e}=i;return{set:async(a,u={})=>(await e(),r().setDomain(a,u.deployment,u.labels)),list:async()=>(await e(),r().listDomains()),get:async a=>(await e(),r().getDomain(a)),remove:async a=>{await e(),await r().removeDomain(a)},verify:async a=>(await e(),r().verifyDomain(a)),validate:async a=>(await e(),r().validateDomain(a)),dns:async a=>(await e(),r().getDomainDns(a)),records:async a=>(await e(),r().getDomainRecords(a)),share:async a=>(await e(),r().getDomainShare(a))}}function Te(i){let{getApi:r,ensureInit:e}=i;return{get:async()=>(await e(),r().getAccount())}}function Ie(i){let{getApi:r,ensureInit:e}=i;return{create:async(a={})=>(await e(),r().createToken(a.ttl,a.labels)),list:async()=>(await e(),r().listTokens()),remove:async a=>{await e(),await r().removeToken(a)}}}var G=class{constructor(r={}){this.initPromise=null;this._config=null;this.auth=null;this.customHeaders={};this.clientOptions=r,r.deployToken?this.auth={type:"token",value:r.deployToken}:r.apiKey&&(this.auth={type:"apiKey",value:r.apiKey}),this.authHeadersCallback=()=>this.getAuthHeaders();let e=this.resolveInitialConfig(r);this.http=new K({...r,...e,getAuthHeaders:this.authHeadersCallback,createDeployBody:this.getDeployBodyCreator()});let a={getApi:()=>this.http,ensureInit:()=>this.ensureInitialized()};this._deployments=xe({...a,processInput:(u,f)=>this.processInput(u,f),clientDefaults:this.clientOptions,hasAuth:()=>this.hasAuth()}),this._domains=Ce(a),this._account=Te(a),this._tokens=Ie(a)}async ensureInitialized(){return this.initPromise||(this.initPromise=this.loadFullConfig()),this.initPromise}async ping(){return await this.ensureInitialized(),this.http.ping()}async deploy(r,e){return this.deployments.upload(r,e)}async whoami(){return this.account.get()}get deployments(){return this._deployments}get domains(){return this._domains}get account(){return this._account}get tokens(){return this._tokens}async getConfig(){return this._config?this._config:(await this.ensureInitialized(),this._config=_(),this._config)}on(r,e){this.http.on(r,e)}off(r,e){this.http.off(r,e)}setHeaders(r){this.customHeaders=r,this.http.setGlobalHeaders(r)}clearHeaders(){this.customHeaders={},this.http.setGlobalHeaders({})}replaceHttpClient(r){if(this.http?.transferEventsTo)try{this.http.transferEventsTo(r)}catch(e){console.warn("Event transfer failed during client replacement:",e)}this.http=r,Object.keys(this.customHeaders).length>0&&this.http.setGlobalHeaders(this.customHeaders)}setDeployToken(r){if(!r||typeof r!="string")throw m.business("Invalid deploy token provided. Deploy token must be a non-empty string.");this.auth={type:"token",value:r}}setApiKey(r){if(!r||typeof r!="string")throw m.business("Invalid API key provided. API key must be a non-empty string.");this.auth={type:"apiKey",value:r}}getAuthHeaders(){return this.auth?{Authorization:`Bearer ${this.auth.value}`}:{}}hasAuth(){return this.clientOptions.useCredentials?!0:this.auth!==null}};O();w();w();async function Fe(i,r,e,a){let u=new FormData,f=[];for(let h of i){if(!(h.content instanceof File||h.content instanceof Blob))throw m.file(`Unsupported file.content type for browser: ${h.path}`,h.path);if(!h.md5)throw m.file(`File missing md5 checksum: ${h.path}`,h.path);let y=new File([h.content],h.path,{type:"application/octet-stream"});u.append("files[]",y),f.push(h.md5)}return u.append("checksums",JSON.stringify(f)),r&&r.length>0&&u.append("labels",JSON.stringify(r)),e&&u.append("via",e),a?.build&&u.append("build","true"),a?.prerender&&u.append("prerender","true"),{body:u,headers:{}}}j();function nn(i,r,e,a=!0){let u=i===1?r:e;return a?`${i} ${u}`:u}ie();se();V();pe();ue();w();O();ce();var fe=class extends G{constructor(r={}){super(r)}resolveInitialConfig(r){return De(r,{})}async loadFullConfig(){try{let r=await this.http.getConfig();te(r)}catch(r){throw this.initPromise=null,r}}async processInput(r,e){if(!this.isFileArray(r))throw m.business("Invalid input type for browser environment. Expected File[].");if(r.length===0)throw m.business("No files to deploy.");let{processFilesForBrowser:a}=await Promise.resolve().then(()=>(ce(),ke));return a(r,e)}isFileArray(r){return Array.isArray(r)&&r.every(e=>e instanceof File)}getDeployBodyCreator(){return Fe}},jn=fe;export{W as API_KEY_HEX_LENGTH,ft as API_KEY_HINT_LENGTH,I as API_KEY_PREFIX,me as API_KEY_TOTAL_LENGTH,ct as AccountPlan,K as ApiHttp,ht as AuthMethod,Je as BLOCKED_EXTENSIONS,M as DEFAULT_API,Z as DEPLOYMENT_CONFIG_FILENAME,X as DEPLOY_TOKEN_HEX_LENGTH,F as DEPLOY_TOKEN_PREFIX,ye as DEPLOY_TOKEN_TOTAL_LENGTH,pt as DeploymentStatus,ut as DomainStatus,S as ErrorType,E as FILE_VALIDATION_STATUS,E as FileValidationStatus,ot as JUNK_DIRECTORIES,Et as LABEL_CONSTRAINTS,vt as LABEL_PATTERN,fe as Ship,m as ShipError,Xe as UNBUILT_PROJECT_MARKERS,We as UNSAFE_FILENAME_CHARS,Lt as __setTestEnvironment,dn as allValidFilesReady,$ as calculateMD5,Te as createAccountResource,xe as createDeploymentResource,Ce as createDomainResource,Ie as createTokenResource,jn as default,Rt as deserializeLabels,Dt as extractSubdomain,Oe as filterJunk,ae as formatFileSize,St as generateDeploymentUrl,bt as generateDomainUrl,_ as getCurrentConfig,H as getENV,at as getValidFiles,k as hasUnbuiltMarker,ge as hasUnsafeChars,B as isBlockedExtension,At as isCustomDomain,gt as isDeployment,Ae as isPlatformDomain,Q as isShipError,Se as mergeDeployOptions,Ne as optimizeDeployPaths,nn as pluralize,Be as processFilesForBrowser,De as resolveConfig,wt as serializeLabels,te as setPlatformConfig,dt as validateApiKey,yt as validateApiUrl,Ue as validateDeployFile,Le as validateDeployPath,mt as validateDeployToken,le as validateFileName,hn as validateFiles};
1
+ var ze=Object.create;var U=Object.defineProperty;var Ke=Object.getOwnPropertyDescriptor;var He=Object.getOwnPropertyNames;var Ve=Object.getPrototypeOf,je=Object.prototype.hasOwnProperty;var Ge=(i,r,e)=>r in i?U(i,r,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[r]=e;var C=(i,r)=>()=>(i&&(r=i(i=0)),r);var de=(i,r)=>()=>(r||i((r={exports:{}}).exports,r),r.exports),qe=(i,r)=>{for(var e in r)U(i,e,{get:r[e],enumerable:!0})},Ye=(i,r,e,a)=>{if(r&&typeof r=="object"||typeof r=="function")for(let u of He(r))!je.call(i,u)&&u!==e&&U(i,u,{get:()=>r[u],enumerable:!(a=Ke(r,u))||a.enumerable});return i};var Y=(i,r,e)=>(e=i!=null?ze(Ve(i)):{},Ye(r||!i||!i.__esModule?U(e,"default",{value:i,enumerable:!0}):e,i));var L=(i,r,e)=>Ge(i,typeof r!="symbol"?r+"":r,e);function Q(i){return i!==null&&typeof i=="object"&&"name"in i&&i.name==="ShipError"&&"status"in i}function B(i){let r=i.lastIndexOf(".");if(r===-1||r===i.length-1)return!1;let e=i.slice(r+1).toLowerCase();return Je.has(e)}function ge(i){return We.test(i)}function k(i){return i.replace(/\\/g,"/").split("/").filter(Boolean).some(e=>Xe.has(e))}function dt(i){if(!i.startsWith(I))throw m.validation(`API key must start with "${I}"`);if(i.length!==me)throw m.validation(`API key must be ${me} characters total (${I} + ${W} hex chars)`);let r=i.slice(I.length);if(!/^[a-f0-9]{64}$/i.test(r))throw m.validation(`API key must contain ${W} hexadecimal characters after "${I}" prefix`)}function mt(i){if(!i.startsWith(F))throw m.validation(`Deploy token must start with "${F}"`);if(i.length!==ye)throw m.validation(`Deploy token must be ${ye} characters total (${F} + ${X} hex chars)`);let r=i.slice(F.length);if(!/^[a-f0-9]{64}$/i.test(r))throw m.validation(`Deploy token must contain ${X} hexadecimal characters after "${F}" prefix`)}function yt(i){try{let r=new URL(i);if(!["http:","https:"].includes(r.protocol))throw m.validation("API URL must use http:// or https:// protocol");if(r.pathname!=="/"&&r.pathname!=="")throw m.validation("API URL must not contain a path");if(r.search||r.hash)throw m.validation("API URL must not contain query parameters or fragments")}catch(r){throw Q(r)?r:m.validation("API URL must be a valid URL")}}function gt(i){return/^[a-z]+-[a-z]+-[a-z0-9]{7}(\.[a-z0-9.-]+)?$/i.test(i)}function Ae(i,r){return i.endsWith(`.${r}`)}function At(i,r){return!Ae(i,r)}function Dt(i,r){return Ae(i,r)?i.slice(0,-(r.length+1)):null}function St(i){return`https://${i}`}function bt(i){return`https://${i}`}function wt(i){return!i||i.length===0?null:JSON.stringify(i)}function Rt(i){if(!i)return[];try{let r=JSON.parse(i);return Array.isArray(r)?r:[]}catch{return[]}}var pt,ut,ct,S,J,m,Je,We,Xe,I,W,me,ft,F,X,ye,ht,Z,M,E,Et,vt,w=C(()=>{"use strict";pt={PENDING:"pending",SUCCESS:"success",FAILED:"failed",DELETING:"deleting"},ut={PENDING:"pending",PARTIAL:"partial",SUCCESS:"success",PAUSED:"paused"},ct={FREE:"free",STANDARD:"standard",SPONSORED:"sponsored",ENTERPRISE:"enterprise",SUSPENDED:"suspended",TERMINATING:"terminating",TERMINATED:"terminated"};(function(i){i.Validation="validation_failed",i.NotFound="not_found",i.RateLimit="rate_limit_exceeded",i.Authentication="authentication_failed",i.Business="business_logic_error",i.Api="internal_server_error",i.Network="network_error",i.Cancelled="operation_cancelled",i.File="file_error",i.Config="config_error"})(S||(S={}));J={client:new Set([S.Business,S.Config,S.File,S.Validation]),network:new Set([S.Network]),auth:new Set([S.Authentication])},m=class i extends Error{constructor(e,a,u,f){super(a);L(this,"type");L(this,"status");L(this,"details");this.type=e,this.status=u,this.details=f,this.name="ShipError"}toResponse(){let e=this.type===S.Authentication&&this.details?.internal?void 0:this.details;return{error:this.type,message:this.message,status:this.status,details:e}}static fromResponse(e){return new i(e.error,e.message,e.status,e.details)}static validation(e,a){return new i(S.Validation,e,400,a)}static notFound(e,a){let u=a?`${e} ${a} not found`:`${e} not found`;return new i(S.NotFound,u,404)}static rateLimit(e="Too many requests"){return new i(S.RateLimit,e,429)}static authentication(e="Authentication required",a){return new i(S.Authentication,e,401,a)}static business(e,a=400){return new i(S.Business,e,a)}static network(e,a){return new i(S.Network,e,void 0,{cause:a})}static cancelled(e){return new i(S.Cancelled,e)}static file(e,a){return new i(S.File,e,void 0,{filePath:a})}static config(e,a){return new i(S.Config,e,void 0,a)}static api(e,a=500){return new i(S.Api,e,a)}static database(e,a=500){return new i(S.Api,e,a)}static storage(e,a=500){return new i(S.Api,e,a)}get filePath(){return this.details?.filePath}isClientError(){return J.client.has(this.type)}isNetworkError(){return J.network.has(this.type)}isAuthError(){return J.auth.has(this.type)}isValidationError(){return this.type===S.Validation}isFileError(){return this.type===S.File}isConfigError(){return this.type===S.Config}isType(e){return this.type===e}};Je=new Set(["exe","msi","dll","scr","bat","cmd","com","pif","app","deb","rpm","pkg","mpkg","dmg","iso","img","cab","cpl","chm","ps1","vbs","vbe","ws","wsf","wsc","wsh","reg","jar","jnlp","apk","crx","lnk","inf","hta"]);We=/[\x00-\x1f\x7f#?%\\<>"]/;Xe=new Set(["node_modules","package.json"]);I="ship-",W=64,me=I.length+W,ft=4,F="token-",X=64,ye=F.length+X,ht={JWT:"jwt",API_KEY:"apiKey",TOKEN:"token",WEBHOOK:"webhook",SYSTEM:"system"},Z="ship.json";M="https://api.shipstatic.com",E={PENDING:"pending",PROCESSING_ERROR:"processing_error",EXCLUDED:"excluded",VALIDATION_FAILED:"validation_failed",READY:"ready"};Et={MIN_LENGTH:3,MAX_LENGTH:25,MAX_COUNT:10,SEPARATORS:"._-"},vt=/^[a-z0-9]+(?:[._-][a-z0-9]+)*$/});function te(i){ee=i}function O(){if(ee===null)throw m.config("Platform configuration not initialized. The SDK must fetch configuration from the API before performing operations.");return ee}var ee,_=C(()=>{"use strict";w();ee=null});function Ut(i){ne=i}function Ze(){return typeof process<"u"&&process.versions&&process.versions.node?"node":typeof window<"u"||typeof self<"u"?"browser":"unknown"}function H(){return ne||Ze()}var ne,V=C(()=>{"use strict";ne=null});var ve=de((be,Ee)=>{"use strict";(function(i){if(typeof be=="object")Ee.exports=i();else if(typeof define=="function"&&define.amd)define(i);else{var r;try{r=window}catch{r=self}r.SparkMD5=i()}})(function(i){"use strict";var r=function(p,l){return p+l&4294967295},e=["0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"];function a(p,l,n,t,s,o){return l=r(r(l,p),r(t,o)),r(l<<s|l>>>32-s,n)}function u(p,l){var n=p[0],t=p[1],s=p[2],o=p[3];n+=(t&s|~t&o)+l[0]-680876936|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[1]-389564586|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[2]+606105819|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[3]-1044525330|0,t=(t<<22|t>>>10)+s|0,n+=(t&s|~t&o)+l[4]-176418897|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[5]+1200080426|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[6]-1473231341|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[7]-45705983|0,t=(t<<22|t>>>10)+s|0,n+=(t&s|~t&o)+l[8]+1770035416|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[9]-1958414417|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[10]-42063|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[11]-1990404162|0,t=(t<<22|t>>>10)+s|0,n+=(t&s|~t&o)+l[12]+1804603682|0,n=(n<<7|n>>>25)+t|0,o+=(n&t|~n&s)+l[13]-40341101|0,o=(o<<12|o>>>20)+n|0,s+=(o&n|~o&t)+l[14]-1502002290|0,s=(s<<17|s>>>15)+o|0,t+=(s&o|~s&n)+l[15]+1236535329|0,t=(t<<22|t>>>10)+s|0,n+=(t&o|s&~o)+l[1]-165796510|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[6]-1069501632|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[11]+643717713|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[0]-373897302|0,t=(t<<20|t>>>12)+s|0,n+=(t&o|s&~o)+l[5]-701558691|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[10]+38016083|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[15]-660478335|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[4]-405537848|0,t=(t<<20|t>>>12)+s|0,n+=(t&o|s&~o)+l[9]+568446438|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[14]-1019803690|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[3]-187363961|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[8]+1163531501|0,t=(t<<20|t>>>12)+s|0,n+=(t&o|s&~o)+l[13]-1444681467|0,n=(n<<5|n>>>27)+t|0,o+=(n&s|t&~s)+l[2]-51403784|0,o=(o<<9|o>>>23)+n|0,s+=(o&t|n&~t)+l[7]+1735328473|0,s=(s<<14|s>>>18)+o|0,t+=(s&n|o&~n)+l[12]-1926607734|0,t=(t<<20|t>>>12)+s|0,n+=(t^s^o)+l[5]-378558|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[8]-2022574463|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[11]+1839030562|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[14]-35309556|0,t=(t<<23|t>>>9)+s|0,n+=(t^s^o)+l[1]-1530992060|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[4]+1272893353|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[7]-155497632|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[10]-1094730640|0,t=(t<<23|t>>>9)+s|0,n+=(t^s^o)+l[13]+681279174|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[0]-358537222|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[3]-722521979|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[6]+76029189|0,t=(t<<23|t>>>9)+s|0,n+=(t^s^o)+l[9]-640364487|0,n=(n<<4|n>>>28)+t|0,o+=(n^t^s)+l[12]-421815835|0,o=(o<<11|o>>>21)+n|0,s+=(o^n^t)+l[15]+530742520|0,s=(s<<16|s>>>16)+o|0,t+=(s^o^n)+l[2]-995338651|0,t=(t<<23|t>>>9)+s|0,n+=(s^(t|~o))+l[0]-198630844|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[7]+1126891415|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[14]-1416354905|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[5]-57434055|0,t=(t<<21|t>>>11)+s|0,n+=(s^(t|~o))+l[12]+1700485571|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[3]-1894986606|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[10]-1051523|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[1]-2054922799|0,t=(t<<21|t>>>11)+s|0,n+=(s^(t|~o))+l[8]+1873313359|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[15]-30611744|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[6]-1560198380|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[13]+1309151649|0,t=(t<<21|t>>>11)+s|0,n+=(s^(t|~o))+l[4]-145523070|0,n=(n<<6|n>>>26)+t|0,o+=(t^(n|~s))+l[11]-1120210379|0,o=(o<<10|o>>>22)+n|0,s+=(n^(o|~t))+l[2]+718787259|0,s=(s<<15|s>>>17)+o|0,t+=(o^(s|~n))+l[9]-343485551|0,t=(t<<21|t>>>11)+s|0,p[0]=n+p[0]|0,p[1]=t+p[1]|0,p[2]=s+p[2]|0,p[3]=o+p[3]|0}function f(p){var l=[],n;for(n=0;n<64;n+=4)l[n>>2]=p.charCodeAt(n)+(p.charCodeAt(n+1)<<8)+(p.charCodeAt(n+2)<<16)+(p.charCodeAt(n+3)<<24);return l}function h(p){var l=[],n;for(n=0;n<64;n+=4)l[n>>2]=p[n]+(p[n+1]<<8)+(p[n+2]<<16)+(p[n+3]<<24);return l}function y(p){var l=p.length,n=[1732584193,-271733879,-1732584194,271733878],t,s,o,v,x,T;for(t=64;t<=l;t+=64)u(n,f(p.substring(t-64,t)));for(p=p.substring(t-64),s=p.length,o=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],t=0;t<s;t+=1)o[t>>2]|=p.charCodeAt(t)<<(t%4<<3);if(o[t>>2]|=128<<(t%4<<3),t>55)for(u(n,o),t=0;t<16;t+=1)o[t]=0;return v=l*8,v=v.toString(16).match(/(.*?)(.{0,8})$/),x=parseInt(v[2],16),T=parseInt(v[1],16)||0,o[14]=x,o[15]=T,u(n,o),n}function c(p){var l=p.length,n=[1732584193,-271733879,-1732584194,271733878],t,s,o,v,x,T;for(t=64;t<=l;t+=64)u(n,h(p.subarray(t-64,t)));for(p=t-64<l?p.subarray(t-64):new Uint8Array(0),s=p.length,o=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],t=0;t<s;t+=1)o[t>>2]|=p[t]<<(t%4<<3);if(o[t>>2]|=128<<(t%4<<3),t>55)for(u(n,o),t=0;t<16;t+=1)o[t]=0;return v=l*8,v=v.toString(16).match(/(.*?)(.{0,8})$/),x=parseInt(v[2],16),T=parseInt(v[1],16)||0,o[14]=x,o[15]=T,u(n,o),n}function g(p){var l="",n;for(n=0;n<4;n+=1)l+=e[p>>n*8+4&15]+e[p>>n*8&15];return l}function d(p){var l;for(l=0;l<p.length;l+=1)p[l]=g(p[l]);return p.join("")}d(y("hello"))!=="5d41402abc4b2a76b9719d911017c592"&&(r=function(p,l){var n=(p&65535)+(l&65535),t=(p>>16)+(l>>16)+(n>>16);return t<<16|n&65535}),typeof ArrayBuffer<"u"&&!ArrayBuffer.prototype.slice&&(function(){function p(l,n){return l=l|0||0,l<0?Math.max(l+n,0):Math.min(l,n)}ArrayBuffer.prototype.slice=function(l,n){var t=this.byteLength,s=p(l,t),o=t,v,x,T,he;return n!==i&&(o=p(n,t)),s>o?new ArrayBuffer(0):(v=o-s,x=new ArrayBuffer(v),T=new Uint8Array(x),he=new Uint8Array(this,s,v),T.set(he),x)}})();function A(p){return/[\u0080-\uFFFF]/.test(p)&&(p=unescape(encodeURIComponent(p))),p}function R(p,l){var n=p.length,t=new ArrayBuffer(n),s=new Uint8Array(t),o;for(o=0;o<n;o+=1)s[o]=p.charCodeAt(o);return l?s:t}function P(p){return String.fromCharCode.apply(null,new Uint8Array(p))}function Me(p,l,n){var t=new Uint8Array(p.byteLength+l.byteLength);return t.set(new Uint8Array(p)),t.set(new Uint8Array(l),p.byteLength),n?t:t.buffer}function N(p){var l=[],n=p.length,t;for(t=0;t<n-1;t+=2)l.push(parseInt(p.substr(t,2),16));return String.fromCharCode.apply(String,l)}function D(){this.reset()}return D.prototype.append=function(p){return this.appendBinary(A(p)),this},D.prototype.appendBinary=function(p){this._buff+=p,this._length+=p.length;var l=this._buff.length,n;for(n=64;n<=l;n+=64)u(this._hash,f(this._buff.substring(n-64,n)));return this._buff=this._buff.substring(n-64),this},D.prototype.end=function(p){var l=this._buff,n=l.length,t,s=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],o;for(t=0;t<n;t+=1)s[t>>2]|=l.charCodeAt(t)<<(t%4<<3);return this._finish(s,n),o=d(this._hash),p&&(o=N(o)),this.reset(),o},D.prototype.reset=function(){return this._buff="",this._length=0,this._hash=[1732584193,-271733879,-1732584194,271733878],this},D.prototype.getState=function(){return{buff:this._buff,length:this._length,hash:this._hash.slice()}},D.prototype.setState=function(p){return this._buff=p.buff,this._length=p.length,this._hash=p.hash,this},D.prototype.destroy=function(){delete this._hash,delete this._buff,delete this._length},D.prototype._finish=function(p,l){var n=l,t,s,o;if(p[n>>2]|=128<<(n%4<<3),n>55)for(u(this._hash,p),n=0;n<16;n+=1)p[n]=0;t=this._length*8,t=t.toString(16).match(/(.*?)(.{0,8})$/),s=parseInt(t[2],16),o=parseInt(t[1],16)||0,p[14]=s,p[15]=o,u(this._hash,p)},D.hash=function(p,l){return D.hashBinary(A(p),l)},D.hashBinary=function(p,l){var n=y(p),t=d(n);return l?N(t):t},D.ArrayBuffer=function(){this.reset()},D.ArrayBuffer.prototype.append=function(p){var l=Me(this._buff.buffer,p,!0),n=l.length,t;for(this._length+=p.byteLength,t=64;t<=n;t+=64)u(this._hash,h(l.subarray(t-64,t)));return this._buff=t-64<n?new Uint8Array(l.buffer.slice(t-64)):new Uint8Array(0),this},D.ArrayBuffer.prototype.end=function(p){var l=this._buff,n=l.length,t=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0],s,o;for(s=0;s<n;s+=1)t[s>>2]|=l[s]<<(s%4<<3);return this._finish(t,n),o=d(this._hash),p&&(o=N(o)),this.reset(),o},D.ArrayBuffer.prototype.reset=function(){return this._buff=new Uint8Array(0),this._length=0,this._hash=[1732584193,-271733879,-1732584194,271733878],this},D.ArrayBuffer.prototype.getState=function(){var p=D.prototype.getState.call(this);return p.buff=P(p.buff),p},D.ArrayBuffer.prototype.setState=function(p){return p.buff=R(p.buff,!0),D.prototype.setState.call(this,p)},D.ArrayBuffer.prototype.destroy=D.prototype.destroy,D.ArrayBuffer.prototype._finish=D.prototype._finish,D.ArrayBuffer.hash=function(p,l){var n=c(new Uint8Array(p)),t=d(n);return l?N(t):t},D})});var re=de((Bt,we)=>{"use strict";we.exports={}});async function et(i){let r=(await Promise.resolve().then(()=>Y(ve(),1))).default;return new Promise((e,a)=>{let f=Math.ceil(i.size/2097152),h=0,y=new r.ArrayBuffer,c=new FileReader,g=()=>{let d=h*2097152,A=Math.min(d+2097152,i.size);c.readAsArrayBuffer(i.slice(d,A))};c.onload=d=>{let A=d.target?.result;if(!A){a(m.business("Failed to read file chunk"));return}y.append(A),h++,h<f?g():e({md5:y.end()})},c.onerror=()=>{a(m.business("Failed to calculate MD5: FileReader error"))},g()})}async function tt(i){let r=await Promise.resolve().then(()=>Y(re(),1));if(Buffer.isBuffer(i)){let a=r.createHash("md5");return a.update(i),{md5:a.digest("hex")}}let e=await Promise.resolve().then(()=>Y(re(),1));return new Promise((a,u)=>{let f=r.createHash("md5"),h=e.createReadStream(i);h.on("error",y=>u(m.business(`Failed to read file for MD5: ${y.message}`))),h.on("data",y=>f.update(y)),h.on("end",()=>a({md5:f.digest("hex")}))})}async function $(i){let r=H();if(r==="browser"){if(!(i instanceof Blob))throw m.business("Invalid input for browser MD5 calculation: Expected Blob or File.");return et(i)}if(r==="node"){if(!(Buffer.isBuffer(i)||typeof i=="string"))throw m.business("Invalid input for Node.js MD5 calculation: Expected Buffer or file path string.");return tt(i)}throw m.business("Unknown or unsupported execution environment for MD5 calculation.")}var j=C(()=>{"use strict";V();w()});function Pe(i){return it.test(i)}var rt,it,Oe=C(()=>{"use strict";rt=["^npm-debug\\.log$","^\\..*\\.swp$","^\\.DS_Store$","^\\.AppleDouble$","^\\.LSOverride$","^Icon\\r$","^\\._.*","^\\.Spotlight-V100(?:$|\\/)","\\.Trashes","^__MACOSX$","~$","^Thumbs\\.db$","^ehthumbs\\.db$","^[Dd]esktop\\.ini$","@eaDir$"],it=new RegExp(rt.join("|"))});function _e(i,r){if(!i||i.length===0)return[];if(!r?.allowUnbuilt&&i.find(a=>a&&k(a)))throw m.business("Unbuilt project detected \u2014 deploy your build output (dist/, build/, out/), not the project folder");return i.filter(e=>{if(!e)return!1;let a=e.replace(/\\/g,"/").split("/").filter(Boolean);if(a.length===0)return!0;let u=a[a.length-1];if(Pe(u))return!1;for(let h of a)if(h!==".well-known"&&(h.startsWith(".")||h.length>255))return!1;let f=a.slice(0,-1);for(let h of f)if(ot.some(y=>h.toLowerCase()===y.toLowerCase()))return!1;return!0})}var ot,ie=C(()=>{"use strict";Oe();w();ot=["__MACOSX",".Trashes",".fseventsd",".Spotlight-V100"]});function q(i){return i.replace(/\\/g,"/").replace(/\/+/g,"/").replace(/^\/+/,"")}var $e=C(()=>{"use strict"});function Ne(i,r={}){if(r.flatten===!1)return i.map(a=>({path:q(a),name:oe(a)}));let e=st(i);return i.map(a=>{let u=q(a);if(e){let f=e.endsWith("/")?e:`${e}/`;u.startsWith(f)&&(u=u.substring(f.length))}return u||(u=oe(a)),{path:u,name:oe(a)}})}function st(i){if(!i.length)return"";let e=i.map(f=>q(f)).map(f=>f.split("/")),a=[],u=Math.min(...e.map(f=>f.length));for(let f=0;f<u-1;f++){let h=e[0][f];if(e.every(y=>y[f]===h))a.push(h);else break}return a.join("/")}function oe(i){return i.split(/[/\\]/).pop()||i}var se=C(()=>{"use strict";$e()});function ae(i,r=1){if(i===0)return"0 Bytes";let e=1024,a=["Bytes","KB","MB","GB"],u=Math.floor(Math.log(i)/Math.log(e));return parseFloat((i/Math.pow(e,u)).toFixed(r))+" "+a[u]}function le(i){if(ge(i))return{valid:!1,reason:"File name contains unsafe characters"};if(i.startsWith(" ")||i.endsWith(" "))return{valid:!1,reason:"File name cannot start/end with spaces"};if(i.endsWith("."))return{valid:!1,reason:"File name cannot end with dots"};let r=/^(CON|PRN|AUX|NUL|COM[1-9]|LPT[1-9])(\.|$)/i,e=i.split("/").pop()||i;return r.test(e)?{valid:!1,reason:"File name uses a reserved system name"}:i.includes("..")?{valid:!1,reason:"File name contains path traversal pattern"}:{valid:!0}}function hn(i,r){let e=[],a=[],u=[];if(i.length===0){let c={file:"(no files)",message:"At least one file must be provided"};return e.push(c),{files:[],validFiles:[],errors:e,warnings:[],canDeploy:!1}}for(let c of i)if(k(c.name))return e.push({file:c.name,message:"Unbuilt project detected \u2014 deploy your build output (dist/, build/, out/), not the project folder"}),{files:i.map(g=>({...g,status:E.VALIDATION_FAILED,statusMessage:"Unbuilt project detected"})),validFiles:[],errors:e,warnings:[],canDeploy:!1};if(i.length>r.maxFilesCount){let c={file:`(${i.length} files)`,message:`File count (${i.length}) exceeds limit of ${r.maxFilesCount}`};return e.push(c),{files:i.map(g=>({...g,status:E.VALIDATION_FAILED,statusMessage:c.message})),validFiles:[],errors:e,warnings:[],canDeploy:!1}}let f=0;for(let c of i){let g=E.READY,d="Ready for upload",A=c.name?le(c.name):{valid:!1,reason:"File name cannot be empty"};if(c.status===E.PROCESSING_ERROR)g=E.VALIDATION_FAILED,d=c.statusMessage||"File failed during processing",e.push({file:c.name,message:d});else if(c.size===0){g=E.EXCLUDED,d="File is empty (0 bytes) and cannot be deployed due to storage limitations",a.push({file:c.name,message:d}),u.push({...c,status:g,statusMessage:d});continue}else c.size<0?(g=E.VALIDATION_FAILED,d="File size must be positive",e.push({file:c.name,message:d})):!c.name||c.name.trim().length===0?(g=E.VALIDATION_FAILED,d="File name cannot be empty",e.push({file:c.name||"(empty)",message:d})):c.name.includes("\0")?(g=E.VALIDATION_FAILED,d="File name contains invalid characters (null byte)",e.push({file:c.name,message:d})):A.valid?B(c.name)?(g=E.VALIDATION_FAILED,d=`File extension not allowed: "${c.name}"`,e.push({file:c.name,message:d})):c.size>r.maxFileSize?(g=E.VALIDATION_FAILED,d=`File size (${ae(c.size)}) exceeds limit of ${ae(r.maxFileSize)}`,e.push({file:c.name,message:d})):(f+=c.size,f>r.maxTotalSize&&(g=E.VALIDATION_FAILED,d=`Total size would exceed limit of ${ae(r.maxTotalSize)}`,e.push({file:c.name,message:d}))):(g=E.VALIDATION_FAILED,d=A.reason||"Invalid file name",e.push({file:c.name,message:d}));u.push({...c,status:g,statusMessage:d})}e.length>0&&(u=u.map(c=>c.status===E.EXCLUDED?c:{...c,status:E.VALIDATION_FAILED,statusMessage:c.status===E.VALIDATION_FAILED?c.statusMessage:"Deployment failed due to validation errors in bundle"}));let h=e.length===0?u.filter(c=>c.status===E.READY):[],y=e.length===0;return{files:u,validFiles:h,errors:e,warnings:a,canDeploy:y}}function at(i){return i.filter(r=>r.status===E.READY)}function dn(i){return at(i).length>0}var pe=C(()=>{"use strict";w()});function Ue(i,r){if(i.includes("\0")||i.includes("/../")||i.startsWith("../")||i.endsWith("/.."))throw m.business(`Security error: Unsafe file path "${i}" for file: ${r}`)}function Le(i,r){let e=le(i);if(!e.valid)throw m.business(e.reason||"Invalid file name");if(B(i))throw m.business(`File extension not allowed: "${r}"`)}var ue=C(()=>{"use strict";w();pe()});var ke={};qe(ke,{processFilesForBrowser:()=>Be});async function Be(i,r={}){if(H()!=="browser")throw m.business("processFilesForBrowser can only be called in a browser environment.");let e=i.map(d=>d.webkitRelativePath||d.name),a=r.build||r.prerender,u=new Set(_e(e,{allowUnbuilt:a})),f=[];for(let d=0;d<i.length;d++)u.has(e[d])&&f.push({file:i[d],rawPath:e[d]});if(f.length===0)return[];let h=Ne(f.map(d=>d.rawPath),{flatten:r.pathDetect!==!1});if(a){let d=[];for(let A=0;A<f.length;A++){let{file:R}=f[A];if(R.size===0)continue;let{md5:P}=await $(R);d.push({path:h[A].path,content:R,size:R.size,md5:P})}return d}let y=O(),c=[],g=0;for(let d=0;d<f.length;d++){let{file:A}=f[d],R=h[d].path;if(Ue(R,A.name),A.size===0)continue;if(Le(R,A.name),A.size>y.maxFileSize)throw m.business(`File ${A.name} is too large. Maximum allowed size is ${y.maxFileSize/(1024*1024)}MB.`);if(g+=A.size,g>y.maxTotalSize)throw m.business(`Total deploy size is too large. Maximum allowed is ${y.maxTotalSize/(1024*1024)}MB.`);let{md5:P}=await $(A);c.push({path:R,content:A,size:A.size,md5:P})}if(c.length>y.maxFilesCount)throw m.business(`Too many files to deploy. Maximum allowed is ${y.maxFilesCount} files.`);return c}var ce=C(()=>{"use strict";j();w();V();ie();se();ue();_()});w();var z=class{constructor(){this.handlers=new Map}on(r,e){this.handlers.has(r)||this.handlers.set(r,new Set),this.handlers.get(r).add(e)}off(r,e){let a=this.handlers.get(r);a&&(a.delete(e),a.size===0&&this.handlers.delete(r))}emit(r,...e){let a=this.handlers.get(r);if(!a)return;let u=Array.from(a);for(let f of u)try{f(...e)}catch(h){a.delete(f),r!=="error"&&setTimeout(()=>{h instanceof Error?this.emit("error",h,String(r)):this.emit("error",new Error(String(h)),String(r))},0)}}transfer(r){this.handlers.forEach((e,a)=>{e.forEach(u=>{r.on(a,u)})})}clear(){this.handlers.clear()}};var b={DEPLOYMENTS:"/deployments",DOMAINS:"/domains",TOKENS:"/tokens",ACCOUNT:"/account",CONFIG:"/config",PING:"/ping",SPA_CHECK:"/spa-check"},Qe=3e4,K=class extends z{constructor(e){super();this.globalHeaders={};this.apiUrl=e.apiUrl||M,this.getAuthHeadersCallback=e.getAuthHeaders,this.useCredentials=e.useCredentials??!1,this.timeout=e.timeout??Qe,this.createDeployBody=e.createDeployBody,this.deployEndpoint=e.deployEndpoint||b.DEPLOYMENTS}setGlobalHeaders(e){this.globalHeaders=e}transferEventsTo(e){this.transfer(e)}async executeRequest(e,a,u){let f=this.mergeHeaders(a.headers),{signal:h,cleanup:y}=this.createTimeoutSignal(a.signal),c={...a,headers:f,credentials:this.useCredentials&&!f.Authorization?"include":void 0,signal:h};this.emit("request",e,c);try{let g=await fetch(e,c);return y(),g.ok||await this.handleResponseError(g,u),this.emit("response",this.safeClone(g),e),{data:await this.parseResponse(this.safeClone(g)),status:g.status}}catch(g){y();let d=g instanceof Error?g:new Error(String(g));this.emit("error",d,e),this.handleFetchError(g,u)}}async request(e,a,u){let{data:f}=await this.executeRequest(e,a,u);return f}async requestWithStatus(e,a,u){return this.executeRequest(e,a,u)}mergeHeaders(e={}){return{...this.globalHeaders,...this.getAuthHeadersCallback(),...e}}createTimeoutSignal(e){let a=new AbortController,u=setTimeout(()=>a.abort(),this.timeout);if(e){let f=()=>a.abort();e.addEventListener("abort",f),e.aborted&&a.abort()}return{signal:a.signal,cleanup:()=>clearTimeout(u)}}safeClone(e){try{return e.clone()}catch{return e}}async parseResponse(e){if(!(e.headers.get("Content-Length")==="0"||e.status===204))return e.json()}async handleResponseError(e,a){let u={};try{if(e.headers.get("content-type")?.includes("application/json")){let y=await e.json();if(y&&typeof y=="object"){let c=y;typeof c.message=="string"&&(u.message=c.message),typeof c.error=="string"&&(u.error=c.error)}}else u={message:await e.text()}}catch{u={message:"Failed to parse error response"}}let f=u.message||u.error||`${a} failed`;throw e.status===401?m.authentication(f):m.api(f,e.status)}handleFetchError(e,a){throw Q(e)?e:e instanceof Error&&e.name==="AbortError"?m.cancelled(`${a} was cancelled`):e instanceof TypeError&&e.message.includes("fetch")?m.network(`${a} failed: ${e.message}`,e):e instanceof Error?m.business(`${a} failed: ${e.message}`):m.business(`${a} failed: Unknown error`)}async deploy(e,a={}){if(!e.length)throw m.business("No files to deploy");for(let c of e)if(!c.md5)throw m.file(`MD5 checksum missing for file: ${c.path}`,c.path);let u=a.build||a.prerender?{build:a.build,prerender:a.prerender}:void 0,{body:f,headers:h}=await this.createDeployBody(e,a.labels,a.via,u),y={};return a.deployToken?y.Authorization=`Bearer ${a.deployToken}`:a.apiKey&&(y.Authorization=`Bearer ${a.apiKey}`),a.caller&&(y["X-Caller"]=a.caller),this.request(`${a.apiUrl||this.apiUrl}${this.deployEndpoint}`,{method:"POST",body:f,headers:{...h,...y},signal:a.signal||null},"Deploy")}async listDeployments(){return this.request(`${this.apiUrl}${b.DEPLOYMENTS}`,{method:"GET"},"List deployments")}async getDeployment(e){return this.request(`${this.apiUrl}${b.DEPLOYMENTS}/${encodeURIComponent(e)}`,{method:"GET"},"Get deployment")}async updateDeploymentLabels(e,a){return this.request(`${this.apiUrl}${b.DEPLOYMENTS}/${encodeURIComponent(e)}`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({labels:a})},"Update deployment labels")}async removeDeployment(e){await this.request(`${this.apiUrl}${b.DEPLOYMENTS}/${encodeURIComponent(e)}`,{method:"DELETE"},"Remove deployment")}async setDomain(e,a,u){let f={};a&&(f.deployment=a),u!==void 0&&(f.labels=u);let{data:h,status:y}=await this.requestWithStatus(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(f)},"Set domain");return{...h,isCreate:y===201}}async listDomains(){return this.request(`${this.apiUrl}${b.DOMAINS}`,{method:"GET"},"List domains")}async getDomain(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}`,{method:"GET"},"Get domain")}async removeDomain(e){await this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}`,{method:"DELETE"},"Remove domain")}async verifyDomain(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/verify`,{method:"POST"},"Verify domain")}async getDomainDns(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/dns`,{method:"GET"},"Get domain DNS")}async getDomainRecords(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/records`,{method:"GET"},"Get domain records")}async getDomainShare(e){return this.request(`${this.apiUrl}${b.DOMAINS}/${encodeURIComponent(e)}/share`,{method:"GET"},"Get domain share")}async validateDomain(e){return this.request(`${this.apiUrl}${b.DOMAINS}/validate`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({domain:e})},"Validate domain")}async createToken(e,a){let u={};return e!==void 0&&(u.ttl=e),a!==void 0&&(u.labels=a),this.request(`${this.apiUrl}${b.TOKENS}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(u)},"Create token")}async listTokens(){return this.request(`${this.apiUrl}${b.TOKENS}`,{method:"GET"},"List tokens")}async removeToken(e){await this.request(`${this.apiUrl}${b.TOKENS}/${encodeURIComponent(e)}`,{method:"DELETE"},"Remove token")}async fetchAgentToken(){return this.request(`${this.apiUrl}${b.TOKENS}/agent`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({})},"Fetch agent token")}async getAccount(){return this.request(`${this.apiUrl}${b.ACCOUNT}`,{method:"GET"},"Get account")}async getConfig(){return this.request(`${this.apiUrl}${b.CONFIG}`,{method:"GET"},"Get config")}async ping(){return(await this.request(`${this.apiUrl}${b.PING}`,{method:"GET"},"Ping"))?.success||!1}async checkSPA(e,a={}){let u=e.find(g=>g.path==="index.html"||g.path==="/index.html");if(!u||u.size>100*1024)return!1;let f;if(typeof Buffer<"u"&&Buffer.isBuffer(u.content))f=u.content.toString("utf-8");else if(typeof Blob<"u"&&u.content instanceof Blob)f=await u.content.text();else if(typeof File<"u"&&u.content instanceof File)f=await u.content.text();else return!1;let h={"Content-Type":"application/json"};a.deployToken?h.Authorization=`Bearer ${a.deployToken}`:a.apiKey&&(h.Authorization=`Bearer ${a.apiKey}`);let y={files:e.map(g=>g.path),index:f};return(await this.request(`${this.apiUrl}${b.SPA_CHECK}`,{method:"POST",headers:h,body:JSON.stringify(y)},"SPA check")).isSPA}};w();_();w();w();function De(i={},r={}){let e={apiUrl:i.apiUrl||r.apiUrl||M,apiKey:i.apiKey!==void 0?i.apiKey:r.apiKey,deployToken:i.deployToken!==void 0?i.deployToken:r.deployToken},a={apiUrl:e.apiUrl};return e.apiKey!==void 0&&(a.apiKey=e.apiKey),e.deployToken!==void 0&&(a.deployToken=e.deployToken),a}function Se(i,r){let e={...i};return e.apiUrl===void 0&&r.apiUrl!==void 0&&(e.apiUrl=r.apiUrl),e.apiKey===void 0&&r.apiKey!==void 0&&(e.apiKey=r.apiKey),e.deployToken===void 0&&r.deployToken!==void 0&&(e.deployToken=r.deployToken),e.timeout===void 0&&r.timeout!==void 0&&(e.timeout=r.timeout),e.maxConcurrency===void 0&&r.maxConcurrency!==void 0&&(e.maxConcurrency=r.maxConcurrency),e.onProgress===void 0&&r.onProgress!==void 0&&(e.onProgress=r.onProgress),e.caller===void 0&&r.caller!==void 0&&(e.caller=r.caller),e}w();j();async function nt(){let r=JSON.stringify({rewrites:[{source:"/(.*)",destination:"/index.html"}]},null,2),e;typeof Buffer<"u"?e=Buffer.from(r,"utf-8"):e=new Blob([r],{type:"application/json"});let{md5:a}=await $(e);return{path:Z,content:e,size:r.length,md5:a}}async function Re(i,r,e){if(e.spaDetect===!1||e.build||e.prerender||i.some(a=>a.path===Z))return i;try{if(await r.checkSPA(i,e)){let u=await nt();return[...i,u]}}catch{}return i}function Ce(i){let{getApi:r,ensureInit:e,processInput:a,clientDefaults:u,hasAuth:f}=i;return{upload:async(h,y={})=>{await e();let c=u?Se(y,u):y;if(f&&!f()&&!c.deployToken&&!c.apiKey)try{let A=r(),{secret:R}=await A.fetchAgentToken();c.deployToken=R}catch{throw m.authentication("Too many requests; try again later or configure a free API key with 'ship config'")}if(!a)throw m.config("processInput function is not provided.");let g=r(),d=await a(h,c);return d=await Re(d,g,c),g.deploy(d,c)},list:async()=>(await e(),r().listDeployments()),get:async h=>(await e(),r().getDeployment(h)),set:async(h,y)=>(await e(),r().updateDeploymentLabels(h,y.labels)),remove:async h=>{await e(),await r().removeDeployment(h)}}}function xe(i){let{getApi:r,ensureInit:e}=i;return{set:async(a,u={})=>(await e(),r().setDomain(a,u.deployment,u.labels)),list:async()=>(await e(),r().listDomains()),get:async a=>(await e(),r().getDomain(a)),remove:async a=>{await e(),await r().removeDomain(a)},verify:async a=>(await e(),r().verifyDomain(a)),validate:async a=>(await e(),r().validateDomain(a)),dns:async a=>(await e(),r().getDomainDns(a)),records:async a=>(await e(),r().getDomainRecords(a)),share:async a=>(await e(),r().getDomainShare(a))}}function Te(i){let{getApi:r,ensureInit:e}=i;return{get:async()=>(await e(),r().getAccount())}}function Ie(i){let{getApi:r,ensureInit:e}=i;return{create:async(a={})=>(await e(),r().createToken(a.ttl,a.labels)),list:async()=>(await e(),r().listTokens()),remove:async a=>{await e(),await r().removeToken(a)}}}var G=class{constructor(r={}){this.initPromise=null;this._config=null;this.auth=null;this.customHeaders={};this.clientOptions=r,r.deployToken?this.auth={type:"token",value:r.deployToken}:r.apiKey&&(this.auth={type:"apiKey",value:r.apiKey}),this.authHeadersCallback=()=>this.getAuthHeaders();let e=this.resolveInitialConfig(r);this.http=new K({...r,...e,getAuthHeaders:this.authHeadersCallback,createDeployBody:this.getDeployBodyCreator()});let a={getApi:()=>this.http,ensureInit:()=>this.ensureInitialized()};this._deployments=Ce({...a,processInput:(u,f)=>this.processInput(u,f),clientDefaults:this.clientOptions,hasAuth:()=>this.hasAuth()}),this._domains=xe(a),this._account=Te(a),this._tokens=Ie(a)}async ensureInitialized(){return this.initPromise||(this.initPromise=this.loadFullConfig()),this.initPromise}async ping(){return await this.ensureInitialized(),this.http.ping()}async deploy(r,e){return this.deployments.upload(r,e)}async whoami(){return this.account.get()}get deployments(){return this._deployments}get domains(){return this._domains}get account(){return this._account}get tokens(){return this._tokens}async getConfig(){return this._config?this._config:(await this.ensureInitialized(),this._config=O(),this._config)}on(r,e){this.http.on(r,e)}off(r,e){this.http.off(r,e)}setHeaders(r){this.customHeaders=r,this.http.setGlobalHeaders(r)}clearHeaders(){this.customHeaders={},this.http.setGlobalHeaders({})}replaceHttpClient(r){if(this.http?.transferEventsTo)try{this.http.transferEventsTo(r)}catch(e){console.warn("Event transfer failed during client replacement:",e)}this.http=r,Object.keys(this.customHeaders).length>0&&this.http.setGlobalHeaders(this.customHeaders)}setDeployToken(r){if(!r||typeof r!="string")throw m.business("Invalid deploy token provided. Deploy token must be a non-empty string.");this.auth={type:"token",value:r}}setApiKey(r){if(!r||typeof r!="string")throw m.business("Invalid API key provided. API key must be a non-empty string.");this.auth={type:"apiKey",value:r}}getAuthHeaders(){return this.auth?{Authorization:`Bearer ${this.auth.value}`}:{}}hasAuth(){return this.clientOptions.useCredentials?!0:this.auth!==null}};_();w();w();async function Fe(i,r,e,a){let u=new FormData,f=[];for(let h of i){if(!(h.content instanceof File||h.content instanceof Blob))throw m.file(`Unsupported file.content type for browser: ${h.path}`,h.path);if(!h.md5)throw m.file(`File missing md5 checksum: ${h.path}`,h.path);let y=new File([h.content],h.path,{type:"application/octet-stream"});u.append("files[]",y),f.push(h.md5)}return u.append("checksums",JSON.stringify(f)),r&&r.length>0&&u.append("labels",JSON.stringify(r)),e&&u.append("via",e),a?.build&&u.append("build","true"),a?.prerender&&u.append("prerender","true"),{body:u,headers:{}}}j();function nn(i,r,e,a=!0){let u=i===1?r:e;return a?`${i} ${u}`:u}ie();se();V();pe();ue();w();_();ce();var fe=class extends G{constructor(r={}){super(r)}resolveInitialConfig(r){return De(r,{})}async loadFullConfig(){try{let r=await this.http.getConfig();te(r)}catch(r){throw this.initPromise=null,r}}async processInput(r,e){if(!this.isFileArray(r))throw m.business("Invalid input type for browser environment. Expected File[].");if(r.length===0)throw m.business("No files to deploy.");let{processFilesForBrowser:a}=await Promise.resolve().then(()=>(ce(),ke));return a(r,e)}isFileArray(r){return Array.isArray(r)&&r.every(e=>e instanceof File)}getDeployBodyCreator(){return Fe}},jn=fe;export{W as API_KEY_HEX_LENGTH,ft as API_KEY_HINT_LENGTH,I as API_KEY_PREFIX,me as API_KEY_TOTAL_LENGTH,ct as AccountPlan,K as ApiHttp,ht as AuthMethod,Je as BLOCKED_EXTENSIONS,M as DEFAULT_API,Z as DEPLOYMENT_CONFIG_FILENAME,X as DEPLOY_TOKEN_HEX_LENGTH,F as DEPLOY_TOKEN_PREFIX,ye as DEPLOY_TOKEN_TOTAL_LENGTH,pt as DeploymentStatus,ut as DomainStatus,S as ErrorType,E as FILE_VALIDATION_STATUS,E as FileValidationStatus,ot as JUNK_DIRECTORIES,Et as LABEL_CONSTRAINTS,vt as LABEL_PATTERN,fe as Ship,m as ShipError,Xe as UNBUILT_PROJECT_MARKERS,We as UNSAFE_FILENAME_CHARS,Ut as __setTestEnvironment,dn as allValidFilesReady,$ as calculateMD5,Te as createAccountResource,Ce as createDeploymentResource,xe as createDomainResource,Ie as createTokenResource,jn as default,Rt as deserializeLabels,Dt as extractSubdomain,_e as filterJunk,ae as formatFileSize,St as generateDeploymentUrl,bt as generateDomainUrl,O as getCurrentConfig,H as getENV,at as getValidFiles,k as hasUnbuiltMarker,ge as hasUnsafeChars,B as isBlockedExtension,At as isCustomDomain,gt as isDeployment,Ae as isPlatformDomain,Q as isShipError,Se as mergeDeployOptions,Ne as optimizeDeployPaths,nn as pluralize,Be as processFilesForBrowser,De as resolveConfig,wt as serializeLabels,te as setPlatformConfig,dt as validateApiKey,yt as validateApiUrl,Le as validateDeployFile,Ue as validateDeployPath,mt as validateDeployToken,le as validateFileName,hn as validateFiles};
2
2
  //# sourceMappingURL=browser.js.map