@upstart.gg/sdk 0.0.88 → 0.0.90

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/dist/node/cli/api.js +2 -2
  2. package/dist/node/cli/commands/build/cmd-build.js +2 -2
  3. package/dist/node/cli/commands/login/cmd-login.js +3 -3
  4. package/dist/node/cli/commands/logout/cmd-logout.js +2 -2
  5. package/dist/node/cli/commands/publish/cmd-publish.js +17 -17
  6. package/dist/node/cli/commands/publish/uploader.js +4 -4
  7. package/dist/node/cli/is-logged-in.js +2 -2
  8. package/dist/node/cli/program.js +26 -26
  9. package/dist/node/cli/store.js +1 -1
  10. package/dist/node/shared/config.js +3 -3
  11. package/dist/node/shared/logger.js +2 -2
  12. package/dist/shared/bricks.js +1 -1
  13. package/dist/shared/chunk-HC4I5B3L.js +3 -0
  14. package/dist/shared/{chunk-TGGTFM2R.js → chunk-OTJI3IWM.js} +1 -1
  15. package/dist/shared/{chunk-KK7J6SRT.js → chunk-SWGSHUTE.js} +1 -1
  16. package/dist/shared/datasources/internal/blog/schema.d.ts +2 -5
  17. package/dist/shared/datasources/internal/blog/schema.d.ts.map +1 -1
  18. package/dist/shared/datasources/internal/changelog/schema.d.ts.map +1 -1
  19. package/dist/shared/datasources/internal/faq/schema.d.ts.map +1 -1
  20. package/dist/shared/datasources/internal/job-board/schema.d.ts +80 -81
  21. package/dist/shared/datasources/internal/job-board/schema.d.ts.map +1 -1
  22. package/dist/shared/datasources/schemas.js +1 -1
  23. package/dist/shared/datasources.js +1 -1
  24. package/dist/shared/page.js +1 -1
  25. package/dist/shared/template.js +1 -1
  26. package/dist/shared/utils/try-catch.d.ts +2 -2
  27. package/dist/shared/utils/try-catch.d.ts.map +1 -1
  28. package/dist/shared/utils/try-catch.js +1 -1
  29. package/package.json +3 -5
  30. package/dist/shared/chunk-ZRWRIZBR.js +0 -3
@@ -1,30 +1,30 @@
1
1
  /*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/upstart-gg/upstart/blob/main/LICENSE */
2
2
 
