@upstart.gg/sdk 0.0.69 → 0.0.71
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/node/cli/api.js +1 -1
- package/dist/node/cli/commands/login/cmd-login.js +4 -4
- package/dist/node/cli/commands/publish/cmd-publish.js +17 -17
- package/dist/node/cli/commands/publish/uploader.js +5 -5
- package/dist/node/cli/is-logged-in.js +1 -1
- package/dist/node/cli/program.js +1 -1
- package/dist/node/shared/config.js +5 -5
- package/dist/node/shared/logger.js +2 -2
- package/dist/shared/ajv.d.ts +1 -0
- package/dist/shared/ajv.d.ts.map +1 -1
- package/dist/shared/ajv.js +3 -0
- package/dist/shared/attributes.d.ts +32 -29
- package/dist/shared/attributes.d.ts.map +1 -1
- package/dist/shared/attributes.js +1 -1
- package/dist/shared/bricks.d.ts.map +1 -1
- package/dist/shared/chunk-6PCNIIO5.js +3 -0
- package/dist/shared/chunk-EK4FWGFA.js +3 -0
- package/dist/shared/page.d.ts +137 -17
- package/dist/shared/page.d.ts.map +1 -1
- package/dist/shared/page.js +1 -1
- package/dist/shared/tests/page.test.d.ts +2 -0
- package/dist/shared/tests/page.test.d.ts.map +1 -0
- package/dist/shared/tests/test-config.d.ts +3 -0
- package/dist/shared/tests/test-config.d.ts.map +1 -0
- package/dist/shared/utils/schema.d.ts +4 -0
- package/dist/shared/utils/schema.d.ts.map +1 -0
- package/package.json +16 -17
- package/dist/node/metafile-esm.json +0 -1
- package/dist/shared/chunk-CXABUYX7.js +0 -3
- package/dist/shared/metafile-esm.json +0 -1
package/dist/node/cli/api.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
2
|
|
|
3
|
-
import{createLogger as E}from"vite";var g="0.0.
|
|
3
|
+
import{createLogger as E}from"vite";var g="0.0.71";import i from"chalk";function h(e,t,o=!1){let s=E(e==="debug"?"info":e,{prefix:"[enpage]",allowClearScreen:t});return o&&s.info(i.hex("#7270c6").bold(`\u{1F680} Enpage v${g}
|
|
4
4
|
`)),{...s,success:(r,n)=>s.info(i.green(r),n),error:(r,n)=>s.error(i.red(r),n),warn:(r,n)=>s.warn(i.yellow(r),n),warnOnce:(r,n)=>s.warnOnce(i.yellow(r),n),debug:(r,n)=>{e==="debug"&&s.info(i.gray(r),n)}}}var p=h();var m="enpage-cli";var I=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",u=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",b=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co";import T from"conf";import c from"node:path";import _ from"node:crypto";import a from"node:fs";import{fileURLToPath as L}from"node:url";import F from"chalk";var x=L(new URL(".",import.meta.url)),R=P(),d=new T({projectName:m,encryptionKey:R,clearInvalidConfig:!0});function O(){let e=x;for(;e!==c.parse(e).root;){let t=c.join(e,"node_modules");if(a.existsSync(t))return t;e=c.dirname(e)}return null}function P(){let e=O();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=c.join(e,".enpage-tmp");a.existsSync(t)||a.mkdirSync(t,{recursive:!0,mode:448});let o=c.join(t,".enpage-key");if(!a.existsSync(o)){let r=_.randomBytes(32).toString("hex");return a.writeFileSync(o,r,{mode:384,flush:!0}),r}return a.readFileSync(o,"utf8")}async function J(e,t,o={}){d.get("access_token")&&(o.Authorization=`Bearer ${d.get("access_token")}`);let s=await fetch(l(e),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...o},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(r=>{p.error(`Fatal Error requesting API: ${r.message} (${r.cause.code})`),p.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return y(s)}async function K(e,t={}){d.get("access_token")&&(t.Authorization=`Bearer ${d.get("access_token")}`);let o=await fetch(l(e),{headers:t,method:"GET"}).catch(s=>{p.error(`Fatal Error requesting API: ${s.message} (${s.cause.code})`),p.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return y(o)}function l(e){let t=new URL(u.endsWith("/")?u:`${u}/`);return new URL(e,t)}async function y(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}}export{K as get,J as post};
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
2
|
|
|
3
|
-
import I from"chalk";import{confirm as b}from"@inquirer/prompts";import A from"open";var
|
|
4
|
-
`)),{...o,success:(
|
|
5
|
-
`);let{isError:n,data:o}=await l(_,{client_id:g,scope:"profile,templates:publish"});n&&(e.error("Failed to get device code. Please try again."),e.error(`Error: ${o.error_description??o.error}`),process.exit(1));let{verification_uri:
|
|
3
|
+
import I from"chalk";import{confirm as b}from"@inquirer/prompts";import A from"open";var f="enpage-cli";var g=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",u=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",j=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co";var _="oauth/devicecode",E="oauth/token";import{createLogger as L}from"vite";var h="0.0.71";import i from"chalk";function x(t,e,n=!1){let o=L(t==="debug"?"info":t,{prefix:"[enpage]",allowClearScreen:e});return n&&o.info(i.hex("#7270c6").bold(`\u{1F680} Enpage v${h}
|
|
4
|
+
`)),{...o,success:(r,s)=>o.info(i.green(r),s),error:(r,s)=>o.error(i.red(r),s),warn:(r,s)=>o.warn(i.yellow(r),s),warnOnce:(r,s)=>o.warnOnce(i.yellow(r),s),debug:(r,s)=>{t==="debug"&&o.info(i.gray(r),s)}}}var m=x();import R from"conf";import c from"node:path";import O from"node:crypto";import a from"node:fs";import{fileURLToPath as v}from"node:url";import Q from"chalk";var w=v(new URL(".",import.meta.url)),k=C(),p=new R({projectName:f,encryptionKey:k,clearInvalidConfig:!0});function P(){let t=w;for(;t!==c.parse(t).root;){let e=c.join(t,"node_modules");if(a.existsSync(e))return e;t=c.dirname(t)}return null}function C(){let t=P();if(!t)throw new Error("Could not find nearest node_modules directory.");let e=c.join(t,".enpage-tmp");a.existsSync(e)||a.mkdirSync(e,{recursive:!0,mode:448});let n=c.join(e,".enpage-key");if(!a.existsSync(n)){let r=O.randomBytes(32).toString("hex");return a.writeFileSync(n,r,{mode:384,flush:!0}),r}return a.readFileSync(n,"utf8")}async function l(t,e,n={}){p.get("access_token")&&(n.Authorization=`Bearer ${p.get("access_token")}`);let o=await fetch(N(t),{method:"POST",headers:{"Content-Type":e instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...n},body:e instanceof URLSearchParams?e:JSON.stringify(e)}).catch(r=>{m.error(`Fatal Error requesting API: ${r.message} (${r.cause.code})`),m.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return S(o)}function N(t){let e=new URL(u.endsWith("/")?u:`${u}/`);return new URL(t,e)}async function S(t){let e=t.headers.get("content-type")?.startsWith("application/json")?await t.json():await t.text();return t.ok?{isSuccess:!0,isError:!1,status:t.status,statusText:t.statusText,data:e}:{isSuccess:!1,isError:!0,status:t.status,statusText:t.statusText,data:e}}async function D(t,e){for(;;){let n=new URLSearchParams({grant_type:"device_code",device_code:t,client_id:g}),o=await l(E,n),{data:r,isSuccess:s}=o;if(s)return r;if(r.error==="authorization_pending")await new Promise(y=>setTimeout(y,5e3));else return e.error(`Error while polling for login: ${r.error_description??r.error}`),!1}}async function de({options:t,logger:e}){e.info(`Logging in to Enpage...
|
|
5
|
+
`);let{isError:n,data:o}=await l(_,{client_id:g,scope:"profile,templates:publish"});n&&(e.error("Failed to get device code. Please try again."),e.error(`Error: ${o.error_description??o.error}`),process.exit(1));let{verification_uri:r,device_code:s}=o;await b({message:"Would you like to open the login page in your browser?",default:!0}).catch(U=>{process.exit(0)})?A(r):e.info(`
|
|
6
6
|
Please visit the following URL to login:
|
|
7
|
-
${
|
|
7
|
+
${r}
|
|
8
8
|
`),e.info(I.gray(`
|
|
9
9
|
Waiting for login...
|
|
10
10
|
`));let d=await D(s,e);d||(e.error("Login failed. Please try again."),process.exit(1)),p.set({...d,...d.expires_in?{expires_at:Date.now()+d.expires_in*1e3}:{}}),e.info(`Login successful!
|
|
@@ -1,33 +1,33 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/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="enpage-cli",ft=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",x=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",yt=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",Y=10,K="oauth/userinfo",V="v1/templates"});import Se from"conf";import v from"node:path";import Ee from"node:crypto";import A from"node:fs";import{fileURLToPath as Te}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
|
|
4
|
-
`)),{...o,success:(n
|
|
5
|
-
${
|
|
6
|
-
${d.trim()}`:i.name.trim(),
|
|
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="enpage-cli",ft=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",x=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",yt=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",Y=10,K="oauth/userinfo",V="v1/templates"});import Se from"conf";import v from"node:path";import Ee from"node:crypto";import A from"node:fs";import{fileURLToPath as Te}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=Ee.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=Te(new URL(".",import.meta.url)),we=be(),y=new Se({projectName:X,encryptionKey:we,clearInvalidConfig:!0})});var ee,Z=b(()=>{ee="0.0.71"});import{createLogger as Ae}from"vite";import O from"chalk";function Oe(e,t,r=!1){let o=Ae(e==="debug"?"info":e,{prefix:"[enpage]",allowClearScreen:t});return r&&o.info(O.hex("#7270c6").bold(`\u{1F680} Enpage 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:()=>N});async function N(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 pt,writeFileSync as lt}from"node:fs";import T from"chalk";R();M();import I 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 Ne=e=>Ce(e)&&Array.isArray(e.patterns)&&Array.isArray(e.sections);var z=(e,t={})=>{let r=t.path;if(Ne(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:[]},c={name:"default",patterns:[]},i=null;for(let a of o){let p=a.trim();if(p.startsWith("#")){let[,d]=/^#+\s*(.*)\s*$/.exec(p)||[];if(i){s.delete(i.name),i.comment=i.comment?`${i.comment}
|
|
5
|
+
${p}`:p,i.name=d?`${i.name.trim()}
|
|
6
|
+
${d.trim()}`:i.name.trim(),s.set(i.name.toLowerCase().trim(),i);continue}c={name:d?.trim()||"",comment:p,patterns:[]},s.set(c.name.toLowerCase(),c),n.sections.push(c),i=c;continue}p!==""&&(c.patterns.push(p),n.patterns.push(p)),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 c of r.sections){let{name:i="",comment:a,patterns:p}=c,d=i.trim().toLowerCase();for(let f of p)s.patterns.includes(f)||s.patterns.push(f);i&&o.has(d)?(n=o.get(d),n.patterns=[...n.patterns,...p]):(n={name:i,comment:a,patterns:p},s.sections.push(n),o.set(d,n))}for(let c of s.sections)c.patterns=[...new Set(c.patterns)];return s},Ie=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}`)),c=(i,a)=>{let p=o[o.length-1],d=i?"unignore":"ignore";p&&p.type===d?p.patterns.includes(a)||p.patterns.push(a):(o.push({type:d,path:t.path||null,patterns:[a],index:s}),s++)};for(let i of n){let a="";i.startsWith("!")&&(i=i.slice(1),a="!"),c(a,i.startsWith("/")?i.slice(1):i),c(a,Ie(i))}return o},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,
|
|
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,
|
|
10
|
-
`))}async function
|
|
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=I.resolve(t,m),l=I.relative(t,m),E=`${x}/v1/templates/${e}/upload/${d}`;return
|
|
8
|
+
`)},Fe=(e,t={})=>{let r=z(e,t),o=t.formatSection||De,s=r.sections||r,n=[];for(let c of[].concat(s))n.push(o(c));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=I.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,c){let i=async a=>{try{return await Ze(e,t,r,o,s,n,c)}catch(p){if(a<c.retryAttempts)return g.warn(`Retrying upload for ${t} (attempt ${a+1})`),await new Promise(d=>setTimeout(d,c.retryDelay)),i(a+1);throw p}};return i(0)}async function Ze(e,t,r,o,s,n,c){return new Promise((i,a)=>{let p=j.statSync(e),d=I.basename(e),f=Date.now(),S=new qe({maxDataSize:c.maxDataSize}),$=j.createReadStream(e),L=0,w=l=>{L+=l.length};$.on("data",w),S.append("file",$,{filename:d,knownLength:p.size});let _={agent:Ke,method:"POST",headers:{authorization:`Bearer ${n}`,"x-enpage-template-file-path":t,"x-enpage-template-id":o,...S.getHeaders()}},P=(r.startsWith("https")?ze:ae).request(r,_,l=>{let E="";l.on("data",C=>{E+=C}),l.on("end",()=>{let C=Date.now(),fe={fileName:d,fileSize:p.size,uploadDuration:C-f,statusCode:l.statusCode??0,serverResponse:E};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(E);U=new k(H.error||"unknown_error",H.error_description||"Unknown error occurred",t)}else U=new k("unknown_error",E||"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 ${d}: ${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 ce(e,t,r,o=!1,s={}){let n={...Ye,...s},c=new He({concurrency:Y}),i=await Ve(t),a=i.length,p={},d=rt(),f=0;for(let m of i){let P=I.relative(t,m),l=await tt(m);p[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=I.resolve(t,m),l=I.relative(t,m),E=`${x}/v1/templates/${e}/upload/${d}`;return c.add(async()=>{let C=await Qe(P,l,E,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/${d}/finalize`,l=await N(m,{signatures:p});if(l.isError)return g.error(`Failed to finalize upload: ${l.data.error_description} (${l.data.error})`),{filesCount:a,uploadedFiles:w.map(E=>E.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"),c=t.getUTCMinutes().toString().padStart(2,"0"),i=t.getUTCSeconds().toString().padStart(2,"0");return`${r}${o}${s}${n}${c}${i}_${e()}`}W();R();import ge from"node:path";import{Type as u}from"@sinclair/typebox";var pe=u.Object({id:u.Optional(u.String({title:"Template ID",description:"A unique identifier for the template. Can be any string, but should be unique."})),name:u.String({title:"Template Name"}),description:u.Optional(u.String({title:"Show template description"})),readme:u.Optional(u.Record(u.RegExp(/^[a-z]{2}$/),u.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:u.Optional(u.Array(u.String(),{title:"Tags"})),author:u.Optional(u.String({title:"Author name"})),thumbnail:u.Optional(u.String({title:"Thumbnail",description:"A URL to the thumbnail image for the template."})),homepage:u.Optional(u.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 ct}from"node:path";async function de(e,t=g){ot.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),
|
|
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 c of n){let i=le(c,".md"),a=ct(i),p=(a===".enpage"?"en":a.substring(1)).toLowerCase();t.debug(`Found template readme file (${p}): ${le(c)}`),s[p]=await st(c,"utf-8")}return r.manifest.readme=s,r}function ue(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=pe.safeParse(e.manifest);if(!r.success){t.error(`\u{1F534} Error: template manifest is invalid. Check your call to defineManifest().
|
|
15
15
|
`);let o=it(r.error);t.error(`Hint: ${o.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(),
|
|
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(` ${T.redBright("Error")}: User token not found. Please run ${T.cyan(`${f} run enpage:login`)} to authenticate or set the ${T.cyan("ENPAGE_API_TOKEN")} environment variable.
|
|
18
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
|
|
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}.
|
|
20
20
|
Please run 'build' before publishing. Aborting.
|
|
21
21
|
`),process.exit(1)),D(h(o,"enpage.config.js"))||(r.error(` ${T.redBright("Error")}: file enpage.config.js not found in ${o}. Aborting.
|
|
22
|
-
`),process.exit(1));let
|
|
22
|
+
`),process.exit(1));let n=await de(h(o,"enpage.config.js"),r);ue(n,r);let c=Q(),i=dt(o);i||(r.error(` ${T.redBright("Error")}: package.json file not found in ${o}. Aborting.
|
|
23
23
|
`),process.exit(1));let a=await ut(i);if(a||(r.error(` ${T.redBright("Error")}: cannot read/parse package.json file in ${o}. Aborting.
|
|
24
|
-
`),process.exit(1)),!a.enpage?.id){let{data:f,isError:S,status:$}=await N(V,{manifest:
|
|
24
|
+
`),process.exit(1)),!a.enpage?.id){let{data:f,isError:S,status:$}=await N(V,{manifest:n.manifest});S&&(r.error(` ${T.redBright("Error")}: Cannot register template: ${J(f)}
|
|
25
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(` ${T.redBright("Error")}: Cannot update template id in package.json file located in ${o}. Aborting.
|
|
26
|
-
`),process.exit(1)}}let
|
|
27
|
-
`),(await
|
|
26
|
+
`),process.exit(1)}}let p=a.enpage.id;r.info(`Submitting template to Enpage...
|
|
27
|
+
`),(await ce(p,o,c,e.dryRun)).success||(r.error(`
|
|
28
28
|
Upload failed. See details above.
|
|
29
|
-
`),process.exit(1)),r.success(`Template ${
|
|
30
|
-
`)}function dt(e){return D(h(e,"package.json"))?h(e,"package.json"):D(h(e,"template-package.json"))?h(e,"template-package.json"):!1}function ut(e){try{return JSON.parse(
|
|
29
|
+
`),process.exit(1)),r.success(`Template ${p} published.
|
|
30
|
+
`)}function dt(e){return D(h(e,"package.json"))?h(e,"package.json"):D(h(e,"template-package.json"))?h(e,"template-package.json"):!1}function ut(e){try{return JSON.parse(pt(e,"utf-8"))}catch{return null}}export{_r as publish};
|
|
31
31
|
/*!
|
|
32
32
|
* parse-gitignore <https://github.com/jonschlinkert/parse-gitignore>
|
|
33
33
|
* Copyright (c) 2015-present, Jon Schlinkert.
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
2
|
|
|
3
|
-
import L from"node:path";import U from"node:fs";import ge from"node:crypto";import me from"fast-glob";var N="enpage-cli";var Oe=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",y=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",Ae=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",I=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.
|
|
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
|
|
3
|
+
import L from"node:path";import U from"node:fs";import ge from"node:crypto";import me from"fast-glob";var N="enpage-cli";var Oe=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",y=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",Ae=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",I=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.71";import _ from"chalk";function H(e,t,n=!1){let i=q(e==="debug"?"info":e,{prefix:"[enpage]",allowClearScreen:t});return n&&i.info(_.hex("#7270c6").bold(`\u{1F680} Enpage v${D}
|
|
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
|
-
${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
|
|
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
|
-
`)},se=(e,t={})=>{let n
|
|
9
|
-
`)};var j
|
|
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 Ee from"ora";import{customAlphabet as Pe}from"nanoid";import oe from"conf";import b from"node:path";import ne from"node:crypto";import T 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:N,encryptionKey:ce,clearInvalidConfig:!0});function pe(){let e=ae;for(;e!==b.parse(e).root;){let t=b.join(e,"node_modules");if(T.existsSync(t))return t;e=b.dirname(e)}return null}function le(){let e=pe();if(!e)throw new Error("Could not find nearest node_modules directory.");let t=b.join(e,".enpage-tmp");T.existsSync(t)||T.mkdirSync(t,{recursive:!0,mode:448});let n=b.join(t,".enpage-key");if(!T.existsSync(n)){let r=ne.randomBytes(32).toString("hex");return T.writeFileSync(n,r,{mode:384,flush:!0}),r}return T.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 w=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},Te=new B.Agent({keepAlive:!0,maxSockets:10,keepAliveMsecs:3e3});async function we(e){let t=L.join(e,".gitignore"),i=U.existsSync(t)?j(U.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 Re(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=U.statSync(e),u=L.basename(e),h=Date.now(),S=new he({maxDataSize:c.maxDataSize}),O=U.createReadStream(e),A=0,E=l=>{A+=l.length};O.on("data",E),S.append("file",O,{filename:u,knownLength:p.size});let P={agent:Te,method:"POST",headers:{authorization:`Bearer ${s}`,"x-enpage-template-file-path":t,"x-enpage-template-id":i,...S.getHeaders()}},f=(n.startsWith("https")?fe:B).request(n,P,l=>{let m="";l.on("data",R=>{m+=R}),l.on("end",()=>{let R=Date.now(),W={fileName:u,fileSize:p.size,uploadDuration:R-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 w(v.error||"unknown_error",v.error_description||"Unknown error occurred",t)}else x=new w("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 w("request_error",l.message,t))}),ye(S,f,l=>{l&&a(new w("pipeline_error",`Pipeline failed for ${u}: ${l.message}`,t))})})}function be(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
10
|
`))}async function mt(e,t,n,i=!1,r={}){let s={..._e,...r},c=new Se({concurrency:I}),o=await we(t),a=o.length,p={},u=Ue(),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
11
|
`),g.info("The following files would have been uploaded:"),o.forEach(d=>g.info(`- ${d}`)),process.exit(0));let S=Ee(`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 R=await Re(f,l,m,e,S,n,s);return h++,R})}),A=await Promise.allSettled(O);S.stop();let E=A.filter(d=>d.status==="fulfilled"),P=A.filter(d=>d.status==="rejected");if(be(e,E.map(d=>d.value),P),!P.length&&E.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:E.map(m=>m.value),failedFiles:[],success:!1}}return{filesCount:a,uploadedFiles:E.map(d=>d.value),failedFiles:P,success:P.length===0}}async function Le(e){let t=await ge.subtle.digest("SHA-1",U.readFileSync(e));return Array.from(new Uint8Array(t)).map(n=>n.toString(16).padStart(2,"0")).join("")}function Ue(){let e=Pe("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
|
/*!
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/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,F,g,M,f,m=p(()=>{"use strict";y="enpage-cli",F=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",g=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",M=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",f="oauth/userinfo"});import
|
|
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,F,g,M,f,m=p(()=>{"use strict";y="enpage-cli",F=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",g=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",M=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",f="oauth/userinfo"});import k from"conf";import u from"node:path";import N from"node:crypto";import a from"node:fs";import{fileURLToPath as P}from"node:url";import X from"chalk";function I(){let e=w;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=I();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=N.randomBytes(32).toString("hex");return a.writeFileSync(s,r,{mode:384,flush:!0}),r}return a.readFileSync(s,"utf8")}var w,v,i,l=p(()=>{"use strict";m();w=P(new URL(".",import.meta.url)),v=b(),i=new k({projectName:y,encryptionKey:v,clearInvalidConfig:!0})});var h,E=p(()=>{h="0.0.71"});import{createLogger as U}from"vite";import c from"chalk";function C(e,t,s=!1){let o=U(e==="debug"?"info":e,{prefix:"[enpage]",allowClearScreen:t});return s&&o.info(c.hex("#7270c6").bold(`\u{1F680} Enpage v${h}
|
|
4
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";E();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(T(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(T(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 T(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};
|
package/dist/node/cli/program.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
3
3
|
|
|
4
|
-
var Ur=Object.create;var ze=Object.defineProperty;var $r=Object.getOwnPropertyDescriptor;var Wr=Object.getOwnPropertyNames;var Br=Object.getPrototypeOf,zr=Object.prototype.hasOwnProperty;var pt=(i,t)=>()=>(i&&(t=i(i=0)),t);var _s=(i,t)=>()=>(t||i((t={exports:{}}).exports,t),t.exports),Gr=(i,t)=>{for(var e in t)ze(i,e,{get:t[e],enumerable:!0})},Hr=(i,t,e,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of Wr(t))!zr.call(i,r)&&r!==e&&ze(i,r,{get:()=>t[r],enumerable:!(s=$r(t,r))||s.enumerable});return i};var qr=(i,t,e)=>(e=i!=null?Ur(Br(i)):{},Hr(t||!i||!i.__esModule?ze(e,"default",{value:i,enumerable:!0}):e,i));function ae(){let i;if(process.env.npm_config_user_agent){let t=process.env.npm_config_user_agent.split(" ")[0];i=t.slice(0,t.lastIndexOf("/"))}return i||(console.log("Warning: could not detect package manager"),i="npm"),i}function ks(i){return`[${i.error}]${i.error_description?`: ${i.error_description}`:""}`}var Ge=pt(()=>{"use strict"});var Ns,He,lt,Ec,Ds,Ps,Ls,Fs,Ms,ft=pt(()=>{"use strict";Ns="enpage-cli",He=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",lt=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",Ec=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",Ds=10,Ps="oauth/devicecode",Ls="oauth/token",Fs="oauth/userinfo",Ms="v1/templates"});import Vr from"conf";import It from"node:path";import Kr from"node:crypto";import mt from"node:fs";import{fileURLToPath as Yr}from"node:url";import Jr from"chalk";function Is(){let i=M.get("access_token");if(!i){let t=ae();throw new Error(`Access token not found. Please run ${Jr.cyan(`${t} run enpage:login`)} to authenticate.`)}return i}function Qr(){let i=Xr;for(;i!==It.parse(i).root;){let t=It.join(i,"node_modules");if(mt.existsSync(t))return t;i=It.dirname(i)}return null}function tn(){let i=Qr();if(!i)throw new Error("Could not find nearest node_modules directory.");let t=It.join(i,".enpage-tmp");mt.existsSync(t)||mt.mkdirSync(t,{recursive:!0,mode:448});let e=It.join(t,".enpage-key");if(!mt.existsSync(e)){let r=Kr.randomBytes(32).toString("hex");return mt.writeFileSync(e,r,{mode:384,flush:!0}),r}return mt.readFileSync(e,"utf8")}var Xr,Zr,M,gt=pt(()=>{"use strict";ft();Ge();Xr=Yr(new URL(".",import.meta.url)),Zr=tn(),M=new Vr({projectName:Ns,encryptionKey:Zr,clearInvalidConfig:!0})});var Us,js=pt(()=>{Us="0.0.
|
|
4
|
+
var Ur=Object.create;var ze=Object.defineProperty;var $r=Object.getOwnPropertyDescriptor;var Wr=Object.getOwnPropertyNames;var Br=Object.getPrototypeOf,zr=Object.prototype.hasOwnProperty;var pt=(i,t)=>()=>(i&&(t=i(i=0)),t);var _s=(i,t)=>()=>(t||i((t={exports:{}}).exports,t),t.exports),Gr=(i,t)=>{for(var e in t)ze(i,e,{get:t[e],enumerable:!0})},Hr=(i,t,e,s)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of Wr(t))!zr.call(i,r)&&r!==e&&ze(i,r,{get:()=>t[r],enumerable:!(s=$r(t,r))||s.enumerable});return i};var qr=(i,t,e)=>(e=i!=null?Ur(Br(i)):{},Hr(t||!i||!i.__esModule?ze(e,"default",{value:i,enumerable:!0}):e,i));function ae(){let i;if(process.env.npm_config_user_agent){let t=process.env.npm_config_user_agent.split(" ")[0];i=t.slice(0,t.lastIndexOf("/"))}return i||(console.log("Warning: could not detect package manager"),i="npm"),i}function ks(i){return`[${i.error}]${i.error_description?`: ${i.error_description}`:""}`}var Ge=pt(()=>{"use strict"});var Ns,He,lt,Ec,Ds,Ps,Ls,Fs,Ms,ft=pt(()=>{"use strict";Ns="enpage-cli",He=process.env.PUBLIC_ENPAGE_OAUTH_CLIENT_ID??"50000000-0000-0000-0000-000000000001",lt=process.env.PUBLIC_ENPAGE_API_BASE_URL??"https://api.enpage.co",Ec=process.env.PUBLIC_ENPAGE_FRONTEND_BASE_URL??"https://enpage.co",Ds=10,Ps="oauth/devicecode",Ls="oauth/token",Fs="oauth/userinfo",Ms="v1/templates"});import Vr from"conf";import It from"node:path";import Kr from"node:crypto";import mt from"node:fs";import{fileURLToPath as Yr}from"node:url";import Jr from"chalk";function Is(){let i=M.get("access_token");if(!i){let t=ae();throw new Error(`Access token not found. Please run ${Jr.cyan(`${t} run enpage:login`)} to authenticate.`)}return i}function Qr(){let i=Xr;for(;i!==It.parse(i).root;){let t=It.join(i,"node_modules");if(mt.existsSync(t))return t;i=It.dirname(i)}return null}function tn(){let i=Qr();if(!i)throw new Error("Could not find nearest node_modules directory.");let t=It.join(i,".enpage-tmp");mt.existsSync(t)||mt.mkdirSync(t,{recursive:!0,mode:448});let e=It.join(t,".enpage-key");if(!mt.existsSync(e)){let r=Kr.randomBytes(32).toString("hex");return mt.writeFileSync(e,r,{mode:384,flush:!0}),r}return mt.readFileSync(e,"utf8")}var Xr,Zr,M,gt=pt(()=>{"use strict";ft();Ge();Xr=Yr(new URL(".",import.meta.url)),Zr=tn(),M=new Vr({projectName:Ns,encryptionKey:Zr,clearInvalidConfig:!0})});var Us,js=pt(()=>{Us="0.0.71"});import{createLogger as sn}from"vite";import wt from"chalk";function qe(i,t,e=!1){let s=sn(i==="debug"?"info":i,{prefix:"[enpage]",allowClearScreen:t});return e&&s.info(wt.hex("#7270c6").bold(`\u{1F680} Enpage v${Us}
|
|
5
5
|
`)),{...s,success:(r,n)=>s.info(wt.green(r),n),error:(r,n)=>s.error(wt.red(r),n),warn:(r,n)=>s.warn(wt.yellow(r),n),warnOnce:(r,n)=>s.warnOnce(wt.yellow(r),n),debug:(r,n)=>{i==="debug"&&s.info(wt.gray(r),n)}}}var k,jt=pt(()=>{"use strict";js();k=qe()});var Gs={};Gr(Gs,{get:()=>mn,post:()=>it});async function it(i,t,e={}){M.get("access_token")&&(e.Authorization=`Bearer ${M.get("access_token")}`);let s=await fetch(Bs(i),{method:"POST",headers:{"Content-Type":t instanceof URLSearchParams?"application/x-www-form-urlencoded":"application/json",...e},body:t instanceof URLSearchParams?t:JSON.stringify(t)}).catch(r=>{k.error(`Fatal Error requesting API: ${r.message} (${r.cause.code})`),k.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return zs(s)}async function mn(i,t={}){M.get("access_token")&&(t.Authorization=`Bearer ${M.get("access_token")}`);let e=await fetch(Bs(i),{headers:t,method:"GET"}).catch(s=>{k.error(`Fatal Error requesting API: ${s.message} (${s.cause.code})`),k.error("Please check your internet connection and try again, or retry later."),process.exit(1)});return zs(e)}function Bs(i){let t=new URL(lt.endsWith("/")?lt:`${lt}/`);return new URL(i,t)}async function zs(i){let t=i.headers.get("content-type")?.startsWith("application/json")?await i.json():await i.text();return i.ok?{isSuccess:!0,isError:!1,status:i.status,statusText:i.statusText,data:t}:{isSuccess:!1,isError:!0,status:i.status,statusText:i.statusText,data:t}}var Ut=pt(()=>{"use strict";jt();ft();gt()});var oi=_s((Ih,ni)=>{"use strict";ni.exports=ii;function ii(i,t,e){i instanceof RegExp&&(i=si(i,e)),t instanceof RegExp&&(t=si(t,e));var s=ri(i,t,e);return s&&{start:s[0],end:s[1],pre:e.slice(0,s[0]),body:e.slice(s[0]+i.length,s[1]),post:e.slice(s[1]+t.length)}}function si(i,t){var e=t.match(i);return e?e[0]:null}ii.range=ri;function ri(i,t,e){var s,r,n,o,a,c=e.indexOf(i),h=e.indexOf(t,c+1),l=c;if(c>=0&&h>0){if(i===t)return[c,h];for(s=[],n=e.length;l>=0&&!a;)l==c?(s.push(l),c=e.indexOf(i,l+1)):s.length==1?a=[s.pop(),h]:(r=s.pop(),r<n&&(n=r,o=h),h=e.indexOf(t,l+1)),l=c<h&&c>=0?c:h;s.length&&(a=[n,o])}return a}});var pi=_s((jh,di)=>{"use strict";var ai=oi();di.exports=Kn;var ci="\0SLASH"+Math.random()+"\0",hi="\0OPEN"+Math.random()+"\0",Ke="\0CLOSE"+Math.random()+"\0",li="\0COMMA"+Math.random()+"\0",fi="\0PERIOD"+Math.random()+"\0";function Ve(i){return parseInt(i,10)==i?parseInt(i,10):i.charCodeAt(0)}function qn(i){return i.split("\\\\").join(ci).split("\\{").join(hi).split("\\}").join(Ke).split("\\,").join(li).split("\\.").join(fi)}function Vn(i){return i.split(ci).join("\\").split(hi).join("{").split(Ke).join("}").split(li).join(",").split(fi).join(".")}function ui(i){if(!i)return[""];var t=[],e=ai("{","}",i);if(!e)return i.split(",");var s=e.pre,r=e.body,n=e.post,o=s.split(",");o[o.length-1]+="{"+r+"}";var a=ui(n);return n.length&&(o[o.length-1]+=a.shift(),o.push.apply(o,a)),t.push.apply(t,o),t}function Kn(i){return i?(i.substr(0,2)==="{}"&&(i="\\{\\}"+i.substr(2)),zt(qn(i),!0).map(Vn)):[]}function Yn(i){return"{"+i+"}"}function Jn(i){return/^-?0\d/.test(i)}function Xn(i,t){return i<=t}function Zn(i,t){return i>=t}function zt(i,t){var e=[],s=ai("{","}",i);if(!s)return[i];var r=s.pre,n=s.post.length?zt(s.post,!1):[""];if(/\$$/.test(s.pre))for(var o=0;o<n.length;o++){var a=r+"{"+s.body+"}"+n[o];e.push(a)}else{var c=/^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(s.body),h=/^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(s.body),l=c||h,f=s.body.indexOf(",")>=0;if(!l&&!f)return s.post.match(/,.*\}/)?(i=s.pre+"{"+s.body+Ke+s.post,zt(i)):[i];var u;if(l)u=s.body.split(/\.\./);else if(u=ui(s.body),u.length===1&&(u=zt(u[0],!1).map(Yn),u.length===1))return n.map(function(oe){return s.pre+u[0]+oe});var d;if(l){var g=Ve(u[0]),p=Ve(u[1]),y=Math.max(u[0].length,u[1].length),m=u.length==3?Math.abs(Ve(u[2])):1,b=Xn,w=p<g;w&&(m*=-1,b=Zn);var S=u.some(Jn);d=[];for(var E=g;b(E,p);E+=m){var v;if(h)v=String.fromCharCode(E),v==="\\"&&(v="");else if(v=String(E),S){var C=y-v.length;if(C>0){var K=new Array(C+1).join("0");E<0?v="-"+K+v.slice(1):v=K+v}}d.push(v)}}else{d=[];for(var B=0;B<u.length;B++)d.push.apply(d,zt(u[B],!1))}for(var B=0;B<d.length;B++)for(var o=0;o<n.length;o++){var a=r+d[B]+n[o];(!t||l||a)&&e.push(a)}}return e}});import{program as Mt}from"commander";Ge();gt();import{resolve as X}from"node:path";import{existsSync as Bt,readFileSync as jn,writeFileSync as Un}from"node:fs";import rt from"chalk";ft();jt();import $t from"node:path";import Wt from"node:fs";import gn from"node:crypto";import wn from"fast-glob";import qs from"node:http";import yn from"node:https";import{pipeline as Sn}from"node:stream";import Hs from"chalk";import bn from"form-data";import*as ce from"node:fs";var rn=/[<>"|?*\n\r\t\f\x00-\x1F]/,nn=/(?:^|\/)[*]{2}($|\/)/,on=248,an=i=>i!==null&&typeof i=="object"&&!Array.isArray(i),cn=i=>typeof i=="string"&&i.length<=on&&!rn.test(i),hn=i=>i.split(/\r\n?|\n/);var ln=i=>an(i)&&Array.isArray(i.patterns)&&Array.isArray(i.sections);var he=(i,t={})=>{let e=t.path;if(ln(i))return i;cn(i)&&ce.existsSync(i)&&(e=i,i=ce.readFileSync(i,"utf8"));let s=hn(i),r=new Map,n={sections:[],patterns:[]},o={name:"default",patterns:[]},a=null;for(let c of s){let h=c.trim();if(h.startsWith("#")){let[,l]=/^#+\s*(.*)\s*$/.exec(h)||[];if(a){r.delete(a.name),a.comment=a.comment?`${a.comment}
|
|
6
6
|
${h}`:h,a.name=l?`${a.name.trim()}
|
|
7
7
|
${l.trim()}`:a.name.trim(),r.set(a.name.toLowerCase().trim(),a);continue}o={name:l?.trim()||"",comment:h,patterns:[]},r.set(o.name.toLowerCase(),o),n.sections.push(o),a=o;continue}h!==""&&(o.patterns.push(h),n.patterns.push(h)),a=null}return(t.dedupe===!0||t.unique===!0)&&(n=$s(n,{...t,format:!1})),n.path=e,n.input=Buffer.from(i),n.format=c=>pn(n,{...t,...c}),n.dedupe=c=>$s(n,{...t,...c}),n.globs=c=>un(n,{path:e,...t,...c}),n};var $s=(i,t)=>{let e=he(i,{...t,dedupe:!1}),s=new Map,r={sections:[],patterns:[]},n;for(let o of e.sections){let{name:a="",comment:c,patterns:h}=o,l=a.trim().toLowerCase();for(let f of h)r.patterns.includes(f)||r.patterns.push(f);a&&s.has(l)?(n=s.get(l),n.patterns=[...n.patterns,...h]):(n={name:a,comment:c,patterns:h},r.sections.push(n),s.set(l,n))}for(let o of r.sections)o.patterns=[...new Set(o.patterns)];return r},fn=i=>{if(nn.test(i))return i;let t=!1;return i.startsWith("/")?(i=i.slice(1),t=!0):i.slice(1,i.length-1).includes("/")&&(t=!0),i+=i.endsWith("/")?"**/":"/**",t?i:`**/${i}`},un=(i,t={})=>{let e=he(i,t),s=[],r=0,n=e.patterns.concat(t.ignore||[]).concat((t.unignore||[]).map(a=>a.startsWith("!")?a:`!${a}`)),o=(a,c)=>{let h=s[s.length-1],l=a?"unignore":"ignore";h&&h.type===l?h.patterns.includes(c)||h.patterns.push(c):(s.push({type:l,path:t.path||null,patterns:[c],index:r}),r++)};for(let a of n){let c="";a.startsWith("!")&&(a=a.slice(1),c="!"),o(c,a.startsWith("/")?a.slice(1):a),o(c,fn(a))}return s},dn=(i={name:"",patterns:[]})=>{let t=[i.comment||""];return i.patterns?.length&&(t.push(i.patterns.join(`
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
2
|
|
|
3
|
-
import{Type as e}from"@sinclair/typebox";var
|
|
4
|
-
`)),{...t,success:(o
|
|
3
|
+
import{Type as e}from"@sinclair/typebox";var m=e.Object({id:e.Optional(e.String({title:"Template ID",description:"A unique identifier for the template. Can be any string, but should be unique."})),name:e.String({title:"Template Name"}),description:e.Optional(e.String({title:"Show template description"})),readme:e.Optional(e.Record(e.RegExp(/^[a-z]{2}$/),e.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:e.Optional(e.Array(e.String(),{title:"Tags"})),author:e.Optional(e.String({title:"Author name"})),thumbnail:e.Optional(e.String({title:"Thumbnail",description:"A URL to the thumbnail image for the template."})),homepage:e.Optional(e.String({title:"Homepage",description:"A URL to the homepage of the template."}))});import d from"node:fs";import{readFile as x}from"node:fs/promises";import L from"fast-glob";import{createLogger as b}from"vite";var g="0.0.71";import n from"chalk";function v(r,i,a=!1){let t=b(r==="debug"?"info":r,{prefix:"[enpage]",allowClearScreen:i});return a&&t.info(n.hex("#7270c6").bold(`\u{1F680} Enpage v${g}
|
|
4
|
+
`)),{...t,success:(s,o)=>t.info(n.green(s),o),error:(s,o)=>t.error(n.red(s),o),warn:(s,o)=>t.warn(n.yellow(s),o),warnOnce:(s,o)=>t.warnOnce(n.yellow(s),o),debug:(s,o)=>{r==="debug"&&t.info(n.gray(s),o)}}}var u=v();import{fromError as O}from"zod-validation-error";import{basename as f,dirname as w,extname as S}from"node:path";async function P(r,i=u){d.existsSync(r)||(i.error(`\u{1F534} No enpage.config.js found!
|
|
5
5
|
Your project must have an enpage.config.js file in the root directory.
|
|
6
6
|
|
|
7
|
-
`),process.exit(1));let a=await import(r),t=w(r),
|
|
7
|
+
`),process.exit(1));let a=await import(r),t=w(r),s={},o=await L(["README.enpage.md","README.enpage.*.md"],{cwd:t,onlyFiles:!0,absolute:!0,caseSensitiveMatch:!1});for(let p of o){let y=f(p,".md"),l=S(y),c=(l===".enpage"?"en":l.substring(1)).toLowerCase();i.debug(`Found template readme file (${c}): ${f(p)}`),s[c]=await x(p,"utf-8")}return a.manifest.readme=s,a}function B(r,i){return d.existsSync(r)||(i.error(`\u{1F534} No enpage.manifest.json found!
|
|
8
8
|
You may want to 'build' your template.
|
|
9
9
|
|
|
10
|
-
`),process.exit(1)),JSON.parse(d.readFileSync(r,"utf-8"))}function H(r,
|
|
11
|
-
`);let t=O(a.error);
|
|
10
|
+
`),process.exit(1)),JSON.parse(d.readFileSync(r,"utf-8"))}function H(r,i){for(let t in r.datasources)if(r.datasources[t].provider==="json"&&!r.datasources[t].sampleData)throw i.error(`\u{1F534} Error: Datasource "${t}" is missing sample data - nothing will be rendered during development! Please check your enpage.config.js file and add a "sampleData" key to your ${t} datasource.`),new Error(`Missing sample data for datasource "${t}"`);let a=m.safeParse(r.manifest);if(!a.success){i.error(`\u{1F534} Error: template manifest is invalid. Check your call to defineManifest().
|
|
11
|
+
`);let t=O(a.error);i.error(`Hint: ${t.toString()}
|
|
12
12
|
|
|
13
13
|
`),process.exit(1)}return r}export{P as loadConfigFromJsFile,B as loadConfigFromManifestFile,H as validateTemplateConfig};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
2
|
|
|
3
|
-
import{createLogger as d}from"vite";var
|
|
4
|
-
`)),{...s,success:(e,t)=>s.info(r.green(e),t),error:(e,t)=>s.error(r.red(e),t),warn:(e,t)=>s.warn(r.yellow(e),t),warnOnce:(e,t)=>s.warnOnce(r.yellow(e),t),debug:(e,t)=>{
|
|
3
|
+
import{createLogger as d}from"vite";var i="0.0.71";import r from"chalk";function g(o,a,n=!1){let s=d(o==="debug"?"info":o,{prefix:"[enpage]",allowClearScreen:a});return n&&s.info(r.hex("#7270c6").bold(`\u{1F680} Enpage v${i}
|
|
4
|
+
`)),{...s,success:(e,t)=>s.info(r.green(e),t),error:(e,t)=>s.error(r.red(e),t),warn:(e,t)=>s.warn(r.yellow(e),t),warnOnce:(e,t)=>s.warnOnce(r.yellow(e),t),debug:(e,t)=>{o==="debug"&&s.info(r.gray(e),t)}}}var y=g();export{g as createLogger,y as logger};
|
package/dist/shared/ajv.d.ts
CHANGED
package/dist/shared/ajv.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ajv.d.ts","sourceRoot":"","sources":["../../src/shared/ajv.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,EAAE,EAAE,KAAK,WAAW,EAAE,MAAM,KAAK,CAAC;AAG5C,eAAO,MAAM,GAAG,
|
|
1
|
+
{"version":3,"file":"ajv.d.ts","sourceRoot":"","sources":["../../src/shared/ajv.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,EAAE,EAAE,KAAK,WAAW,EAAE,MAAM,KAAK,CAAC;AAG5C,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,KAAK,CAAC;AAE3D,eAAO,MAAM,GAAG,KAGd,CAAC;AA0BH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,WAAW,EAAE,GAAG,IAAI,GAAG,SAAS,GAAG,MAAM,CAcnF"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { type StringOptions, type NumberOptions, type SchemaOptions, type ObjectOptions, type TProperties } from "@sinclair/typebox";
|
|
1
|
+
import { type StringOptions, type NumberOptions, type SchemaOptions, type ObjectOptions, type TProperties, type TObject, type Static } from "@sinclair/typebox";
|
|
2
2
|
import type { ElementColor } from "./themes/color-system";
|
|
3
|
+
import type { JSONSchemaType } from "ajv";
|
|
3
4
|
type EnumOption = {
|
|
4
5
|
title?: string;
|
|
5
6
|
description?: string;
|
|
@@ -18,20 +19,20 @@ type GeoPoint = {
|
|
|
18
19
|
lng: number;
|
|
19
20
|
name?: string;
|
|
20
21
|
};
|
|
21
|
-
export declare function defineAttributes(attrs: TProperties):
|
|
22
|
-
$pageLanguage:
|
|
23
|
-
$pagePath:
|
|
24
|
-
$pageTitle:
|
|
25
|
-
$pageDescription:
|
|
26
|
-
$pageKeywords:
|
|
27
|
-
$pageLastUpdated:
|
|
28
|
-
$pageWidth:
|
|
29
|
-
$pagePaddingVertical:
|
|
30
|
-
$pagePaddingHorizontal:
|
|
31
|
-
$backgroundColor:
|
|
32
|
-
$textColor:
|
|
22
|
+
export declare function defineAttributes(attrs: TProperties): JSONSchemaType<{
|
|
23
|
+
$pageLanguage: string;
|
|
24
|
+
$pagePath: string;
|
|
25
|
+
$pageTitle: string;
|
|
26
|
+
$pageDescription: string;
|
|
27
|
+
$pageKeywords: string;
|
|
28
|
+
$pageLastUpdated: string;
|
|
29
|
+
$pageWidth: string;
|
|
30
|
+
$pagePaddingVertical: string;
|
|
31
|
+
$pagePaddingHorizontal: string;
|
|
32
|
+
$backgroundColor: string;
|
|
33
|
+
$textColor: string;
|
|
33
34
|
}>;
|
|
34
|
-
export type
|
|
35
|
+
export type AttributesSchema = ReturnType<typeof defineAttributes>;
|
|
35
36
|
export declare const attr: {
|
|
36
37
|
/**
|
|
37
38
|
* Define a text
|
|
@@ -75,25 +76,27 @@ export declare const attr: {
|
|
|
75
76
|
/**
|
|
76
77
|
* Define a geolocation
|
|
77
78
|
*/
|
|
78
|
-
geolocation(name: string, defaultValue: GeoPoint, opts?: AttributeOptions<Omit<ObjectOptions, "title" | "default">>):
|
|
79
|
+
geolocation(name: string, defaultValue: GeoPoint, opts?: AttributeOptions<Omit<ObjectOptions, "title" | "default">>): TObject<{
|
|
79
80
|
lat: import("@sinclair/typebox").TNumber;
|
|
80
81
|
lng: import("@sinclair/typebox").TNumber;
|
|
81
82
|
name: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
|
|
82
83
|
}>;
|
|
83
84
|
};
|
|
84
|
-
export declare
|
|
85
|
-
$pageLanguage: string
|
|
86
|
-
$pagePath:
|
|
87
|
-
$pageTitle:
|
|
88
|
-
$pageDescription:
|
|
89
|
-
$pageKeywords:
|
|
90
|
-
$pageLastUpdated:
|
|
91
|
-
$pageWidth: string
|
|
92
|
-
$pagePaddingVertical: string
|
|
93
|
-
$pagePaddingHorizontal: string
|
|
94
|
-
$backgroundColor:
|
|
95
|
-
$textColor:
|
|
96
|
-
}
|
|
97
|
-
export type
|
|
85
|
+
export declare const defaultAttributesSchema: TObject<{
|
|
86
|
+
$pageLanguage: import("@sinclair/typebox").TUnion<import("@sinclair/typebox").TLiteral<string>[]>;
|
|
87
|
+
$pagePath: import("@sinclair/typebox").TString;
|
|
88
|
+
$pageTitle: import("@sinclair/typebox").TString;
|
|
89
|
+
$pageDescription: import("@sinclair/typebox").TString;
|
|
90
|
+
$pageKeywords: import("@sinclair/typebox").TString;
|
|
91
|
+
$pageLastUpdated: import("@sinclair/typebox").TString;
|
|
92
|
+
$pageWidth: import("@sinclair/typebox").TUnion<import("@sinclair/typebox").TLiteral<string>[]>;
|
|
93
|
+
$pagePaddingVertical: import("@sinclair/typebox").TUnion<import("@sinclair/typebox").TLiteral<string>[]>;
|
|
94
|
+
$pagePaddingHorizontal: import("@sinclair/typebox").TUnion<import("@sinclair/typebox").TLiteral<string>[]>;
|
|
95
|
+
$backgroundColor: import("@sinclair/typebox").TString;
|
|
96
|
+
$textColor: import("@sinclair/typebox").TString;
|
|
97
|
+
}>;
|
|
98
|
+
export type Attributes = Static<typeof defaultAttributesSchema>;
|
|
99
|
+
export declare function resolveAttributes(attributesSchema: JSONSchemaType<Attributes>, initialData?: Record<string, unknown>): AttributesResolved;
|
|
100
|
+
export type AttributesResolved = Record<string, unknown>;
|
|
98
101
|
export {};
|
|
99
102
|
//# sourceMappingURL=attributes.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"attributes.d.ts","sourceRoot":"","sources":["../../src/shared/attributes.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,WAAW,
|
|
1
|
+
{"version":3,"file":"attributes.d.ts","sourceRoot":"","sources":["../../src/shared/attributes.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,aAAa,EAClB,KAAK,WAAW,EAChB,KAAK,OAAO,EACZ,KAAK,MAAM,EACZ,MAAM,mBAAmB,CAAC;AAE3B,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAK1C,KAAK,UAAU,GAAG;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,KAAK,gBAAgB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI;IACzD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,OAAO,GAAG,UAAU,CAAC;CACpC,GAAG,CAAC,CAAC;AAEN,KAAK,QAAQ,GAAG;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAE5D,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,WAAW;;;;;;;;;;;;GAUlD;AAED,MAAM,MAAM,gBAAgB,GAAG,UAAU,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAEnE,eAAO,MAAM,IAAI;IACf;;OAEG;iBACU,MAAM,gCAA4B,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IAGzG;;OAEG;iBACU,MAAM,gCAA2B,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IAGxG;;OAEG;kBAEK,MAAM,iCAEL,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IAOnE;;OAEG;eAEK,MAAM,gBACE,MAAM,QACd,gBAAgB,CACpB,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,GAAG;QACzC,OAAO,EAAE,UAAU,EAAE,GAAG,MAAM,EAAE,CAAC;QACjC,SAAS,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,cAAc,GAAG,YAAY,CAAC;KAChE,CACF;IAsBH;;OAEG;eAEK,MAAM,gCAEN,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IAIlE;;OAEG;cAEK,MAAM,gCAEN,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IAIlE;;OAEG;gBAEK,MAAM,iBACE,YAAY,SACnB,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IASnE;;OAEG;eAEK,MAAM,8BAEN,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IAIlE;;OAEG;mBAEK,MAAM,8BAEN,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;IAIlE;;OAEG;sBAEK,MAAM,gBACE,QAAQ,SAChB,gBAAgB,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC;;;;;CAWnE,CAAC;AAuHF,eAAO,MAAM,uBAAuB;;;;;;;;;;;;EAAiC,CAAC;AACtE,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,uBAAuB,CAAC,CAAC;AAEhE,wBAAgB,iBAAiB,CAC/B,gBAAgB,EAAE,cAAc,CAAC,UAAU,CAAC,EAC5C,WAAW,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,GACxC,kBAAkB,CAQpB;AAED,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
2
|
|
|
3
|
-
import{a,b,c}from"./chunk-
|
|
3
|
+
import{a,b,c,d}from"./chunk-EK4FWGFA.js";import"./chunk-6PCNIIO5.js";export{b as attr,c as defaultAttributesSchema,a as defineAttributes,d as resolveAttributes};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bricks.d.ts","sourceRoot":"","sources":["../../src/shared/bricks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,MAAM,EAAE,MAAM,mBAAmB,CAAC;
|
|
1
|
+
{"version":3,"file":"bricks.d.ts","sourceRoot":"","sources":["../../src/shared/bricks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAoBtD;;GAEG;AACH,eAAO,MAAM,UAAU,2BAAsF,CAAC;AAE9G,QAAA,MAAM,mBAAmB;;;;;;;EA2BvB,CAAC;AAEH,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAE/D,QAAA,MAAM,0BAA0B;;;;;;EA6C9B,CAAC;AAEH,MAAM,MAAM,oBAAoB,GAAG,MAAM,CAAC,OAAO,0BAA0B,CAAC,CAAC;AAE7E,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmFtB,CAAC;AAEH,MAAM,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,WAAW,CAAC,CAAC;AAC/C,MAAM,MAAM,YAAY,GAAG,KAAK,EAAE,CAAC;AACnC,MAAM,MAAM,kBAAkB,GAAG,KAAK,CAAC,UAAU,CAAC,CAAC;AAEnD,QAAA,MAAM,kBAAkB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAQtB,CAAC;AAEH,MAAM,MAAM,YAAY,GAAG,MAAM,CAAC,OAAO,kBAAkB,CAAC,CAAC;AAE7D,MAAM,MAAM,UAAU,GAAG;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAwCF,wBAAgB,YAAY,CAAC,CAAC,SAAS,YAAY,EAAE,EAAE,MAAM,EAAE,CAAC,GAAG,KAAK,EAAE,CASzE;AAED;;;GAGG;AACH,KAAK,eAAe,GAAG,IAAI,CAAC,KAAK,EAAE,IAAI,GAAG,UAAU,GAAG,UAAU,CAAC,GAAG;IAEnE,QAAQ,EAAE;QACR,MAAM,CAAC,EAAE,IAAI,CAAC,oBAAoB,EAAE,GAAG,CAAC,CAAC;QACzC,OAAO,EAAE,IAAI,CAAC,oBAAoB,EAAE,GAAG,CAAC,CAAC;KAC1C,CAAC;CACH,CAAC;AAQF;;GAEG;AACH,wBAAgB,SAAS,CAAC,CAAC,SAAS,eAAe,EAAE,EAAE,MAAM,EAAE,CAAC,GAAG,YAAY,EAAE,CA4ChF"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
|
+
|
|
3
|
+
import p from"ajv";import u from"ajv-formats";var t=new p({useDefaults:!0,strictSchema:!1});u(t,["date-time","time","date","email","hostname","ipv4","ipv6","uri","uri-reference","uuid","uri-template","json-pointer","relative-json-pointer","regex"]);t.addFormat("date-object",{validate:e=>e instanceof Date&&!Number.isNaN(e.getTime()),async:!1});function d(e){return!e||e.length===0?"Unknown validation error":e.map(r=>{let{instancePath:a,message:n,params:i}=r,o=a||"root",s=Object.entries(i||{}).map(([m,c])=>`${m}: ${c}`).join(", ");return`${o} ${n} (${s})`}).join("; ")}export{t as a,d as b};
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/*! Upstart.gg - Copyright (C) 2024 Flippable - https://github.com/enpage/enpage/blob/main/LICENSE */
|
|
2
|
+
|
|
3
|
+
import{a as l}from"./chunk-6PCNIIO5.js";import{Type as r}from"@sinclair/typebox";function s(t){return JSON.parse(JSON.stringify(t))}function y(t){for(let e in t)if(e.startsWith("$"))throw new Error(`Attribute names starting with '$' (like "${e}") are reserved for internal use. Please rename it.`);return s(r.Object({...p,...t}))}var o={string(t,e="",i){return r.String({title:t,default:e,...i})},number(t,e=0,i){return r.Number({title:t,default:e,...i})},boolean(t,e=!1,i){let a={"ui:field":"switch"};return r.Boolean({title:t,default:e,...a,...i})},enum(t,e,i){let a={"ui:field":"enum","ui:display":i.displayAs||"select"},{options:u,displayAs:m,...g}=i;return r.Union(u.map(n=>r.Literal(typeof n=="string"?n:n.value,{title:typeof n=="string"?n:n.title,"ui:icon":typeof n=="string"?void 0:n.icon})),{title:t,default:e,...a,...g})},file(t,e="",i={}){return r.String({title:t,default:e,...i,format:"data-url"})},url(t,e="",i={}){return r.String({title:t,default:e,...i,format:"uri"})},color(t,e="",i){let a={"ui:field":"color"};return r.String({title:t,default:e,...a,...i})},date(t,e=new Date,i={}){return r.String({title:t,default:e.toISOString(),...i,format:"date"})},datetime(t,e=new Date,i={}){return r.String({title:t,default:e.toISOString(),...i,format:"date-time"})},geolocation(t,e,i={}){return r.Object({lat:r.Number({minimum:-90,maximum:90}),lng:r.Number({minimum:-180,maximum:180}),name:r.Optional(r.String({title:"Name"}))},{title:t,default:e,...i})}},p={$pageLanguage:o.enum("Page language","en",{options:[{value:"ar",title:"Arabic"},{value:"zh",title:"Chinese"},{value:"cs",title:"Czech"},{value:"nl",title:"Dutch"},{value:"en",title:"English"},{value:"fr",title:"French"},{value:"de",title:"German"},{value:"he",title:"Hebrew"},{value:"hi",title:"Hindi"},{value:"it",title:"Italian"},{value:"ja",title:"Japanese"},{value:"ko",title:"Korean"},{value:"fa",title:"Persian"},{value:"pl",title:"Polish"},{value:"pt",title:"Portuguese"},{value:"ru",title:"Russian"},{value:"es",title:"Spanish"},{value:"tr",title:"Turkish"},{value:"vi",title:"Vietnamese"}],"ui:group":"meta","ui:group:title":"Meta tags / SEO"}),$pagePath:o.string("Page path","/",{description:"The URL path of the page","ui:group":"location","ui:group:title":"Location","ui:group:order":1,"ui:field":"path"}),$pageTitle:o.string("Page title","Untitled",{"ui:group":"meta","ui:group:title":"Meta tags / SEO"}),$pageDescription:o.string("Page description","",{"ui:widget":"textarea","ui:options":{rows:3,widget:"textarea"},"ui:group":"meta","ui:group:title":"Meta tags / SEO"}),$pageKeywords:o.string("Page keywords","",{"ui:group":"meta","ui:group:title":"Meta tags / SEO"}),$pageLastUpdated:o.datetime("Last updated",void 0,{"ui:hidden":!0}),$pageWidth:o.enum("Page width","max-w-screen-2xl",{options:[{value:"max-w-screen-lg",title:"M",description:"Common for text-heavy content/blog posts"},{value:"max-w-screen-xl",title:"L",description:"Usefull or some landing pages"},{value:"max-w-screen-2xl",title:"XL",description:"Common width"},{value:"max-w-full",title:"Full",description:"Takes the entire space"}],description:"The maximum width of the page. Desktop only.",displayAs:"button-group","ui:group":"layout","ui:group:title":"Page Layout & Design"}),$pagePaddingVertical:o.enum("Page vertical spacing","20",{options:[{value:"0",title:"None"},{value:"10",title:"S"},{value:"20",title:"M"},{value:"30",title:"L"},{value:"50",title:"XL"}],description:"Vertical spacing. Desktop only.",displayAs:"button-group","ui:group":"layout","ui:group:title":"Page Layout & Design"}),$pagePaddingHorizontal:o.enum("Page horizontal spacing","20",{options:[{value:"0",title:"None"},{value:"10",title:"S"},{value:"20",title:"M"},{value:"30",title:"L"},{value:"50",title:"XL"}],description:"Horizontal spacing. Desktop only.",displayAs:"button-group","ui:group":"layout","ui:group:title":"Page Layout & Design"}),$backgroundColor:o.color("Page background color","#ffffff",{"ui:field":"color","ui:group":"layout","ui:group:title":"Page Layout & Design"}),$textColor:o.color("Default text color","#222222",{"ui:field":"color","ui:group":"layout","ui:group:title":"Page Layout & Design","ui:color-type":"page-text"})},b=r.Object(p);function h(t,e={}){let i=l.compile(t),a={...e};if(!i(a))throw new Error(`Invalid attributes: ${i.errors}`);return a}export{y as a,o as b,b as c,h as d};
|