3
- var ye=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var he=(e,t)=>{for(var r in t)ye(e,r,{get:t[r],enumerable:!0})};function F(){let e;if(process.env.npm_config_user_agent){let t=process.env.npm_config_user_agent.split(" ")[0];e=t.slice(0,t.lastIndexOf("/"))}return e||(console.log("Warning: could not detect package manager"),e="npm"),e}function J(e){return`[${e.error}]${e.error_description?`: ${e.error_description}`:""}`}var q=b(()=>{"use strict"});var X,ft,x,yt,Y,K,V,R=b(()=>{"use strict";X="upstart-cli",ft=process.env.PUBLIC_UPSTART_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",x=process.env.PUBLIC_UPSTART_API_BASE_URL??"https://api.upstart.gg",yt=process.env.PUBLIC_UPSTART_EDITOR_BASE_URL??"https://upstart.gg",Y=10,K="oauth/userinfo",V="v1/templates"});import Se from"conf";import v from"node:path";import Te from"node:crypto";import A from"node:fs";import{fileURLToPath as Ee}from"node:url";import Pe from"chalk";function Q(){let e=y.get("access_token");if(!e){let t=F();throw new Error(`Access token not found. Please run ${Pe.cyan(`${t} run enpage:login`)} to authenticate.`)}return e}function _e(){let e=xe;for(;e!==v.parse(e).root;){let t=v.join(e,"node_modules");if(A.existsSync(t))return t;e=v.dirname(e)}return null}function be(){let e=_e();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=v.join(e,".enpage-tmp");A.existsSync(t)||A.mkdirSync(t,{recursive:!0,mode:448});let r=v.join(t,".enpage-key");if(!A.existsSync(r)){let s=Te.randomBytes(32).toString("hex");return A.writeFileSync(r,s,{mode:384,flush:!0}),s}return A.readFileSync(r,"utf8")}var xe,we,y,G=b(()=>{"use strict";R();q();xe=Ee(new URL(".",import.meta.url)),we=be(),y=new Se({projectName:X,encryptionKey:we,clearInvalidConfig:!0})});var ee,Z=b(()=>{ee="0.0.88"});import{createLogger as Ae}from"vite";import O from"chalk";function Oe(e,t,r=!1){let o=Ae(e==="debug"?"info":e,{prefix:"[upstart]",allowClearScreen:t});return r&&o.info(O.hex("#7270c6").bold(`\u{1F680} Upstart v${ee}
4
- `)),{...o,success:(s,n)=>o.info(O.green(s),n),error:(s,n)=>o.error(O.red(s),n),warn:(s,n)=>o.warn(O.yellow(s),n),warnOnce:(s,n)=>o.warnOnce(O.yellow(s),n),debug:(s,n)=>{e==="debug"&&o.info(O.gray(s),n)}}}var g,M=b(()=>{"use strict";Z();g=Oe()});var ne={};he(ne,{get:()=>Ge,post:()=>I});async function I(e,t,r={}){y.get("access_token")&&(r.Authorization=`Bearer ${y.get("access_token")}`);let o=await fetch(oe(e),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...r},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(s=>{g.error(`Fatal Error requesting API: ${s.message} (${s.cause.code})`),g.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return se(o)}async function Ge(e,t={}){y.get("access_token")&&(t.Authorization=`Bearer ${y.get("access_token")}`);let r=await fetch(oe(e),{headers:t,method:"GET"}).catch(o=>{g.error(`Fatal Error requesting API: ${o.message} (${o.cause.code})`),g.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return se(r)}function oe(e){let t=new URL(x.endsWith("/")?x:`${x}/`);return new URL(e,t)}async function se(e){let t=e.headers.get("content-type")?.startsWith("application/json")?await e.json():await e.text();return e.ok?{isSuccess:!0,isError:!1,status:e.status,statusText:e.statusText,data:t}:{isSuccess:!1,isError:!0,status:e.status,statusText:e.statusText,data:t}}var W=b(()=>{"use strict";M();R();G()});q();G();import{resolve as h}from"node:path";import{existsSync as D,readFileSync as ct,writeFileSync as lt}from"node:fs";import E from"chalk";R();M();import N from"node:path";import j from"node:fs";import Me from"node:crypto";import Be from"fast-glob";import ae from"node:http";import ze from"node:https";import{pipeline as We}from"node:stream";import ie from"chalk";import qe from"form-data";import*as B from"node:fs";var ke=/[<>"|?*\n\r\t\f\x00-\x1F]/,$e=/(?:^|\/)[*]{2}($|\/)/,Le=248,Ce=e=>e!==null&&typeof e=="object"&&!Array.isArray(e),Ue=e=>typeof e=="string"&&e.length<=Le&&!ke.test(e),ve=e=>e.split(/\r\n?|\n/);var Ie=e=>Ce(e)&&Array.isArray(e.patterns)&&Array.isArray(e.sections);var z=(e,t={})=>{let r=t.path;if(Ie(e))return e;Ue(e)&&B.existsSync(e)&&(r=e,e=B.readFileSync(e,"utf8"));let o=ve(e),s=new Map,n={sections:[],patterns:[]},p={name:"default",patterns:[]},i=null;for(let a of o){let c=a.trim();if(c.startsWith("#")){let[,u]=/^#+\s*(.*)\s*$/.exec(c)||[];if(i){s.delete(i.name),i.comment=i.comment?`${i.comment}
3
+ var ye=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var he=(e,t)=>{for(var r in t)ye(e,r,{get:t[r],enumerable:!0})};function F(){let e;if(process.env.npm_config_user_agent){let t=process.env.npm_config_user_agent.split(" ")[0];e=t.slice(0,t.lastIndexOf("/"))}return e||(console.log("Warning: could not detect package manager"),e="npm"),e}function J(e){return`[${e.error}]${e.error_description?`: ${e.error_description}`:""}`}var q=b(()=>{"use strict"});var X,ft,x,yt,Y,K,V,R=b(()=>{"use strict";X="upstart-cli",ft=process.env.PUBLIC_UPSTART_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",x=process.env.PUBLIC_UPSTART_API_BASE_URL??"https://api.upstart.gg",yt=process.env.PUBLIC_UPSTART_EDITOR_BASE_URL??"https://upstart.gg",Y=10,K="oauth/userinfo",V="v1/templates"});import Se from"conf";import v from"node:path";import Te from"node:crypto";import A from"node:fs";import{fileURLToPath as Ee}from"node:url";import Pe from"chalk";function Q(){let e=y.get("access_token");if(!e){let t=F();throw new Error(`Access token not found. Please run ${Pe.cyan(`${t} run enpage:login`)} to authenticate.`)}return e}function _e(){let e=xe;for(;e!==v.parse(e).root;){let t=v.join(e,"node_modules");if(A.existsSync(t))return t;e=v.dirname(e)}return null}function be(){let e=_e();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=v.join(e,".enpage-tmp");A.existsSync(t)||A.mkdirSync(t,{recursive:!0,mode:448});let r=v.join(t,".enpage-key");if(!A.existsSync(r)){let o=Te.randomBytes(32).toString("hex");return A.writeFileSync(r,o,{mode:384}),o}return A.readFileSync(r,"utf8")}var xe,we,y,G=b(()=>{"use strict";R();q();xe=Ee(new URL(".",import.meta.url)),we=be(),y=new Se({projectName:X,encryptionKey:we,clearInvalidConfig:!0})});var ee,Z=b(()=>{ee="0.0.90"});import{createLogger as Ae}from"vite";import O from"chalk";function Oe(e,t,r=!1){let s=Ae(e==="debug"?"info":e,{prefix:"[upstart]",allowClearScreen:t});return r&&s.info(O.hex("#7270c6").bold(`\u{1F680} Upstart v${ee}
4
+ `)),{...s,success:(o,n)=>s.info(O.green(o),n),error:(o,n)=>s.error(O.red(o),n),warn:(o,n)=>s.warn(O.yellow(o),n),warnOnce:(o,n)=>s.warnOnce(O.yellow(o),n),debug:(o,n)=>{e==="debug"&&s.info(O.gray(o),n)}}}var g,M=b(()=>{"use strict";Z();g=Oe()});var ne={};he(ne,{get:()=>Ge,post:()=>I});async function I(e,t,r={}){y.get("access_token")&&(r.Authorization=`Bearer ${y.get("access_token")}`);let s=await fetch(se(e),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...r},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(o=>{g.error(`Fatal Error requesting API: ${o.message} (${o.cause.code})`),g.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return oe(s)}async function Ge(e,t={}){y.get("access_token")&&(t.Authorization=`Bearer ${y.get("access_token")}`);let r=await fetch(se(e),{headers:t,method:"GET"}).catch(s=>{g.error(`Fatal Error requesting API: ${s.message} (${s.cause.code})`),g.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return oe(r)}function se(e){let t=new URL(x.endsWith("/")?x:`${x}/`);return new URL(e,t)}async function oe(e){let t=e.headers.get("content-type")?.startsWith("application/json")?await e.json():await e.text();return e.ok?{isSuccess:!0,isError:!1,status:e.status,statusText:e.statusText,data:t}:{isSuccess:!1,isError:!0,status:e.status,statusText:e.statusText,data:t}}var W=b(()=>{"use strict";M();R();G()});q();G();import{resolve as h}from"node:path";import{existsSync as D,readFileSync as ct,writeFileSync as lt}from"node:fs";import E from"chalk";R();M();import N from"node:path";import j from"node:fs";import Me from"node:crypto";import Be from"fast-glob";import ae from"node:http";import ze from"node:https";import{pipeline as We}from"node:stream";import ie from"chalk";import qe from"form-data";import*as B from"node:fs";var ke=/[<>"|?*\n\r\t\f\x00-\x1F]/,$e=/(?:^|\/)[*]{2}($|\/)/,Le=248,Ce=e=>e!==null&&typeof e=="object"&&!Array.isArray(e),Ue=e=>typeof e=="string"&&e.length<=Le&&!ke.test(e),ve=e=>e.split(/\r\n?|\n/);var Ie=e=>Ce(e)&&Array.isArray(e.patterns)&&Array.isArray(e.sections);var z=(e,t={})=>{let r=t.path;if(Ie(e))return e;Ue(e)&&B.existsSync(e)&&(r=e,e=B.readFileSync(e,"utf8"));let s=ve(e),o=new Map,n={sections:[],patterns:[]},p={name:"default",patterns:[]},i=null;for(let a of s){let c=a.trim();if(c.startsWith("#")){let[,u]=/^#+\s*(.*)\s*$/.exec(c)||[];if(i){o.delete(i.name),i.comment=i.comment?`${i.comment}
5
5
  ${c}`:c,i.name=u?`${i.name.trim()}
6
- ${u.trim()}`:i.name.trim(),s.set(i.name.toLowerCase().trim(),i);continue}p={name:u?.trim()||"",comment:c,patterns:[]},s.set(p.name.toLowerCase(),p),n.sections.push(p),i=p;continue}c!==""&&(p.patterns.push(c),n.patterns.push(c)),i=null}return(t.dedupe===!0||t.unique===!0)&&(n=te(n,{...t,format:!1})),n.path=r,n.input=Buffer.from(e),n.format=a=>Fe(n,{...t,...a}),n.dedupe=a=>te(n,{...t,...a}),n.globs=a=>je(n,{path:r,...t,...a}),n};var te=(e,t)=>{let r=z(e,{...t,dedupe:!1}),o=new Map,s={sections:[],patterns:[]},n;for(let p of r.sections){let{name:i="",comment:a,patterns:c}=p,u=i.trim().toLowerCase();for(let f of c)s.patterns.includes(f)||s.patterns.push(f);i&&o.has(u)?(n=o.get(u),n.patterns=[...n.patterns,...c]):(n={name:i,comment:a,patterns:c},s.sections.push(n),o.set(u,n))}for(let p of s.sections)p.patterns=[...new Set(p.patterns)];return s},Ne=e=>{if($e.test(e))return e;let t=!1;return e.startsWith("/")?(e=e.slice(1),t=!0):e.slice(1,e.length-1).includes("/")&&(t=!0),e+=e.endsWith("/")?"**/":"/**",t?e:`**/${e}`},je=(e,t={})=>{let r=z(e,t),o=[],s=0,n=r.patterns.concat(t.ignore||[]).concat((t.unignore||[]).map(i=>i.startsWith("!")?i:`!${i}`)),p=(i,a)=>{let c=o[o.length-1],u=i?"unignore":"ignore";c&&c.type===u?c.patterns.includes(a)||c.patterns.push(a):(o.push({type:u,path:t.path||null,patterns:[a],index:s}),s++)};for(let i of n){let a="";i.startsWith("!")&&(i=i.slice(1),a="!"),p(a,i.startsWith("/")?i.slice(1):i),p(a,Ne(i))}return o},De=(e={name:"",patterns:[]})=>{let t=[e.comment||""];return e.patterns?.length&&(t.push(e.patterns.join(`
6
+ ${u.trim()}`:i.name.trim(),o.set(i.name.toLowerCase().trim(),i);continue}p={name:u?.trim()||"",comment:c,patterns:[]},o.set(p.name.toLowerCase(),p),n.sections.push(p),i=p;continue}c!==""&&(p.patterns.push(c),n.patterns.push(c)),i=null}return(t.dedupe===!0||t.unique===!0)&&(n=te(n,{...t,format:!1})),n.path=r,n.input=Buffer.from(e),n.format=a=>Fe(n,{...t,...a}),n.dedupe=a=>te(n,{...t,...a}),n.globs=a=>je(n,{path:r,...t,...a}),n};var te=(e,t)=>{let r=z(e,{...t,dedupe:!1}),s=new Map,o={sections:[],patterns:[]},n;for(let p of r.sections){let{name:i="",comment:a,patterns:c}=p,u=i.trim().toLowerCase();for(let f of c)o.patterns.includes(f)||o.patterns.push(f);i&&s.has(u)?(n=s.get(u),n.patterns=[...n.patterns,...c]):(n={name:i,comment:a,patterns:c},o.sections.push(n),s.set(u,n))}for(let p of o.sections)p.patterns=[...new Set(p.patterns)];return o},Ne=e=>{if($e.test(e))return e;let t=!1;return e.startsWith("/")?(e=e.slice(1),t=!0):e.slice(1,e.length-1).includes("/")&&(t=!0),e+=e.endsWith("/")?"**/":"/**",t?e:`**/${e}`},je=(e,t={})=>{let r=z(e,t),s=[],o=0,n=r.patterns.concat(t.ignore||[]).concat((t.unignore||[]).map(i=>i.startsWith("!")?i:`!${i}`)),p=(i,a)=>{let c=s[s.length-1],u=i?"unignore":"ignore";c&&c.type===u?c.patterns.includes(a)||c.patterns.push(a):(s.push({type:u,path:t.path||null,patterns:[a],index:o}),o++)};for(let i of n){let a="";i.startsWith("!")&&(i=i.slice(1),a="!"),p(a,i.startsWith("/")?i.slice(1):i),p(a,Ne(i))}return s},De=(e={name:"",patterns:[]})=>{let t=[e.comment||""];return e.patterns?.length&&(t.push(e.patterns.join(`
7
7
  `)),t.push("")),t.join(`
8
- `)},Fe=(e,t={})=>{let r=z(e,t),o=t.formatSection||De,s=r.sections||r,n=[];for(let p of[].concat(s))n.push(o(p));return n.join(`
9
- `)};var re=z;W();import He from"p-queue";import Je from"ora";import{customAlphabet as Xe}from"nanoid";var k=class extends Error{constructor(r,o,s){super(`${r}: ${o}`);this.error=r;this.error_description=o;this.filename=s;this.name="UploadError"}},Ye={maxDataSize:12*1024*1024,retryAttempts:2,retryDelay:1e3},Ke=new ae.Agent({keepAlive:!0,maxSockets:10,keepAliveMsecs:3e3});async function Ve(e){let t=N.join(e,".gitignore"),o=j.existsSync(t)?re(j.readFileSync(t,"utf-8")).patterns:[];return Be("**/*",{cwd:e,onlyFiles:!0,dot:!0,absolute:!0,ignore:["node_modules/**",".cache/**","**/.DS_Store",".gitignore",".env",".env.*",".git/**","dist/**",...o]})}async function Qe(e,t,r,o,s,n,p){let i=async a=>{try{return await Ze(e,t,r,o,s,n,p)}catch(c){if(a<p.retryAttempts)return g.warn(`Retrying upload for ${t} (attempt ${a+1})`),await new Promise(u=>setTimeout(u,p.retryDelay)),i(a+1);throw c}};return i(0)}async function Ze(e,t,r,o,s,n,p){return new Promise((i,a)=>{let c=j.statSync(e),u=N.basename(e),f=Date.now(),S=new qe({maxDataSize:p.maxDataSize}),$=j.createReadStream(e),L=0,w=l=>{L+=l.length};$.on("data",w),S.append("file",$,{filename:u,knownLength:c.size});let _={agent:Ke,method:"POST",headers:{authorization:`Bearer ${n}`,"x-upstart-template-file-path":t,"x-upstart-template-id":o,...S.getHeaders()}},P=(r.startsWith("https")?ze:ae).request(r,_,l=>{let T="";l.on("data",C=>{T+=C}),l.on("end",()=>{let C=Date.now(),fe={fileName:u,fileSize:c.size,uploadDuration:C-f,statusCode:l.statusCode??0,serverResponse:T};if(l.statusCode&&l.statusCode>=200&&l.statusCode<300)s.text=`Uploaded ${t}`,i(fe);else{let U;if(l.headers["content-type"]?.startsWith("application/json")){let H=JSON.parse(T);U=new k(H.error||"unknown_error",H.error_description||"Unknown error occurred",t)}else U=new k("unknown_error",T||"Unknown error occurred",t);s.fail(`Failed to upload ${t} [${U.error}] ${U.error_description}`),a(U)}})});P.on("error",l=>{a(new k("request_error",l.message,t))}),We(S,P,l=>{l&&a(new k("pipeline_error",`Pipeline failed for ${u}: ${l.message}`,t))})})}function et(e,t,r){r.length>0?(g.error(ie.red(`Failed to upload ${r.length} files:`)),r.forEach(o=>{let s=o.reason;g.error(`- ${s.filename}: ${s.error_description} (${s.error})`)})):g.info(ie.green(`Uploaded ${t.length} files successfully for template ${e}.
10
- `))}async function pe(e,t,r,o=!1,s={}){let n={...Ye,...s},p=new He({concurrency:Y}),i=await Ve(t),a=i.length,c={},u=rt(),f=0;for(let m of i){let P=N.relative(t,m),l=await tt(m);c[P]=l}o&&(g.info(`Dry run mode enabled. Skipping upload.
11
- `),g.info("The following files would have been uploaded:"),i.forEach(m=>g.info(`- ${m}`)),process.exit(0));let S=Je(`Uploading ${a} files...`).start(),$=i.map(m=>{let P=N.resolve(t,m),l=N.relative(t,m),T=`${x}/v1/templates/${e}/upload/${u}`;return p.add(async()=>{let C=await Qe(P,l,T,e,S,r,n);return f++,C})}),L=await Promise.allSettled($);S.stop();let w=L.filter(m=>m.status==="fulfilled"),_=L.filter(m=>m.status==="rejected");if(et(e,w.map(m=>m.value),_),!_.length&&w.length){let m=`${x}/v1/templates/${e}/upload/${u}/finalize`,l=await I(m,{signatures:c});if(l.isError)return g.error(`Failed to finalize upload: ${l.data.error_description} (${l.data.error})`),{filesCount:a,uploadedFiles:w.map(T=>T.value),failedFiles:[],success:!1}}return{filesCount:a,uploadedFiles:w.map(m=>m.value),failedFiles:_,success:_.length===0}}async function tt(e){let t=await Me.subtle.digest("SHA-1",j.readFileSync(e));return Array.from(new Uint8Array(t)).map(r=>r.toString(16).padStart(2,"0")).join("")}function rt(){let e=Xe("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",5),t=new Date,r=t.getUTCFullYear(),o=(t.getUTCMonth()+1).toString().padStart(2,"0"),s=t.getUTCDate().toString().padStart(2,"0"),n=t.getUTCHours().toString().padStart(2,"0"),p=t.getUTCMinutes().toString().padStart(2,"0"),i=t.getUTCSeconds().toString().padStart(2,"0");return`${r}${o}${s}${n}${p}${i}_${e()}`}W();R();import ge from"node:path";import{Type as d}from"@sinclair/typebox";var ce=d.Object({id:d.Optional(d.String({title:"Template ID",description:"A unique identifier for the template. Can be any string, but should be unique."})),name:d.String({title:"Template Name"}),description:d.Optional(d.String({title:"Show template description"})),readme:d.Optional(d.Record(d.RegExp(/^[a-z]{2}$/),d.String(),{title:"Readme texts.",description:"A dictionary of readme files for different languages (iso 2 letters code). Currently on supported for 'en' and 'fr'."})),tags:d.Optional(d.Array(d.String(),{title:"Tags"})),author:d.Optional(d.String({title:"Author name"})),thumbnail:d.Optional(d.String({title:"Thumbnail",description:"A URL to the thumbnail image for the template."})),homepage:d.Optional(d.String({title:"Homepage",description:"A URL to the homepage of the template."}))});M();import ot from"node:fs";import{readFile as st}from"node:fs/promises";import nt from"fast-glob";import{fromError as it}from"zod-validation-error";import{basename as le,dirname as at,extname as pt}from"node:path";async function ue(e,t=g){ot.existsSync(e)||(t.error(`\u{1F534} No enpage.config.js found!
8
+ `)},Fe=(e,t={})=>{let r=z(e,t),s=t.formatSection||De,o=r.sections||r,n=[];for(let p of[].concat(o))n.push(s(p));return n.join(`
9
+ `)};var re=z;W();import He from"p-queue";import Je from"ora";import{customAlphabet as Xe}from"nanoid";var k=class extends Error{constructor(r,s,o){super(`${r}: ${s}`);this.error=r;this.error_description=s;this.filename=o;this.name="UploadError"}},Ye={maxDataSize:12*1024*1024,retryAttempts:2,retryDelay:1e3},Ke=new ae.Agent({keepAlive:!0,maxSockets:10,keepAliveMsecs:3e3});async function Ve(e){let t=N.join(e,".gitignore"),s=j.existsSync(t)?re(j.readFileSync(t,"utf-8")).patterns:[];return Be("**/*",{cwd:e,onlyFiles:!0,dot:!0,absolute:!0,ignore:["node_modules/**",".cache/**","**/.DS_Store",".gitignore",".env",".env.*",".git/**","dist/**",...s]})}async function Qe(e,t,r,s,o,n,p){let i=async a=>{try{return await Ze(e,t,r,s,o,n,p)}catch(c){if(a<p.retryAttempts)return g.warn(`Retrying upload for ${t} (attempt ${a+1})`),await new Promise(u=>setTimeout(u,p.retryDelay)),i(a+1);throw c}};return i(0)}async function Ze(e,t,r,s,o,n,p){return new Promise((i,a)=>{let c=j.statSync(e),u=N.basename(e),f=Date.now(),S=new qe({maxDataSize:p.maxDataSize}),$=j.createReadStream(e),L=0,w=l=>{L+=l.length};$.on("data",w),S.append("file",$,{filename:u,knownLength:c.size});let _={agent:Ke,method:"POST",headers:{authorization:`Bearer ${n}`,"x-upstart-template-file-path":t,"x-upstart-template-id":s,...S.getHeaders()}},P=(r.startsWith("https")?ze:ae).request(r,_,l=>{let T="";l.on("data",C=>{T+=C}),l.on("end",()=>{let C=Date.now(),fe={fileName:u,fileSize:c.size,uploadDuration:C-f,statusCode:l.statusCode??0,serverResponse:T};if(l.statusCode&&l.statusCode>=200&&l.statusCode<300)o.text=`Uploaded ${t}`,i(fe);else{let U;if(l.headers["content-type"]?.startsWith("application/json")){let H=JSON.parse(T);U=new k(H.error||"unknown_error",H.error_description||"Unknown error occurred",t)}else U=new k("unknown_error",T||"Unknown error occurred",t);o.fail(`Failed to upload ${t} [${U.error}] ${U.error_description}`),a(U)}})});P.on("error",l=>{a(new k("request_error",l.message,t))}),We(S,P,l=>{l&&a(new k("pipeline_error",`Pipeline failed for ${u}: ${l.message}`,t))})})}function et(e,t,r){r.length>0?(g.error(ie.red(`Failed to upload ${r.length} files:`)),r.forEach(s=>{let o=s.reason;g.error(`- ${o.filename}: ${o.error_description} (${o.error})`)})):g.info(ie.green(`Uploaded ${t.length} files successfully for template ${e}.
10
+ `))}async function pe(e,t,r,s=!1,o={}){let n={...Ye,...o},p=new He({concurrency:Y}),i=await Ve(t),a=i.length,c={},u=rt(),f=0;for(let m of i){let P=N.relative(t,m),l=await tt(m);c[P]=l}s&&(g.info(`Dry run mode enabled. Skipping upload.
11
+ `),g.info("The following files would have been uploaded:"),i.forEach(m=>g.info(`- ${m}`)),process.exit(0));let S=Je(`Uploading ${a} files...`).start(),$=i.map(m=>{let P=N.resolve(t,m),l=N.relative(t,m),T=`${x}/v1/templates/${e}/upload/${u}`;return p.add(async()=>{let C=await Qe(P,l,T,e,S,r,n);return f++,C})}),L=await Promise.allSettled($);S.stop();let w=L.filter(m=>m.status==="fulfilled"),_=L.filter(m=>m.status==="rejected");if(et(e,w.map(m=>m.value),_),!_.length&&w.length){let m=`${x}/v1/templates/${e}/upload/${u}/finalize`,l=await I(m,{signatures:c});if(l.isError)return g.error(`Failed to finalize upload: ${l.data.error_description} (${l.data.error})`),{filesCount:a,uploadedFiles:w.map(T=>T.value),failedFiles:[],success:!1}}return{filesCount:a,uploadedFiles:w.map(m=>m.value),failedFiles:_,success:_.length===0}}async function tt(e){let t=await Me.subtle.digest("SHA-1",j.readFileSync(e));return Array.from(new Uint8Array(t)).map(r=>r.toString(16).padStart(2,"0")).join("")}function rt(){let e=Xe("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",5),t=new Date,r=t.getUTCFullYear(),s=(t.getUTCMonth()+1).toString().padStart(2,"0"),o=t.getUTCDate().toString().padStart(2,"0"),n=t.getUTCHours().toString().padStart(2,"0"),p=t.getUTCMinutes().toString().padStart(2,"0"),i=t.getUTCSeconds().toString().padStart(2,"0");return`${r}${s}${o}${n}${p}${i}_${e()}`}W();R();import ge from"node:path";import{Type as d}from"@sinclair/typebox";var ce=d.Object({id:d.Optional(d.String({title:"Template ID",description:"A unique identifier for the template. Can be any string, but should be unique."})),name:d.String({title:"Template Name"}),description:d.Optional(d.String({title:"Show template description"})),readme:d.Optional(d.Record(d.RegExp(/^[a-z]{2}$/),d.String(),{title:"Readme texts.",description:"A dictionary of readme files for different languages (iso 2 letters code). Currently on supported for 'en' and 'fr'."})),tags:d.Optional(d.Array(d.String(),{title:"Tags"})),author:d.Optional(d.String({title:"Author name"})),thumbnail:d.Optional(d.String({title:"Thumbnail",description:"A URL to the thumbnail image for the template."})),homepage:d.Optional(d.String({title:"Homepage",description:"A URL to the homepage of the template."}))});M();import st from"node:fs";import{readFile as ot}from"node:fs/promises";import nt from"fast-glob";import{fromError as it}from"zod-validation-error";import{basename as le,dirname as at,extname as pt}from"node:path";async function ue(e,t=g){st.existsSync(e)||(t.error(`\u{1F534} No enpage.config.js found!
12
12
  Your project must have an enpage.config.js file in the root directory.
13
13
 
14
- `),process.exit(1));let r=await import(e),o=at(e),s={},n=await nt(["README.enpage.md","README.enpage.*.md"],{cwd:o,onlyFiles:!0,absolute:!0,caseSensitiveMatch:!1});for(let p of n){let i=le(p,".md"),a=pt(i),c=(a===".enpage"?"en":a.substring(1)).toLowerCase();t.debug(`Found template readme file (${c}): ${le(p)}`),s[c]=await st(p,"utf-8")}return r.manifest&&(r.manifest.readme=s),r}function de(e,t){for(let o in e.datasources)if(e.datasources[o].provider==="json"&&!e.datasources[o].sampleData)throw t.error(`\u{1F534} Error: Datasource "${o}" is missing sample data - nothing will be rendered during development! Please check your enpage.config.js file and add a "sampleData" key to your ${o} datasource.`),new Error(`Missing sample data for datasource "${o}"`);let r=ce.safeParse(e.manifest);if(!r.success){t.error(`\u{1F534} Error: template manifest is invalid. Check your call to defineManifest().
15
- `);let o=it(r.error);t.error(`Hint: ${o.toString()}
14
+ `),process.exit(1));let r=await import(e),s=at(e),o={},n=await nt(["README.enpage.md","README.enpage.*.md"],{cwd:s,onlyFiles:!0,absolute:!0,caseSensitiveMatch:!1});for(let p of n){let i=le(p,".md"),a=pt(i),c=(a===".enpage"?"en":a.substring(1)).toLowerCase();t.debug(`Found template readme file (${c}): ${le(p)}`),o[c]=await ot(p,"utf-8")}return r.manifest&&(r.manifest.readme=o),r}function de(e,t){for(let s in e.datasources)if(e.datasources[s].provider==="json"&&!e.datasources[s].sampleData)throw t.error(`\u{1F534} Error: Datasource "${s}" is missing sample data - nothing will be rendered during development! Please check your enpage.config.js file and add a "sampleData" key to your ${s} datasource.`),new Error(`Missing sample data for datasource "${s}"`);let r=ce.safeParse(e.manifest);if(!r.success){t.error(`\u{1F534} Error: template manifest is invalid. Check your call to defineManifest().
15
+ `);let s=it(r.error);t.error(`Hint: ${s.toString()}
16
16
 
17
- `),process.exit(1)}return e}R();G();async function me(e=!1){let t=y.get("access_token"),r=y.get("expires_at");if(!t)return!1;if(r&&r<Date.now())return console.log("Seems like your token expired..."),!1;if(!e)return!0;let{get:o}=await Promise.resolve().then(()=>(W(),ne)),{isSuccess:s}=await o(K);return s}async function _r({options:e,args:t,logger:r}){if(!await me(!0)){let f=F();r.error(` ${E.redBright("Error")}: User token not found. Please run ${E.cyan(`${f} run enpage:login`)} to authenticate or set the ${E.cyan("ENPAGE_API_TOKEN")} environment variable.
18
- `),process.exit(1)}let o=t.length?ge.isAbsolute(t[0])?t[0]:h(process.cwd(),t[0]):process.cwd();D(o)||(r.error(` Template directory not found: ${o}. Aborting.
19
- `),process.exit(1));let s=t.length>1?ge.isAbsolute(t[1])?t[1]:h(process.cwd(),t[1]):h(o,"dist");D(s)||(r.error(` Dist directory not found: ${s}.
17
+ `),process.exit(1)}return e}R();G();async function me(e=!1){let t=y.get("access_token"),r=y.get("expires_at");if(!t)return!1;if(r&&r<Date.now())return console.log("Seems like your token expired..."),!1;if(!e)return!0;let{get:s}=await Promise.resolve().then(()=>(W(),ne)),{isSuccess:o}=await s(K);return o}async function _r({options:e,args:t,logger:r}){if(!await me(!0)){let f=F();r.error(` ${E.redBright("Error")}: User token not found. Please run ${E.cyan(`${f} run enpage:login`)} to authenticate or set the ${E.cyan("ENPAGE_API_TOKEN")} environment variable.
18
+ `),process.exit(1)}let s=t.length?ge.isAbsolute(t[0])?t[0]:h(process.cwd(),t[0]):process.cwd();D(s)||(r.error(` Template directory not found: ${s}. Aborting.
19
+ `),process.exit(1));let o=t.length>1?ge.isAbsolute(t[1])?t[1]:h(process.cwd(),t[1]):h(s,"dist");D(o)||(r.error(` Dist directory not found: ${o}.
20
20
  Please run 'build' before publishing. Aborting.
21
- `),process.exit(1)),D(h(o,"enpage.config.js"))||(r.error(` ${E.redBright("Error")}: file enpage.config.js not found in ${o}. Aborting.
22
- `),process.exit(1));let n=await ue(h(o,"enpage.config.js"),r);de(n,r);let p=Q(),i=ut(o);i||(r.error(` ${E.redBright("Error")}: package.json file not found in ${o}. Aborting.
23
- `),process.exit(1));let a=await dt(i);if(a||(r.error(` ${E.redBright("Error")}: cannot read/parse package.json file in ${o}. Aborting.
21
+ `),process.exit(1)),D(h(s,"enpage.config.js"))||(r.error(` ${E.redBright("Error")}: file enpage.config.js not found in ${s}. Aborting.
22
+ `),process.exit(1));let n=await ue(h(s,"enpage.config.js"),r);de(n,r);let p=Q(),i=ut(s);i||(r.error(` ${E.redBright("Error")}: package.json file not found in ${s}. Aborting.
23
+ `),process.exit(1));let a=await dt(i);if(a||(r.error(` ${E.redBright("Error")}: cannot read/parse package.json file in ${s}. Aborting.
24
24
  `),process.exit(1)),!a.enpage?.id){let{data:f,isError:S,status:$}=await I(V,{manifest:n.manifest});S&&(r.error(` ${E.redBright("Error")}: Cannot register template: ${J(f)}
25
- `),process.exit(1)),a.enpage??={},a.enpage.id=f.template.id;try{e.dryRun||lt(i,JSON.stringify(a,null,2))}catch{r.error(` ${E.redBright("Error")}: Cannot update template id in package.json file located in ${o}. Aborting.
25
+ `),process.exit(1)),a.enpage??={},a.enpage.id=f.template.id;try{e.dryRun||lt(i,JSON.stringify(a,null,2))}catch{r.error(` ${E.redBright("Error")}: Cannot update template id in package.json file located in ${s}. Aborting.
26
26
  `),process.exit(1)}}let c=a.enpage.id;r.info(`Submitting template to Enpage...
27
- `),(await pe(c,o,p,e.dryRun)).success||(r.error(`
27
+ `),(await pe(c,s,p,e.dryRun)).success||(r.error(`
28
28
  Upload failed. See details above.
29
29
  `),process.exit(1)),r.success(`Template ${c} published.
30
30
  `)}function ut(e){return D(h(e,"package.json"))?h(e,"package.json"):D(h(e,"template-package.json"))?h(e,"template-package.json"):!1}function dt(e){try{return JSON.parse(ct(e,"utf-8"))}catch{return null}}export{_r as publish};
@@ -1,14 +1,14 @@
1
1
  /*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/upstart-gg/upstart/blob/main/LICENSE */
2
2
 
3
- import b from"node:path";import L from"node:fs";import ge from"node:crypto";import me from"fast-glob";var I="upstart-cli";var Oe=process.env.PUBLIC_UPSTART_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",y=process.env.PUBLIC_UPSTART_API_BASE_URL??"https://api.upstart.gg",Ae=process.env.PUBLIC_UPSTART_EDITOR_BASE_URL??"https://upstart.gg",N=10;import B from"node:http";import fe from"node:https";import{pipeline as ye}from"node:stream";import{createLogger as q}from"vite";var D="0.0.88";import _ from"chalk";function H(e,t,n=!1){let i=q(e==="debug"?"info":e,{prefix:"[upstart]",allowClearScreen:t});return n&&i.info(_.hex("#7270c6").bold(`\u{1F680} Upstart v${D}
3
+ import L from"node:path";import b from"node:fs";import ge from"node:crypto";import me from"fast-glob";var I="upstart-cli";var Oe=process.env.PUBLIC_UPSTART_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",y=process.env.PUBLIC_UPSTART_API_BASE_URL??"https://api.upstart.gg",Ae=process.env.PUBLIC_UPSTART_EDITOR_BASE_URL??"https://upstart.gg",N=10;import B from"node:http";import fe from"node:https";import{pipeline as ye}from"node:stream";import{createLogger as q}from"vite";var D="0.0.90";import _ from"chalk";function H(e,t,n=!1){let i=q(e==="debug"?"info":e,{prefix:"[upstart]",allowClearScreen:t});return n&&i.info(_.hex("#7270c6").bold(`\u{1F680} Upstart v${D}
4
4
  `)),{...i,success:(r,s)=>i.info(_.green(r),s),error:(r,s)=>i.error(_.red(r),s),warn:(r,s)=>i.warn(_.yellow(r),s),warnOnce:(r,s)=>i.warnOnce(_.yellow(r),s),debug:(r,s)=>{e==="debug"&&i.info(_.gray(r),s)}}}var g=H();import z from"chalk";import he from"form-data";import*as C from"node:fs";var X=/[<>"|?*\n\r\t\f\x00-\x1F]/,J=/(?:^|\/)[*]{2}($|\/)/,V=248,K=e=>e!==null&&typeof e=="object"&&!Array.isArray(e),Y=e=>typeof e=="string"&&e.length<=V&&!X.test(e),Q=e=>e.split(/\r\n?|\n/);var Z=e=>K(e)&&Array.isArray(e.patterns)&&Array.isArray(e.sections);var k=(e,t={})=>{let n=t.path;if(Z(e))return e;Y(e)&&C.existsSync(e)&&(n=e,e=C.readFileSync(e,"utf8"));let i=Q(e),r=new Map,s={sections:[],patterns:[]},c={name:"default",patterns:[]},o=null;for(let a of i){let p=a.trim();if(p.startsWith("#")){let[,u]=/^#+\s*(.*)\s*$/.exec(p)||[];if(o){r.delete(o.name),o.comment=o.comment?`${o.comment}
5
5
  ${p}`:p,o.name=u?`${o.name.trim()}
6
6
  ${u.trim()}`:o.name.trim(),r.set(o.name.toLowerCase().trim(),o);continue}c={name:u?.trim()||"",comment:p,patterns:[]},r.set(c.name.toLowerCase(),c),s.sections.push(c),o=c;continue}p!==""&&(c.patterns.push(p),s.patterns.push(p)),o=null}return(t.dedupe===!0||t.unique===!0)&&(s=G(s,{...t,format:!1})),s.path=n,s.input=Buffer.from(e),s.format=a=>se(s,{...t,...a}),s.dedupe=a=>G(s,{...t,...a}),s.globs=a=>te(s,{path:n,...t,...a}),s};var G=(e,t)=>{let n=k(e,{...t,dedupe:!1}),i=new Map,r={sections:[],patterns:[]},s;for(let c of n.sections){let{name:o="",comment:a,patterns:p}=c,u=o.trim().toLowerCase();for(let h of p)r.patterns.includes(h)||r.patterns.push(h);o&&i.has(u)?(s=i.get(u),s.patterns=[...s.patterns,...p]):(s={name:o,comment:a,patterns:p},r.sections.push(s),i.set(u,s))}for(let c of r.sections)c.patterns=[...new Set(c.patterns)];return r},ee=e=>{if(J.test(e))return e;let t=!1;return e.startsWith("/")?(e=e.slice(1),t=!0):e.slice(1,e.length-1).includes("/")&&(t=!0),e+=e.endsWith("/")?"**/":"/**",t?e:`**/${e}`},te=(e,t={})=>{let n=k(e,t),i=[],r=0,s=n.patterns.concat(t.ignore||[]).concat((t.unignore||[]).map(o=>o.startsWith("!")?o:`!${o}`)),c=(o,a)=>{let p=i[i.length-1],u=o?"unignore":"ignore";p&&p.type===u?p.patterns.includes(a)||p.patterns.push(a):(i.push({type:u,path:t.path||null,patterns:[a],index:r}),r++)};for(let o of s){let a="";o.startsWith("!")&&(o=o.slice(1),a="!"),c(a,o.startsWith("/")?o.slice(1):o),c(a,ee(o))}return i},re=(e={name:"",patterns:[]})=>{let t=[e.comment||""];return e.patterns?.length&&(t.push(e.patterns.join(`
7
7
  `)),t.push("")),t.join(`
8
8
  `)},se=(e,t={})=>{let n=k(e,t),i=t.formatSection||re,r=n.sections||n,s=[];for(let c of[].concat(r))s.push(i(c));return s.join(`
9
- `)};var j=k;import Se from"p-queue";import Pe from"ora";import{customAlphabet as Te}from"nanoid";import oe from"conf";import U from"node:path";import ne from"node:crypto";import E from"node:fs";import{fileURLToPath as ie}from"node:url";import He from"chalk";var ae=ie(new URL(".",import.meta.url)),ce=le(),$=new oe({projectName:I,encryptionKey:ce,clearInvalidConfig:!0});function pe(){let e=ae;for(;e!==U.parse(e).root;){let t=U.join(e,"node_modules");if(E.existsSync(t))return t;e=U.dirname(e)}return null}function le(){let e=pe();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=U.join(e,".enpage-tmp");E.existsSync(t)||E.mkdirSync(t,{recursive:!0,mode:448});let n=U.join(t,".enpage-key");if(!E.existsSync(n)){let r=ne.randomBytes(32).toString("hex");return E.writeFileSync(n,r,{mode:384,flush:!0}),r}return E.readFileSync(n,"utf8")}async function F(e,t,n={}){$.get("access_token")&&(n.Authorization=`Bearer ${$.get("access_token")}`);let i=await fetch(ue(e),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...n},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(r=>{g.error(`Fatal Error requesting API: ${r.message} (${r.cause.code})`),g.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return de(i)}function ue(e){let t=new URL(y.endsWith("/")?y:`${y}/`);return new URL(e,t)}async function de(e){let t=e.headers.get("content-type")?.startsWith("application/json")?await e.json():await e.text();return e.ok?{isSuccess:!0,isError:!1,status:e.status,statusText:e.statusText,data:t}:{isSuccess:!1,isError:!0,status:e.status,statusText:e.statusText,data:t}}var R=class extends Error{constructor(n,i,r){super(`${n}: ${i}`);this.error=n;this.error_description=i;this.filename=r;this.name="UploadError"}},_e={maxDataSize:12*1024*1024,retryAttempts:2,retryDelay:1e3},Ee=new B.Agent({keepAlive:!0,maxSockets:10,keepAliveMsecs:3e3});async function Re(e){let t=b.join(e,".gitignore"),i=L.existsSync(t)?j(L.readFileSync(t,"utf-8")).patterns:[];return me("**/*",{cwd:e,onlyFiles:!0,dot:!0,absolute:!0,ignore:["node_modules/**",".cache/**","**/.DS_Store",".gitignore",".env",".env.*",".git/**","dist/**",...i]})}async function we(e,t,n,i,r,s,c){let o=async a=>{try{return await xe(e,t,n,i,r,s,c)}catch(p){if(a<c.retryAttempts)return g.warn(`Retrying upload for ${t} (attempt ${a+1})`),await new Promise(u=>setTimeout(u,c.retryDelay)),o(a+1);throw p}};return o(0)}async function xe(e,t,n,i,r,s,c){return new Promise((o,a)=>{let p=L.statSync(e),u=b.basename(e),h=Date.now(),S=new he({maxDataSize:c.maxDataSize}),O=L.createReadStream(e),A=0,P=l=>{A+=l.length};O.on("data",P),S.append("file",O,{filename:u,knownLength:p.size});let T={agent:Ee,method:"POST",headers:{authorization:`Bearer ${s}`,"x-upstart-template-file-path":t,"x-upstart-template-id":i,...S.getHeaders()}},f=(n.startsWith("https")?fe:B).request(n,T,l=>{let m="";l.on("data",w=>{m+=w}),l.on("end",()=>{let w=Date.now(),W={fileName:u,fileSize:p.size,uploadDuration:w-h,statusCode:l.statusCode??0,serverResponse:m};if(l.statusCode&&l.statusCode>=200&&l.statusCode<300)r.text=`Uploaded ${t}`,o(W);else{let x;if(l.headers["content-type"]?.startsWith("application/json")){let v=JSON.parse(m);x=new R(v.error||"unknown_error",v.error_description||"Unknown error occurred",t)}else x=new R("unknown_error",m||"Unknown error occurred",t);r.fail(`Failed to upload ${t} [${x.error}] ${x.error_description}`),a(x)}})});f.on("error",l=>{a(new R("request_error",l.message,t))}),ye(S,f,l=>{l&&a(new R("pipeline_error",`Pipeline failed for ${u}: ${l.message}`,t))})})}function Ue(e,t,n){n.length>0?(g.error(z.red(`Failed to upload ${n.length} files:`)),n.forEach(i=>{let r=i.reason;g.error(`- ${r.filename}: ${r.error_description} (${r.error})`)})):g.info(z.green(`Uploaded ${t.length} files successfully for template ${e}.
10
- `))}async function mt(e,t,n,i=!1,r={}){let s={..._e,...r},c=new Se({concurrency:N}),o=await Re(t),a=o.length,p={},u=Le(),h=0;for(let d of o){let f=b.relative(t,d),l=await be(d);p[f]=l}i&&(g.info(`Dry run mode enabled. Skipping upload.
11
- `),g.info("The following files would have been uploaded:"),o.forEach(d=>g.info(`- ${d}`)),process.exit(0));let S=Pe(`Uploading ${a} files...`).start(),O=o.map(d=>{let f=b.resolve(t,d),l=b.relative(t,d),m=`${y}/v1/templates/${e}/upload/${u}`;return c.add(async()=>{let w=await we(f,l,m,e,S,n,s);return h++,w})}),A=await Promise.allSettled(O);S.stop();let P=A.filter(d=>d.status==="fulfilled"),T=A.filter(d=>d.status==="rejected");if(Ue(e,P.map(d=>d.value),T),!T.length&&P.length){let d=`${y}/v1/templates/${e}/upload/${u}/finalize`,l=await F(d,{signatures:p});if(l.isError)return g.error(`Failed to finalize upload: ${l.data.error_description} (${l.data.error})`),{filesCount:a,uploadedFiles:P.map(m=>m.value),failedFiles:[],success:!1}}return{filesCount:a,uploadedFiles:P.map(d=>d.value),failedFiles:T,success:T.length===0}}async function be(e){let t=await ge.subtle.digest("SHA-1",L.readFileSync(e));return Array.from(new Uint8Array(t)).map(n=>n.toString(16).padStart(2,"0")).join("")}function Le(){let e=Te("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",5),t=new Date,n=t.getUTCFullYear(),i=(t.getUTCMonth()+1).toString().padStart(2,"0"),r=t.getUTCDate().toString().padStart(2,"0"),s=t.getUTCHours().toString().padStart(2,"0"),c=t.getUTCMinutes().toString().padStart(2,"0"),o=t.getUTCSeconds().toString().padStart(2,"0");return`${n}${i}${r}${s}${c}${o}_${e()}`}export{mt as uploadTemplate};
9
+ `)};var j=k;import Se from"p-queue";import Pe from"ora";import{customAlphabet as Te}from"nanoid";import oe from"conf";import U from"node:path";import ne from"node:crypto";import E from"node:fs";import{fileURLToPath as ie}from"node:url";import He from"chalk";var ae=ie(new URL(".",import.meta.url)),ce=le(),$=new oe({projectName:I,encryptionKey:ce,clearInvalidConfig:!0});function pe(){let e=ae;for(;e!==U.parse(e).root;){let t=U.join(e,"node_modules");if(E.existsSync(t))return t;e=U.dirname(e)}return null}function le(){let e=pe();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=U.join(e,".enpage-tmp");E.existsSync(t)||E.mkdirSync(t,{recursive:!0,mode:448});let n=U.join(t,".enpage-key");if(!E.existsSync(n)){let r=ne.randomBytes(32).toString("hex");return E.writeFileSync(n,r,{mode:384}),r}return E.readFileSync(n,"utf8")}async function F(e,t,n={}){$.get("access_token")&&(n.Authorization=`Bearer ${$.get("access_token")}`);let i=await fetch(ue(e),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...n},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(r=>{g.error(`Fatal Error requesting API: ${r.message} (${r.cause.code})`),g.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return de(i)}function ue(e){let t=new URL(y.endsWith("/")?y:`${y}/`);return new URL(e,t)}async function de(e){let t=e.headers.get("content-type")?.startsWith("application/json")?await e.json():await e.text();return e.ok?{isSuccess:!0,isError:!1,status:e.status,statusText:e.statusText,data:t}:{isSuccess:!1,isError:!0,status:e.status,statusText:e.statusText,data:t}}var R=class extends Error{constructor(n,i,r){super(`${n}: ${i}`);this.error=n;this.error_description=i;this.filename=r;this.name="UploadError"}},_e={maxDataSize:12*1024*1024,retryAttempts:2,retryDelay:1e3},Ee=new B.Agent({keepAlive:!0,maxSockets:10,keepAliveMsecs:3e3});async function Re(e){let t=L.join(e,".gitignore"),i=b.existsSync(t)?j(b.readFileSync(t,"utf-8")).patterns:[];return me("**/*",{cwd:e,onlyFiles:!0,dot:!0,absolute:!0,ignore:["node_modules/**",".cache/**","**/.DS_Store",".gitignore",".env",".env.*",".git/**","dist/**",...i]})}async function we(e,t,n,i,r,s,c){let o=async a=>{try{return await xe(e,t,n,i,r,s,c)}catch(p){if(a<c.retryAttempts)return g.warn(`Retrying upload for ${t} (attempt ${a+1})`),await new Promise(u=>setTimeout(u,c.retryDelay)),o(a+1);throw p}};return o(0)}async function xe(e,t,n,i,r,s,c){return new Promise((o,a)=>{let p=b.statSync(e),u=L.basename(e),h=Date.now(),S=new he({maxDataSize:c.maxDataSize}),O=b.createReadStream(e),A=0,P=l=>{A+=l.length};O.on("data",P),S.append("file",O,{filename:u,knownLength:p.size});let T={agent:Ee,method:"POST",headers:{authorization:`Bearer ${s}`,"x-upstart-template-file-path":t,"x-upstart-template-id":i,...S.getHeaders()}},f=(n.startsWith("https")?fe:B).request(n,T,l=>{let m="";l.on("data",w=>{m+=w}),l.on("end",()=>{let w=Date.now(),W={fileName:u,fileSize:p.size,uploadDuration:w-h,statusCode:l.statusCode??0,serverResponse:m};if(l.statusCode&&l.statusCode>=200&&l.statusCode<300)r.text=`Uploaded ${t}`,o(W);else{let x;if(l.headers["content-type"]?.startsWith("application/json")){let v=JSON.parse(m);x=new R(v.error||"unknown_error",v.error_description||"Unknown error occurred",t)}else x=new R("unknown_error",m||"Unknown error occurred",t);r.fail(`Failed to upload ${t} [${x.error}] ${x.error_description}`),a(x)}})});f.on("error",l=>{a(new R("request_error",l.message,t))}),ye(S,f,l=>{l&&a(new R("pipeline_error",`Pipeline failed for ${u}: ${l.message}`,t))})})}function Ue(e,t,n){n.length>0?(g.error(z.red(`Failed to upload ${n.length} files:`)),n.forEach(i=>{let r=i.reason;g.error(`- ${r.filename}: ${r.error_description} (${r.error})`)})):g.info(z.green(`Uploaded ${t.length} files successfully for template ${e}.
10
+ `))}async function mt(e,t,n,i=!1,r={}){let s={..._e,...r},c=new Se({concurrency:N}),o=await Re(t),a=o.length,p={},u=be(),h=0;for(let d of o){let f=L.relative(t,d),l=await Le(d);p[f]=l}i&&(g.info(`Dry run mode enabled. Skipping upload.
11
+ `),g.info("The following files would have been uploaded:"),o.forEach(d=>g.info(`- ${d}`)),process.exit(0));let S=Pe(`Uploading ${a} files...`).start(),O=o.map(d=>{let f=L.resolve(t,d),l=L.relative(t,d),m=`${y}/v1/templates/${e}/upload/${u}`;return c.add(async()=>{let w=await we(f,l,m,e,S,n,s);return h++,w})}),A=await Promise.allSettled(O);S.stop();let P=A.filter(d=>d.status==="fulfilled"),T=A.filter(d=>d.status==="rejected");if(Ue(e,P.map(d=>d.value),T),!T.length&&P.length){let d=`${y}/v1/templates/${e}/upload/${u}/finalize`,l=await F(d,{signatures:p});if(l.isError)return g.error(`Failed to finalize upload: ${l.data.error_description} (${l.data.error})`),{filesCount:a,uploadedFiles:P.map(m=>m.value),failedFiles:[],success:!1}}return{filesCount:a,uploadedFiles:P.map(d=>d.value),failedFiles:T,success:T.length===0}}async function Le(e){let t=await ge.subtle.digest("SHA-1",b.readFileSync(e));return Array.from(new Uint8Array(t)).map(n=>n.toString(16).padStart(2,"0")).join("")}function be(){let e=Te("0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz",5),t=new Date,n=t.getUTCFullYear(),i=(t.getUTCMonth()+1).toString().padStart(2,"0"),r=t.getUTCDate().toString().padStart(2,"0"),s=t.getUTCHours().toString().padStart(2,"0"),c=t.getUTCMinutes().toString().padStart(2,"0"),o=t.getUTCSeconds().toString().padStart(2,"0");return`${n}${i}${r}${s}${c}${o}_${e()}`}export{mt as uploadTemplate};
12
12
  /*!
13
13
  * parse-gitignore <https://github.com/jonschlinkert/parse-gitignore>
14
14
  * Copyright (c) 2015-present, Jon Schlinkert.
@@ -1,4 +1,4 @@
1
1
  /*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/upstart-gg/upstart/blob/main/LICENSE */
2
2
 
3
- var O=Object.defineProperty;var p=(e,t)=>()=>(e&&(t=e(e=0)),t);var S=(e,t)=>{for(var s in t)O(e,s,{get:t[s],enumerable:!0})};var y,M,g,$,f,m=p(()=>{"use strict";y="upstart-cli",M=process.env.PUBLIC_UPSTART_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",g=process.env.PUBLIC_UPSTART_API_BASE_URL??"https://api.upstart.gg",$=process.env.PUBLIC_UPSTART_EDITOR_BASE_URL??"https://upstart.gg",f="oauth/userinfo"});import k from"conf";import u from"node:path";import P from"node:crypto";import a from"node:fs";import{fileURLToPath as I}from"node:url";import X from"chalk";function w(){let e=U;for(;e!==u.parse(e).root;){let t=u.join(e,"node_modules");if(a.existsSync(t))return t;e=u.dirname(e)}return null}function b(){let e=w();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=u.join(e,".enpage-tmp");a.existsSync(t)||a.mkdirSync(t,{recursive:!0,mode:448});let s=u.join(t,".enpage-key");if(!a.existsSync(s)){let r=P.randomBytes(32).toString("hex");return a.writeFileSync(s,r,{mode:384,flush:!0}),r}return a.readFileSync(s,"utf8")}var U,v,i,l=p(()=>{"use strict";m();U=I(new URL(".",import.meta.url)),v=b(),i=new k({projectName:y,encryptionKey:v,clearInvalidConfig:!0})});var h,T=p(()=>{h="0.0.88"});import{createLogger as A}from"vite";import c from"chalk";function C(e,t,s=!1){let o=A(e==="debug"?"info":e,{prefix:"[upstart]",allowClearScreen:t});return s&&o.info(c.hex("#7270c6").bold(`\u{1F680} Upstart v${h}
4
- `)),{...o,success:(r,n)=>o.info(c.green(r),n),error:(r,n)=>o.error(c.red(r),n),warn:(r,n)=>o.warn(c.yellow(r),n),warnOnce:(r,n)=>o.warnOnce(c.yellow(r),n),debug:(r,n)=>{e==="debug"&&o.info(c.gray(r),n)}}}var d,_=p(()=>{"use strict";T();d=C()});var x={};S(x,{get:()=>j,post:()=>D});async function D(e,t,s={}){i.get("access_token")&&(s.Authorization=`Bearer ${i.get("access_token")}`);let o=await fetch(E(e),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...s},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(r=>{d.error(`Fatal Error requesting API: ${r.message} (${r.cause.code})`),d.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return L(o)}async function j(e,t={}){i.get("access_token")&&(t.Authorization=`Bearer ${i.get("access_token")}`);let s=await fetch(E(e),{headers:t,method:"GET"}).catch(o=>{d.error(`Fatal Error requesting API: ${o.message} (${o.cause.code})`),d.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return L(s)}function E(e){let t=new URL(g.endsWith("/")?g:`${g}/`);return new URL(e,t)}async function L(e){let t=e.headers.get("content-type")?.startsWith("application/json")?await e.json():await e.text();return e.ok?{isSuccess:!0,isError:!1,status:e.status,statusText:e.statusText,data:t}:{isSuccess:!1,isError:!0,status:e.status,statusText:e.statusText,data:t}}var R=p(()=>{"use strict";_();m();l()});m();l();async function ce(e=!1){let t=i.get("access_token"),s=i.get("expires_at");if(!t)return!1;if(s&&s<Date.now())return console.log("Seems like your token expired..."),!1;if(!e)return!0;let{get:o}=await Promise.resolve().then(()=>(R(),x)),{isSuccess:r}=await o(f);return r}export{ce as isLoggedIn};
3
+ var O=Object.defineProperty;var c=(e,t)=>()=>(e&&(t=e(e=0)),t);var S=(e,t)=>{for(var s in t)O(e,s,{get:t[s],enumerable:!0})};var y,M,g,$,f,m=c(()=>{"use strict";y="upstart-cli",M=process.env.PUBLIC_UPSTART_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",g=process.env.PUBLIC_UPSTART_API_BASE_URL??"https://api.upstart.gg",$=process.env.PUBLIC_UPSTART_EDITOR_BASE_URL??"https://upstart.gg",f="oauth/userinfo"});import k from"conf";import u from"node:path";import P from"node:crypto";import a from"node:fs";import{fileURLToPath as I}from"node:url";import X from"chalk";function w(){let e=U;for(;e!==u.parse(e).root;){let t=u.join(e,"node_modules");if(a.existsSync(t))return t;e=u.dirname(e)}return null}function N(){let e=w();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=u.join(e,".enpage-tmp");a.existsSync(t)||a.mkdirSync(t,{recursive:!0,mode:448});let s=u.join(t,".enpage-key");if(!a.existsSync(s)){let r=P.randomBytes(32).toString("hex");return a.writeFileSync(s,r,{mode:384}),r}return a.readFileSync(s,"utf8")}var U,v,i,l=c(()=>{"use strict";m();U=I(new URL(".",import.meta.url)),v=N(),i=new k({projectName:y,encryptionKey:v,clearInvalidConfig:!0})});var _,T=c(()=>{_="0.0.90"});import{createLogger as b}from"vite";import p from"chalk";function C(e,t,s=!1){let o=b(e==="debug"?"info":e,{prefix:"[upstart]",allowClearScreen:t});return s&&o.info(p.hex("#7270c6").bold(`\u{1F680} Upstart v${_}
4
+ `)),{...o,success:(r,n)=>o.info(p.green(r),n),error:(r,n)=>o.error(p.red(r),n),warn:(r,n)=>o.warn(p.yellow(r),n),warnOnce:(r,n)=>o.warnOnce(p.yellow(r),n),debug:(r,n)=>{e==="debug"&&o.info(p.gray(r),n)}}}var d,h=c(()=>{"use strict";T();d=C()});var x={};S(x,{get:()=>j,post:()=>D});async function D(e,t,s={}){i.get("access_token")&&(s.Authorization=`Bearer ${i.get("access_token")}`);let o=await fetch(E(e),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...s},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(r=>{d.error(`Fatal Error requesting API: ${r.message} (${r.cause.code})`),d.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return L(o)}async function j(e,t={}){i.get("access_token")&&(t.Authorization=`Bearer ${i.get("access_token")}`);let s=await fetch(E(e),{headers:t,method:"GET"}).catch(o=>{d.error(`Fatal Error requesting API: ${o.message} (${o.cause.code})`),d.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return L(s)}function E(e){let t=new URL(g.endsWith("/")?g:`${g}/`);return new URL(e,t)}async function L(e){let t=e.headers.get("content-type")?.startsWith("application/json")?await e.json():await e.text();return e.ok?{isSuccess:!0,isError:!1,status:e.status,statusText:e.statusText,data:t}:{isSuccess:!1,isError:!0,status:e.status,statusText:e.statusText,data:t}}var R=c(()=>{"use strict";h();m();l()});m();l();async function pe(e=!1){let t=i.get("access_token"),s=i.get("expires_at");if(!t)return!1;if(s&&s<Date.now())return console.log("Seems like your token expired..."),!1;if(!e)return!0;let{get:o}=await Promise.resolve().then(()=>(R(),x)),{isSuccess:r}=await o(f);return r}export{pe as isLoggedIn};