@fnet/cli 0.47.0 → 0.48.0
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/builder/lib-cli.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var e=require("child_process"),t=require("@fnet/config"),a=require("path"),o=require("yargs/yargs"),n=require("yargs/helpers"),r=require("fs"),s=require("yaml"),i=require("shelljs"),c=require("@fnet/yaml"),l=require("@fnet/object-from-schema"),p=require("@flownet/lib-render-templates-dir"),d=require("node:fs"),m=require("node:path"),u=require("nunjucks"),f=require("redis"),g=require("@flownet/lib-is-redis-online"),y=require("nanoid"),w=require("@flownet/lib-atom-api-js"),h=require("axios"),b=require("qs"),_=require("lodash.merge"),v=require("@flownet/lib-parse-imports-js"),j=require("@flownet/lib-list-npm-versions"),k=require("@fnet/yargs-options-from-schema"),x=require("@fnet/shell"),D=require("semver"),A=require("node:os"),P=require("@node-red/util"),S=require("@flownet/lib-to-ios-app"),I=require("lodash.clonedeep"),E=require("@flownet/lib-to-macos-app"),$=require("@flownet/lib-to-electron"),T=require("@flownet/lib-to-webos"),O=require("@flownet/lib-to-nextjs"),C=require("@flownet/lib-to-docker"),R=require("form-data"),M=require("@fnet/to-rust"),q=require("@flownet/lib-parse-node-url"),F=require("@flownet/lib-pick-npm-versions"),L=require("chalk");const N=f,U=g;const{Api:z}=w,B=h.default,J=b;const W=_,K=d,G=m,H=v;function X({dir:e,name:t="index"}){let a=G.resolve(e,`./${t}.tsx`);if(K.existsSync(a)||(a=G.resolve(e,`./${t}.ts`)),K.existsSync(a)||(a=G.resolve(e,`./${t}.jsx`)),K.existsSync(a)||(a=G.resolve(e,`./${t}.js`)),!K.existsSync(a))return{};const o=a,n=G.extname(a);return{file:o,ext:n,ts:".ts"===n||".tsx"===n,name:t}}const Y=j;const Z=d,Q=m,V=p;const ee=u,te=d,ae=m,oe=v,ne=j;const re=d,se=m,ie=p;const ce=d,le=m,pe=u,de=v;const me=d,ue=m,fe=u,ge=k;const ye=d,we=m,he=u;const be=d,_e=m,ve=u;const je=u,ke=d,xe=m;const De=i,Ae=a;const Pe=i;const Se=i;const Ie=i;const Ee=x,$e=t;const Te=d,Oe=m,Ce=D,Re=x,Me=t;const qe=d,Fe=m,Le=D,Ne=i,Ue=t;const ze=d,Be=m,Je=A,We=u,Ke=P,Ge=t;const He=r,Xe=a,Ye=t;const Ze=t,Qe=S,Ve=I,et=D;const tt=t,at=E,ot=I,nt=D;const rt=t,st=$,it=I,ct=D;const lt=t,pt=T,dt=I,mt=D;const ut=t,ft=O,gt=I,yt=D;const wt=t,ht=C,bt=I,_t=D;const vt=d,jt=m,kt=D,xt=x,Dt=t,At=h.default;const Pt=D,St=t,It=h.default;const Et=D,$t=t,Tt=h.default,Ot=r,Ct=x,Rt=R;const Mt=D,qt=t,Ft=h.default,Lt=r,Nt=x,Ut=R;const zt=t,Bt=M,Jt=I,Wt=D;const Kt=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o,buildId:n})=>{await e({message:"Deploying it as gitlab project."});const r=t.projectDir;let s="fnet-to-gitlab";const i=o.params.config||"gitlab",c=await $e({name:i,dir:t.projectDir});if(!c)throw new Error(`Couldnt load config ${i}`);const{data:l}=c.data;s+=` --projectGroupId=${l.projectGroupId}`,s+=` --projectPath='${r}'`,s+=` --projectName='${o.params.name}'`,s+=` --projectBranch='${o.params.branch||"main"}'`,s+=` --gitlabHost='${l.gitlabHost}'`,s+=` --gitlabToken='${l.gitlabToken}'`,s+=` --gitlabUsername='${l.gitlabUsername}'`,s+=` --gitlabUserEmail='${l.gitlabUserEmail}'`,!0!==o.dryRun&&(await Ee({cmd:s}),a.isDirty=!0)},Gt=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o,registerToPackageManager:n})=>{await e({message:"Deploying it as gcs package."});const r=t.projectDir,s=Oe.resolve(r,"package.json"),i=Te.readFileSync(s),c=JSON.parse(i);c.name=o.params.name,c.version=Ce.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,Te.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Me({name:o.config||"gcs",dir:t.projectDir});let d="fnet-files-to-gcs";d+=` --projectId='${p.env.GCS_PROJECT_ID}'`,d+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,d+=` --keyFilename='${Oe.resolve(Oe.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,d+=` --dir='${r}'`,d+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",d+=` --destDir='${c.name}/${c.version}'`,d+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(d+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(d+=" --dryRun"),await Re({cmd:d}),Te.writeFileSync(s,i),!0!==o.dryRun&&(a.isDirty=!0,o.params.version=c.version,await n({target:o,packageJSON:c}))},Ht=async({atom:e,setInProgress:t,context:a,deploymentProject:o,deploymentProjectTarget:n})=>{await t({message:"Deploying it as npm package."});const r=a.projectDir,s=Fe.resolve(r,"package.json"),i=qe.readFileSync(s),c=JSON.parse(i);c.name=n.params.name,c.version=Le.inc(n.params.version,"patch");const l=n.params.bin?.name||n.params.bin;!1!==n.params.bin?.enabled&&l&&"string"==typeof l&&(c.bin={[l]:"dist/cli/esm/index.js",[e.doc.name]:"dist/cli/esm/index.js"}),delete c.scripts,delete c.devDependencies,c.scripts={serve:"npx serve ."},qe.writeFileSync(s,JSON.stringify(c,null,"\t"));const p=(await Ue({name:a.npmConfig||"npm",dir:a.projectDir}))?.data;if(qe.writeFileSync(Fe.resolve(r,".npmrc"),`//registry.npmjs.org/:_authToken=${p.env.NPM_TOKEN}`),!0===n.dryRun)return;if(0!==Ne.exec("npm publish --access public",{cwd:r}).code)throw new Error("Couldnt publish to npm");qe.writeFileSync(s,i),o.isDirty=!0,n.params.version=c.version},Xt=async({atom:e,setInProgress:t,context:a,deploymentProject:o,deploymentProjectTarget:n,buildId:r,packageDependencies:s,njEnv:i})=>{await t({message:"Deploying it as node-red flow."});const c=a.projectDir,l=a.templateDir,p="workflow"===e.type?"WF":"LIB";let d;if("simple"===n.deploy.template)d={atom:e,packageDependencies:s,red:{tab:{id:n.deploy.id||Ke.util.generateId(),label:`${p}/${e.id?e.id:Je.hostname()}/${e.name}/${n.deploy.name||n.deploy.template}`},function:{id:Ke.util.generateId(),name:e.doc.name,initialize:{content:ze.readFileSync(Be.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},inject:{id:Ke.util.generateId(),...n.params?.inject,payload:"json"===n.params?.inject?.payloadType?`'${JSON.stringify(n.params?.inject?.payload)}'`:n.params?.inject?.payload},debug:{id:Ke.util.generateId()}}};else if("cronjob"===n.deploy.template){let t=n.params?.schedules?cloneDeep(n.params?.schedules):void 0;t?.forEach((e=>{"json"===e.payloadType&&(e.payload=`'${JSON.stringify(e.payload)}'`)})),d={atom:e,packageDependencies:s,red:{tab:{id:n.deploy.id||Ke.util.generateId(),label:`${p}/${e.id?e.id:Je.hostname()}/${n.deploy.name||n.deploy.template}`},function:{id:Ke.util.generateId(),name:e.doc.name,initialize:{content:ze.readFileSync(Be.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},cronjob:{id:Ke.util.generateId(),schedules:t},debug:{id:Ke.util.generateId()}}}}else{if("http"!==n.deploy.template)return;d={atom:e,packageDependencies:s,red:{tab:{id:n.deploy.id||Ke.util.generateId(),label:`${p}/${e.id?e.id:Je.hostname()}/${n.deploy.name||n.deploy.template}`},function:{id:Ke.util.generateId(),name:e.doc.name,initialize:{content:ze.readFileSync(Be.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},httpin:{id:Ke.util.generateId(),method:n.params.method||"get",url:n.params.url},httpout:{id:Ke.util.generateId()},debug:{id:Ke.util.generateId()}}}}let m=We.compile(ze.readFileSync(Be.resolve(l,`deploy/node-red/${n.deploy.template}.yaml.njk`),"utf8"),i).render(d);if(ze.writeFileSync(Be.resolve(c,"node-red.yaml"),m),m=yaml.load(m),!0===n.dryRun)return;o.isDirty=!0;const u=(await Ge({name:a.redConfig||"red",dir:a.projectDir}))?.data,f=n.deploy.url||u.env.RED_URL,g={};if(!1!==n.deploy.auth&&(g.Authorization="Bearer "+atomAccessToken),n.deploy.id)!0===n.actions?.delete?(await axios({method:"DELETE",url:`${f}/flow/${n.deploy.id}`,headers:g}),delete n.actions.delete,delete n.deploy.id,n.enabled=!1):await axios({method:"PUT",url:`${f}/flow/${n.deploy.id}`,data:m,headers:g});else{const e=await axios({method:"POST",url:`${f}/flow`,data:m,headers:g});n.deploy.id=e.data.id}},Yt=async({atom:e,Atom:t,setInProgress:a,context:o,packageDependencies:n,deploymentProject:r,deploymentProjectTarget:s})=>{await a({message:"Deploying it as workflow lib."});const i=(await Ye({name:"atom",dir:o.projectDir}))?.data;let c,l,p,d=s.deploy.name.split("/");if(1===d.length)l=i.env.ATOM_LIBRARIES_ID,p=s.deploy.name;else{if(2!==d.length)throw new Error("Wrong name path.");{const e=await t.first({where:{name:d[0],parent_id:i.env.ATOM_LIBRARIES_ID,type:"folder"},limit:1});if(!e)throw new Error("Couldnt file lib folder.");l=e.id,p=d[1]}}if(!0===s.dryRun)return;if(r.isDirty=!0,s.deploy.id){if(c=await t.get({id:s.deploy.id}),!c)return}else{if(c=await t.create({parent_id:l,doc:{name:p,type:"workflow.lib","content-type":"javascript",dependencies:[],content:void 0,subtype:"workflow"}}),!c)return;s.deploy.id=c.id}const m=o.projectDir;c.doc.contents=[{content:He.readFileSync(Xe.resolve(m,"dist/default/esm/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"esm"},{content:He.readFileSync(Xe.resolve(m,"dist/default/cjs/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"cjs"},{content:He.readFileSync(Xe.resolve(m,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"iife"}],c.doc.name=p,c.doc.dependencies=n,"workflow.lib"===e.type?c.doc.subtype="library":"workflow"===e.type&&(c.doc.subtype="workflow"),c=await t.update(c,{id:c.id})},Zt=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as ios-app package."});const r=t?.config?await Ze({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=et.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=Ve(t.params);i.dependencies=Ve(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await Qe(c)}},Qt=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as macos-app package."});const r=t?.config?await tt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=nt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=ot(t.params);i.dependencies=ot(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await at(c)}},Vt=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as electron package."});const r=t?.config?await rt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=ct.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=it(t.params);i.dependencies=it(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await st(c)}},ea=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as webos package."});const r=t?.config?await lt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=mt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=dt(t.params);i.dependencies=dt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await pt(c)}},ta=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as nextjs package."});const r=t?.config?await ut({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=yt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=gt(t.params);i.dependencies=gt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await ft(c)}},aa=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as docker package."});const r=t?.config?await wt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=_t.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=bt(t.params);i.dependencies=bt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await ht(c)}},oa=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o,registerToPackageManager:n})=>{await e({message:"Deploying it as fnet package."});const r=t.projectDir,s=jt.resolve(r,"package.json"),i=vt.readFileSync(s),c=JSON.parse(i);c.name=o.params.name,c.version=kt.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,vt.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Dt({name:o.config||"fnet-package",dir:t.projectDir});if(!p.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${l}`);if(!p.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${l}`);if(!p.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${l}`);const d=`${p.env.ATOM_API_URL}/v1/auth/token`,m=p.env.ATOM_API_USERNAME,u=p.env.ATOM_API_PASSWORD;let f=await At({method:"POST",url:d,data:{username:m,password:u},headers:{"Content-Type":"application/json"}});const g=f.data?.access_token;if(!g)throw new Error(`Invalid access_token from ${d}`);let y="fnet-files-to-gcs";if(y+=` --projectId='${p.env.GCS_PROJECT_ID}'`,y+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,y+=` --keyFilename='${jt.resolve(jt.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,y+=` --dir='${r}'`,y+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",y+=` --destDir='${c.name}/${c.version}'`,y+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(y+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(y+=" --dryRun"),await xt({cmd:y}),vt.writeFileSync(s,i),!0===o.dryRun)return;a.isDirty=!0,o.params.version=c.version;const w=`${p.env.ATOM_API_URL}/v1/service/fnet-package/publish`;if(f=await At({method:"POST",url:w,data:{name:c.name,version:c.version,version_domain:p.env.DOMAIN,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${g}`}}),f.data?.error)throw new Error("Failed to publish fnet package.")},na=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet form."});const n=Pt.inc(o.params.version,"patch"),{file:r,data:s}=await St({name:o.config||"fnet-form",dir:t.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${r}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${r}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${r}`);const i=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await It({method:"POST",url:i,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${i}`);a.isDirty=!0,o.params.version=n;const m=`${s.env.ATOM_API_URL}/v1/service/fnet-form/publish`;if(p=await It({method:"POST",url:m,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet form.")},ra=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet flow."});const n=Et.inc(o.params.version,"patch"),{file:r,data:s}=await $t({name:o.config||"fnet-flow",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${r}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${r}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${r}`);const i=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Tt({method:"POST",url:i,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${i}`);a.isDirty=!0,o.params.version=n;const m=`${s.env.ATOM_API_URL}/v1/service/fnet-flow/publish`;if(p=await Tt({method:"POST",url:m,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet flow.");const u=p.data?.upload.id;let f="fnet-dir-zipper";f+=` --sourceDir='${t.project.projectDir}'`,f+=" -p=**/*",f+=" -g",f+=" --stdout_format=json";const g=await Ct({cmd:f});if(0!==g.code)throw new Error(g.stderr);const y=JSON.parse(g.stdout).path;let w=new Rt;w.append("file",Ot.createReadStream(y));const h=await Tt.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${u}`,headers:{...w.getHeaders(),Authorization:`Bearer ${d}`},data:w});if(h.data?.error)throw new Error("Error uploading fnet flow.")},sa=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet node."});const n=Mt.inc(o.params.version,"patch"),{file:r,data:s}=await qt({name:o.config||"fnet-node",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${r}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${r}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${r}`);const i=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Ft({method:"POST",url:i,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${i}`);a.isDirty=!0,o.params.version=n;const m=`${s.env.ATOM_API_URL}/v1/service/fnet-node/publish`;if(p=await Ft({method:"POST",url:m,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet node.");const u=p.data?.upload.id;let f="fnet-dir-zipper";f+=` --sourceDir='${t.project.projectDir}'`,f+=" -p=**/*",f+=" -g",f+=" --stdout_format=json";const g=await Nt({cmd:f});if(0!==g.code)throw new Error(g.stderr);const y=JSON.parse(g.stdout).path;let w=new Ut;w.append("file",Lt.createReadStream(y));const h=await Ft.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${u}`,headers:{...w.getHeaders(),Authorization:`Bearer ${d}`},data:w});if(h.data?.error)throw new Error("Error uploading fnet node.")},ia=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as Rust package."});const r=t?.config?await zt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=Wt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=Jt(t.params);i.dependencies=Jt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await Bt(c)}};const ca=d,la=m,pa=s,da=i,ma=u,ua=async()=>{if(!await U({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=N.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e},{nanoid:fa}=y,ga=class{init({config:e,accessToken:t}){return new Promise(((a,o)=>{if(z.set_api_url(e.data.url),t)return z.set_req_token(t),void a(t);B({method:"POST",url:`${e.data.issuer}/protocol/openid-connect/token`,data:J.stringify(e.data.grant.params),headers:{"Content-Type":"application/x-www-form-urlencoded"}}).then((e=>{z.set_req_token(e.data.access_token),a(e.data.access_token)})).catch((e=>{z.set_req_token(),o(e)}))}))}},ya=async({atom:e,context:t})=>{e.doc.features=e.doc.features||{};const a=e.doc.features;a.project=a.project||{},a.project.format=a.project.format||a.project_format||"esm",a.project_format=a.project.format,a.dts_enabled=!0===a.dts||void 0!==a.dts&&!1!==a.dts,a.hasOwnProperty("all_parsed_imports")||(a.all_parsed_imports=!0);const o=G.resolve(t.project.projectDir),n=X({dir:G.resolve(o,"./app")});if(n.file){let e=await H({file:n.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));a.app_uses_jsx=t,a.app_has_entry=!0,e=await H({file:n.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),a.app_entry_uses_jsx=t,a.app_entry_is_ts=n.ts,a.app_entry_ext=n.ext}const r=X({dir:G.resolve(o,"./cli")});if(r.file){let e=await H({file:r.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));a.cli_uses_jsx=t,a.cli_has_entry=!0,e=await H({file:r.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),a.cli_entry_uses_jsx=t,a.cli_entry_is_ts=r.ts,a.cli_entry_ext=r.ext}if("workflow.lib"===e.type){const e=X({dir:G.resolve(o,"./src")});if(e.file){let t=await H({file:e.file,recursive:!0}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));a.src_uses_jsx=o,a.src_has_entry=!0,t=await H({file:e.file}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),a.src_entry_uses_jsx=o,a.src_entry_is_ts=e.ts,a.src_entry_ext=e.ext}}const s=!0===a.app_has_entry||!0===a.src_uses_jsx,i=!0===a.cli_has_entry||!0===a.src_uses_jsx;a.form_enabled=!0===e.doc.form||!0===e.doc.form?.enabled||!0===a.form||!0===a.form?.enabled,a.multiple_enabled=a.multiple_enabled||!0===a.multiple||!0===a.multiple?.enabled,!1===a.app?a.app={enabled:!1}:!0===a.app?a.app={enabled:!0,extend:!0===a.app_has_entry,export:!0,react:s}:a.app={enabled:!0,extend:!0===a.app_has_entry,export:!0,react:s,...a.app||{}},a.app.enabled=!0===a.app.enabled&&(!0===e.doc.features.form_enabled||!0===a.app.extend||!0===a.app.enabled),a.app.format=a.app.format||"esm",a.app.folder=a.app.folder||a.app.format||"default",!1===a.cli?a.cli={enabled:!1}:!0===a.cli?a.cli={enabled:!0,extend:!0===a.cli_has_entry,export:!0,react:i}:a.cli={enabled:!0,extend:!0===a.cli_has_entry,export:!0,react:i,...a.cli||{}},a.cli.enabled=!0===a.cli.enabled&&(!1===e.doc.features.form_enabled||!0===a.cli.extend||!0===a.cli.enabled),a.cli.format=a.cli.format||"esm",a.cli.folder=a.cli.folder||a.cli.folder||"esm",a.cli.node_options=a.cli.node?.options||a.cli.node_options||"";const c={cjs:{format:"cjs",context:a.form_enabled?"window":"global",babel:!0===a.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!0,string:!0},cjsx:{format:"cjs",context:a.form_enabled?"window":"global",babel:!0===a.src_uses_jsx||!1,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0},esm:{format:"esm",context:a.form_enabled?"window":"global",babel:!0===a.src_uses_jsx||!1,browser:!1,replace:!0,browsersync:!0,terser:!1,enabled:!0,copy:!0,string:!0},esmx:{format:"esm",browser:!0,babel:!0,context:a.form_enabled?"window":"global",replace:!0,browsersync:!1,enabled:!1,terser:!0,string:!0},iife:{format:"iife",context:a.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1!==a.iife,terser:!0,string:!0},umd:{format:"umd",context:a.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0}},l={};!0===a.webos&&(c.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",babel_options:{targets:{chrome:"79"}}}),!0===a.electron&&(c.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===a.nextjs&&(c.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===a.ios&&(c.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===a.macos&&(c.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===a.app.enabled&&(a.app.dir=`./dist/app/${a.app.folder}`,c.app={format:a.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:a.app.dir,terser:!0,output_exports:!1===a.app.export?"none":"auto",string:!0},l.targets=l.targets||[],l.targets.push({src:"./src/app/index.html",dest:a.app.dir})),!0===a.cli.enabled&&(a.cli.dir=`./dist/cli/${a.cli.folder}`,c.cli={format:a.cli.format,context:"global",babel:!0===a.src_uses_jsx||!0===a.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:a.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===a.cli.export?"none":"auto",string:!0});const p={server:".",startPath:`${G.normalize(a.app.dir||".")}`,files:[G.normalize("./dist/**/*")],cors:!0,open:!1};a.babel_options=a.babel_options||a.babel?.options||{targets:{browsers:"last 9 versions, not dead",node:"18"}},a.browsersync_options=W(p,a.browsersync_options||a.browsersync?.options||{}),a.replace_options=W({},a.replace_options||a.replace?.options||{}),a.terser_options=W({},a.terser_options||a.terser?.options||{}),a.css_options=W({},a.css_options||a.css?.options||{}),a.wasm_options=W({},a.wasm_options||a.wasm?.options||{}),a.copy_options=W(l,a.copy_options||a.copy?.options||{}),a.json_options=W({},a.json_options||a.json?.options||{}),a.image_options=W({},a.image_options||a.image?.options||{}),a.analyzer_options=W({summaryOnly:!0,limit:12},a.analyzer_options||a.analyzer?.options||{}),a.visualizer_options=W({},a.visualizer_options||a.visualizer?.options||{}),a.string_options=W({},a.string_options||a.string?.options||{}),a.nunjucks_options=W({},a.nunjucks_options||a.nunjucks?.options||{}),Reflect.has(a.browsersync_options,"proxy")&&delete a.browsersync_options.server,a.rollup=a.rollup||{},a.rollup_output=W(c,a.rollup_output||a.rollup?.output||{}),a.string_enabled=!0===a.string||a.string&&!1!==a.string?.enabled,a.preact_enabled=!0===a.preact||a.preact&&!1!==a.preact?.enabled;const d=Object.keys(c);for(const e of d){const t=c[e];t&&(!1!==a.rollup[e]?(!0===a.rollup[e]&&(t.enabled=!0),t.babel_options=t.babel_options||a.babel_options,t.browsersync_options=W(a.browsersync_options,t.browsersync_options),t.replace_options=W(a.replace_options,t.replace_options),t.terser_options=W(a.terser_options,t.terser_options),t.css_options=W(a.css_options,t.css_options),t.wasm_options=W(a.wasm_options,t.wasm_options),t.copy_options=W(a.copy_options,t.copy_options),t.json_options=W(a.json_options,t.json_options),t.image_options=W(a.image_options,t.image_options),t.analyzer_options=W(a.analyzer_options,t.analyzer_options),t.visualizer_options=W(a.visualizer_options,t.visualizer_options),t.string_options=W(a.string_options,t.string_options),t.string=a.string_enabled&&t.string,t.nunjucks_options=W(a.nunjucks_options,t.nunjucks_options),a.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),a.form_enabled&&(t.babel=!0)):t.enabled=!1)}a.babel_enabled=d.some((e=>!0===a.rollup_output[e].babel)),a.browser_enabled=d.some((e=>!0===a.rollup_output[e].babel)),a.browsersync_enabled=!1!==a.browsersync&&d.some((e=>!0===a.rollup_output[e].browsersync)),a.browsersync_enabled=a.browsersync_enabled&&a.app.enabled,a.wasm_enabled=!0===a.wasm||a.wasm&&!1!==a.wasm?.enabled,a.css_enabled=!0===a.css||a.css&&!1!==a.css?.enabled,a.json_enabled=!0===a.json||a.json&&!1!==a.json?.enabled,a.terser_enabled=!1!==a.terser,a.copy_enabled=a.app.enabled||a.copy_enabled||a.copy&&!1!==a.copy?.enabled,a.image_enabled=!0===a.image||a.image&&!1!==a.image?.enabled,a.analyzer_enabled=!0===a.analyzer||a.analyzer&&!1!==a.analyzer?.enabled,a.visualizer_enabled=!0===a.visualizer||a.visualizer&&!1!==a.visualizer?.enabled,a.dependency_auto_enabled=!1!==a.dependency_auto&&!1!==a.dependency_auto?.enabled,a.npm_install_flags=a.npm_install_flags||"",a.react_version=a.react_version||a.react?.version||18,a.polyfill_enabled=!0===a.polyfill||a.polyfill&&!1!==a.polyfill?.enabled,a.nunjucks_enabled=!0===a.nunjucks||a.nunjucks&&!1!==a.nunjucks?.enabled},wa=async({atom:e,packageDependencies:t,packageDevDependencies:a})=>{if("workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let a="^18.2";a=`^${(await Y({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:a}),t.push({package:"react-dom",version:a}),"workflow"===e.type&&(t.push({package:"@flownet/react-app",version:"^0.1"}),t.push({package:"@flownet/react-app-state",version:"^0.1"}))}if(e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&t.push({package:"yargs",version:"^17"}),a.push({package:"@babel/core",version:"^7"}),a.push({package:"@rollup/plugin-commonjs",version:"^26"}),a.push({package:"@rollup/plugin-node-resolve",version:"^15"}),a.push({package:"@rollup/plugin-replace",version:"^5"}),a.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&a.push({package:"rollup-plugin-dts",version:"^6"}),a.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),a.push({package:"@rollup/plugin-alias",version:"^5"}),a.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(a.push({package:"@rollup/plugin-babel",version:"^6"}),a.push({package:"@babel/preset-env",version:"^7"}),a.push({package:"@babel/preset-react",version:"^7"}),a.push({package:"@babel/plugin-proposal-decorators",version:"^7"}),a.push({package:"@babel/plugin-proposal-class-properties",version:"^7"})),a.push({package:"@fnet/rollup-plugin-delete",version:"0.1.3"}),e.doc.features.nunjucks_enabled&&a.push({package:"@fnet/rollup-plugin-nunjucks",version:"0.1.3"}),e.doc.features.browsersync_enabled&&a.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.1"}),e.doc.features.json_enabled&&a.push({package:"@rollup/plugin-json",version:"^6"}),e.doc.features.terser_enabled&&a.push({package:"@rollup/plugin-terser",version:"^0.4"}),e.doc.features.wasm_enabled&&a.push({package:"@rollup/plugin-wasm",version:"^6"}),e.doc.features.image_enabled&&a.push({package:"@rollup/plugin-image",version:"^3"}),e.doc.features.analyzer_enabled&&a.push({package:"rollup-plugin-analyzer",version:"^3"}),e.doc.features.visualizer_enabled&&a.push({package:"rollup-plugin-visualizer",version:"^5"}),e.doc.features.string_enabled&&a.push({package:"rollup-plugin-string",version:"^3"}),e.doc.features.css_enabled){a.push({package:"rollup-plugin-postcss",version:"^4"}),a.push({package:"sass",version:"^1.66"});(e.doc.features.css_options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":a.push({package:"postcss-import",version:"^15"});break;case"postcss-url":a.push({package:"postcss-url",version:"^10"});break;case"postcss-preset-env":a.push({package:"postcss-preset-env",version:"^9"});break;case"autoprefixer":a.push({package:"autoprefixer",version:"^10"});break;case"cssnano":a.push({package:"cssnano",version:"^6"})}}))}e.doc.features.polyfill_enabled&&a.push({package:"rollup-plugin-node-polyfills",version:"^0.2"}),e.doc.features.copy_enabled&&(a.push({package:"rollup-plugin-copy",version:"^3"}),a.push({package:"chokidar",version:"^3"}))},ha=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{if(!0!==e.doc.features.app.enabled)return;await t({message:"Creating index.html."});const n={workflowAtom:e,libraryAtom:e,atom:e,packageDependencies:o,ts:Date.now()},r=a.templateDir,s=Q.resolve(a.projectDir,"src/app");Z.existsSync(s)||Z.mkdirSync(s,{recursive:!0}),await V({pattern:["index.html.njk","index.js.njk"],dir:Q.resolve(r,"src/app"),outDir:s,context:n})},ba=async({atom:e,context:t,packageDependencies:a,packageDevDependencies:o,setInProgress:n})=>{await n({message:"Creating package.json."});a.filter((e=>!0===e.dev)).forEach((e=>{o.find((t=>t.package===e.package))||o.push(e);const t=a.findIndex((t=>t.package===e.package));a.splice(t,1)}));const r=a.find((e=>"react"===e.package)),s=a.find((e=>"react-dom"===e.package));r&&!s?a.push({package:"react-dom",version:r.version}):r&&s&&(s.version=r.version),r&&e.doc.features.react_version>=17&&(a.find((e=>"@emotion/react"===e.package))||a.push({package:"@emotion/react",version:"^11"}),a.find((e=>"@emotion/styled"===e.package))||a.push({package:"@emotion/styled",version:"^11"}));const i=[];!0===e.doc.features.app.enabled&&i.push({file:ae.resolve(t.projectDir,"src/app/index.js"),dev:!1!==e.doc.features.app.dev}),!0===e.doc.features.cli.enabled&&i.push({file:ae.resolve(t.projectDir,"src/cli/index.js"),dev:!1!==e.doc.features.cli.dev});for await(const t of i){const n=t.file;if(!te.existsSync(n))throw new Error(`App file not found: ${n}`);const r=await oe({file:n,recursive:!0}),s=!0===e.doc.features.all_parsed_imports?r.all:r.required;for await(const e of s){if("npm"!==e.type)continue;if(a.find((t=>t.package===e.package)))continue;if(o.find((t=>t.package===e.package)))continue;const n=(await ne({name:e.package,groupBy:{minor:!0}}))[0][0];(!0===t.dev?o:a).push({package:e.package,subpath:e.subpath,version:`^${n}`,type:"npm"})}}const c={atom:e,packageDependencies:a,packageDevDependencies:o},l=t.templateCommonDir,p=ee.compile(te.readFileSync(ae.resolve(l,"package.json.njk"),"utf8"),ee.configure(l)).render(c),d=t.projectDir,m=ae.resolve(d,"package.json");te.writeFileSync(m,p,"utf8")},_a=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating cli."});const n={workflowAtom:e,libraryAtom:e,atom:e,packageDependencies:o},r=a.templateDir,s=se.resolve(a.projectDir,"src/cli");re.existsSync(s)||re.mkdirSync(s,{recursive:!0}),await ie({pattern:["index.js.njk"],dir:se.resolve(r,"src/cli"),outDir:s,context:n})},va=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{await t({message:"Creating rollup file."});const n={atom:e,packageDependencies:o},r=le.resolve(a.projectDir,"src","default/index.js");if(!ce.existsSync(r))throw new Error(`Entry file not found: ${r}`);const s=(await de({file:r,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),i=e.doc.features.rollup_output,c=Object.keys(i);for(let e=0;e<c.length;e++){const t=i[c[e]];if(!0===t.browser&&s.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(s.map((e=>({key:e,value:e})))),t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{};for(let e=0;e<s.length;e++){const a=s[e];t.alias.entries[a]=`node:${a}`,t.alias.entries[`node:${a}`]=a}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(s)}}const l=a.templateCommonDir;let p=pe.compile(ce.readFileSync(le.resolve(l,"rollup.config.mjs.njk"),"utf8"),pe.configure(l)).render(n);const d=a.projectDir;let m=le.resolve(d,"rollup.config.mjs");ce.writeFileSync(m,p,"utf8")},ja=async({atom:e,setInProgress:t,context:a,njEnv:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating yargs."});let n={};const r=e.doc.inputs||[],s=[],i=e.doc.input;i?n=await ge({schema:i}):r.forEach((e=>{if(!1===e.cli||!e.name)return;e.import&&s.push(e);const t={};Reflect.has(e,"type")&&(t.type=e.type),Reflect.has(e,"default")&&(t.default=e.default),Reflect.has(e,"choices")&&(t.choices=e.choices),(Reflect.has(e,"describe")||Reflect.has(e,"description"))&&(t.describe=e.describe||e.description),Reflect.has(e,"alias")&&(t.alias=e.alias),Reflect.has(e,"required")&&!0===e.required&&(t.required=!0),Reflect.has(e,"hidden")&&!0===e.hidden&&(t.hidden=!0),Reflect.has(e,"array")&&!0===e.array&&(t.array=!0),Reflect.has(e,"normalize")&&!0===e.normalize&&(t.normalize=!0),Reflect.has(e,"nargs")&&(t.nargs=e.nargs),n[e.name]=t}));const c={options:n,imports:s,atom:e},l=a.templateDir,p=fe.compile(me.readFileSync(ue.resolve(l,"src/default/to.yargs.js.njk"),"utf8"),o).render(c),d=a.projectDir,m=ue.resolve(d,"src/default/to.yargs.js");me.writeFileSync(m,p,"utf8")},ka=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{await t({message:"Creating .gitignore"});const n={atom:e,packageDependencies:o},r=a.templateCommonDir,s=he.compile(ye.readFileSync(we.resolve(r,".gitignore.njk"),"utf8"),he.configure(r)).render(n),i=a.projectDir,c=we.resolve(i,".gitignore");ye.writeFileSync(c,s,"utf8")},xa=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{await t({message:"Creating tsconfig.json."});const n={atom:e,packageDependencies:o},r=a.templateCommonDir,s=ve.compile(be.readFileSync(_e.resolve(r,"tsconfig.json.njk"),"utf8"),ve.configure(r)).render(n),i=a.projectDir,c=_e.resolve(i,"tsconfig.json");be.writeFileSync(c,s,"utf8")},Da=async({atom:e,context:t,setInProgress:a,Atom:o})=>{const n="readme.md",r=`Creating ${n}`;if(await a({message:r}),t.project?.readme){const e={content:t.project.readme.doc.content},a=t.templateCommonDir,o=je.compile(ke.readFileSync(xe.resolve(a,`${n}.njk`),"utf8"),je.configure(a)).render(e),r=t.projectDir,s=xe.resolve(r,`${n}`);ke.writeFileSync(s,o,"utf8")}else if(e.id){const a=await o.first({type:"wiki",parent_id:e.id});if(!a||"markdown"!==a.doc?.["content-type"])return;const{content:r,...s}=a.doc,i={content:r},c=t.templateCommonDir,l=je.compile(ke.readFileSync(xe.resolve(c,`${n}.njk`),"utf8"),je.configure(c)).render(i),p=t.projectDir,d=xe.resolve(p,`${n}`);ke.writeFileSync(d,l,"utf8")}},Aa=async({setInProgress:e,context:t})=>{const a=t.projectDir;await e({message:"Prettifiying source files."});let o=Ae.join("src","**","*");if(0!==De.exec(`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:a}).code)throw new Error("Couldnt format files.")},Pa=async({atom:e,setInProgress:t,context:a})=>{if(!e.doc.features.dts_enabled)return;const o=a.projectDir;await t({message:"Creating .d.ts"});if(0!==Pe.exec("tsc",{cwd:o}).code)throw new Error("Couldnt create .d.ts files.")},Sa=async({setInProgress:e,atom:t,context:a})=>{const o=a.projectDir;await e({message:"Installing npm packages."});if(0!==Se.exec(`npm install ${t.doc.features.npm_install_flags}`,{cwd:o}).code)throw new Error("Couldnt install npm packages.")},Ia=async({setInProgress:e,context:t})=>{const a=t.projectDir;await e({message:"Building main project."});if(0!==Ie.exec("npm run build",{cwd:a}).code)throw new Error("Couldnt build project.")},Ea=async e=>{const{atom:t,packageDependencies:a,context:o,deploymentProjectTarget:n,setInProgress:r,deploymentProject:s}=e;if(!0===n.enabled)if("lib"===n.name)await Yt({...e});else if("red"===n.name)await Xt({...e});else if("npm"===n.name)await Ht({...e});else if("gcs"===n.name)await Gt({...e});else if("gitlab"===n.name)await Kt({...e});else if("fnet-package"===n.name)await oa({...e});else if("fnet-form"===n.name)await na({...e});else if("fnet-node"===n.name)await sa({...e});else if("fnet-flow"===n.name)await ra({...e});else{let e;if("nextjs"===n.name?e=ta:"webos"===n.name?e=ea:"electron"===n.name?e=Vt:"docker"===n.name?e=aa:"ios"===n.name?e=Zt:"macos"===n.name?e=Qt:"rust"===n.name&&(e=ia),!e)return;await e({atom:t,target:n,onProgress:r,projectDir:o.projectDir,dependencies:a}),s.isDirty=!0}},{Atom:$a}=w,Ta=q,Oa=t,Ca=v,Ra=F,Ma=L;var qa=class{#e;#t;#a;#o;#n;#r;#s;#i;#c;#l;#p;#d;#m;#u;#f;#g;#y;constructor(e){this.#e=new ga,this.#t=e,this.#r=[],this.#s=[],this._expire_ttl=3600,this._expire_ttl_short=300,this.#y={packageDependencies:this.#r,packageDevDependencies:this.#s,setInProgress:this.setInProgress.bind(this),context:this.#t,Atom:$a,registerToPackageManager:this.registerToPackageManager.bind(this)}}async _cache_set(e,t,a){this._redis_client&&await this._redis_client.SETEX(e,a||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await ua(),this.#c=this.#t.buildId||fa(24),this.#y.buildId=this.#c,this.#m=this.#t.mode,this.#u=["all","deploy","build","file"].includes(this.#m),this.#f=["all","deploy","build"].includes(this.#m),this.#g=["all","deploy"].includes(this.#m),this.#p=this.#t.protocol,this.#l="BUILD:"+this.#c,this.#d=(await Oa({optional:!0,name:this.#t.atomConfig||"atom",dir:this.#t.projectDir}))?.data;try{await this.setInProgress({message:"Initialization started."}),await this.initAuth(),await this.initLibrary(),await ya(this.#y),await wa(this.#y),await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}catch(e){throw await this._cache_set(this.#l,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#t.id&&(this.#i=await this.#e.init({config:this.#d}),this.#y.atomAccessToken=this.#i)}async initLibrary(){const e=this.#t.id;this.#a=this.#t.project?.libraryAtom||await $a.get({id:e});let t=this.#a.doc.bundleName;t=t||(this.#a.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#a.doc.bundleName=t,this.#a.type=this.#a.type||"workflow.lib",this.#y.atom=this.#a}async initLibraryDir(){const e=this.#t.projectDir;let t;const a=["node_modules"];ca.existsSync(e)&&ca.readdirSync(e).forEach((o=>{a.includes(o)||(t=da.rm("-rf",la.join(e,o)))}));let o=e;if(!ca.existsSync(o)&&(t=da.exec(`mkdir "${e}"`),0!==t.code))throw new Error("Couldnt create workflow dir.");if(o=la.join(e,"src"),!ca.existsSync(o)&&(t=da.exec(`mkdir "${o}"`),0!==t.code))throw new Error("Couldnt create library/src dir.");if(o=la.join(e,"src","default"),!ca.existsSync()&&(t=da.exec(`mkdir "${o}"`),0!==t.code))throw new Error("Couldnt create library/src/default dir.")}async initNunjucks(){const e=this.#t.templateDir;this.#o=ma.configure(e,{watch:!1,dev:!0}),this.#y.njEnv=this.#o}async initLibs(){const e=[{name:this.#a.doc.name,type:"atom",parent_id:this.#a.parent_id}];this.#n=e,await this.initAtomLibsAndDeps({libs:e,packageDependencies:this.#r})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const a=e.filter((e=>"atom"===e.type));for(let e=0;e<a.length;e++){const o=a[e],n=await this.findAtomLibrary({url:o.name});o.atom=n;const r=n.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));r?.forEach((e=>{const a=t.find((t=>t.package===e.package));a?"string"==typeof e.path?(a.path||[]).some((t=>t===e.path))||(a.path=a.path||[],a.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(a.path||[]).some((t=>t===e))||(a.path=a.path||[],a.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const t=Ta({url:e});if(!t)throw new Error(`Invalid package name: ${e}`);if(t.protocol||(t.protocol=this.#p),"ac:"===t.protocol){const a=t.pathname.split("/");if(1===a.length)return await $a.first({where:{name:e,parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===a.length){const e=await $a.first({where:{name:a[0],parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"folder"}});return await $a.first({where:{name:a[1],parent_id:e.id,type:"workflow.lib"}})}}else if("local:"===t.protocol){const e=this.#a;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const t=la.resolve(this.#t.projectSrcDir,"index.js"),a=await Ca({file:t,recursive:!0}),o=e.doc.dependencies,n=!0===this.#a.doc.features.all_parsed_imports?a.all:a.required;for await(const e of n){if("npm"!==e.type)continue;if(o.find((t=>t.package===e.package)))continue;const t=await Ra({name:e.package,count:1});o.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return e}}async createAtomLibFiles({libs:e}){await this.setInProgress({message:"Creating external lib files."}),this.#a.typesDir="./types";const t=e.filter((e=>"atom"===e.type));for(let e=0;e<t.length;e++){const a=t[e].atom,o=this.#t.projectDir;if("local:"===a.protocol){const e=la.resolve(this.#t.projectSrcDir,`${a.fileName||a.name}.js`),t=la.relative(la.join(this.#t.projectDir,"src","default"),e);if(!ca.existsSync(e)){ca.mkdirSync(la.dirname(e),{recursive:!0});let t="export default async (args)=>{\n";t+="}",ca.writeFileSync(e,t,"utf8")}a.relativePath=t.split(la.sep).join("/"),this.#a.typesDir=`./types/${la.basename(o)}/src`}else{const e=la.join(o,"src","libs",`${a.id}.js`),t=a.doc.contents?.find((e=>"esm"===e.format))||a.doc;ca.writeFileSync(e,t.content,"utf8")}}}async createEngine(){await this.setInProgress({message:"Creating engine file."});const e={libs:this.#n.filter((e=>"atom"===e.type)),libraryAtom:this.#a,atom:this.#a},t=this.#t.templateDir,a=ma.compile(ca.readFileSync(la.resolve(t,la.join("src","default","engine.js.njk")),"utf8"),this.#o).render(e),o=this.#t.projectDir,n=la.resolve(o,la.join("src","default","index.js"));ca.writeFileSync(n,a,"utf8")}async createProjectYaml(){const e="node.yaml",t=`Creating ${e}`;await this.setInProgress({message:t});const{content:a,...o}=this.#a.doc,n={content:pa.stringify(o)},r=this.#t.templateDir,s=ma.compile(ca.readFileSync(la.resolve(r,`${e}.njk`),"utf8"),this.#o).render(n),i=this.#t.projectDir,c=la.resolve(i,`${e}`);ca.writeFileSync(c,s,"utf8")}async deploy(){if(await this.setInProgress({message:"Deploying."}),this.#t.project?.devops){const e=[this.#t.project?.devops];for(let t=0;t<e.length;t++){let a=e[t];await this.deployProject({deploymentProject:a}),!0===a.isDirty&&await a.save()}}else if(this.#a.id){const e=await $a.list({type:"library.deploy",parent_id:this.#a.id});for(let t=0;t<e.length;t++){let a=e[t];await this.deployProject({deploymentProject:a}),!0===a.isDirty&&(a=await $a.update(a,{id:a.id}))}}}async deployProject(e){const{deploymentProject:t}=e,a=t.doc.targets||[];for(let e=0;e<a.length;e++){const o=a[e];await Ea({...this.#y,deploymentProject:t,deploymentProjectTarget:o})}}async registerToPackageManager(e){const{target:t,packageJSON:a}=e;if(!this.#t.id)return;let o=await $a.first({name:t.params.name,parent_id:this.#d.env.ATOM_PACKAGES_ID});o?(o.doc.versions.splice(0,0,{v:a.version}),await $a.update(o,{id:o.id})):o=await $a.create({parent_id:this.#d.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:a.version}]}})}async setInProgress({message:e}){console.log(Ma.blue(e)),await this._cache_set(this.#l,{status:"IN_PROGRESS",message:e})}async build(){try{this.#u&&(await this.createAtomLibFiles({libs:this.#n}),await this.createEngine(),await this.createProjectYaml(),await Da(this.#y),await xa(this.#y),await ka(this.#y),await ja(this.#y),await _a(this.#y),await ha(this.#y),await va(this.#y),await ba(this.#y),await Aa(this.#y),await Pa(this.#y),this.#f&&(await Sa(this.#y),await Ia(this.#y),this.#g&&await this.deploy())),await this._cache_set(this.#l,{status:"COMPLETED"})}catch(e){throw await this._cache_set(this.#l,{status:"FAILED",message:e.message||e}),console.log(e),e}}};const Fa=d,La=m;var Na=function({baseDir:e=__dirname}){let t=e;for(;t!==La.parse(t).root;){const e=La.join(t,"node_modules");if(Fa.existsSync(e))return e;t=La.dirname(t)}return null};const Ua=process.cwd(),{spawn:za}=e;t({name:["redis"],dir:Ua,optional:!0});const Ba=a,Ja=o,{hideBin:Wa}=n,Ka=r,Ga=s,Ha=i,Xa=c,Ya=t,Za=l,Qa=p,Va=qa,eo=Na({baseDir:__dirname}),to="win32"===process.platform?";":":";process.env.PATH=`${Ba.join(eo,"/.bin")}${to}${process.env.PATH}`;let ao=Ja(Wa(process.argv)).command("create","Create flow node project",(e=>e.option("name",{type:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs"})),(async e=>{try{const t=Ba.resolve(eo,"@fnet/cli-project-node/dist/template/project"),a=Ba.resolve(Ua,e.name);Ka.existsSync(a)||Ka.mkdirSync(a),await Qa({dir:t,outDir:a,context:e,copyUnmatchedAlso:!0});let o=Ha.exec("fnode build",{cwd:a});if(0!==o.code)throw new Error("Failed to build project.");if(Ha.which("git")&&(o=Ha.exec("git init",{cwd:a}),0!==o.code))throw new Error("Failed to initialize git.");if(Ha.which("code")&&e.vscode&&(o=Ha.exec(`cd ${a} && code .`),0!==o.code))throw new Error("Failed to open vscode.");console.log("Creating project succeeded!"),process.exit(0)}catch(e){console.error("Initialization failed!",e.message),process.exit(1)}})).command("project","Flow node project",(e=>e.option("update",{type:"boolean",default:!1,alias:"-u"})),(async e=>{try{const t=Ba.resolve(eo,"@fnet/cli-project-node/dist/template/project"),a=process.cwd();if(e.name=Ba.basename(a),e.update){if(await Qa({dir:t,outDir:a,context:e,copyUnmatchedAlso:!0}),0!==Ha.exec("fnode build",{cwd:a}).code)throw new Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(e){console.error("Project failed.",e.message),process.exit(1)}})).command("build","Build flow node project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("mode",{type:"string",alias:"m",default:"build",choices:["all","file","build","deploy","bpmn"]})),(async e=>{try{const t=await no(e),a=new Va(t);await a.init(),await a.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}})).command("deploy","Build and deploy flow node project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"})),(async e=>{try{const t=await no({...e,mode:"all"}),a=new Va(t);await a.init(),await a.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}})).command("file","Just create files",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"})),(async e=>{try{const t=await no({...e,mode:"file"}),a=new Va(t);await a.init(),await a.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}));function oo(e,{name:t,bin:a,preArgs:o=[]}){return e.command(`${t||a} [commands..]`,`${a} ${o.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await no(e),{projectDir:n}=t,r=process.argv.slice(3);za(a,[...o,...r],{cwd:n,stdio:"inherit",shell:!0}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}async function no(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:Ba.resolve(eo,"./@fnet/cli-project-node/dist/template/default"),templateCommonDir:Ba.resolve(eo,"./@fnet/cli-project-common/dist/template/default"),projectDir:Ba.resolve(Ua,`./.output/${e.id}`)};{const t=await async function(){const e=Ba.resolve(Ua,"node.yaml");if(!Ka.existsSync(e))throw new Error("node.yaml file not found in current directory.");const t=Ka.readFileSync(e,"utf8"),{parsed:a}=await Xa({content:t}),o=Ba.dirname(e),n={libraryAtom:{doc:{...a},fileName:"index"},projectDir:o,projectFilePath:e,projectFileContent:t,projectFileParsed:a},r=Ba.resolve(o,"node.devops.yaml");if(Ka.existsSync(r)){const e=Ka.readFileSync(r,"utf8"),t=Ga.parse(e);n.devops={filePath:r,fileContent:e,doc:{...t},type:"library.deploy",save:async()=>{Ka.writeFileSync(n.devops.filePath,Ga.stringify(n.devops.doc))}}}const s=Ba.resolve(o,"readme.md");if(Ka.existsSync(s)){const e=Ka.readFileSync(s,"utf8");n.readme={filePath:s,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return n}();return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:Ba.resolve(eo,"./@fnet/cli-project-node/dist/template/default"),templateCommonDir:Ba.resolve(eo,"./@fnet/cli-project-common/dist/template/default"),projectDir:Ba.resolve(t.projectDir,"./.workspace"),projectSrcDir:Ba.resolve(t.projectDir,"./src"),project:t}}}ao=ao.command("config create <name>","Create a config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await no(e),{project:a}=t,{projectDir:o,projectFileParsed:n}=a,r=n.config;if(!r)throw new Error("Config schema not found in project file.");const s=await Za({schema:r}),i=Ba.resolve(o,".fnet");Ka.existsSync(i)||Ka.mkdirSync(i);const c=Ba.resolve(i,`${e.name}.fnet`);Ka.writeFileSync(c,Ga.stringify(s))}catch(e){console.error(e.message),process.exit(1)}})),ao=oo(ao,{bin:"npm"}),ao=oo(ao,{bin:"node"}),ao=oo(ao,{name:"serve",bin:"npm",preArgs:["run","serve","--"]}),ao=oo(ao,{name:"watch",bin:"npm",preArgs:["run","watch","--"]}),ao=oo(ao,{name:"app",bin:"npm",preArgs:["run","app","--"]}),ao=oo(ao,{name:"cli",bin:"npm",preArgs:["run","cli","--"]}),ao=oo(ao,{bin:"npx"}),ao=oo(ao,{bin:"cdk"}),ao=oo(ao,{bin:"aws"}),ao=function(e,{name:t,preArgs:a=[]}){return e.command(`${t} <config> <command> [options..]`,"Run a command with a config context",(e=>e.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await no(e),{projectDir:o}=t,n=e.config,r=await Ya({name:n,dir:o,transferEnv:!1,optional:!0}),s=r?.data?.env||void 0,i=e.command,c=process.argv.slice(5);za(i,[...a,...c],{cwd:o,stdio:"inherit",shell:!0,env:{...process.env,...s}}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}(ao,{name:"with"}),ao.demandCommand(1,"You need at least one command before moving on").help().argv,module.exports={};
|
|
2
|
+
"use strict";var e=require("child_process"),t=require("@fnet/config"),a=require("path"),o=require("yargs/yargs"),n=require("yargs/helpers"),r=require("fs"),s=require("yaml"),i=require("shelljs"),c=require("@fnet/yaml"),l=require("@fnet/object-from-schema"),p=require("@flownet/lib-render-templates-dir"),d=require("node:fs"),m=require("node:path"),u=require("nunjucks"),f=require("redis"),g=require("@flownet/lib-is-redis-online"),y=require("nanoid"),h=require("@flownet/lib-atom-api-js"),w=require("axios"),b=require("qs"),_=require("lodash.merge"),v=require("@flownet/lib-parse-imports-js"),j=require("@flownet/lib-list-npm-versions"),k=require("@fnet/yargs-options-from-schema"),x=require("@fnet/shell"),D=require("semver"),A=require("node:os"),P=require("@node-red/util"),S=require("@flownet/lib-to-ios-app"),I=require("lodash.clonedeep"),E=require("@flownet/lib-to-macos-app"),$=require("@flownet/lib-to-electron"),T=require("@flownet/lib-to-webos"),O=require("@flownet/lib-to-nextjs"),C=require("@flownet/lib-to-docker"),R=require("form-data"),M=require("@fnet/to-rust"),q=require("@flownet/lib-parse-node-url"),F=require("@flownet/lib-pick-npm-versions"),L=require("chalk");const N=f,U=g;const{Api:z}=h,B=w.default,J=b;const W=_,K=d,G=m,H=v;function X({dir:e,name:t="index"}){let a=G.resolve(e,`./${t}.tsx`);if(K.existsSync(a)||(a=G.resolve(e,`./${t}.ts`)),K.existsSync(a)||(a=G.resolve(e,`./${t}.jsx`)),K.existsSync(a)||(a=G.resolve(e,`./${t}.js`)),!K.existsSync(a))return{};const o=a,n=G.extname(a);return{file:o,ext:n,ts:".ts"===n||".tsx"===n,name:t}}const Y=j;const Z=d,Q=m,V=p;const ee=u,te=d,ae=m,oe=v,ne=j;const re=d,se=m,ie=p;const ce=d,le=m,pe=u,de=v;const me=d,ue=m,fe=u,ge=k;const ye=d,he=m,we=u;const be=d,_e=m,ve=u;const je=u,ke=d,xe=m;const De=i,Ae=a;const Pe=i;const Se=i;const Ie=i;const Ee=x,$e=t;const Te=d,Oe=m,Ce=D,Re=x,Me=t;const qe=d,Fe=m,Le=D,Ne=i,Ue=t;const ze=d,Be=m,Je=A,We=u,Ke=P,Ge=t;const He=r,Xe=a,Ye=t;const Ze=t,Qe=S,Ve=I,et=D;const tt=t,at=E,ot=I,nt=D;const rt=t,st=$,it=I,ct=D;const lt=t,pt=T,dt=I,mt=D;const ut=t,ft=O,gt=I,yt=D;const ht=t,wt=C,bt=I,_t=D;const vt=d,jt=m,kt=D,xt=x,Dt=t,At=w.default;const Pt=D,St=t,It=w.default;const Et=D,$t=t,Tt=w.default,Ot=r,Ct=x,Rt=R;const Mt=D,qt=t,Ft=w.default,Lt=r,Nt=x,Ut=R;const zt=t,Bt=M,Jt=I,Wt=D;const Kt=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o,buildId:n})=>{await e({message:"Deploying it as gitlab project."});const r=t.projectDir;let s="fnet-to-gitlab";const i=o.params.config||"gitlab",c=await $e({name:i,dir:t.projectDir});if(!c)throw new Error(`Couldnt load config ${i}`);const{data:l}=c.data;s+=` --projectGroupId=${l.projectGroupId}`,s+=` --projectPath='${r}'`,s+=` --projectName='${o.params.name}'`,s+=` --projectBranch='${o.params.branch||"main"}'`,s+=` --gitlabHost='${l.gitlabHost}'`,s+=` --gitlabToken='${l.gitlabToken}'`,s+=` --gitlabUsername='${l.gitlabUsername}'`,s+=` --gitlabUserEmail='${l.gitlabUserEmail}'`,!0!==o.dryRun&&(await Ee({cmd:s}),a.isDirty=!0)},Gt=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o,registerToPackageManager:n})=>{await e({message:"Deploying it as gcs package."});const r=t.projectDir,s=Oe.resolve(r,"package.json"),i=Te.readFileSync(s),c=JSON.parse(i);c.name=o.params.name,c.version=Ce.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,Te.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Me({name:o.config||"gcs",dir:t.projectDir});let d="fnet-files-to-gcs";d+=` --projectId='${p.env.GCS_PROJECT_ID}'`,d+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,d+=` --keyFilename='${Oe.resolve(Oe.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,d+=` --dir='${r}'`,d+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",d+=` --destDir='${c.name}/${c.version}'`,d+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(d+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(d+=" --dryRun"),await Re({cmd:d}),Te.writeFileSync(s,i),!0!==o.dryRun&&(a.isDirty=!0,o.params.version=c.version,await n({target:o,packageJSON:c}))},Ht=async({atom:e,setInProgress:t,context:a,deploymentProject:o,deploymentProjectTarget:n})=>{await t({message:"Deploying it as npm package."});const r=a.projectDir,s=Fe.resolve(r,"package.json"),i=qe.readFileSync(s),c=JSON.parse(i);c.name=n.params.name,c.version=Le.inc(n.params.version,"patch");const l=n.params.bin?.name||n.params.bin;!1!==n.params.bin?.enabled&&l&&"string"==typeof l&&(c.bin={[l]:"dist/cli/esm/index.js",[e.doc.name]:"dist/cli/esm/index.js"}),delete c.scripts,delete c.devDependencies,c.scripts={serve:"npx serve ."},qe.writeFileSync(s,JSON.stringify(c,null,"\t"));const p=(await Ue({name:a.npmConfig||"npm",dir:a.projectDir}))?.data;if(qe.writeFileSync(Fe.resolve(r,".npmrc"),`//registry.npmjs.org/:_authToken=${p.env.NPM_TOKEN}`),!0===n.dryRun)return;if(0!==Ne.exec("npm publish --access public",{cwd:r}).code)throw new Error("Couldnt publish to npm");qe.writeFileSync(s,i),o.isDirty=!0,n.params.version=c.version},Xt=async({atom:e,setInProgress:t,context:a,deploymentProject:o,deploymentProjectTarget:n,buildId:r,packageDependencies:s,njEnv:i})=>{await t({message:"Deploying it as node-red flow."});const c=a.projectDir,l=a.templateDir,p="workflow"===e.type?"WF":"LIB";let d;if("simple"===n.deploy.template)d={atom:e,packageDependencies:s,red:{tab:{id:n.deploy.id||Ke.util.generateId(),label:`${p}/${e.id?e.id:Je.hostname()}/${e.name}/${n.deploy.name||n.deploy.template}`},function:{id:Ke.util.generateId(),name:e.doc.name,initialize:{content:ze.readFileSync(Be.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},inject:{id:Ke.util.generateId(),...n.params?.inject,payload:"json"===n.params?.inject?.payloadType?`'${JSON.stringify(n.params?.inject?.payload)}'`:n.params?.inject?.payload},debug:{id:Ke.util.generateId()}}};else if("cronjob"===n.deploy.template){let t=n.params?.schedules?cloneDeep(n.params?.schedules):void 0;t?.forEach((e=>{"json"===e.payloadType&&(e.payload=`'${JSON.stringify(e.payload)}'`)})),d={atom:e,packageDependencies:s,red:{tab:{id:n.deploy.id||Ke.util.generateId(),label:`${p}/${e.id?e.id:Je.hostname()}/${n.deploy.name||n.deploy.template}`},function:{id:Ke.util.generateId(),name:e.doc.name,initialize:{content:ze.readFileSync(Be.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},cronjob:{id:Ke.util.generateId(),schedules:t},debug:{id:Ke.util.generateId()}}}}else{if("http"!==n.deploy.template)return;d={atom:e,packageDependencies:s,red:{tab:{id:n.deploy.id||Ke.util.generateId(),label:`${p}/${e.id?e.id:Je.hostname()}/${n.deploy.name||n.deploy.template}`},function:{id:Ke.util.generateId(),name:e.doc.name,initialize:{content:ze.readFileSync(Be.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},httpin:{id:Ke.util.generateId(),method:n.params.method||"get",url:n.params.url},httpout:{id:Ke.util.generateId()},debug:{id:Ke.util.generateId()}}}}let m=We.compile(ze.readFileSync(Be.resolve(l,`deploy/node-red/${n.deploy.template}.yaml.njk`),"utf8"),i).render(d);if(ze.writeFileSync(Be.resolve(c,"node-red.yaml"),m),m=yaml.load(m),!0===n.dryRun)return;o.isDirty=!0;const u=(await Ge({name:a.redConfig||"red",dir:a.projectDir}))?.data,f=n.deploy.url||u.env.RED_URL,g={};if(!1!==n.deploy.auth&&(g.Authorization="Bearer "+atomAccessToken),n.deploy.id)!0===n.actions?.delete?(await axios({method:"DELETE",url:`${f}/flow/${n.deploy.id}`,headers:g}),delete n.actions.delete,delete n.deploy.id,n.enabled=!1):await axios({method:"PUT",url:`${f}/flow/${n.deploy.id}`,data:m,headers:g});else{const e=await axios({method:"POST",url:`${f}/flow`,data:m,headers:g});n.deploy.id=e.data.id}},Yt=async({atom:e,Atom:t,setInProgress:a,context:o,packageDependencies:n,deploymentProject:r,deploymentProjectTarget:s})=>{await a({message:"Deploying it as workflow lib."});const i=(await Ye({name:"atom",dir:o.projectDir}))?.data;let c,l,p,d=s.deploy.name.split("/");if(1===d.length)l=i.env.ATOM_LIBRARIES_ID,p=s.deploy.name;else{if(2!==d.length)throw new Error("Wrong name path.");{const e=await t.first({where:{name:d[0],parent_id:i.env.ATOM_LIBRARIES_ID,type:"folder"},limit:1});if(!e)throw new Error("Couldnt file lib folder.");l=e.id,p=d[1]}}if(!0===s.dryRun)return;if(r.isDirty=!0,s.deploy.id){if(c=await t.get({id:s.deploy.id}),!c)return}else{if(c=await t.create({parent_id:l,doc:{name:p,type:"workflow.lib","content-type":"javascript",dependencies:[],content:void 0,subtype:"workflow"}}),!c)return;s.deploy.id=c.id}const m=o.projectDir;c.doc.contents=[{content:He.readFileSync(Xe.resolve(m,"dist/default/esm/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"esm"},{content:He.readFileSync(Xe.resolve(m,"dist/default/cjs/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"cjs"},{content:He.readFileSync(Xe.resolve(m,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"iife"}],c.doc.name=p,c.doc.dependencies=n,"workflow.lib"===e.type?c.doc.subtype="library":"workflow"===e.type&&(c.doc.subtype="workflow"),c=await t.update(c,{id:c.id})},Zt=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as ios-app package."});const r=t?.config?await Ze({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=et.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=Ve(t.params);i.dependencies=Ve(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await Qe(c)}},Qt=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as macos-app package."});const r=t?.config?await tt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=nt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=ot(t.params);i.dependencies=ot(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await at(c)}},Vt=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as electron package."});const r=t?.config?await rt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=ct.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=it(t.params);i.dependencies=it(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await st(c)}},ea=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as webos package."});const r=t?.config?await lt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=mt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=dt(t.params);i.dependencies=dt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await pt(c)}},ta=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as nextjs package."});const r=t?.config?await ut({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=yt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=gt(t.params);i.dependencies=gt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await ft(c)}},aa=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as docker package."});const r=t?.config?await ht({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=_t.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=bt(t.params);i.dependencies=bt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await wt(c)}},oa=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o,registerToPackageManager:n})=>{await e({message:"Deploying it as fnet package."});const r=t.projectDir,s=jt.resolve(r,"package.json"),i=vt.readFileSync(s),c=JSON.parse(i);c.name=o.params.name,c.version=kt.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,vt.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Dt({name:o.config||"fnet-package",dir:t.projectDir});if(!p.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${l}`);if(!p.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${l}`);if(!p.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${l}`);const d=`${p.env.ATOM_API_URL}/v1/auth/token`,m=p.env.ATOM_API_USERNAME,u=p.env.ATOM_API_PASSWORD;let f=await At({method:"POST",url:d,data:{username:m,password:u},headers:{"Content-Type":"application/json"}});const g=f.data?.access_token;if(!g)throw new Error(`Invalid access_token from ${d}`);let y="fnet-files-to-gcs";if(y+=` --projectId='${p.env.GCS_PROJECT_ID}'`,y+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,y+=` --keyFilename='${jt.resolve(jt.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,y+=` --dir='${r}'`,y+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",y+=` --destDir='${c.name}/${c.version}'`,y+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(y+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(y+=" --dryRun"),await xt({cmd:y}),vt.writeFileSync(s,i),!0===o.dryRun)return;a.isDirty=!0,o.params.version=c.version;const h=`${p.env.ATOM_API_URL}/v1/service/fnet-package/publish`;if(f=await At({method:"POST",url:h,data:{name:c.name,version:c.version,version_domain:p.env.DOMAIN,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${g}`}}),f.data?.error)throw new Error("Failed to publish fnet package.")},na=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet form."});const n=Pt.inc(o.params.version,"patch"),{file:r,data:s}=await St({name:o.config||"fnet-form",dir:t.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${r}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${r}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${r}`);const i=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await It({method:"POST",url:i,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${i}`);a.isDirty=!0,o.params.version=n;const m=`${s.env.ATOM_API_URL}/v1/service/fnet-form/publish`;if(p=await It({method:"POST",url:m,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet form.")},ra=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet flow."});const n=Et.inc(o.params.version,"patch"),{file:r,data:s}=await $t({name:o.config||"fnet-flow",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${r}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${r}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${r}`);const i=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Tt({method:"POST",url:i,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${i}`);a.isDirty=!0,o.params.version=n;const m=`${s.env.ATOM_API_URL}/v1/service/fnet-flow/publish`;if(p=await Tt({method:"POST",url:m,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet flow.");const u=p.data?.upload.id;let f="fnet-dir-zipper";f+=` --sourceDir='${t.project.projectDir}'`,f+=" -p=**/*",f+=" -g",f+=" --stdout_format=json";const g=await Ct({cmd:f});if(0!==g.code)throw new Error(g.stderr);const y=JSON.parse(g.stdout).path;let h=new Rt;h.append("file",Ot.createReadStream(y));const w=await Tt.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${u}`,headers:{...h.getHeaders(),Authorization:`Bearer ${d}`},data:h});if(w.data?.error)throw new Error("Error uploading fnet flow.")},sa=async({setInProgress:e,context:t,deploymentProject:a,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet node."});const n=Mt.inc(o.params.version,"patch"),{file:r,data:s}=await qt({name:o.config||"fnet-node",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${r}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${r}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${r}`);const i=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Ft({method:"POST",url:i,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${i}`);a.isDirty=!0,o.params.version=n;const m=`${s.env.ATOM_API_URL}/v1/service/fnet-node/publish`;if(p=await Ft({method:"POST",url:m,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet node.");const u=p.data?.upload.id;let f="fnet-dir-zipper";f+=` --sourceDir='${t.project.projectDir}'`,f+=" -p=**/*",f+=" -g",f+=" --stdout_format=json";const g=await Nt({cmd:f});if(0!==g.code)throw new Error(g.stderr);const y=JSON.parse(g.stdout).path;let h=new Ut;h.append("file",Lt.createReadStream(y));const w=await Ft.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${u}`,headers:{...h.getHeaders(),Authorization:`Bearer ${d}`},data:h});if(w.data?.error)throw new Error("Error uploading fnet node.")},ia=async({atom:e,target:t,onProgress:a,projectDir:o,dependencies:n})=>{a&&await a({message:"Deploying it as Rust package."});const r=t?.config?await zt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=Wt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const i=Jt(t.params);i.dependencies=Jt(n);const c={atom:e,params:i,config:r?.config,src:o,dest:o};return{deployer:await Bt(c)}};const ca=d,la=m,pa=s,da=i,ma=u,ua=async()=>{if(!await U({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=N.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e},{nanoid:fa}=y,ga=class{init({config:e,accessToken:t}){return new Promise(((a,o)=>{if(z.set_api_url(e.data.url),t)return z.set_req_token(t),void a(t);B({method:"POST",url:`${e.data.issuer}/protocol/openid-connect/token`,data:J.stringify(e.data.grant.params),headers:{"Content-Type":"application/x-www-form-urlencoded"}}).then((e=>{z.set_req_token(e.data.access_token),a(e.data.access_token)})).catch((e=>{z.set_req_token(),o(e)}))}))}},ya=async({atom:e,context:t})=>{e.doc.features=e.doc.features||{};const a=e.doc.features;a.project=a.project||{},a.project.format=a.project.format||a.project_format||"esm",a.project_format=a.project.format,a.dts_enabled=!0===a.dts||void 0!==a.dts&&!1!==a.dts,a.hasOwnProperty("all_parsed_imports")||(a.all_parsed_imports=!0);const o=G.resolve(t.project.projectDir),n=X({dir:G.resolve(o,"./app")});if(n.file){let e=await H({file:n.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));a.app_uses_jsx=t,a.app_has_entry=!0,e=await H({file:n.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),a.app_entry_uses_jsx=t,a.app_entry_is_ts=n.ts,a.app_entry_ext=n.ext}const r=X({dir:G.resolve(o,"./cli")});if(r.file){let e=await H({file:r.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));a.cli_uses_jsx=t,a.cli_has_entry=!0,e=await H({file:r.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),a.cli_entry_uses_jsx=t,a.cli_entry_is_ts=r.ts,a.cli_entry_ext=r.ext}if("workflow.lib"===e.type){const e=X({dir:G.resolve(o,"./src")});if(e.file){let t=await H({file:e.file,recursive:!0}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));a.src_uses_jsx=o,a.src_has_entry=!0,t=await H({file:e.file}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),a.src_entry_uses_jsx=o,a.src_entry_is_ts=e.ts,a.src_entry_ext=e.ext}}const s=!0===a.src_uses_jsx,i=!0===a.src_uses_jsx;a.form_enabled=!0===e.doc.form||!0===e.doc.form?.enabled||!0===a.form||!0===a.form?.enabled,a.multiple_enabled=a.multiple_enabled||!0===a.multiple||!0===a.multiple?.enabled,!1===a.app?a.app={enabled:!1}:!0===a.app?a.app={enabled:!0,extend:!0===a.app_has_entry,export:!0,react:s}:a.app={enabled:!0,extend:!0===a.app_has_entry,export:!0,react:s,...a.app||{}},a.app.enabled=!0===a.app.enabled&&(!0===e.doc.features.form_enabled||!0===a.app.extend||!0===a.app.enabled),a.app.format=a.app.format||"esm",a.app.folder=a.app.folder||a.app.format||"default",!1===a.cli?a.cli={enabled:!1}:!0===a.cli?a.cli={enabled:!0,extend:!0===a.cli_has_entry,export:!0,react:i}:a.cli={enabled:!0,extend:!0===a.cli_has_entry,export:!0,react:i,...a.cli||{}},a.cli.enabled=!0===a.cli.enabled&&(!1===e.doc.features.form_enabled||!0===a.cli.extend||!0===a.cli.enabled),a.cli.format=a.cli.format||"esm",a.cli.folder=a.cli.folder||a.cli.folder||"esm",a.cli.node_options=a.cli.node?.options||a.cli.node_options||"";const c={cjs:{format:"cjs",context:a.form_enabled?"window":"global",babel:!0===a.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!0,string:!0},cjsx:{format:"cjs",context:a.form_enabled?"window":"global",babel:!0===a.src_uses_jsx||!1,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0},esm:{format:"esm",context:a.form_enabled?"window":"global",babel:!0===a.src_uses_jsx||!1,browser:!1,replace:!0,browsersync:!0,terser:!1,enabled:!0,copy:!0,string:!0},esmx:{format:"esm",browser:!0,babel:!0,context:a.form_enabled?"window":"global",replace:!0,browsersync:!1,enabled:!1,terser:!0,string:!0},iife:{format:"iife",context:a.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1!==a.iife,terser:!0,string:!0},umd:{format:"umd",context:a.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0}},l={};!0===a.webos&&(c.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",babel_options:{targets:{chrome:"79"}}}),!0===a.electron&&(c.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===a.nextjs&&(c.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===a.ios&&(c.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===a.macos&&(c.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===a.app.enabled&&(a.app.dir=`./dist/app/${a.app.folder}`,c.app={format:a.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:a.app.dir,terser:!0,output_exports:!1===a.app.export?"none":"auto",string:!0},l.targets=l.targets||[],l.targets.push({src:"./src/app/index.html",dest:a.app.dir})),!0===a.cli.enabled&&(a.cli.dir=`./dist/cli/${a.cli.folder}`,c.cli={format:a.cli.format,context:"global",babel:!0===a.src_uses_jsx||!0===a.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:a.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===a.cli.export?"none":"auto",string:!0});const p={server:".",startPath:`${G.normalize(a.app.dir||".")}`,files:[G.normalize("./dist/**/*")],cors:!0,open:!1};a.babel_options=W({targets:{browsers:"last 9 versions, not dead",node:"18"}},a.babel_options||a.babel?.options),a.browsersync_options=W(p,a.browsersync_options||a.browsersync?.options||{}),a.replace_options=W({},a.replace_options||a.replace?.options||{}),a.terser_options=W({},a.terser_options||a.terser?.options||{}),a.css_options=W({},a.css_options||a.css?.options||{}),a.wasm_options=W({},a.wasm_options||a.wasm?.options||{}),a.copy_options=W(l,a.copy_options||a.copy?.options||{}),a.json_options=W({},a.json_options||a.json?.options||{}),a.image_options=W({},a.image_options||a.image?.options||{}),a.analyzer_options=W({summaryOnly:!0,limit:12},a.analyzer_options||a.analyzer?.options||{}),a.visualizer_options=W({},a.visualizer_options||a.visualizer?.options||{}),a.string_options=W({},a.string_options||a.string?.options||{}),a.nunjucks_options=W({},a.nunjucks_options||a.nunjucks?.options||{}),Reflect.has(a.browsersync_options,"proxy")&&delete a.browsersync_options.server,a.rollup=a.rollup||{},a.rollup_output=W(c,a.rollup_output||a.rollup?.output||{}),a.string_enabled=!0===a.string||a.string&&!1!==a.string?.enabled,a.preact_enabled=!0===a.preact||a.preact&&!1!==a.preact?.enabled;const d=Object.keys(c);for(const e of d){const t=c[e];t&&(!1!==a.rollup[e]?(!0===a.rollup[e]&&(t.enabled=!0),t.babel_options=t.babel_options||a.babel_options,t.browsersync_options=W(a.browsersync_options,t.browsersync_options),t.replace_options=W(a.replace_options,t.replace_options),t.terser_options=W(a.terser_options,t.terser_options),t.css_options=W(a.css_options,t.css_options),t.wasm_options=W(a.wasm_options,t.wasm_options),t.copy_options=W(a.copy_options,t.copy_options),t.json_options=W(a.json_options,t.json_options),t.image_options=W(a.image_options,t.image_options),t.analyzer_options=W(a.analyzer_options,t.analyzer_options),t.visualizer_options=W(a.visualizer_options,t.visualizer_options),t.string_options=W(a.string_options,t.string_options),t.string=a.string_enabled&&t.string,t.nunjucks_options=W(a.nunjucks_options,t.nunjucks_options),a.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),a.form_enabled&&(t.babel=!0)):t.enabled=!1)}a.babel_enabled=d.some((e=>!0===a.rollup_output[e].babel)),a.browser_enabled=d.some((e=>!0===a.rollup_output[e].babel)),a.browsersync_enabled=!1!==a.browsersync&&d.some((e=>!0===a.rollup_output[e].browsersync)),a.browsersync_enabled=a.browsersync_enabled&&a.app.enabled,a.wasm_enabled=!0===a.wasm||a.wasm&&!1!==a.wasm?.enabled,a.css_enabled=!0===a.css||a.css&&!1!==a.css?.enabled,a.json_enabled=!0===a.json||a.json&&!1!==a.json?.enabled,a.terser_enabled=!1!==a.terser,a.copy_enabled=a.app.enabled||a.copy_enabled||a.copy&&!1!==a.copy?.enabled,a.image_enabled=!0===a.image||a.image&&!1!==a.image?.enabled,a.analyzer_enabled=!0===a.analyzer||a.analyzer&&!1!==a.analyzer?.enabled,a.visualizer_enabled=!0===a.visualizer||a.visualizer&&!1!==a.visualizer?.enabled,a.dependency_auto_enabled=!1!==a.dependency_auto&&!1!==a.dependency_auto?.enabled,a.npm_install_flags=a.npm_install_flags||"",a.react_version=a.react_version||a.react?.version||18,a.polyfill_enabled=!0===a.polyfill||a.polyfill&&!1!==a.polyfill?.enabled,a.nunjucks_enabled=!0===a.nunjucks||a.nunjucks&&!1!==a.nunjucks?.enabled},ha=async({atom:e,packageDependencies:t,packageDevDependencies:a})=>{if("workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let a="^18.2";a=`^${(await Y({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:a}),t.push({package:"react-dom",version:a}),"workflow"===e.type&&(t.push({package:"@flownet/react-app",version:"^0.1"}),t.push({package:"@flownet/react-app-state",version:"^0.1"}))}if(e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&t.push({package:"yargs",version:"^17"}),a.push({package:"@babel/core",version:"^7"}),a.push({package:"@rollup/plugin-commonjs",version:"^26"}),a.push({package:"@rollup/plugin-node-resolve",version:"^15"}),a.push({package:"@rollup/plugin-replace",version:"^5"}),a.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&a.push({package:"rollup-plugin-dts",version:"^6"}),a.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),a.push({package:"@rollup/plugin-alias",version:"^5"}),a.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(a.push({package:"@rollup/plugin-babel",version:"^6"}),a.push({package:"@babel/preset-env",version:"^7"}),a.push({package:"@babel/preset-react",version:"^7"}),e.doc.features.babel?.plugins?.forEach((e=>{switch(e[0]){case"proposal-decorators":a.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"proposal-class-properties":a.push({package:"@babel/plugin-proposal-class-properties",version:"^7"})}}))),a.push({package:"@fnet/rollup-plugin-delete",version:"0.1.3"}),e.doc.features.nunjucks_enabled&&a.push({package:"@fnet/rollup-plugin-nunjucks",version:"0.1.3"}),e.doc.features.browsersync_enabled&&a.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.4"}),e.doc.features.json_enabled&&a.push({package:"@rollup/plugin-json",version:"^6"}),e.doc.features.terser_enabled&&a.push({package:"@rollup/plugin-terser",version:"^0.4"}),e.doc.features.wasm_enabled&&a.push({package:"@rollup/plugin-wasm",version:"^6"}),e.doc.features.image_enabled&&a.push({package:"@rollup/plugin-image",version:"^3"}),e.doc.features.analyzer_enabled&&a.push({package:"rollup-plugin-analyzer",version:"^3"}),e.doc.features.visualizer_enabled&&a.push({package:"rollup-plugin-visualizer",version:"^5"}),e.doc.features.string_enabled&&a.push({package:"rollup-plugin-string",version:"^3"}),e.doc.features.css_enabled){a.push({package:"rollup-plugin-postcss",version:"^4"}),a.push({package:"sass",version:"^1.66"});(e.doc.features.css_options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":a.push({package:"postcss-import",version:"^15"});break;case"postcss-url":a.push({package:"postcss-url",version:"^10"});break;case"postcss-preset-env":a.push({package:"postcss-preset-env",version:"^9"});break;case"autoprefixer":a.push({package:"autoprefixer",version:"^10"});break;case"cssnano":a.push({package:"cssnano",version:"^6"})}}))}e.doc.features.polyfill_enabled&&a.push({package:"rollup-plugin-node-polyfills",version:"^0.2"}),e.doc.features.copy_enabled&&(a.push({package:"rollup-plugin-copy",version:"^3"}),a.push({package:"chokidar",version:"^3"}))},wa=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{if(!0!==e.doc.features.app.enabled)return;await t({message:"Creating index.html."});const n={atom:e,packageDependencies:o,ts:Date.now()},r=a.templateDir,s=Q.resolve(a.projectDir,"src/app");Z.existsSync(s)||Z.mkdirSync(s,{recursive:!0}),await V({pattern:["index.html.njk","index.js.njk"],dir:Q.resolve(r,"src/app"),outDir:s,context:n})},ba=async({atom:e,context:t,packageDependencies:a,packageDevDependencies:o,setInProgress:n})=>{await n({message:"Creating package.json."});a.filter((e=>!0===e.dev)).forEach((e=>{o.find((t=>t.package===e.package))||o.push(e);const t=a.findIndex((t=>t.package===e.package));a.splice(t,1)}));const r=a.find((e=>"react"===e.package)),s=a.find((e=>"react-dom"===e.package));r&&!s?a.push({package:"react-dom",version:r.version}):r&&s&&(s.version=r.version),r&&e.doc.features.react_version>=17&&(a.find((e=>"@emotion/react"===e.package))||a.push({package:"@emotion/react",version:"^11"}),a.find((e=>"@emotion/styled"===e.package))||a.push({package:"@emotion/styled",version:"^11"}));const i=[];!0===e.doc.features.app.enabled&&i.push({file:ae.resolve(t.projectDir,"src/app/index.js"),dev:!1!==e.doc.features.app.dev}),!0===e.doc.features.cli.enabled&&i.push({file:ae.resolve(t.projectDir,"src/cli/index.js"),dev:!1!==e.doc.features.cli.dev});for await(const t of i){const n=t.file;if(!te.existsSync(n))throw new Error(`App file not found: ${n}`);const r=await oe({file:n,recursive:!0}),s=!0===e.doc.features.all_parsed_imports?r.all:r.required;for await(const e of s){if("npm"!==e.type)continue;if(a.find((t=>t.package===e.package)))continue;if(o.find((t=>t.package===e.package)))continue;const n=(await ne({name:e.package,groupBy:{minor:!0}}))[0][0];(!0===t.dev?o:a).push({package:e.package,subpath:e.subpath,version:`^${n}`,type:"npm"})}}const c={atom:e,packageDependencies:a,packageDevDependencies:o},l=t.templateCommonDir,p=ee.compile(te.readFileSync(ae.resolve(l,"package.json.njk"),"utf8"),ee.configure(l)).render(c),d=t.projectDir,m=ae.resolve(d,"package.json");te.writeFileSync(m,p,"utf8")},_a=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating cli."});const n={atom:e,packageDependencies:o},r=a.templateDir,s=se.resolve(a.projectDir,"src/cli");re.existsSync(s)||re.mkdirSync(s,{recursive:!0}),await ie({pattern:["index.js.njk"],dir:se.resolve(r,"src/cli"),outDir:s,context:n})},va=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{await t({message:"Creating rollup file."});const n={atom:e,packageDependencies:o},r=le.resolve(a.projectDir,"src","default/index.js");if(!ce.existsSync(r))throw new Error(`Entry file not found: ${r}`);const s=(await de({file:r,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),i=e.doc.features.rollup_output,c=Object.keys(i);for(let e=0;e<c.length;e++){const t=i[c[e]];if(!0===t.browser&&s.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(s.map((e=>({key:e,value:e})))),t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{};for(let e=0;e<s.length;e++){const a=s[e];t.alias.entries[a]=`node:${a}`,t.alias.entries[`node:${a}`]=a}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(s)}}const l=a.templateCommonDir;let p=pe.compile(ce.readFileSync(le.resolve(l,"rollup.config.mjs.njk"),"utf8"),pe.configure(l)).render(n);const d=a.projectDir;let m=le.resolve(d,"rollup.config.mjs");ce.writeFileSync(m,p,"utf8")},ja=async({atom:e,setInProgress:t,context:a,njEnv:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating yargs."});let n={};const r=e.doc.inputs||[],s=[],i=e.doc.input;i?n=await ge({schema:i}):r.forEach((e=>{if(!1===e.cli||!e.name)return;e.import&&s.push(e);const t={};Reflect.has(e,"type")&&(t.type=e.type),Reflect.has(e,"default")&&(t.default=e.default),Reflect.has(e,"choices")&&(t.choices=e.choices),(Reflect.has(e,"describe")||Reflect.has(e,"description"))&&(t.describe=e.describe||e.description),Reflect.has(e,"alias")&&(t.alias=e.alias),Reflect.has(e,"required")&&!0===e.required&&(t.required=!0),Reflect.has(e,"hidden")&&!0===e.hidden&&(t.hidden=!0),Reflect.has(e,"array")&&!0===e.array&&(t.array=!0),Reflect.has(e,"normalize")&&!0===e.normalize&&(t.normalize=!0),Reflect.has(e,"nargs")&&(t.nargs=e.nargs),n[e.name]=t}));const c={options:n,imports:s,atom:e},l=a.templateDir,p=fe.compile(me.readFileSync(ue.resolve(l,"src/default/to.yargs.js.njk"),"utf8"),o).render(c),d=a.projectDir,m=ue.resolve(d,"src/default/to.yargs.js");me.writeFileSync(m,p,"utf8")},ka=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{await t({message:"Creating .gitignore"});const n={atom:e,packageDependencies:o},r=a.templateCommonDir,s=we.compile(ye.readFileSync(he.resolve(r,".gitignore.njk"),"utf8"),we.configure(r)).render(n),i=a.projectDir,c=he.resolve(i,".gitignore");ye.writeFileSync(c,s,"utf8")},xa=async({atom:e,setInProgress:t,context:a,packageDependencies:o})=>{await t({message:"Creating tsconfig.json."});const n={atom:e,packageDependencies:o},r=a.templateCommonDir,s=ve.compile(be.readFileSync(_e.resolve(r,"tsconfig.json.njk"),"utf8"),ve.configure(r)).render(n),i=a.projectDir,c=_e.resolve(i,"tsconfig.json");be.writeFileSync(c,s,"utf8")},Da=async({atom:e,context:t,setInProgress:a,Atom:o})=>{const n="readme.md",r=`Creating ${n}`;if(await a({message:r}),t.project?.readme){const e={content:t.project.readme.doc.content},a=t.templateCommonDir,o=je.compile(ke.readFileSync(xe.resolve(a,`${n}.njk`),"utf8"),je.configure(a)).render(e),r=t.projectDir,s=xe.resolve(r,`${n}`);ke.writeFileSync(s,o,"utf8")}else if(e.id){const a=await o.first({type:"wiki",parent_id:e.id});if(!a||"markdown"!==a.doc?.["content-type"])return;const{content:r,...s}=a.doc,i={content:r},c=t.templateCommonDir,l=je.compile(ke.readFileSync(xe.resolve(c,`${n}.njk`),"utf8"),je.configure(c)).render(i),p=t.projectDir,d=xe.resolve(p,`${n}`);ke.writeFileSync(d,l,"utf8")}},Aa=async({setInProgress:e,context:t})=>{const a=t.projectDir;await e({message:"Prettifiying source files."});let o=Ae.join("src","**","*");if(0!==De.exec(`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:a}).code)throw new Error("Couldnt format files.")},Pa=async({atom:e,setInProgress:t,context:a})=>{if(!e.doc.features.dts_enabled)return;const o=a.projectDir;await t({message:"Creating .d.ts"});if(0!==Pe.exec("tsc",{cwd:o}).code)throw new Error("Couldnt create .d.ts files.")},Sa=async({setInProgress:e,atom:t,context:a})=>{const o=a.projectDir;await e({message:"Installing npm packages."});if(0!==Se.exec(`npm install ${t.doc.features.npm_install_flags}`,{cwd:o}).code)throw new Error("Couldnt install npm packages.")},Ia=async({setInProgress:e,context:t})=>{const a=t.projectDir;await e({message:"Building main project."});if(0!==Ie.exec("npm run build",{cwd:a}).code)throw new Error("Couldnt build project.")},Ea=async e=>{const{atom:t,packageDependencies:a,context:o,deploymentProjectTarget:n,setInProgress:r,deploymentProject:s}=e;if(!0===n.enabled)if("lib"===n.name)await Yt({...e});else if("red"===n.name)await Xt({...e});else if("npm"===n.name)await Ht({...e});else if("gcs"===n.name)await Gt({...e});else if("gitlab"===n.name)await Kt({...e});else if("fnet-package"===n.name)await oa({...e});else if("fnet-form"===n.name)await na({...e});else if("fnet-node"===n.name)await sa({...e});else if("fnet-flow"===n.name)await ra({...e});else{let e;if("nextjs"===n.name?e=ta:"webos"===n.name?e=ea:"electron"===n.name?e=Vt:"docker"===n.name?e=aa:"ios"===n.name?e=Zt:"macos"===n.name?e=Qt:"rust"===n.name&&(e=ia),!e)return;await e({atom:t,target:n,onProgress:r,projectDir:o.projectDir,dependencies:a}),s.isDirty=!0}},{Atom:$a}=h,Ta=q,Oa=t,Ca=v,Ra=F,Ma=L;var qa=class{#e;#t;#a;#o;#n;#r;#s;#i;#c;#l;#p;#d;#m;#u;#f;#g;#y;constructor(e){this.#e=new ga,this.#t=e,this.#r=[],this.#s=[],this._expire_ttl=3600,this._expire_ttl_short=300,this.#y={packageDependencies:this.#r,packageDevDependencies:this.#s,setInProgress:this.setInProgress.bind(this),context:this.#t,Atom:$a,registerToPackageManager:this.registerToPackageManager.bind(this)}}async _cache_set(e,t,a){this._redis_client&&await this._redis_client.SETEX(e,a||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await ua(),this.#c=this.#t.buildId||fa(24),this.#y.buildId=this.#c,this.#m=this.#t.mode,this.#u=["all","deploy","build","file"].includes(this.#m),this.#f=["all","deploy","build"].includes(this.#m),this.#g=["all","deploy"].includes(this.#m),this.#p=this.#t.protocol,this.#l="BUILD:"+this.#c,this.#d=(await Oa({optional:!0,name:this.#t.atomConfig||"atom",dir:this.#t.projectDir}))?.data;try{await this.setInProgress({message:"Initialization started."}),await this.initAuth(),await this.initLibrary(),await ya(this.#y),await ha(this.#y),await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}catch(e){throw await this._cache_set(this.#l,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#t.id&&(this.#i=await this.#e.init({config:this.#d}),this.#y.atomAccessToken=this.#i)}async initLibrary(){const e=this.#t.id;this.#a=this.#t.project?.libraryAtom||await $a.get({id:e});let t=this.#a.doc.bundleName;t=t||(this.#a.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#a.doc.bundleName=t,this.#a.type=this.#a.type||"workflow.lib",this.#y.atom=this.#a}async initLibraryDir(){const e=this.#t.projectDir;let t;const a=["node_modules"];ca.existsSync(e)&&ca.readdirSync(e).forEach((o=>{a.includes(o)||(t=da.rm("-rf",la.join(e,o)))}));let o=e;if(!ca.existsSync(o)&&(t=da.exec(`mkdir "${e}"`),0!==t.code))throw new Error("Couldnt create workflow dir.");if(o=la.join(e,"src"),!ca.existsSync(o)&&(t=da.exec(`mkdir "${o}"`),0!==t.code))throw new Error("Couldnt create library/src dir.");if(o=la.join(e,"src","default"),!ca.existsSync()&&(t=da.exec(`mkdir "${o}"`),0!==t.code))throw new Error("Couldnt create library/src/default dir.")}async initNunjucks(){const e=this.#t.templateDir;this.#o=ma.configure(e,{watch:!1,dev:!0}),this.#y.njEnv=this.#o}async initLibs(){const e=[{name:this.#a.doc.name,type:"atom",parent_id:this.#a.parent_id}];this.#n=e,await this.initAtomLibsAndDeps({libs:e,packageDependencies:this.#r})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const a=e.filter((e=>"atom"===e.type));for(let e=0;e<a.length;e++){const o=a[e],n=await this.findAtomLibrary({url:o.name});o.atom=n;const r=n.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));r?.forEach((e=>{const a=t.find((t=>t.package===e.package));a?"string"==typeof e.path?(a.path||[]).some((t=>t===e.path))||(a.path=a.path||[],a.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(a.path||[]).some((t=>t===e))||(a.path=a.path||[],a.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const t=Ta({url:e});if(!t)throw new Error(`Invalid package name: ${e}`);if(t.protocol||(t.protocol=this.#p),"ac:"===t.protocol){const a=t.pathname.split("/");if(1===a.length)return await $a.first({where:{name:e,parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===a.length){const e=await $a.first({where:{name:a[0],parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"folder"}});return await $a.first({where:{name:a[1],parent_id:e.id,type:"workflow.lib"}})}}else if("local:"===t.protocol){const e=this.#a;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const t=la.resolve(this.#t.projectSrcDir,"index.js"),a=await Ca({file:t,recursive:!0}),o=e.doc.dependencies,n=!0===this.#a.doc.features.all_parsed_imports?a.all:a.required;for await(const e of n){if("npm"!==e.type)continue;if(o.find((t=>t.package===e.package)))continue;const t=await Ra({name:e.package,count:1});o.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return e}}async createAtomLibFiles({libs:e}){await this.setInProgress({message:"Creating external lib files."}),this.#a.typesDir="./types";const t=e.filter((e=>"atom"===e.type));for(let e=0;e<t.length;e++){const a=t[e].atom,o=this.#t.projectDir;if("local:"===a.protocol){const e=la.resolve(this.#t.projectSrcDir,`${a.fileName||a.name}.js`),t=la.relative(la.join(this.#t.projectDir,"src","default"),e);if(!ca.existsSync(e)){ca.mkdirSync(la.dirname(e),{recursive:!0});let t="export default async (args)=>{\n";t+="}",ca.writeFileSync(e,t,"utf8")}a.relativePath=t.split(la.sep).join("/"),this.#a.typesDir=`./types/${la.basename(o)}/src`}else{const e=la.join(o,"src","libs",`${a.id}.js`),t=a.doc.contents?.find((e=>"esm"===e.format))||a.doc;ca.writeFileSync(e,t.content,"utf8")}}}async createEngine(){await this.setInProgress({message:"Creating engine file."});const e={libs:this.#n.filter((e=>"atom"===e.type)),libraryAtom:this.#a,atom:this.#a},t=this.#t.templateDir,a=ma.compile(ca.readFileSync(la.resolve(t,la.join("src","default","engine.js.njk")),"utf8"),this.#o).render(e),o=this.#t.projectDir,n=la.resolve(o,la.join("src","default","index.js"));ca.writeFileSync(n,a,"utf8")}async createProjectYaml(){const e="node.yaml",t=`Creating ${e}`;await this.setInProgress({message:t});const{content:a,...o}=this.#a.doc,n={content:pa.stringify(o)},r=this.#t.templateDir,s=ma.compile(ca.readFileSync(la.resolve(r,`${e}.njk`),"utf8"),this.#o).render(n),i=this.#t.projectDir,c=la.resolve(i,`${e}`);ca.writeFileSync(c,s,"utf8")}async deploy(){if(await this.setInProgress({message:"Deploying."}),this.#t.project?.devops){const e=[this.#t.project?.devops];for(let t=0;t<e.length;t++){let a=e[t];await this.deployProject({deploymentProject:a}),!0===a.isDirty&&await a.save()}}else if(this.#a.id){const e=await $a.list({type:"library.deploy",parent_id:this.#a.id});for(let t=0;t<e.length;t++){let a=e[t];await this.deployProject({deploymentProject:a}),!0===a.isDirty&&(a=await $a.update(a,{id:a.id}))}}}async deployProject(e){const{deploymentProject:t}=e,a=t.doc.targets||[];for(let e=0;e<a.length;e++){const o=a[e];await Ea({...this.#y,deploymentProject:t,deploymentProjectTarget:o})}}async registerToPackageManager(e){const{target:t,packageJSON:a}=e;if(!this.#t.id)return;let o=await $a.first({name:t.params.name,parent_id:this.#d.env.ATOM_PACKAGES_ID});o?(o.doc.versions.splice(0,0,{v:a.version}),await $a.update(o,{id:o.id})):o=await $a.create({parent_id:this.#d.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:a.version}]}})}async setInProgress({message:e}){console.log(Ma.blue(e)),await this._cache_set(this.#l,{status:"IN_PROGRESS",message:e})}async build(){try{this.#u&&(await this.createAtomLibFiles({libs:this.#n}),await this.createEngine(),await this.createProjectYaml(),await Da(this.#y),await xa(this.#y),await ka(this.#y),await ja(this.#y),await _a(this.#y),await wa(this.#y),await va(this.#y),await ba(this.#y),await Aa(this.#y),await Pa(this.#y),this.#f&&(await Sa(this.#y),await Ia(this.#y),this.#g&&await this.deploy())),await this._cache_set(this.#l,{status:"COMPLETED"})}catch(e){throw await this._cache_set(this.#l,{status:"FAILED",message:e.message||e}),console.log(e),e}}};const Fa=d,La=m;var Na=function({baseDir:e=__dirname}){let t=e;for(;t!==La.parse(t).root;){const e=La.join(t,"node_modules");if(Fa.existsSync(e))return e;t=La.dirname(t)}return null};const Ua=process.cwd(),{spawn:za}=e;t({name:["redis"],dir:Ua,optional:!0});const Ba=a,Ja=o,{hideBin:Wa}=n,Ka=r,Ga=s,Ha=i,Xa=c,Ya=t,Za=l,Qa=p,Va=qa,eo=Na({baseDir:__dirname}),to="win32"===process.platform?";":":";process.env.PATH=`${Ba.join(eo,"/.bin")}${to}${process.env.PATH}`;let ao=Ja(Wa(process.argv)).command("create","Create flow node project",(e=>e.option("name",{type:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs"})),(async e=>{try{const t=Ba.resolve(eo,"@fnet/cli-project-node/dist/template/project"),a=Ba.resolve(Ua,e.name);Ka.existsSync(a)||Ka.mkdirSync(a),await Qa({dir:t,outDir:a,context:e,copyUnmatchedAlso:!0});let o=Ha.exec("fnode build",{cwd:a});if(0!==o.code)throw new Error("Failed to build project.");if(Ha.which("git")&&(o=Ha.exec("git init --initial-branch=main",{cwd:a}),0!==o.code))throw new Error("Failed to initialize git.");if(Ha.which("code")&&e.vscode&&(o=Ha.exec(`cd ${a} && code .`),0!==o.code))throw new Error("Failed to open vscode.");console.log("Creating project succeeded!"),process.exit(0)}catch(e){console.error("Initialization failed!",e.message),process.exit(1)}})).command("project","Flow node project",(e=>e.option("update",{type:"boolean",default:!1,alias:"-u"})),(async e=>{try{const t=Ba.resolve(eo,"@fnet/cli-project-node/dist/template/project"),a=process.cwd();if(e.name=Ba.basename(a),e.update){if(await Qa({dir:t,outDir:a,context:e,copyUnmatchedAlso:!0}),0!==Ha.exec("fnode build",{cwd:a}).code)throw new Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(e){console.error("Project failed.",e.message),process.exit(1)}})).command("build","Build flow node project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("mode",{type:"string",alias:"m",default:"build",choices:["all","file","build","deploy","bpmn"]}).option("target",{type:"string",alias:"t"})),(async e=>{try{const t=await no(e),a=new Va(t);await a.init(),await a.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}})).command("deploy","Build and deploy flow node project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("target",{type:"string",alias:"t"})),(async e=>{try{const t=await no({...e,mode:"all"}),a=new Va(t);await a.init(),await a.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}})).command("file","Just create files",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("target",{type:"string",alias:"t"})),(async e=>{try{const t=await no({...e,mode:"file"}),a=new Va(t);await a.init(),await a.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}));function oo(e,{name:t,bin:a,preArgs:o=[]}){return e.command(`${t||a} [commands..]`,`${a} ${o.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await no(e),{projectDir:n}=t,r=process.argv.slice(3);za(a,[...o,...r],{cwd:n,stdio:"inherit",shell:!0}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}async function no(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:Ba.resolve(eo,"./@fnet/cli-project-node/dist/template/default"),templateCommonDir:Ba.resolve(eo,"./@fnet/cli-project-common/dist/template/default"),projectDir:Ba.resolve(Ua,`./.output/${e.id}`),target:e.target};{const t=await async function(){const e=Ba.resolve(Ua,"node.yaml");if(!Ka.existsSync(e))throw new Error("node.yaml file not found in current directory.");const t=Ka.readFileSync(e,"utf8"),{parsed:a}=await Xa({content:t}),o=Ba.dirname(e),n={libraryAtom:{doc:{...a},fileName:"index"},projectDir:o,projectFilePath:e,projectFileContent:t,projectFileParsed:a},r=Ba.resolve(o,"node.devops.yaml");if(Ka.existsSync(r)){const e=Ka.readFileSync(r,"utf8"),t=Ga.parse(e);n.devops={filePath:r,fileContent:e,doc:{...t},type:"library.deploy",save:async()=>{Ka.writeFileSync(n.devops.filePath,Ga.stringify(n.devops.doc))}}}const s=Ba.resolve(o,"readme.md");if(Ka.existsSync(s)){const e=Ka.readFileSync(s,"utf8");n.readme={filePath:s,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return n}();return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:Ba.resolve(eo,"./@fnet/cli-project-node/dist/template/default"),templateCommonDir:Ba.resolve(eo,"./@fnet/cli-project-common/dist/template/default"),projectDir:Ba.resolve(t.projectDir,"./.workspace"),projectSrcDir:Ba.resolve(t.projectDir,"./src"),project:t,target:e.target}}}ao=ao.command("config create <name>","Create a config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await no(e),{project:a}=t,{projectDir:o,projectFileParsed:n}=a,r=n.config;if(!r)throw new Error("Config schema not found in project file.");const s=await Za({schema:r}),i=Ba.resolve(o,".fnet");Ka.existsSync(i)||Ka.mkdirSync(i);const c=Ba.resolve(i,`${e.name}.fnet`);Ka.writeFileSync(c,Ga.stringify(s))}catch(e){console.error(e.message),process.exit(1)}})),ao=oo(ao,{bin:"npm"}),ao=oo(ao,{bin:"node"}),ao=oo(ao,{name:"serve",bin:"npm",preArgs:["run","serve","--"]}),ao=oo(ao,{name:"watch",bin:"npm",preArgs:["run","watch","--"]}),ao=oo(ao,{name:"app",bin:"npm",preArgs:["run","app","--"]}),ao=oo(ao,{name:"cli",bin:"npm",preArgs:["run","cli","--"]}),ao=oo(ao,{bin:"npx"}),ao=oo(ao,{bin:"cdk"}),ao=oo(ao,{bin:"aws"}),ao=function(e,{name:t,preArgs:a=[]}){return e.command(`${t} <config> <command> [options..]`,"Run a command with a config context",(e=>e.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await no(e),{projectDir:o}=t,n=e.config,r=await Ya({name:n,dir:o,transferEnv:!1,optional:!0}),s=r?.data?.env||void 0,i=e.command,c=process.argv.slice(5);za(i,[...a,...c],{cwd:o,stdio:"inherit",shell:!0,env:{...process.env,...s}}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}(ao,{name:"with"}),ao.demandCommand(1,"You need at least one command before moving on").help().argv,module.exports={};
|
package/dist/builder/wf-cli.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var e=require("child_process"),t=require("@fnet/config"),n=require("path"),o=require("yargs/yargs"),i=require("yargs/helpers"),a=require("fs"),s=require("yaml"),r=require("shelljs"),c=require("@fnet/yaml"),l=require("@fnet/object-from-schema"),p=require("@flownet/lib-render-templates-dir"),d=require("node:fs"),f=require("node:path"),m=require("nunjucks"),u=require("lodash.clonedeep"),h=require("isobject"),w=require("redis"),y=require("@flownet/lib-is-redis-online"),g=require("nanoid"),b=require("@flownet/lib-atom-api-js"),v=require("axios"),_=require("qs"),x=require("lodash.merge"),k=require("@flownet/lib-parse-imports-js"),j=require("@flownet/lib-list-npm-versions"),D=require("@fnet/yargs-options-from-schema"),P=require("@fnet/shell"),S=require("semver"),A=require("node:os"),T=require("@node-red/util"),E=require("@flownet/lib-to-ios-app"),$=require("@flownet/lib-to-macos-app"),I=require("@flownet/lib-to-electron"),O=require("@flownet/lib-to-webos"),C=require("@flownet/lib-to-nextjs"),N=require("@flownet/lib-to-docker"),M=require("form-data"),R=require("@fnet/to-rust"),F=require("@flownet/lib-parse-node-url"),q=require("@flownet/lib-bpmn-from-flow"),U=require("@fnet/expression"),B=require("chalk"),L=require("lodash.pick"),z=require("lodash.omit");const J=w,W=y;const{Api:K}=b,G=v.default,H=_;const V=x,X=d,Y=f,Z=k;function Q({dir:e,name:t="index"}){let n=Y.resolve(e,`./${t}.tsx`);if(X.existsSync(n)||(n=Y.resolve(e,`./${t}.ts`)),X.existsSync(n)||(n=Y.resolve(e,`./${t}.jsx`)),X.existsSync(n)||(n=Y.resolve(e,`./${t}.js`)),!X.existsSync(n))return{};const o=n,i=Y.extname(n);return{file:o,ext:i,ts:".ts"===i||".tsx"===i,name:t}}const ee=j;const te=d,ne=f,oe=p;const ie=m,ae=d,se=f,re=k,ce=j;const le=d,pe=f,de=p;const fe=d,me=f,ue=m,he=k;const we=d,ye=f,ge=m,be=D;const ve=d,_e=f,xe=m;const ke=d,je=f,De=m;const Pe=m,Se=d,Ae=f;const Te=r,Ee=n;const $e=r;const Ie=r;const Oe=r;const Ce=P,Ne=t;const Me=d,Re=f,Fe=S,qe=P,Ue=t;const Be=d,Le=f,ze=S,Je=r,We=t;const Ke=d,Ge=f,He=A,Ve=m,Xe=T,Ye=t;const Ze=a,Qe=n,et=t;const tt=t,nt=E,ot=u,it=S;const at=t,st=$,rt=u,ct=S;const lt=t,pt=I,dt=u,ft=S;const mt=t,ut=O,ht=u,wt=S;const yt=t,gt=C,bt=u,vt=S;const _t=t,xt=N,kt=u,jt=S;const Dt=d,Pt=f,St=S,At=P,Tt=t,Et=v.default;const $t=S,It=t,Ot=v.default;const Ct=S,Nt=t,Mt=v.default,Rt=a,Ft=P,qt=M;const Ut=S,Bt=t,Lt=v.default,zt=a,Jt=P,Wt=M;const Kt=t,Gt=R,Ht=u,Vt=S;const Xt=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o,buildId:i})=>{await e({message:"Deploying it as gitlab project."});const a=t.projectDir;let s="fnet-to-gitlab";const r=o.params.config||"gitlab",c=await Ne({name:r,dir:t.projectDir});if(!c)throw new Error(`Couldnt load config ${r}`);const{data:l}=c.data;s+=` --projectGroupId=${l.projectGroupId}`,s+=` --projectPath='${a}'`,s+=` --projectName='${o.params.name}'`,s+=` --projectBranch='${o.params.branch||"main"}'`,s+=` --gitlabHost='${l.gitlabHost}'`,s+=` --gitlabToken='${l.gitlabToken}'`,s+=` --gitlabUsername='${l.gitlabUsername}'`,s+=` --gitlabUserEmail='${l.gitlabUserEmail}'`,!0!==o.dryRun&&(await Ce({cmd:s}),n.isDirty=!0)},Yt=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o,registerToPackageManager:i})=>{await e({message:"Deploying it as gcs package."});const a=t.projectDir,s=Re.resolve(a,"package.json"),r=Me.readFileSync(s),c=JSON.parse(r);c.name=o.params.name,c.version=Fe.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,Me.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Ue({name:o.config||"gcs",dir:t.projectDir});let d="fnet-files-to-gcs";d+=` --projectId='${p.env.GCS_PROJECT_ID}'`,d+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,d+=` --keyFilename='${Re.resolve(Re.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,d+=` --dir='${a}'`,d+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",d+=` --destDir='${c.name}/${c.version}'`,d+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(d+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(d+=" --dryRun"),await qe({cmd:d}),Me.writeFileSync(s,r),!0!==o.dryRun&&(n.isDirty=!0,o.params.version=c.version,await i({target:o,packageJSON:c}))},Zt=async({atom:e,setInProgress:t,context:n,deploymentProject:o,deploymentProjectTarget:i})=>{await t({message:"Deploying it as npm package."});const a=n.projectDir,s=Le.resolve(a,"package.json"),r=Be.readFileSync(s),c=JSON.parse(r);c.name=i.params.name,c.version=ze.inc(i.params.version,"patch");const l=i.params.bin?.name||i.params.bin;!1!==i.params.bin?.enabled&&l&&"string"==typeof l&&(c.bin={[l]:"dist/cli/esm/index.js",[e.doc.name]:"dist/cli/esm/index.js"}),delete c.scripts,delete c.devDependencies,c.scripts={serve:"npx serve ."},Be.writeFileSync(s,JSON.stringify(c,null,"\t"));const p=(await We({name:n.npmConfig||"npm",dir:n.projectDir}))?.data;if(Be.writeFileSync(Le.resolve(a,".npmrc"),`//registry.npmjs.org/:_authToken=${p.env.NPM_TOKEN}`),!0===i.dryRun)return;if(0!==Je.exec("npm publish --access public",{cwd:a}).code)throw new Error("Couldnt publish to npm");Be.writeFileSync(s,r),o.isDirty=!0,i.params.version=c.version},Qt=async({atom:e,setInProgress:t,context:n,deploymentProject:o,deploymentProjectTarget:i,buildId:a,packageDependencies:s,njEnv:r})=>{await t({message:"Deploying it as node-red flow."});const c=n.projectDir,l=n.templateDir,p="workflow"===e.type?"WF":"LIB";let d;if("simple"===i.deploy.template)d={atom:e,packageDependencies:s,red:{tab:{id:i.deploy.id||Xe.util.generateId(),label:`${p}/${e.id?e.id:He.hostname()}/${e.name}/${i.deploy.name||i.deploy.template}`},function:{id:Xe.util.generateId(),name:e.doc.name,initialize:{content:Ke.readFileSync(Ge.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},inject:{id:Xe.util.generateId(),...i.params?.inject,payload:"json"===i.params?.inject?.payloadType?`'${JSON.stringify(i.params?.inject?.payload)}'`:i.params?.inject?.payload},debug:{id:Xe.util.generateId()}}};else if("cronjob"===i.deploy.template){let t=i.params?.schedules?cloneDeep(i.params?.schedules):void 0;t?.forEach((e=>{"json"===e.payloadType&&(e.payload=`'${JSON.stringify(e.payload)}'`)})),d={atom:e,packageDependencies:s,red:{tab:{id:i.deploy.id||Xe.util.generateId(),label:`${p}/${e.id?e.id:He.hostname()}/${i.deploy.name||i.deploy.template}`},function:{id:Xe.util.generateId(),name:e.doc.name,initialize:{content:Ke.readFileSync(Ge.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},cronjob:{id:Xe.util.generateId(),schedules:t},debug:{id:Xe.util.generateId()}}}}else{if("http"!==i.deploy.template)return;d={atom:e,packageDependencies:s,red:{tab:{id:i.deploy.id||Xe.util.generateId(),label:`${p}/${e.id?e.id:He.hostname()}/${i.deploy.name||i.deploy.template}`},function:{id:Xe.util.generateId(),name:e.doc.name,initialize:{content:Ke.readFileSync(Ge.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},httpin:{id:Xe.util.generateId(),method:i.params.method||"get",url:i.params.url},httpout:{id:Xe.util.generateId()},debug:{id:Xe.util.generateId()}}}}let f=Ve.compile(Ke.readFileSync(Ge.resolve(l,`deploy/node-red/${i.deploy.template}.yaml.njk`),"utf8"),r).render(d);if(Ke.writeFileSync(Ge.resolve(c,"node-red.yaml"),f),f=yaml.load(f),!0===i.dryRun)return;o.isDirty=!0;const m=(await Ye({name:n.redConfig||"red",dir:n.projectDir}))?.data,u=i.deploy.url||m.env.RED_URL,h={};if(!1!==i.deploy.auth&&(h.Authorization="Bearer "+atomAccessToken),i.deploy.id)!0===i.actions?.delete?(await axios({method:"DELETE",url:`${u}/flow/${i.deploy.id}`,headers:h}),delete i.actions.delete,delete i.deploy.id,i.enabled=!1):await axios({method:"PUT",url:`${u}/flow/${i.deploy.id}`,data:f,headers:h});else{const e=await axios({method:"POST",url:`${u}/flow`,data:f,headers:h});i.deploy.id=e.data.id}},en=async({atom:e,Atom:t,setInProgress:n,context:o,packageDependencies:i,deploymentProject:a,deploymentProjectTarget:s})=>{await n({message:"Deploying it as workflow lib."});const r=(await et({name:"atom",dir:o.projectDir}))?.data;let c,l,p,d=s.deploy.name.split("/");if(1===d.length)l=r.env.ATOM_LIBRARIES_ID,p=s.deploy.name;else{if(2!==d.length)throw new Error("Wrong name path.");{const e=await t.first({where:{name:d[0],parent_id:r.env.ATOM_LIBRARIES_ID,type:"folder"},limit:1});if(!e)throw new Error("Couldnt file lib folder.");l=e.id,p=d[1]}}if(!0===s.dryRun)return;if(a.isDirty=!0,s.deploy.id){if(c=await t.get({id:s.deploy.id}),!c)return}else{if(c=await t.create({parent_id:l,doc:{name:p,type:"workflow.lib","content-type":"javascript",dependencies:[],content:void 0,subtype:"workflow"}}),!c)return;s.deploy.id=c.id}const f=o.projectDir;c.doc.contents=[{content:Ze.readFileSync(Qe.resolve(f,"dist/default/esm/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"esm"},{content:Ze.readFileSync(Qe.resolve(f,"dist/default/cjs/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"cjs"},{content:Ze.readFileSync(Qe.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"iife"}],c.doc.name=p,c.doc.dependencies=i,"workflow.lib"===e.type?c.doc.subtype="library":"workflow"===e.type&&(c.doc.subtype="workflow"),c=await t.update(c,{id:c.id})},tn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as ios-app package."});const a=t?.config?await tt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=it.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=ot(t.params);r.dependencies=ot(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await nt(c)}},nn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as macos-app package."});const a=t?.config?await at({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=ct.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=rt(t.params);r.dependencies=rt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await st(c)}},on=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as electron package."});const a=t?.config?await lt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=ft.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=dt(t.params);r.dependencies=dt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await pt(c)}},an=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as webos package."});const a=t?.config?await mt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=wt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=ht(t.params);r.dependencies=ht(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await ut(c)}},sn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as nextjs package."});const a=t?.config?await yt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=vt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=bt(t.params);r.dependencies=bt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await gt(c)}},rn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as docker package."});const a=t?.config?await _t({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=jt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=kt(t.params);r.dependencies=kt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await xt(c)}},cn=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o,registerToPackageManager:i})=>{await e({message:"Deploying it as fnet package."});const a=t.projectDir,s=Pt.resolve(a,"package.json"),r=Dt.readFileSync(s),c=JSON.parse(r);c.name=o.params.name,c.version=St.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,Dt.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Tt({name:o.config||"fnet-package",dir:t.projectDir});if(!p.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${l}`);if(!p.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${l}`);if(!p.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${l}`);const d=`${p.env.ATOM_API_URL}/v1/auth/token`,f=p.env.ATOM_API_USERNAME,m=p.env.ATOM_API_PASSWORD;let u=await Et({method:"POST",url:d,data:{username:f,password:m},headers:{"Content-Type":"application/json"}});const h=u.data?.access_token;if(!h)throw new Error(`Invalid access_token from ${d}`);let w="fnet-files-to-gcs";if(w+=` --projectId='${p.env.GCS_PROJECT_ID}'`,w+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,w+=` --keyFilename='${Pt.resolve(Pt.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,w+=` --dir='${a}'`,w+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",w+=` --destDir='${c.name}/${c.version}'`,w+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(w+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(w+=" --dryRun"),await At({cmd:w}),Dt.writeFileSync(s,r),!0===o.dryRun)return;n.isDirty=!0,o.params.version=c.version;const y=`${p.env.ATOM_API_URL}/v1/service/fnet-package/publish`;if(u=await Et({method:"POST",url:y,data:{name:c.name,version:c.version,version_domain:p.env.DOMAIN,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${h}`}}),u.data?.error)throw new Error("Failed to publish fnet package.")},ln=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet form."});const i=$t.inc(o.params.version,"patch"),{file:a,data:s}=await It({name:o.config||"fnet-form",dir:t.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${a}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${a}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${a}`);const r=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Ot({method:"POST",url:r,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${r}`);n.isDirty=!0,o.params.version=i;const f=`${s.env.ATOM_API_URL}/v1/service/fnet-form/publish`;if(p=await Ot({method:"POST",url:f,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet form.")},pn=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet flow."});const i=Ct.inc(o.params.version,"patch"),{file:a,data:s}=await Nt({name:o.config||"fnet-flow",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${a}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${a}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${a}`);const r=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Mt({method:"POST",url:r,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${r}`);n.isDirty=!0,o.params.version=i;const f=`${s.env.ATOM_API_URL}/v1/service/fnet-flow/publish`;if(p=await Mt({method:"POST",url:f,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet flow.");const m=p.data?.upload.id;let u="fnet-dir-zipper";u+=` --sourceDir='${t.project.projectDir}'`,u+=" -p=**/*",u+=" -g",u+=" --stdout_format=json";const h=await Ft({cmd:u});if(0!==h.code)throw new Error(h.stderr);const w=JSON.parse(h.stdout).path;let y=new qt;y.append("file",Rt.createReadStream(w));const g=await Mt.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${m}`,headers:{...y.getHeaders(),Authorization:`Bearer ${d}`},data:y});if(g.data?.error)throw new Error("Error uploading fnet flow.")},dn=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet node."});const i=Ut.inc(o.params.version,"patch"),{file:a,data:s}=await Bt({name:o.config||"fnet-node",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${a}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${a}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${a}`);const r=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Lt({method:"POST",url:r,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${r}`);n.isDirty=!0,o.params.version=i;const f=`${s.env.ATOM_API_URL}/v1/service/fnet-node/publish`;if(p=await Lt({method:"POST",url:f,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet node.");const m=p.data?.upload.id;let u="fnet-dir-zipper";u+=` --sourceDir='${t.project.projectDir}'`,u+=" -p=**/*",u+=" -g",u+=" --stdout_format=json";const h=await Jt({cmd:u});if(0!==h.code)throw new Error(h.stderr);const w=JSON.parse(h.stdout).path;let y=new Wt;y.append("file",zt.createReadStream(w));const g=await Lt.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${m}`,headers:{...y.getHeaders(),Authorization:`Bearer ${d}`},data:y});if(g.data?.error)throw new Error("Error uploading fnet node.")},fn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as Rust package."});const a=t?.config?await Kt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=Vt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=Ht(t.params);r.dependencies=Ht(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await Gt(c)}};const mn=u;async function un({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||mn(e.definition);for(const t of e.childs)t.context.transform=t.context.transform||mn(t.definition),t.definition.hasOwnProperty("condition")&&(t.context.transform.condition=await o(t.definition.condition));await t({node:e}),n({node:e})}var hn={hits:async function({node:e}){if(!e.definition.hasOwnProperty("switch"))return!1;const t=e.definition.switch||[];if(!t.every((e=>e.hasOwnProperty("condition")||e.hasOwnProperty("default"))))throw new Error("Switch must have condition or default");if(0===t.filter((e=>e.hasOwnProperty("condition"))).length)throw new Error("Switch must have at least one condition");const n=t.filter((e=>e.hasOwnProperty("default")));if(n.length>1)throw new Error("Switch must have only one default");if(1===n.length&&!t[t.length-1].hasOwnProperty("default"))throw new Error("Switch default must be the last child");return!0},init:async function({node:e,initNode:t}){e.type="switch",e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0;for(let n=0;n<e.definition.switch.length;n++){let o=e.definition.switch[n],i=`${n}`;o.hasOwnProperty("default")&&(i="default",o=o.default);const a={name:o.condition||i,childs:[],parent:e,definition:o,index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=un},resolve:un};const wn=U,yn=hn;var gn={hits:async function({node:e}){const t=Object.keys(e.definition);return 1===(await Promise.all(t.map((e=>wn({expression:e}))))).filter((e=>"if"===e?.processor)).length},init:async function(e){const{node:t}=e,n=Object.keys(t.definition),o=await Promise.all(n.map((e=>wn({expression:e})))),i=[],a=o.find((e=>"if"===e?.processor)),s=t.definition[a.expression];i.push({name:`${t.name}_if`,definition:s,processor:a}),delete t.definition[a.expression];const r=o.filter((e=>"elseif"===e?.processor));let c=0;for(const e of r){const n=t.definition[e.expression];i.push({name:`${t.name}_elseif_${c++}`,definition:n,processor:e}),delete t.definition[e.expression]}t.definition.switch=[];for(const e of i)t.definition.switch.push({condition:e.processor.statement,...e.definition});await yn.init(e)}};const bn=u;async function vn({node:e,resolveTypeCommon:t,resolveNextBlock:n}){if(e.context.transform=e.context.transform||bn(e.definition),e.context.transform,e.context.try=e.childs.find((e=>"try"===e.name)),e.context.except=e.childs.find((e=>"except"===e.name)),e.context.except){const t=e.context.except;t.context.transform=t.context.transform||bn(t.definition),t.context.transform.hasOwnProperty("as")||(t.context.transform.as="error")}await t({node:e}),n({node:e})}var _n={hits:async function({node:e}){return e.definition.hasOwnProperty("try")&&e.definition.hasOwnProperty("except")},init:async function({node:e,initNode:t}){if(e.type="tryexcept",e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0,e.definition.try){const n="try",o={name:n,childs:[],parent:e,definition:e.definition[n],index:e.childs.length,context:{}};e.childs.push(o),await t({node:o})}if(e.definition.except){const n="except",o={name:n,childs:[],parent:e,definition:e.definition[n],index:e.childs.length,context:{}};e.childs.push(o),await t({node:o})}e.resolve=vn},resolve:vn};const xn=u;async function kn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=xn(e.definition);const i=e.context.transform;for(let e=0;e<i.assign?.length;e++){let t=i.assign[e],n=Object.keys(t)[0],a=t[n],s={key:await o(n),value:await o(a)};i.assign[e]=s}await t({node:e}),n({node:e})}var jn={hits:async function({node:e}){return e.definition.hasOwnProperty("assign")},init:async function({node:e,initNode:t}){e.type="assign",e.resolve=kn},resolve:kn};const Dn=u,Pn=L,Sn=z;async function An({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||Dn(e.definition);e.context.transform.for.in=await o(e.definition.for.in),await t({node:e}),n({node:e})}var Tn={hits:async function({node:e}){return e.definition.hasOwnProperty("for")},init:async function({node:e,initNode:t}){if(e.type="for",e.blockAutoJumpToParent=!0,e.blockAutoJumpToSibling=!1,!e.definition.for.hasOwnProperty("steps")){const t=["value","in"],[n,o]=[Pn(e.definition.for,t),Sn(e.definition.for,t)];e.definition.for=n,e.definition.for.steps=[{[`${e.name}_step`]:o}]}Array.isArray(e.definition.for.steps)||(e.definition.for.steps=[{[`${e.name}_step`]:e.definition.for.steps}]);for(let n=0;n<e.definition.for.steps.length;n++){const o=e.definition.for.steps[n],i=Object.keys(o)[0],a={name:i,childs:[],parent:e,definition:o[i],index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=An},resolve:An};var En={hits:async function({node:e}){return!1},init:async function({node:e,initNode:t}){},resolve:async function({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o,transformValue:i}){}};const $n=u;async function In({node:e,resolveTypeCommon:t,transformExpression:n}){e.context.transform=e.context.transform||$n(e.definition);const o=e.context.transform;o.raise=await n(o.raise),await t({node:e})}var On={hits:async function({node:e}){return e.definition.hasOwnProperty("raise")},init:async function({node:e,initNode:t}){e.type="raise",e.resolve=In},resolve:In};const Cn=u;async function Nn({node:e,resolveTypeCommon:t,transformExpression:n}){e.context.transform=e.context.transform||Cn(e.definition);const o=e.context.transform;o.return=await n(o.return),await t({node:e})}var Mn={hits:async function({node:e}){return e.definition.hasOwnProperty("return")},init:async function({node:e,initNode:t}){e.type="return",e.resolve=Nn},resolve:Nn};const Rn=u;async function Fn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||Rn(e.definition);const i=e.context.transform;i.args&&(i.args=await o(i.args)),i.result&&(i.result=await o(i.result));const a=e.workflow.parent;e.context.lib=a.context.libs.find((e=>e.name===i.call)),await t({node:e}),n({node:e})}var qn={hits:async function({node:e}){return e.definition.hasOwnProperty("call")},init:async function({node:e,initNode:t}){e.type="call";for(let n=0;n<e.definition.modules?.length;n++){const o=e.definition.modules[n],i=Object.keys(o)[0],a={name:i,childs:[],parent:e,definition:o[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=Fn},resolve:Fn};const Un=qn;var Bn={hits:async function({node:e}){return e.definition.hasOwnProperty("shell")},init:async function(e){const{node:t}=e,n="shell",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/shell",o.args="string"===i?{...o.args,cmd:o[n]}:o[n],delete o[n],await Un.init(e)}};const Ln=qn;var zn={hits:async function({node:e}){return e.definition.hasOwnProperty("config")},init:async function(e){const{node:t}=e,n="config",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/config",o.args="string"===i?{...o.args,name:o[n]}:o[n],delete o[n],await Ln.init(e)}};const Jn=qn;var Wn={hits:async function({node:e}){return e.definition.hasOwnProperty("yaml")},init:async function(e){const{node:t}=e,n="yaml",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/yaml",o.args="string"===i?{...o.args,file:o[n]}:o[n],delete o[n],await Jn.init(e)}};async function Kn({node:e}){e.context.next=e.childs[0]}var Gn={hits:async function({node:e}){return e.definition.hasOwnProperty("steps")},init:async function({node:e,initNode:t}){e.type||(e.type="steps");const n=e.definition.steps||[];for await(const o of n){const n=Object.keys(o)[0],i={name:n,childs:[],parent:e,definition:o[n],index:e.childs.length,context:{}};e.childs.push(i),await t({node:i})}e.resolve=Kn},resolve:Kn};const Hn=u;async function Vn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||Hn(e.definition);const i=e.context.transform;i.props&&(i.props=await o(i.props));const a=e.workflow.parent;e.context.lib=a.context.libs.find((e=>e.name===i.form)),await t({node:e}),n({node:e})}var Xn={hits:async function({node:e}){return e.definition.hasOwnProperty("form")},init:async function({node:e,initNode:t}){e.type="form";for(let n=0;n<e.definition.modules?.length;n++){const o=e.definition.modules[n],i=Object.keys(o)[0],a={name:i,childs:[],parent:e,definition:o[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=Vn},resolve:Vn};const Yn=u;async function Zn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o,transformValue:i}){e.context.transform=e.context.transform||Yn(e.definition),await t({node:e})}var Qn={hits:async function({node:e}){return e.definition.hasOwnProperty("operation")},init:async function({node:e,initNode:t}){e.type="operation",e.resolve=Zn},resolve:Zn};const eo=u;async function to({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||eo(e.definition);const i=e.context.transform;i.next=await o(i.next),await t({node:e}),n({node:e})}var no={hits:async function({node:e}){return e.definition.hasOwnProperty("next")},init:async function({node:e,initNode:t}){e.type="jump",e.resolve=to},resolve:to};const oo=qn;var io={hits:async function({node:e}){return e.definition.hasOwnProperty("prompt")},init:async function(e){const{node:t}=e,n="prompt",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/prompt",o.args="string"===i?{...o.args,message:o[n]}:o[n],delete o[n],await oo.init(e)}};const ao=qn;var so={hits:async function({node:e}){return e.definition.hasOwnProperty("html-script")},init:async function(e){const{node:t}=e,n="html-script",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@flownet/lib-load-browser-script-url",o.args="string"===i?{...o.args,src:o[n]}:o[n],delete o[n],await ao.init(e)}};const ro=qn;var co={hits:async function({node:e}){return e.definition.hasOwnProperty("html-link")},init:async function(e){const{node:t}=e,n="html-link",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@flownet/lib-load-browser-link-url",o.args="string"===i?{...o.args,src:o[n]}:o[n],delete o[n],await ro.init(e)}};const lo=d,po=f,fo=s,mo=r,uo=m,ho=u,wo=h,yo=async()=>{if(!await W({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=J.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e},{nanoid:go}=g,bo=class{init({config:e,accessToken:t}){return new Promise(((n,o)=>{if(K.set_api_url(e.data.url),t)return K.set_req_token(t),void n(t);G({method:"POST",url:`${e.data.issuer}/protocol/openid-connect/token`,data:H.stringify(e.data.grant.params),headers:{"Content-Type":"application/x-www-form-urlencoded"}}).then((e=>{K.set_req_token(e.data.access_token),n(e.data.access_token)})).catch((e=>{K.set_req_token(),o(e)}))}))}},vo=async({atom:e,context:t})=>{e.doc.features=e.doc.features||{};const n=e.doc.features;n.project=n.project||{},n.project.format=n.project.format||n.project_format||"esm",n.project_format=n.project.format,n.dts_enabled=!0===n.dts||void 0!==n.dts&&!1!==n.dts,n.hasOwnProperty("all_parsed_imports")||(n.all_parsed_imports=!0);const o=Y.resolve(t.project.projectDir),i=Q({dir:Y.resolve(o,"./app")});if(i.file){let e=await Z({file:i.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));n.app_uses_jsx=t,n.app_has_entry=!0,e=await Z({file:i.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),n.app_entry_uses_jsx=t,n.app_entry_is_ts=i.ts,n.app_entry_ext=i.ext}const a=Q({dir:Y.resolve(o,"./cli")});if(a.file){let e=await Z({file:a.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));n.cli_uses_jsx=t,n.cli_has_entry=!0,e=await Z({file:a.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),n.cli_entry_uses_jsx=t,n.cli_entry_is_ts=a.ts,n.cli_entry_ext=a.ext}if("workflow.lib"===e.type){const e=Q({dir:Y.resolve(o,"./src")});if(e.file){let t=await Z({file:e.file,recursive:!0}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));n.src_uses_jsx=o,n.src_has_entry=!0,t=await Z({file:e.file}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),n.src_entry_uses_jsx=o,n.src_entry_is_ts=e.ts,n.src_entry_ext=e.ext}}const s=!0===n.app_has_entry||!0===n.src_uses_jsx,r=!0===n.cli_has_entry||!0===n.src_uses_jsx;n.form_enabled=!0===e.doc.form||!0===e.doc.form?.enabled||!0===n.form||!0===n.form?.enabled,n.multiple_enabled=n.multiple_enabled||!0===n.multiple||!0===n.multiple?.enabled,!1===n.app?n.app={enabled:!1}:!0===n.app?n.app={enabled:!0,extend:!0===n.app_has_entry,export:!0,react:s}:n.app={enabled:!0,extend:!0===n.app_has_entry,export:!0,react:s,...n.app||{}},n.app.enabled=!0===n.app.enabled&&(!0===e.doc.features.form_enabled||!0===n.app.extend||!0===n.app.enabled),n.app.format=n.app.format||"esm",n.app.folder=n.app.folder||n.app.format||"default",!1===n.cli?n.cli={enabled:!1}:!0===n.cli?n.cli={enabled:!0,extend:!0===n.cli_has_entry,export:!0,react:r}:n.cli={enabled:!0,extend:!0===n.cli_has_entry,export:!0,react:r,...n.cli||{}},n.cli.enabled=!0===n.cli.enabled&&(!1===e.doc.features.form_enabled||!0===n.cli.extend||!0===n.cli.enabled),n.cli.format=n.cli.format||"esm",n.cli.folder=n.cli.folder||n.cli.folder||"esm",n.cli.node_options=n.cli.node?.options||n.cli.node_options||"";const c={cjs:{format:"cjs",context:n.form_enabled?"window":"global",babel:!0===n.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!0,string:!0},cjsx:{format:"cjs",context:n.form_enabled?"window":"global",babel:!0===n.src_uses_jsx||!1,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0},esm:{format:"esm",context:n.form_enabled?"window":"global",babel:!0===n.src_uses_jsx||!1,browser:!1,replace:!0,browsersync:!0,terser:!1,enabled:!0,copy:!0,string:!0},esmx:{format:"esm",browser:!0,babel:!0,context:n.form_enabled?"window":"global",replace:!0,browsersync:!1,enabled:!1,terser:!0,string:!0},iife:{format:"iife",context:n.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1!==n.iife,terser:!0,string:!0},umd:{format:"umd",context:n.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0}},l={};!0===n.webos&&(c.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",babel_options:{targets:{chrome:"79"}}}),!0===n.electron&&(c.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===n.nextjs&&(c.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===n.ios&&(c.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===n.macos&&(c.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===n.app.enabled&&(n.app.dir=`./dist/app/${n.app.folder}`,c.app={format:n.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:n.app.dir,terser:!0,output_exports:!1===n.app.export?"none":"auto",string:!0},l.targets=l.targets||[],l.targets.push({src:"./src/app/index.html",dest:n.app.dir})),!0===n.cli.enabled&&(n.cli.dir=`./dist/cli/${n.cli.folder}`,c.cli={format:n.cli.format,context:"global",babel:!0===n.src_uses_jsx||!0===n.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:n.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===n.cli.export?"none":"auto",string:!0});const p={server:".",startPath:`${Y.normalize(n.app.dir||".")}`,files:[Y.normalize("./dist/**/*")],cors:!0,open:!1};n.babel_options=n.babel_options||n.babel?.options||{targets:{browsers:"last 9 versions, not dead",node:"18"}},n.browsersync_options=V(p,n.browsersync_options||n.browsersync?.options||{}),n.replace_options=V({},n.replace_options||n.replace?.options||{}),n.terser_options=V({},n.terser_options||n.terser?.options||{}),n.css_options=V({},n.css_options||n.css?.options||{}),n.wasm_options=V({},n.wasm_options||n.wasm?.options||{}),n.copy_options=V(l,n.copy_options||n.copy?.options||{}),n.json_options=V({},n.json_options||n.json?.options||{}),n.image_options=V({},n.image_options||n.image?.options||{}),n.analyzer_options=V({summaryOnly:!0,limit:12},n.analyzer_options||n.analyzer?.options||{}),n.visualizer_options=V({},n.visualizer_options||n.visualizer?.options||{}),n.string_options=V({},n.string_options||n.string?.options||{}),n.nunjucks_options=V({},n.nunjucks_options||n.nunjucks?.options||{}),Reflect.has(n.browsersync_options,"proxy")&&delete n.browsersync_options.server,n.rollup=n.rollup||{},n.rollup_output=V(c,n.rollup_output||n.rollup?.output||{}),n.string_enabled=!0===n.string||n.string&&!1!==n.string?.enabled,n.preact_enabled=!0===n.preact||n.preact&&!1!==n.preact?.enabled;const d=Object.keys(c);for(const e of d){const t=c[e];t&&(!1!==n.rollup[e]?(!0===n.rollup[e]&&(t.enabled=!0),t.babel_options=t.babel_options||n.babel_options,t.browsersync_options=V(n.browsersync_options,t.browsersync_options),t.replace_options=V(n.replace_options,t.replace_options),t.terser_options=V(n.terser_options,t.terser_options),t.css_options=V(n.css_options,t.css_options),t.wasm_options=V(n.wasm_options,t.wasm_options),t.copy_options=V(n.copy_options,t.copy_options),t.json_options=V(n.json_options,t.json_options),t.image_options=V(n.image_options,t.image_options),t.analyzer_options=V(n.analyzer_options,t.analyzer_options),t.visualizer_options=V(n.visualizer_options,t.visualizer_options),t.string_options=V(n.string_options,t.string_options),t.string=n.string_enabled&&t.string,t.nunjucks_options=V(n.nunjucks_options,t.nunjucks_options),n.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),n.form_enabled&&(t.babel=!0)):t.enabled=!1)}n.babel_enabled=d.some((e=>!0===n.rollup_output[e].babel)),n.browser_enabled=d.some((e=>!0===n.rollup_output[e].babel)),n.browsersync_enabled=!1!==n.browsersync&&d.some((e=>!0===n.rollup_output[e].browsersync)),n.browsersync_enabled=n.browsersync_enabled&&n.app.enabled,n.wasm_enabled=!0===n.wasm||n.wasm&&!1!==n.wasm?.enabled,n.css_enabled=!0===n.css||n.css&&!1!==n.css?.enabled,n.json_enabled=!0===n.json||n.json&&!1!==n.json?.enabled,n.terser_enabled=!1!==n.terser,n.copy_enabled=n.app.enabled||n.copy_enabled||n.copy&&!1!==n.copy?.enabled,n.image_enabled=!0===n.image||n.image&&!1!==n.image?.enabled,n.analyzer_enabled=!0===n.analyzer||n.analyzer&&!1!==n.analyzer?.enabled,n.visualizer_enabled=!0===n.visualizer||n.visualizer&&!1!==n.visualizer?.enabled,n.dependency_auto_enabled=!1!==n.dependency_auto&&!1!==n.dependency_auto?.enabled,n.npm_install_flags=n.npm_install_flags||"",n.react_version=n.react_version||n.react?.version||18,n.polyfill_enabled=!0===n.polyfill||n.polyfill&&!1!==n.polyfill?.enabled,n.nunjucks_enabled=!0===n.nunjucks||n.nunjucks&&!1!==n.nunjucks?.enabled},_o=async({atom:e,packageDependencies:t,packageDevDependencies:n})=>{if("workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let n="^18.2";n=`^${(await ee({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:n}),t.push({package:"react-dom",version:n}),"workflow"===e.type&&(t.push({package:"@flownet/react-app",version:"^0.1"}),t.push({package:"@flownet/react-app-state",version:"^0.1"}))}if(e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&t.push({package:"yargs",version:"^17"}),n.push({package:"@babel/core",version:"^7"}),n.push({package:"@rollup/plugin-commonjs",version:"^26"}),n.push({package:"@rollup/plugin-node-resolve",version:"^15"}),n.push({package:"@rollup/plugin-replace",version:"^5"}),n.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&n.push({package:"rollup-plugin-dts",version:"^6"}),n.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),n.push({package:"@rollup/plugin-alias",version:"^5"}),n.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(n.push({package:"@rollup/plugin-babel",version:"^6"}),n.push({package:"@babel/preset-env",version:"^7"}),n.push({package:"@babel/preset-react",version:"^7"}),n.push({package:"@babel/plugin-proposal-decorators",version:"^7"}),n.push({package:"@babel/plugin-proposal-class-properties",version:"^7"})),n.push({package:"@fnet/rollup-plugin-delete",version:"0.1.3"}),e.doc.features.nunjucks_enabled&&n.push({package:"@fnet/rollup-plugin-nunjucks",version:"0.1.3"}),e.doc.features.browsersync_enabled&&n.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.1"}),e.doc.features.json_enabled&&n.push({package:"@rollup/plugin-json",version:"^6"}),e.doc.features.terser_enabled&&n.push({package:"@rollup/plugin-terser",version:"^0.4"}),e.doc.features.wasm_enabled&&n.push({package:"@rollup/plugin-wasm",version:"^6"}),e.doc.features.image_enabled&&n.push({package:"@rollup/plugin-image",version:"^3"}),e.doc.features.analyzer_enabled&&n.push({package:"rollup-plugin-analyzer",version:"^3"}),e.doc.features.visualizer_enabled&&n.push({package:"rollup-plugin-visualizer",version:"^5"}),e.doc.features.string_enabled&&n.push({package:"rollup-plugin-string",version:"^3"}),e.doc.features.css_enabled){n.push({package:"rollup-plugin-postcss",version:"^4"}),n.push({package:"sass",version:"^1.66"});(e.doc.features.css_options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":n.push({package:"postcss-import",version:"^15"});break;case"postcss-url":n.push({package:"postcss-url",version:"^10"});break;case"postcss-preset-env":n.push({package:"postcss-preset-env",version:"^9"});break;case"autoprefixer":n.push({package:"autoprefixer",version:"^10"});break;case"cssnano":n.push({package:"cssnano",version:"^6"})}}))}e.doc.features.polyfill_enabled&&n.push({package:"rollup-plugin-node-polyfills",version:"^0.2"}),e.doc.features.copy_enabled&&(n.push({package:"rollup-plugin-copy",version:"^3"}),n.push({package:"chokidar",version:"^3"}))},xo=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{if(!0!==e.doc.features.app.enabled)return;await t({message:"Creating index.html."});const i={workflowAtom:e,libraryAtom:e,atom:e,packageDependencies:o,ts:Date.now()},a=n.templateDir,s=ne.resolve(n.projectDir,"src/app");te.existsSync(s)||te.mkdirSync(s,{recursive:!0}),await oe({pattern:["index.html.njk","index.js.njk"],dir:ne.resolve(a,"src/app"),outDir:s,context:i})},ko=async({atom:e,context:t,packageDependencies:n,packageDevDependencies:o,setInProgress:i})=>{await i({message:"Creating package.json."});n.filter((e=>!0===e.dev)).forEach((e=>{o.find((t=>t.package===e.package))||o.push(e);const t=n.findIndex((t=>t.package===e.package));n.splice(t,1)}));const a=n.find((e=>"react"===e.package)),s=n.find((e=>"react-dom"===e.package));a&&!s?n.push({package:"react-dom",version:a.version}):a&&s&&(s.version=a.version),a&&e.doc.features.react_version>=17&&(n.find((e=>"@emotion/react"===e.package))||n.push({package:"@emotion/react",version:"^11"}),n.find((e=>"@emotion/styled"===e.package))||n.push({package:"@emotion/styled",version:"^11"}));const r=[];!0===e.doc.features.app.enabled&&r.push({file:se.resolve(t.projectDir,"src/app/index.js"),dev:!1!==e.doc.features.app.dev}),!0===e.doc.features.cli.enabled&&r.push({file:se.resolve(t.projectDir,"src/cli/index.js"),dev:!1!==e.doc.features.cli.dev});for await(const t of r){const i=t.file;if(!ae.existsSync(i))throw new Error(`App file not found: ${i}`);const a=await re({file:i,recursive:!0}),s=!0===e.doc.features.all_parsed_imports?a.all:a.required;for await(const e of s){if("npm"!==e.type)continue;if(n.find((t=>t.package===e.package)))continue;if(o.find((t=>t.package===e.package)))continue;const i=(await ce({name:e.package,groupBy:{minor:!0}}))[0][0];(!0===t.dev?o:n).push({package:e.package,subpath:e.subpath,version:`^${i}`,type:"npm"})}}const c={atom:e,packageDependencies:n,packageDevDependencies:o},l=t.templateCommonDir,p=ie.compile(ae.readFileSync(se.resolve(l,"package.json.njk"),"utf8"),ie.configure(l)).render(c),d=t.projectDir,f=se.resolve(d,"package.json");ae.writeFileSync(f,p,"utf8")},jo=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating cli."});const i={workflowAtom:e,libraryAtom:e,atom:e,packageDependencies:o},a=n.templateDir,s=pe.resolve(n.projectDir,"src/cli");le.existsSync(s)||le.mkdirSync(s,{recursive:!0}),await de({pattern:["index.js.njk"],dir:pe.resolve(a,"src/cli"),outDir:s,context:i})},Do=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{await t({message:"Creating rollup file."});const i={atom:e,packageDependencies:o},a=me.resolve(n.projectDir,"src","default/index.js");if(!fe.existsSync(a))throw new Error(`Entry file not found: ${a}`);const s=(await he({file:a,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),r=e.doc.features.rollup_output,c=Object.keys(r);for(let e=0;e<c.length;e++){const t=r[c[e]];if(!0===t.browser&&s.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(s.map((e=>({key:e,value:e})))),t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{};for(let e=0;e<s.length;e++){const n=s[e];t.alias.entries[n]=`node:${n}`,t.alias.entries[`node:${n}`]=n}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(s)}}const l=n.templateCommonDir;let p=ue.compile(fe.readFileSync(me.resolve(l,"rollup.config.mjs.njk"),"utf8"),ue.configure(l)).render(i);const d=n.projectDir;let f=me.resolve(d,"rollup.config.mjs");fe.writeFileSync(f,p,"utf8")},Po=async({atom:e,setInProgress:t,context:n,njEnv:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating yargs."});let i={};const a=e.doc.inputs||[],s=[],r=e.doc.input;r?i=await be({schema:r}):a.forEach((e=>{if(!1===e.cli||!e.name)return;e.import&&s.push(e);const t={};Reflect.has(e,"type")&&(t.type=e.type),Reflect.has(e,"default")&&(t.default=e.default),Reflect.has(e,"choices")&&(t.choices=e.choices),(Reflect.has(e,"describe")||Reflect.has(e,"description"))&&(t.describe=e.describe||e.description),Reflect.has(e,"alias")&&(t.alias=e.alias),Reflect.has(e,"required")&&!0===e.required&&(t.required=!0),Reflect.has(e,"hidden")&&!0===e.hidden&&(t.hidden=!0),Reflect.has(e,"array")&&!0===e.array&&(t.array=!0),Reflect.has(e,"normalize")&&!0===e.normalize&&(t.normalize=!0),Reflect.has(e,"nargs")&&(t.nargs=e.nargs),i[e.name]=t}));const c={options:i,imports:s,atom:e},l=n.templateDir,p=ge.compile(we.readFileSync(ye.resolve(l,"src/default/to.yargs.js.njk"),"utf8"),o).render(c),d=n.projectDir,f=ye.resolve(d,"src/default/to.yargs.js");we.writeFileSync(f,p,"utf8")},So=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{await t({message:"Creating .gitignore"});const i={atom:e,packageDependencies:o},a=n.templateCommonDir,s=xe.compile(ve.readFileSync(_e.resolve(a,".gitignore.njk"),"utf8"),xe.configure(a)).render(i),r=n.projectDir,c=_e.resolve(r,".gitignore");ve.writeFileSync(c,s,"utf8")},Ao=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{await t({message:"Creating tsconfig.json."});const i={atom:e,packageDependencies:o},a=n.templateCommonDir,s=De.compile(ke.readFileSync(je.resolve(a,"tsconfig.json.njk"),"utf8"),De.configure(a)).render(i),r=n.projectDir,c=je.resolve(r,"tsconfig.json");ke.writeFileSync(c,s,"utf8")},To=async({atom:e,context:t,setInProgress:n,Atom:o})=>{const i="readme.md",a=`Creating ${i}`;if(await n({message:a}),t.project?.readme){const e={content:t.project.readme.doc.content},n=t.templateCommonDir,o=Pe.compile(Se.readFileSync(Ae.resolve(n,`${i}.njk`),"utf8"),Pe.configure(n)).render(e),a=t.projectDir,s=Ae.resolve(a,`${i}`);Se.writeFileSync(s,o,"utf8")}else if(e.id){const n=await o.first({type:"wiki",parent_id:e.id});if(!n||"markdown"!==n.doc?.["content-type"])return;const{content:a,...s}=n.doc,r={content:a},c=t.templateCommonDir,l=Pe.compile(Se.readFileSync(Ae.resolve(c,`${i}.njk`),"utf8"),Pe.configure(c)).render(r),p=t.projectDir,d=Ae.resolve(p,`${i}`);Se.writeFileSync(d,l,"utf8")}},Eo=async({setInProgress:e,context:t})=>{const n=t.projectDir;await e({message:"Prettifiying source files."});let o=Ee.join("src","**","*");if(0!==Te.exec(`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:n}).code)throw new Error("Couldnt format files.")},$o=async({atom:e,setInProgress:t,context:n})=>{if(!e.doc.features.dts_enabled)return;const o=n.projectDir;await t({message:"Creating .d.ts"});if(0!==$e.exec("tsc",{cwd:o}).code)throw new Error("Couldnt create .d.ts files.")},Io=async({setInProgress:e,atom:t,context:n})=>{const o=n.projectDir;await e({message:"Installing npm packages."});if(0!==Ie.exec(`npm install ${t.doc.features.npm_install_flags}`,{cwd:o}).code)throw new Error("Couldnt install npm packages.")},Oo=async({setInProgress:e,context:t})=>{const n=t.projectDir;await e({message:"Building main project."});if(0!==Oe.exec("npm run build",{cwd:n}).code)throw new Error("Couldnt build project.")},Co=async e=>{const{atom:t,packageDependencies:n,context:o,deploymentProjectTarget:i,setInProgress:a,deploymentProject:s}=e;if(!0===i.enabled)if("lib"===i.name)await en({...e});else if("red"===i.name)await Qt({...e});else if("npm"===i.name)await Zt({...e});else if("gcs"===i.name)await Yt({...e});else if("gitlab"===i.name)await Xt({...e});else if("fnet-package"===i.name)await cn({...e});else if("fnet-form"===i.name)await ln({...e});else if("fnet-node"===i.name)await dn({...e});else if("fnet-flow"===i.name)await pn({...e});else{let e;if("nextjs"===i.name?e=sn:"webos"===i.name?e=an:"electron"===i.name?e=on:"docker"===i.name?e=rn:"ios"===i.name?e=tn:"macos"===i.name?e=nn:"rust"===i.name&&(e=fn),!e)return;await e({atom:t,target:i,onProgress:a,projectDir:o.projectDir,dependencies:n}),s.isDirty=!0}},{Atom:No}=b,Mo=F,Ro=j,Fo=q,qo=t,Uo=k,Bo=U,Lo=c,zo=B,Jo=gn,Wo=_n,Ko=jn,Go=Tn,Ho=hn,Vo=En,Xo=On,Yo=Mn,Zo=qn,Qo=Bn,ei=zn,ti=Wn,ni=Gn,oi=Xn,ii=Qn,ai=no,si=io,ri=so,ci=co,li=({node:e})=>{const t=e.definition;if("end"===t.next);else if("stop"===t.next);else if("none"===t.next);else if(t.next){let n=e.parent;for(;n.parent;){const o=n.childs.find((e=>e.name===t.next));if(o){e.context.next=o;break}n=n.parent}}else{let t=e.parent,n=e.index+1;for(;t.parent&&(!t.blockAutoJumpToParent||!t.blockAutoJumpToSibling);)if(void 0!==t.blockAutoJumpToParent||void 0!==t.blockAutoJumpToSibling){if(t.blockAutoJumpToParent){const o=t.childs.find((e=>e.index===n));o&&(e.context.next=o);break}t.blockAutoJumpToParent||(n=t.index+1,t=t.parent)}else{const o=t.childs.find((e=>e.index===n));if(o){e.context.next=o;break}n=t.index+1,t=t.parent}}};var pi=class{#e;#t;#n;#o;#i;#a;#s;#r;#c;#l;#p;#d;#f;#m;#u;#h;#w;#y;#g;#b;#v;constructor(e){this.#e=new bo,this.#t=e,this.#a=[],this.#s=[],this.#r={},this._expire_ttl=3600,this._expire_ttl_short=300,this.#b={packageDependencies:this.#a,packageDevDependencies:this.#s,setInProgress:this.setInProgress.bind(this),context:this.#t,Atom:No,registerToPackageManager:this.registerToPackageManager.bind(this)},this.#v={initNode:this.initNode.bind(this),cloneDeep:ho,resolveTypeCommon:this.resolveTypeCommon.bind(this),resolveNextBlock:li,transformExpression:this.transformExpression.bind(this),transformValue:this.transformValue.bind(this)}}async _cache_set(e,t,n){this._redis_client&&await this._redis_client.SETEX(e,n||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await yo(),this.#p=this.#t.buildId||go(24),this.#b.buildId=this.#p,this.#u=this.#t.mode,this.#h=["all","deploy","build","file"].includes(this.#u),this.#w=["all","deploy","build"].includes(this.#u),this.#y=["all","deploy"].includes(this.#u),this.#g=["all","deploy","build","file","bpmn"].includes(this.#u),this.#f=this.#t.protocol,this.#d="BUILD:"+this.#p,this.#m=(await qo({optional:!0,name:"atom",dir:this.#t.projectDir}))?.data;try{await this.setInProgress({message:"Initialization started."}),await this.initAuth(),await this.initWorkflow(),await vo(this.#b),await _o(this.#b),await this.transformWorkflow({workflow:this.#o});const e=await this.initNodeTree({workflow:this.#o});await this.initNodeTreeIndex({root:e}),await this.initNodeCalls({root:e}),await this.initNodeCallLibs({root:e}),await this.initNodeForms({root:e}),await this.initNodeFormLibs({root:e}),await this.initAtomLibsAndDeps({libs:e.context.libs,packageDependencies:this.#a}),await this.resolveNodeTree({root:e}),this.#l=e}catch(e){throw await this._cache_set(this.#d,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#t.id&&(this.#c=await this.#e.init({config:this.#m}),this.#b.atomAccessToken=this.#c)}async initWorkflow(){const e=this.#t.id;this.#n=this.#t.project?.workflowAtom||await No.get({id:e}),this.#o="string"==typeof this.#n.doc.content?(await Lo({content:this.#n.doc.content})).parsed:this.#n.doc.content;let t=this.#n.doc.bundleName;t=t||(this.#n.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#n.doc.bundleName=t,this.#n.type=this.#n.type||"workflow",this.#b.atom=this.#n}async initDependencies(){this.#a.push({package:"get-value",version:"^3.0"}),this.#a.push({package:"set-value",version:"^4.1"}),this.#n.doc.features.form_enabled?(this.#a.push({package:"react",version:"^18.2"}),this.#a.push({package:"react-dom",version:"^18.2"}),this.#a.push({package:"@flownet/react-app",version:"^0.1"}),this.#a.push({package:"@flownet/react-app-state",version:"^0.1"})):this.#a.push({package:"yargs",version:"^17"}),this.#a.push({package:"chalk",version:"^4"})}#_(e){console.log("filePath",e),lo.statSync(e).isDirectory()?(lo.readdirSync(e).forEach((t=>{const n=po.join(e,t);this.#_(n)})),lo.rmSync(e)):lo.unlinkSync(e)}#x(e,t){const n=lo.existsSync(e),o=n&&lo.statSync(e);n&&o.isDirectory()?(lo.mkdirSync(t,{recursive:!0}),lo.readdirSync(e).forEach((n=>{this.#x(po.join(e,n),po.join(t,n))}))):lo.copyFileSync(e,t)}async initWorkflowDir(){const e=this.#t.projectDir,t=this.#t.coreDir,n=["node_modules"];if(lo.existsSync(e)){const t=lo.readdirSync(e);for(const o of t)if(!n.includes(o)){const t=po.join(e,o);lo.rmSync(t,{recursive:!0})}}lo.existsSync(e)||lo.mkdirSync(e,{recursive:!0});const o=po.join(e,"src");lo.existsSync(o)||lo.mkdirSync(o,{recursive:!0});const i=po.join(o,"core");this.#x(t,i);const a=po.join(o,"default","blocks");lo.existsSync(a)||lo.mkdirSync(a,{recursive:!0})}async initNunjucks(){const e=this.#t.templateDir;this.#i=uo.configure(e,{watch:!1,dev:!0}),this.#b.njEnv=this.#i}transformWorkflow({workflow:e}){for(const t of Object.values(e))t.steps=t.steps||[],t.steps=t.steps.map((e=>this.transformStep({step:e})))}transformStep({step:e}){if(Array.isArray(e))throw new Error("Step must be an object.");const[t,n]=Object.entries(e)[0];if(n.hasOwnProperty("onerror")){const{onerror:o,...i}=n;e[t]={try:i,except:o}}if(e[t].hasOwnProperty("steps")){const n=e[t].steps;if(!Array.isArray(n))throw new Error("Steps must be an array.");e[t].steps=n.map((e=>this.transformStep({step:e})))}return e}async initNodeTree({workflow:e}){const t=Object.keys(e),n={definition:e,name:void 0,type:"root",parent:void 0,childs:[],blockAutoJumpToParent:!0,blockAutoJumpToSibling:!0,index:0,depth:0,context:{libs:[],atom:this.#n}};t.forEach((t=>{const o={name:t,type:"main"===t?"workflow":"subworkflow",childs:[],parent:n,definition:e[t],index:n.childs.length,depth:n.depth+1,context:{},blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1};n.childs.push(o)}));for await(const e of n.childs)await this.initNode({node:e});return n}async initNode({node:e}){const t={...this.#v,node:e};if(e.workflow=e.parent.workflow||e,e.depth=e.parent.depth+1,await Wo.hits(t))await Wo.init(t);else if(await Go.hits(t))await Go.init(t);else if(await Ho.hits(t))await Ho.init(t);else if(await Jo.hits(t))await Jo.init(t);else if(await Vo.hits(t))await Vo.init(t);else if(await Ko.hits(t))await Ko.init(t);else if(await Xo.hits(t))await Xo.init(t);else if(await Yo.hits(t))await Yo.init(t);else if(await Zo.hits(t))await Zo.init(t);else if(await Qo.hits(t))await Qo.init(t);else if(await ei.hits(t))await ei.init(t);else if(await ti.hits(t))await ti.init(t);else if(await ri.hits(t))await ri.init(t);else if(await ci.hits(t))await ci.init(t);else if(await oi.hits(t))await oi.init(t);else if(await ii.hits(t))await ii.init(t);else if(await si.hits(t))await si.init(t);else if(await ni.hits(t))await ni.init(t);else{if(!await ai.hits(t))throw new Error("Undefined step type.");await ai.init(t)}}async initNodeTreeIndex({root:e}){const t={};e.indexKey="/";for await(const n of e.childs)await this.initNodeIndex({node:n,index:t});return e.context.index=t,t}async initNodeIndex({node:e,index:t}){const n=po.join(e.parent.indexKey,e.name);e.indexKey=n,t[n]=e;const o=[];let i=e;for(;i?.parent;)o.push(i.index),i=i.parent;o.reverse(),e.codeKey=`B_${o.join("_")}_${e.type}`,e.pathKey=`${o.join(".")}`,e.typeId=go(24);for await(const n of e.childs)await this.initNodeIndex({node:n,index:t})}async initNodeCalls({root:e}){const t=e.context.index,n=[];for await(const e of Object.keys(t)){const o=t[e];"call"===o.type&&n.push(o)}return e.context.calls=n,n}async initNodeCallLibs({root:e}){const t=[],n=e.context.calls;for await(const e of n){const n=e.definition.call,o=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:n,type:"atom"},i=t.find((e=>e.name===o.name&&e.type===o.type));i||t.push(o),e.target=i||o}return e.context.callLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeCallTarget({refNode:e,curNode:t}){if(!t)return;const n=e.definition.call,o=t.childs.find((e=>e.name===n&&"subworkflow"===e.type));return o||await this.findNodeCallTarget({refNode:e,curNode:t.parent})}async initNodeForms({root:e}){const t=e.context.index,n=[];for await(const e of Object.keys(t)){const o=t[e];"form"===o.type&&n.push(o)}return e.context.forms=n,n}async initNodeFormLibs({root:e}){const t=[],n=e.context.forms;for await(const e of n){const n=e.definition.form,o=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:n,type:"atom"},i=t.find((e=>e.name===o.name&&e.type===o.type));i||t.push(o),e.target=i||o}return e.context.formLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeFormTarget({refNode:e,curNode:t}){if(!t)return;const n=e.definition.form,o=t.childs.find((e=>e.name===n&&"subworkflow"===e.type));return o||await this.findNodeFormTarget({refNode:e,curNode:t.parent})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const n=e.filter((e=>"atom"===e.type));for(let e=0;e<n.length;e++){const o=n[e],i=await this.findAtomLibrary({url:o.name});o.atom=i;const a=i.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));a?.forEach((e=>{const n=t.find((t=>t.package===e.package));n?"string"==typeof e.path?(n.path||[]).some((t=>t===e.path))||(n.path=n.path||[],n.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(n.path||[]).some((t=>t===e))||(n.path=n.path||[],n.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const t=Mo({url:e});if(!t)throw new Error(`Invalid package name: ${e}`);if(t.protocol||(t.protocol=this.#f),"ac:"===t.protocol){const n=t.pathname.split("/");if(1===n.length)return await No.first({where:{name:e,parent_id:this.#m.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===n.length){const e=await No.first({where:{name:n[0],parent_id:this.#m.env.ATOM_LIBRARIES_ID,type:"folder"}});return await No.first({where:{name:n[1],parent_id:e.id,type:"workflow.lib"}})}}else{if("local:"===t.protocol){const e=po.resolve(this.#t.projectSrcDir,`${t.pathname}.js`),n=[],o=await Uo({file:e,recursive:!0}),i=!0===this.#n.doc.features.all_parsed_imports?o.all:o.required;for await(const e of i){if("npm"!==e.type)continue;if(n.find((t=>t.package===e.package)))continue;const t=(await Ro({name:e.package,groupBy:{minor:!0}}))[0][0];n.push({package:e.package,subpath:e.subpath,version:`^${t}`,type:"npm"})}return{name:t.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:n},protocol:t.protocol}}if("npm:"===t.protocol){const e=(await Ro({name:t.pathname,groupBy:{minor:!0}}))[0][0];return{name:t.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:[{package:t.pathname,version:`^${e}`,type:"npm"}]},protocol:t.protocol}}}}async resolveNodeTree({root:e}){for await(const t of e.childs)await this.resolveTypeWorkflow({node:t})}async resolveTypeWorkflow({node:e}){e.context.transform=ho(e.definition);const t=e.context.transform;for(let e=0;e<t.params?.length;e++){const n=t.params[e];if("string"==typeof n)t.params[e]={key:n,hasDefault:!1};else{const o=Object.keys(n)[0];t.params[e]={key:o,hasDefault:!0,default:n[o]}}}e.context.next=e.childs[0];for await(const t of e.childs)await this.resolveType({node:t})}async resolveType({node:e}){const t={...this.#v,node:e};"function"==typeof e.resolve&&await e.resolve(t);for await(const t of e.childs)await this.resolveType({node:t})}async resolveTypeCommon({node:e}){const t=e.context.transform;t.hasOwnProperty("operation")&&(t.operation=await this.transformExpression(t.operation)),t.hasOwnProperty("page")&&(t.page=await this.transformExpression(t.page)),t.hasOwnProperty("print")&&(t.print=await this.transformExpression(t.print)),t.hasOwnProperty("sleep")&&(t.sleep=await this.transformExpression(t.sleep)),t.hasOwnProperty("assert")&&(t.assert=await this.transformExpression(t.assert))}async createAtomLibFiles({root:e}){await this.setInProgress({message:"Creating external lib files."}),this.#n.typesDir="./types";const t=e.context.libs.filter((e=>"atom"===e.type));for(let e=0;e<t.length;e++){const n=t[e].atom,o=this.#t.projectDir;if("local:"===n.protocol){const e=po.resolve(this.#t.projectSrcDir,`${n.fileName||n.name}.js`),t=po.relative(`${this.#t.projectDir}/src/default/blocks`,e);if(!lo.existsSync(e)){lo.mkdirSync(po.dirname(e),{recursive:!0});let t="export default async (args)=>{\n";t+="}",lo.writeFileSync(e,t,"utf8")}n.relativePath=t.split(po.sep).join("/"),this.#n.typesDir=`./types/${po.basename(o)}/src`}else if("npm:"===n.protocol)n.relativePath=n.name;else{const e=`${o}/src/libs/${n.id}.js`,t=n.doc.contents?.find((e=>"esm"===e.format))||n.doc;lo.writeFileSync(po.normalize(e),t.content,"utf8")}}}async createEngine({root:e}){await this.setInProgress({message:"Creating engine file."});const t=this.#t.templateDir,n=uo.compile(lo.readFileSync(po.resolve(t,"src/default/engine.js.njk"),"utf8"),this.#i).render({...e,ui:{package:"@flownet/react-app"}}),o=this.#t.projectDir,i=po.resolve(o,"src/default/index.js");lo.writeFileSync(i,n,"utf8")}async createNodeTree({root:e}){await this.setInProgress({message:"Creating block files."});for await(const t of e.childs)await this.createTypeWorkflow({node:t})}async createTypeWorkflow({node:e}){const t=this.#t.templateDir,n=uo.compile(lo.readFileSync(po.resolve(t,"src/default/workflow.js.njk"),"utf8"),this.#i).render(e),o=this.#t.projectDir,i=po.resolve(o,`src/default/${e.codeKey}.js`);lo.writeFileSync(i,n,"utf8");for await(const t of e.childs)await this.createType({node:t})}async createType({node:e}){switch(e.type){case"assign":case"steps":case"return":case"call":case"form":case"raise":case"switch":case"jump":case"tryexcept":case"for":case"operation":this.createBlockFromTemplate({node:e})}for await(const t of e.childs)await this.createType({node:t})}createBlockFromTemplate({node:e}){const t=this.getBlockTemplate({node:e});e.context.render=t.render(e),this.createStepFile({node:e})}getBlockTemplate({node:e}){let t=this.#r[e.type];if(t)return t;const n=this.#t.templateDir;return t=uo.compile(lo.readFileSync(po.resolve(n,`src/default/blocks/${e.type}.js.njk`),"utf8"),this.#i),this.#r[e.type]=t,t}createStepFile({node:e}){const t=this.#t.projectDir,n=`${e.codeKey}.js`,o=po.resolve(t,`src/default/blocks/${n}`);lo.writeFileSync(o,e.context.render,"utf8"),e.context.fileName=n,e.context.filePath=o}async transformExpression(e){let t=await this.transformValue(e);return t=JSON.stringify(t),t=this.replaceSpecialPattern(t),t}async transformValue(e){if(Array.isArray(e))for(let t=0;t<e.length;t++)e[t]=await this.transformValue(e[t]);else if(wo(e)){const t=Object.keys(e);for(let n=0;n<t.length;n++)e[t[n]]=await this.transformValue(e[t[n]])}else if("string"==typeof e){const t=await Bo({expression:e});if(t){const{processor:n,statement:o}=t;switch(n){case"v":e=`$::v.${o}::`;break;case"e":e=`$::${o}::`;break;case"m":e=`$::closure.module['${o}']::`;break;case"f":e=`$::closure.form.${o}::`;break;case"for":e=`$::caller.for.${o}::`}}}return e}replaceSpecialPattern(e){return e.replace(/"\$::(.*?)::"/g,"$1")}replaceExpressionLegacy(e){return e.replaceAll(/(?<outer>"\${(?<inner>[^{]*)}")/g,"$2")}async createProjectYaml(){const e="flow.yaml",t=`Creating ${e}`;await this.setInProgress({message:t});const{content:n,...o}=this.#n.doc,i={content:fo.stringify(o)},a=this.#t.templateDir,s=uo.compile(lo.readFileSync(po.resolve(a,`${e}.njk`),"utf8"),this.#i).render(i),r=this.#t.projectDir,c=po.resolve(r,`${e}`);lo.writeFileSync(c,s,"utf8")}async createProjectMainYaml(){const e="flow.main.yaml",t=`Creating ${e}`;await this.setInProgress({message:t});const n={content:fo.stringify(this.#o)},o=this.#t.templateDir,i=uo.compile(lo.readFileSync(po.resolve(o,`${e}.njk`),"utf8"),this.#i).render(n),a=this.#t.projectDir,s=po.resolve(a,`${e}`);lo.writeFileSync(s,i,"utf8")}async runPrettifier(){const e=this.#t.projectDir,t=mo.exec("prettier --write .",{cwd:po.resolve(e,"src")});if(0!==t.code)throw new Error(t.stderr)}async deploy(){if(await this.setInProgress({message:"Deploying."}),this.#t.project?.devops){const e=[this.#t.project?.devops];for(let t=0;t<e.length;t++){let n=e[t];await this.deployProject({deploymentProject:n}),!0===n.isDirty&&await n.save()}}else if(this.#n.id){const e=await No.list({type:"workflow.deploy",parent_id:this.#n.id});for(let t=0;t<e.length;t++){let n=e[t];await this.deployProject({deploymentProject:n}),!0===n.isDirty&&(n=await No.update(n,{id:n.id}))}}}async deployProject(e){const{deploymentProject:t}=e,n=t.doc.targets;for(let e=0;e<n.length;e++){const o=n[e];await Co({...this.#b,deploymentProject:t,deploymentProjectTarget:o})}}async registerToPackageManager(e){const{target:t,packageJSON:n}=e;if(!this.#t.id)return;let o=await No.first({name:t.params.name,parent_id:this.#m.env.ATOM_PACKAGES_ID});o?(o.doc.versions.splice(0,0,{v:n.version}),await No.update(o,{id:o.id})):o=await No.create({parent_id:this.#m.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:n.version}]}})}async setInProgress({message:e}){console.log(zo.blue(e)),await this._cache_set(this.#d,{status:"IN_PROGRESS",message:e})}async build(){if(this.#g&&!this.#h)return await this.createNetwork();try{const e=this.#g?await Fo({root:this.#l}):void 0;if(this.#h){if(await this.initWorkflowDir(),await this.initNunjucks(),this.#g){const t=this.#t.project?.projectDir||this.#t.projectDir;lo.writeFileSync(po.resolve(t,"./flow.bpmn"),e.diagramXML,"utf8")}await this.createAtomLibFiles({root:this.#l}),await this.createEngine({root:this.#l}),await this.createNodeTree({root:this.#l}),await this.createProjectYaml(),await this.createProjectMainYaml(),await To(this.#b),await Ao(this.#b),await So(this.#b),await Po(this.#b),await jo(this.#b),await xo(this.#b),await Do(this.#b),await ko(this.#b),await Eo(this.#b),await $o(this.#b),this.#w&&(await Io(this.#b),await Oo(this.#b),this.#y&&await this.deploy())}await this._cache_set(this.#d,{status:"COMPLETED",data:{network:e}})}catch(e){throw await this._cache_set(this.#d,{status:"FAILED",message:e.message||e}),e}}async createNetwork(){try{const e=await Fo({root:this.#l});await this._cache_set(this.#d,{status:"COMPLETED",data:{...e}})}catch(e){throw await this._cache_set(this.#d,{status:"FAILED",message:e.message||e}),e}}};const di=d,fi=f;var mi=function({baseDir:e=__dirname}){let t=e;for(;t!==fi.parse(t).root;){const e=fi.join(t,"node_modules");if(di.existsSync(e))return e;t=fi.dirname(t)}return null};const ui=process.cwd(),{spawn:hi}=e;t({name:["redis"],dir:ui,optional:!0});const wi=n,yi=o,{hideBin:gi}=i,bi=a,vi=s,_i=r,xi=c,ki=t,ji=l,Di=p,Pi=pi,Si=mi({baseDir:__dirname}),Ai="win32"===process.platform?";":":";process.env.PATH=`${wi.join(Si,"/.bin")}${Ai}${process.env.PATH}`;let Ti=yi(gi(process.argv)).command("create","Initialize flow node project",(e=>e.option("name",{type:"string"}).option("vscode",{type:"boolean",default:!0,alias:"vs"})),(async e=>{try{const t=wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/project"),n=wi.resolve(ui,e.name);bi.existsSync(n)||bi.mkdirSync(n),await Di({dir:t,outDir:n,context:e,copyUnmatchedAlso:!0});let o=_i.exec("fnet build",{cwd:n});if(0!==o.code)throw new Error("Failed to build project.");if(_i.which("git")&&(o=_i.exec("git init",{cwd:n}),0!==o.code))throw new Error("Failed to initialize git.");if(_i.which("code")&&e.vscode&&(o=_i.exec(`cd ${n} && code .`),0!==o.code))throw new Error("Failed to open vscode.");console.log("Creating project succeeded!"),process.exit(0)}catch(e){console.error("Initialization failed!",e.message),process.exit(1)}})).command("project","Flow node project",(e=>e.option("update",{type:"boolean",default:!1,alias:"-u"})),(async e=>{try{const t=wi.resolve(Si,"@fnet/cli-project-flow/dist/template/project"),n=process.cwd();if(e.name=wi.basename(n),e.update){if(await Di({dir:t,outDir:n,context:e,copyUnmatchedAlso:!0}),0!==_i.exec("fnet build",{cwd:n}).code)throw new Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(e){console.error("Project failed.",e.message),process.exit(1)}})).command("build","Build flownet project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("mode",{type:"string",alias:"m",default:"build",choices:["all","file","build","deploy","bpmn"]})),(async e=>{try{const t=await $i(e),n=new Pi(t);await n.init(),await n.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}})).command("deploy","Build and deploy flownet project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"})),(async e=>{try{const t=await $i({...e,mode:"all"}),n=new Pi(t);await n.init(),await n.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}})).command("file","Just create files",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"})),(async e=>{try{const t=await $i({...e,mode:"file"}),n=new Pi(t);await n.init(),await n.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}));function Ei(e,{name:t,bin:n,preArgs:o=[]}){return e.command(`${t||n} [commands..]`,`${n} ${o.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await $i(e),{projectDir:i}=t,a=process.argv.slice(3);hi(n,[...o,...a],{cwd:i,stdio:"inherit",shell:!0}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}async function $i(e){if(e.id){return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",projectDir:wi.resolve(ui,`./.output/${e.id}`),templateDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/default"),templateCommonDir:wi.resolve(Si,"./@fnet/cli-project-common/dist/template/default"),coreDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/core")}}{const t=await async function(){const e=wi.resolve(ui,"flow.yaml");if(!bi.existsSync(e))throw new Error("flow.yaml file not found in current directory.");const t=bi.readFileSync(e,"utf8"),{parsed:n}=await xi({content:t}),o=wi.dirname(e),i=n.main||"flow.main.yaml";let a=wi.resolve(o,i);if(!bi.existsSync(a)&&(a=wi.resolve(o,i+".yaml"),!bi.existsSync(a)))throw new Error(`${i} file not found in ${a}.`);const s=bi.readFileSync(a,"utf8"),{parsed:r}=await xi({content:s}),c={workflowAtom:{doc:{...n,"content-type":"yaml",content:s}},projectDir:o,projectFilePath:e,projectFileContent:t,projectFileParsed:n,projectMainFilePath:a,projectMainFileContent:s,projectMainFileParsed:r},l=wi.resolve(o,"flow.devops.yaml");if(bi.existsSync(l)){const e=bi.readFileSync(l,"utf8"),t=vi.parse(e);c.devops={filePath:l,fileContent:e,doc:{...t},type:"workflow.deploy",save:async()=>{bi.writeFileSync(c.devops.filePath,vi.stringify(c.devops.doc))}}}const p=wi.resolve(o,"readme.md");if(bi.existsSync(p)){const e=bi.readFileSync(p,"utf8");c.readme={filePath:p,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return c}();return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/default"),templateCommonDir:wi.resolve(Si,"./@fnet/cli-project-common/dist/template/default"),coreDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/core"),projectDir:wi.resolve(t.projectDir,"./.workspace"),projectSrcDir:wi.resolve(t.projectDir,"./src"),project:t}}}Ti=Ti.command("config create <name>","Create a config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $i(e),{project:n}=t,{projectDir:o,projectFileParsed:i}=n,a=i.config;if(!a)throw new Error("Config schema not found in project file.");const s=await ji({schema:a}),r=wi.resolve(o,".fnet");bi.existsSync(r)||bi.mkdirSync(r);const c=wi.resolve(r,`${e.name}.fnet`);bi.writeFileSync(c,vi.stringify(s))}catch(e){console.error(e.message),process.exit(1)}})),Ti=Ei(Ti,{bin:"npm"}),Ti=Ei(Ti,{bin:"node"}),Ti=Ei(Ti,{name:"serve",bin:"npm",preArgs:["run","serve","--"]}),Ti=Ei(Ti,{name:"watch",bin:"npm",preArgs:["run","watch","--"]}),Ti=Ei(Ti,{name:"app",bin:"npm",preArgs:["run","app","--"]}),Ti=Ei(Ti,{name:"cli",bin:"npm",preArgs:["run","cli","--"]}),Ti=Ei(Ti,{bin:"npx"}),Ti=Ei(Ti,{bin:"cdk"}),Ti=Ei(Ti,{bin:"aws"}),Ti=function(e,{name:t,preArgs:n=[]}){return e.command(`${t} <config> <command> [options..]`,"Run a command with a config context",(e=>e.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $i(e),{projectDir:o}=t,i=e.config,a=await ki({name:i,dir:o,transferEnv:!1,optional:!0}),s=a?.data?.env||void 0,r=e.command,c=process.argv.slice(5);hi(r,[...n,...c],{cwd:o,stdio:"inherit",shell:!0,env:{...process.env,...s}}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}(Ti,{name:"with"}),Ti.demandCommand(1,"You need at least one command before moving on").help().argv,module.exports={};
|
|
2
|
+
"use strict";var e=require("child_process"),t=require("@fnet/config"),n=require("path"),o=require("yargs/yargs"),i=require("yargs/helpers"),a=require("fs"),s=require("yaml"),r=require("shelljs"),c=require("@fnet/yaml"),l=require("@fnet/object-from-schema"),p=require("@flownet/lib-render-templates-dir"),d=require("node:fs"),f=require("node:path"),m=require("nunjucks"),u=require("lodash.clonedeep"),h=require("isobject"),w=require("redis"),g=require("@flownet/lib-is-redis-online"),y=require("nanoid"),b=require("@flownet/lib-atom-api-js"),v=require("axios"),_=require("qs"),x=require("lodash.merge"),k=require("@flownet/lib-parse-imports-js"),j=require("@flownet/lib-list-npm-versions"),D=require("@fnet/yargs-options-from-schema"),P=require("@fnet/shell"),S=require("semver"),A=require("node:os"),T=require("@node-red/util"),E=require("@flownet/lib-to-ios-app"),$=require("@flownet/lib-to-macos-app"),I=require("@flownet/lib-to-electron"),O=require("@flownet/lib-to-webos"),C=require("@flownet/lib-to-nextjs"),N=require("@flownet/lib-to-docker"),M=require("form-data"),R=require("@fnet/to-rust"),F=require("@flownet/lib-parse-node-url"),q=require("@flownet/lib-bpmn-from-flow"),U=require("@fnet/expression"),B=require("chalk"),L=require("lodash.pick"),z=require("lodash.omit");const J=w,W=g;const{Api:K}=b,G=v.default,H=_;const V=x,X=d,Y=f,Z=k;function Q({dir:e,name:t="index"}){let n=Y.resolve(e,`./${t}.tsx`);if(X.existsSync(n)||(n=Y.resolve(e,`./${t}.ts`)),X.existsSync(n)||(n=Y.resolve(e,`./${t}.jsx`)),X.existsSync(n)||(n=Y.resolve(e,`./${t}.js`)),!X.existsSync(n))return{};const o=n,i=Y.extname(n);return{file:o,ext:i,ts:".ts"===i||".tsx"===i,name:t}}const ee=j;const te=d,ne=f,oe=p;const ie=m,ae=d,se=f,re=k,ce=j;const le=d,pe=f,de=p;const fe=d,me=f,ue=m,he=k;const we=d,ge=f,ye=m,be=D;const ve=d,_e=f,xe=m;const ke=d,je=f,De=m;const Pe=m,Se=d,Ae=f;const Te=r,Ee=n;const $e=r;const Ie=r;const Oe=r;const Ce=P,Ne=t;const Me=d,Re=f,Fe=S,qe=P,Ue=t;const Be=d,Le=f,ze=S,Je=r,We=t;const Ke=d,Ge=f,He=A,Ve=m,Xe=T,Ye=t;const Ze=a,Qe=n,et=t;const tt=t,nt=E,ot=u,it=S;const at=t,st=$,rt=u,ct=S;const lt=t,pt=I,dt=u,ft=S;const mt=t,ut=O,ht=u,wt=S;const gt=t,yt=C,bt=u,vt=S;const _t=t,xt=N,kt=u,jt=S;const Dt=d,Pt=f,St=S,At=P,Tt=t,Et=v.default;const $t=S,It=t,Ot=v.default;const Ct=S,Nt=t,Mt=v.default,Rt=a,Ft=P,qt=M;const Ut=S,Bt=t,Lt=v.default,zt=a,Jt=P,Wt=M;const Kt=t,Gt=R,Ht=u,Vt=S;const Xt=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o,buildId:i})=>{await e({message:"Deploying it as gitlab project."});const a=t.projectDir;let s="fnet-to-gitlab";const r=o.params.config||"gitlab",c=await Ne({name:r,dir:t.projectDir});if(!c)throw new Error(`Couldnt load config ${r}`);const{data:l}=c.data;s+=` --projectGroupId=${l.projectGroupId}`,s+=` --projectPath='${a}'`,s+=` --projectName='${o.params.name}'`,s+=` --projectBranch='${o.params.branch||"main"}'`,s+=` --gitlabHost='${l.gitlabHost}'`,s+=` --gitlabToken='${l.gitlabToken}'`,s+=` --gitlabUsername='${l.gitlabUsername}'`,s+=` --gitlabUserEmail='${l.gitlabUserEmail}'`,!0!==o.dryRun&&(await Ce({cmd:s}),n.isDirty=!0)},Yt=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o,registerToPackageManager:i})=>{await e({message:"Deploying it as gcs package."});const a=t.projectDir,s=Re.resolve(a,"package.json"),r=Me.readFileSync(s),c=JSON.parse(r);c.name=o.params.name,c.version=Fe.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,Me.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Ue({name:o.config||"gcs",dir:t.projectDir});let d="fnet-files-to-gcs";d+=` --projectId='${p.env.GCS_PROJECT_ID}'`,d+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,d+=` --keyFilename='${Re.resolve(Re.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,d+=` --dir='${a}'`,d+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",d+=` --destDir='${c.name}/${c.version}'`,d+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(d+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(d+=" --dryRun"),await qe({cmd:d}),Me.writeFileSync(s,r),!0!==o.dryRun&&(n.isDirty=!0,o.params.version=c.version,await i({target:o,packageJSON:c}))},Zt=async({atom:e,setInProgress:t,context:n,deploymentProject:o,deploymentProjectTarget:i})=>{await t({message:"Deploying it as npm package."});const a=n.projectDir,s=Le.resolve(a,"package.json"),r=Be.readFileSync(s),c=JSON.parse(r);c.name=i.params.name,c.version=ze.inc(i.params.version,"patch");const l=i.params.bin?.name||i.params.bin;!1!==i.params.bin?.enabled&&l&&"string"==typeof l&&(c.bin={[l]:"dist/cli/esm/index.js",[e.doc.name]:"dist/cli/esm/index.js"}),delete c.scripts,delete c.devDependencies,c.scripts={serve:"npx serve ."},Be.writeFileSync(s,JSON.stringify(c,null,"\t"));const p=(await We({name:n.npmConfig||"npm",dir:n.projectDir}))?.data;if(Be.writeFileSync(Le.resolve(a,".npmrc"),`//registry.npmjs.org/:_authToken=${p.env.NPM_TOKEN}`),!0===i.dryRun)return;if(0!==Je.exec("npm publish --access public",{cwd:a}).code)throw new Error("Couldnt publish to npm");Be.writeFileSync(s,r),o.isDirty=!0,i.params.version=c.version},Qt=async({atom:e,setInProgress:t,context:n,deploymentProject:o,deploymentProjectTarget:i,buildId:a,packageDependencies:s,njEnv:r})=>{await t({message:"Deploying it as node-red flow."});const c=n.projectDir,l=n.templateDir,p="workflow"===e.type?"WF":"LIB";let d;if("simple"===i.deploy.template)d={atom:e,packageDependencies:s,red:{tab:{id:i.deploy.id||Xe.util.generateId(),label:`${p}/${e.id?e.id:He.hostname()}/${e.name}/${i.deploy.name||i.deploy.template}`},function:{id:Xe.util.generateId(),name:e.doc.name,initialize:{content:Ke.readFileSync(Ge.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},inject:{id:Xe.util.generateId(),...i.params?.inject,payload:"json"===i.params?.inject?.payloadType?`'${JSON.stringify(i.params?.inject?.payload)}'`:i.params?.inject?.payload},debug:{id:Xe.util.generateId()}}};else if("cronjob"===i.deploy.template){let t=i.params?.schedules?cloneDeep(i.params?.schedules):void 0;t?.forEach((e=>{"json"===e.payloadType&&(e.payload=`'${JSON.stringify(e.payload)}'`)})),d={atom:e,packageDependencies:s,red:{tab:{id:i.deploy.id||Xe.util.generateId(),label:`${p}/${e.id?e.id:He.hostname()}/${i.deploy.name||i.deploy.template}`},function:{id:Xe.util.generateId(),name:e.doc.name,initialize:{content:Ke.readFileSync(Ge.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},cronjob:{id:Xe.util.generateId(),schedules:t},debug:{id:Xe.util.generateId()}}}}else{if("http"!==i.deploy.template)return;d={atom:e,packageDependencies:s,red:{tab:{id:i.deploy.id||Xe.util.generateId(),label:`${p}/${e.id?e.id:He.hostname()}/${i.deploy.name||i.deploy.template}`},function:{id:Xe.util.generateId(),name:e.doc.name,initialize:{content:Ke.readFileSync(Ge.resolve(c,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:e.doc.bundleName}},httpin:{id:Xe.util.generateId(),method:i.params.method||"get",url:i.params.url},httpout:{id:Xe.util.generateId()},debug:{id:Xe.util.generateId()}}}}let f=Ve.compile(Ke.readFileSync(Ge.resolve(l,`deploy/node-red/${i.deploy.template}.yaml.njk`),"utf8"),r).render(d);if(Ke.writeFileSync(Ge.resolve(c,"node-red.yaml"),f),f=yaml.load(f),!0===i.dryRun)return;o.isDirty=!0;const m=(await Ye({name:n.redConfig||"red",dir:n.projectDir}))?.data,u=i.deploy.url||m.env.RED_URL,h={};if(!1!==i.deploy.auth&&(h.Authorization="Bearer "+atomAccessToken),i.deploy.id)!0===i.actions?.delete?(await axios({method:"DELETE",url:`${u}/flow/${i.deploy.id}`,headers:h}),delete i.actions.delete,delete i.deploy.id,i.enabled=!1):await axios({method:"PUT",url:`${u}/flow/${i.deploy.id}`,data:f,headers:h});else{const e=await axios({method:"POST",url:`${u}/flow`,data:f,headers:h});i.deploy.id=e.data.id}},en=async({atom:e,Atom:t,setInProgress:n,context:o,packageDependencies:i,deploymentProject:a,deploymentProjectTarget:s})=>{await n({message:"Deploying it as workflow lib."});const r=(await et({name:"atom",dir:o.projectDir}))?.data;let c,l,p,d=s.deploy.name.split("/");if(1===d.length)l=r.env.ATOM_LIBRARIES_ID,p=s.deploy.name;else{if(2!==d.length)throw new Error("Wrong name path.");{const e=await t.first({where:{name:d[0],parent_id:r.env.ATOM_LIBRARIES_ID,type:"folder"},limit:1});if(!e)throw new Error("Couldnt file lib folder.");l=e.id,p=d[1]}}if(!0===s.dryRun)return;if(a.isDirty=!0,s.deploy.id){if(c=await t.get({id:s.deploy.id}),!c)return}else{if(c=await t.create({parent_id:l,doc:{name:p,type:"workflow.lib","content-type":"javascript",dependencies:[],content:void 0,subtype:"workflow"}}),!c)return;s.deploy.id=c.id}const f=o.projectDir;c.doc.contents=[{content:Ze.readFileSync(Qe.resolve(f,"dist/default/esm/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"esm"},{content:Ze.readFileSync(Qe.resolve(f,"dist/default/cjs/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"cjs"},{content:Ze.readFileSync(Qe.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"iife"}],c.doc.name=p,c.doc.dependencies=i,"workflow.lib"===e.type?c.doc.subtype="library":"workflow"===e.type&&(c.doc.subtype="workflow"),c=await t.update(c,{id:c.id})},tn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as ios-app package."});const a=t?.config?await tt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=it.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=ot(t.params);r.dependencies=ot(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await nt(c)}},nn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as macos-app package."});const a=t?.config?await at({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=ct.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=rt(t.params);r.dependencies=rt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await st(c)}},on=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as electron package."});const a=t?.config?await lt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=ft.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=dt(t.params);r.dependencies=dt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await pt(c)}},an=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as webos package."});const a=t?.config?await mt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=wt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=ht(t.params);r.dependencies=ht(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await ut(c)}},sn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as nextjs package."});const a=t?.config?await gt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=vt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=bt(t.params);r.dependencies=bt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await yt(c)}},rn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as docker package."});const a=t?.config?await _t({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=jt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=kt(t.params);r.dependencies=kt(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await xt(c)}},cn=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o,registerToPackageManager:i})=>{await e({message:"Deploying it as fnet package."});const a=t.projectDir,s=Pt.resolve(a,"package.json"),r=Dt.readFileSync(s),c=JSON.parse(r);c.name=o.params.name,c.version=St.inc(o.params.version,"patch"),delete c.scripts,delete c.devDependencies,Dt.writeFileSync(s,JSON.stringify(c,null,"\t"));const{file:l,data:p}=await Tt({name:o.config||"fnet-package",dir:t.projectDir});if(!p.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${l}`);if(!p.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${l}`);if(!p.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${l}`);const d=`${p.env.ATOM_API_URL}/v1/auth/token`,f=p.env.ATOM_API_USERNAME,m=p.env.ATOM_API_PASSWORD;let u=await Et({method:"POST",url:d,data:{username:f,password:m},headers:{"Content-Type":"application/json"}});const h=u.data?.access_token;if(!h)throw new Error(`Invalid access_token from ${d}`);let w="fnet-files-to-gcs";if(w+=` --projectId='${p.env.GCS_PROJECT_ID}'`,w+=` --bucketName='${p.env.GCS_BUCKET_NAME}'`,w+=` --keyFilename='${Pt.resolve(Pt.dirname(l),p.env.GCS_UPLOADER_KEY_FILE)}'`,w+=` --dir='${a}'`,w+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",w+=` --destDir='${c.name}/${c.version}'`,w+=" --metadata.cacheControl='public, max-age=31536000, immutable'",p.env.DOMAIN&&(w+=` --domain='${p.env.DOMAIN}'`),!0!==o.dry_run&&!0!==o.params.dry_run||(w+=" --dryRun"),await At({cmd:w}),Dt.writeFileSync(s,r),!0===o.dryRun)return;n.isDirty=!0,o.params.version=c.version;const g=`${p.env.ATOM_API_URL}/v1/service/fnet-package/publish`;if(u=await Et({method:"POST",url:g,data:{name:c.name,version:c.version,version_domain:p.env.DOMAIN,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${h}`}}),u.data?.error)throw new Error("Failed to publish fnet package.")},ln=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet form."});const i=$t.inc(o.params.version,"patch"),{file:a,data:s}=await It({name:o.config||"fnet-form",dir:t.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${a}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${a}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${a}`);const r=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Ot({method:"POST",url:r,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${r}`);n.isDirty=!0,o.params.version=i;const f=`${s.env.ATOM_API_URL}/v1/service/fnet-form/publish`;if(p=await Ot({method:"POST",url:f,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet form.")},pn=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet flow."});const i=Ct.inc(o.params.version,"patch"),{file:a,data:s}=await Nt({name:o.config||"fnet-flow",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${a}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${a}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${a}`);const r=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Mt({method:"POST",url:r,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${r}`);n.isDirty=!0,o.params.version=i;const f=`${s.env.ATOM_API_URL}/v1/service/fnet-flow/publish`;if(p=await Mt({method:"POST",url:f,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet flow.");const m=p.data?.upload.id;let u="fnet-dir-zipper";u+=` --sourceDir='${t.project.projectDir}'`,u+=" -p=**/*",u+=" -g",u+=" --stdout_format=json";const h=await Ft({cmd:u});if(0!==h.code)throw new Error(h.stderr);const w=JSON.parse(h.stdout).path;let g=new qt;g.append("file",Rt.createReadStream(w));const y=await Mt.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${m}`,headers:{...g.getHeaders(),Authorization:`Bearer ${d}`},data:g});if(y.data?.error)throw new Error("Error uploading fnet flow.")},dn=async({setInProgress:e,context:t,deploymentProject:n,deploymentProjectTarget:o})=>{await e({message:"Deploying it as fnet node."});const i=Ut.inc(o.params.version,"patch"),{file:a,data:s}=await Bt({name:o.config||"fnet-node",dir:t.project.projectDir});if(!s.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${a}`);if(!s.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${a}`);if(!s.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${a}`);const r=`${s.env.ATOM_API_URL}/v1/auth/token`,c=s.env.ATOM_API_USERNAME,l=s.env.ATOM_API_PASSWORD;let p=await Lt({method:"POST",url:r,data:{username:c,password:l},headers:{"Content-Type":"application/json"}});const d=p.data?.access_token;if(!d)throw new Error(`Invalid access_token from ${r}`);n.isDirty=!0,o.params.version=i;const f=`${s.env.ATOM_API_URL}/v1/service/fnet-node/publish`;if(p=await Lt({method:"POST",url:f,data:{name:o.params.name,version:o.params.version,docs:o.params.docs,configs:o.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${d}`}}),p.data?.error)throw new Error("Error publishing fnet node.");const m=p.data?.upload.id;let u="fnet-dir-zipper";u+=` --sourceDir='${t.project.projectDir}'`,u+=" -p=**/*",u+=" -g",u+=" --stdout_format=json";const h=await Jt({cmd:u});if(0!==h.code)throw new Error(h.stderr);const w=JSON.parse(h.stdout).path;let g=new Wt;g.append("file",zt.createReadStream(w));const y=await Lt.request({method:"POST",maxBodyLength:1/0,url:`${s.env.ATOM_API_URL}/v1/service/upload/single/${m}`,headers:{...g.getHeaders(),Authorization:`Bearer ${d}`},data:g});if(y.data?.error)throw new Error("Error uploading fnet node.")},fn=async({atom:e,target:t,onProgress:n,projectDir:o,dependencies:i})=>{n&&await n({message:"Deploying it as Rust package."});const a=t?.config?await Kt({name:t.config,dir:o,optional:!0,transferEnv:!1}):void 0,s=Vt.inc(t.params.version||"0.1.0","patch");t.params.version=s;const r=Ht(t.params);r.dependencies=Ht(i);const c={atom:e,params:r,config:a?.config,src:o,dest:o};return{deployer:await Gt(c)}};const mn=u;async function un({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||mn(e.definition);for(const t of e.childs)t.context.transform=t.context.transform||mn(t.definition),t.definition.hasOwnProperty("condition")&&(t.context.transform.condition=await o(t.definition.condition));await t({node:e}),n({node:e})}var hn={hits:async function({node:e}){if(!e.definition.hasOwnProperty("switch"))return!1;const t=e.definition.switch||[];if(!t.every((e=>e.hasOwnProperty("condition")||e.hasOwnProperty("default"))))throw new Error("Switch must have condition or default");if(0===t.filter((e=>e.hasOwnProperty("condition"))).length)throw new Error("Switch must have at least one condition");const n=t.filter((e=>e.hasOwnProperty("default")));if(n.length>1)throw new Error("Switch must have only one default");if(1===n.length&&!t[t.length-1].hasOwnProperty("default"))throw new Error("Switch default must be the last child");return!0},init:async function({node:e,initNode:t}){e.type="switch",e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0;for(let n=0;n<e.definition.switch.length;n++){let o=e.definition.switch[n],i=`${n}`;o.hasOwnProperty("default")&&(i="default",o=o.default);const a={name:o.condition||i,childs:[],parent:e,definition:o,index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=un},resolve:un};const wn=U,gn=hn;var yn={hits:async function({node:e}){const t=Object.keys(e.definition);return 1===(await Promise.all(t.map((e=>wn({expression:e}))))).filter((e=>"if"===e?.processor)).length},init:async function(e){const{node:t}=e,n=Object.keys(t.definition),o=await Promise.all(n.map((e=>wn({expression:e})))),i=[],a=o.find((e=>"if"===e?.processor)),s=t.definition[a.expression];i.push({name:`${t.name}_if`,definition:s,processor:a}),delete t.definition[a.expression];const r=o.filter((e=>"elseif"===e?.processor));let c=0;for(const e of r){const n=t.definition[e.expression];i.push({name:`${t.name}_elseif_${c++}`,definition:n,processor:e}),delete t.definition[e.expression]}t.definition.switch=[];for(const e of i)t.definition.switch.push({condition:e.processor.statement,...e.definition});await gn.init(e)}};const bn=u;async function vn({node:e,resolveTypeCommon:t,resolveNextBlock:n}){if(e.context.transform=e.context.transform||bn(e.definition),e.context.transform,e.context.try=e.childs.find((e=>"try"===e.name)),e.context.except=e.childs.find((e=>"except"===e.name)),e.context.except){const t=e.context.except;t.context.transform=t.context.transform||bn(t.definition),t.context.transform.hasOwnProperty("as")||(t.context.transform.as="error")}await t({node:e}),n({node:e})}var _n={hits:async function({node:e}){return e.definition.hasOwnProperty("try")&&e.definition.hasOwnProperty("except")},init:async function({node:e,initNode:t}){if(e.type="tryexcept",e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0,e.definition.try){const n="try",o={name:n,childs:[],parent:e,definition:e.definition[n],index:e.childs.length,context:{}};e.childs.push(o),await t({node:o})}if(e.definition.except){const n="except",o={name:n,childs:[],parent:e,definition:e.definition[n],index:e.childs.length,context:{}};e.childs.push(o),await t({node:o})}e.resolve=vn},resolve:vn};const xn=u;async function kn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=xn(e.definition);const i=e.context.transform;for(let e=0;e<i.assign?.length;e++){let t=i.assign[e],n=Object.keys(t)[0],a=t[n],s={key:await o(n),value:await o(a)};i.assign[e]=s}await t({node:e}),n({node:e})}var jn={hits:async function({node:e}){return e.definition.hasOwnProperty("assign")},init:async function({node:e,initNode:t}){e.type="assign",e.resolve=kn},resolve:kn};const Dn=u,Pn=L,Sn=z;async function An({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||Dn(e.definition);e.context.transform.for.in=await o(e.definition.for.in),await t({node:e}),n({node:e})}var Tn={hits:async function({node:e}){return e.definition.hasOwnProperty("for")},init:async function({node:e,initNode:t}){if(e.type="for",e.blockAutoJumpToParent=!0,e.blockAutoJumpToSibling=!1,!e.definition.for.hasOwnProperty("steps")){const t=["value","in"],[n,o]=[Pn(e.definition.for,t),Sn(e.definition.for,t)];e.definition.for=n,e.definition.for.steps=[{[`${e.name}_step`]:o}]}Array.isArray(e.definition.for.steps)||(e.definition.for.steps=[{[`${e.name}_step`]:e.definition.for.steps}]);for(let n=0;n<e.definition.for.steps.length;n++){const o=e.definition.for.steps[n],i=Object.keys(o)[0],a={name:i,childs:[],parent:e,definition:o[i],index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=An},resolve:An};var En={hits:async function({node:e}){return!1},init:async function({node:e,initNode:t}){},resolve:async function({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o,transformValue:i}){}};const $n=u;async function In({node:e,resolveTypeCommon:t,transformExpression:n}){e.context.transform=e.context.transform||$n(e.definition);const o=e.context.transform;o.raise=await n(o.raise),await t({node:e})}var On={hits:async function({node:e}){return e.definition.hasOwnProperty("raise")},init:async function({node:e,initNode:t}){e.type="raise",e.resolve=In},resolve:In};const Cn=u;async function Nn({node:e,resolveTypeCommon:t,transformExpression:n}){e.context.transform=e.context.transform||Cn(e.definition);const o=e.context.transform;o.return=await n(o.return),await t({node:e})}var Mn={hits:async function({node:e}){return e.definition.hasOwnProperty("return")},init:async function({node:e,initNode:t}){e.type="return",e.resolve=Nn},resolve:Nn};const Rn=u;async function Fn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||Rn(e.definition);const i=e.context.transform;i.args&&(i.args=await o(i.args)),i.result&&(i.result=await o(i.result));const a=e.workflow.parent;e.context.lib=a.context.libs.find((e=>e.name===i.call)),await t({node:e}),n({node:e})}var qn={hits:async function({node:e}){return e.definition.hasOwnProperty("call")},init:async function({node:e,initNode:t}){e.type="call";for(let n=0;n<e.definition.modules?.length;n++){const o=e.definition.modules[n],i=Object.keys(o)[0],a={name:i,childs:[],parent:e,definition:o[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=Fn},resolve:Fn};const Un=qn;var Bn={hits:async function({node:e}){return e.definition.hasOwnProperty("shell")},init:async function(e){const{node:t}=e,n="shell",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/shell",o.args="string"===i?{...o.args,cmd:o[n]}:o[n],delete o[n],await Un.init(e)}};const Ln=qn;var zn={hits:async function({node:e}){return e.definition.hasOwnProperty("config")},init:async function(e){const{node:t}=e,n="config",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/config",o.args="string"===i?{...o.args,name:o[n]}:o[n],delete o[n],await Ln.init(e)}};const Jn=qn;var Wn={hits:async function({node:e}){return e.definition.hasOwnProperty("yaml")},init:async function(e){const{node:t}=e,n="yaml",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/yaml",o.args="string"===i?{...o.args,file:o[n]}:o[n],delete o[n],await Jn.init(e)}};async function Kn({node:e}){e.context.next=e.childs[0]}var Gn={hits:async function({node:e}){return e.definition.hasOwnProperty("steps")},init:async function({node:e,initNode:t}){e.type||(e.type="steps");const n=e.definition.steps||[];for await(const o of n){const n=Object.keys(o)[0],i={name:n,childs:[],parent:e,definition:o[n],index:e.childs.length,context:{}};e.childs.push(i),await t({node:i})}e.resolve=Kn},resolve:Kn};const Hn=u;async function Vn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||Hn(e.definition);const i=e.context.transform;i.props&&(i.props=await o(i.props));const a=e.workflow.parent;e.context.lib=a.context.libs.find((e=>e.name===i.form)),await t({node:e}),n({node:e})}var Xn={hits:async function({node:e}){return e.definition.hasOwnProperty("form")},init:async function({node:e,initNode:t}){e.type="form";for(let n=0;n<e.definition.modules?.length;n++){const o=e.definition.modules[n],i=Object.keys(o)[0],a={name:i,childs:[],parent:e,definition:o[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(a),await t({node:a})}e.resolve=Vn},resolve:Vn};const Yn=u;async function Zn({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o,transformValue:i}){e.context.transform=e.context.transform||Yn(e.definition),await t({node:e})}var Qn={hits:async function({node:e}){return e.definition.hasOwnProperty("operation")},init:async function({node:e,initNode:t}){e.type="operation",e.resolve=Zn},resolve:Zn};const eo=u;async function to({node:e,resolveTypeCommon:t,resolveNextBlock:n,transformExpression:o}){e.context.transform=e.context.transform||eo(e.definition);const i=e.context.transform;i.next=await o(i.next),await t({node:e}),n({node:e})}var no={hits:async function({node:e}){return e.definition.hasOwnProperty("next")},init:async function({node:e,initNode:t}){e.type="jump",e.resolve=to},resolve:to};const oo=qn;var io={hits:async function({node:e}){return e.definition.hasOwnProperty("prompt")},init:async function(e){const{node:t}=e,n="prompt",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@fnet/prompt",o.args="string"===i?{...o.args,message:o[n]}:o[n],delete o[n],await oo.init(e)}};const ao=qn;var so={hits:async function({node:e}){return e.definition.hasOwnProperty("html-script")},init:async function(e){const{node:t}=e,n="html-script",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@flownet/lib-load-browser-script-url",o.args="string"===i?{...o.args,src:o[n]}:o[n],delete o[n],await ao.init(e)}};const ro=qn;var co={hits:async function({node:e}){return e.definition.hasOwnProperty("html-link")},init:async function(e){const{node:t}=e,n="html-link",o=t.definition,i=typeof o[n];if("string"!==i&&"object"!==i)throw new Error(`Unsupported ${n} usage`);o.call="npm:@flownet/lib-load-browser-link-url",o.args="string"===i?{...o.args,src:o[n]}:o[n],delete o[n],await ro.init(e)}};const lo=d,po=f,fo=s,mo=r,uo=m,ho=u,wo=h,go=async()=>{if(!await W({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=J.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e},{nanoid:yo}=y,bo=class{init({config:e,accessToken:t}){return new Promise(((n,o)=>{if(K.set_api_url(e.data.url),t)return K.set_req_token(t),void n(t);G({method:"POST",url:`${e.data.issuer}/protocol/openid-connect/token`,data:H.stringify(e.data.grant.params),headers:{"Content-Type":"application/x-www-form-urlencoded"}}).then((e=>{K.set_req_token(e.data.access_token),n(e.data.access_token)})).catch((e=>{K.set_req_token(),o(e)}))}))}},vo=async({atom:e,context:t})=>{e.doc.features=e.doc.features||{};const n=e.doc.features;n.project=n.project||{},n.project.format=n.project.format||n.project_format||"esm",n.project_format=n.project.format,n.dts_enabled=!0===n.dts||void 0!==n.dts&&!1!==n.dts,n.hasOwnProperty("all_parsed_imports")||(n.all_parsed_imports=!0);const o=Y.resolve(t.project.projectDir),i=Q({dir:Y.resolve(o,"./app")});if(i.file){let e=await Z({file:i.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));n.app_uses_jsx=t,n.app_has_entry=!0,e=await Z({file:i.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),n.app_entry_uses_jsx=t,n.app_entry_is_ts=i.ts,n.app_entry_ext=i.ext}const a=Q({dir:Y.resolve(o,"./cli")});if(a.file){let e=await Z({file:a.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));n.cli_uses_jsx=t,n.cli_has_entry=!0,e=await Z({file:a.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),n.cli_entry_uses_jsx=t,n.cli_entry_is_ts=a.ts,n.cli_entry_ext=a.ext}if("workflow.lib"===e.type){const e=Q({dir:Y.resolve(o,"./src")});if(e.file){let t=await Z({file:e.file,recursive:!0}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));n.src_uses_jsx=o,n.src_has_entry=!0,t=await Z({file:e.file}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),n.src_entry_uses_jsx=o,n.src_entry_is_ts=e.ts,n.src_entry_ext=e.ext}}const s=!0===n.src_uses_jsx,r=!0===n.src_uses_jsx;n.form_enabled=!0===e.doc.form||!0===e.doc.form?.enabled||!0===n.form||!0===n.form?.enabled,n.multiple_enabled=n.multiple_enabled||!0===n.multiple||!0===n.multiple?.enabled,!1===n.app?n.app={enabled:!1}:!0===n.app?n.app={enabled:!0,extend:!0===n.app_has_entry,export:!0,react:s}:n.app={enabled:!0,extend:!0===n.app_has_entry,export:!0,react:s,...n.app||{}},n.app.enabled=!0===n.app.enabled&&(!0===e.doc.features.form_enabled||!0===n.app.extend||!0===n.app.enabled),n.app.format=n.app.format||"esm",n.app.folder=n.app.folder||n.app.format||"default",!1===n.cli?n.cli={enabled:!1}:!0===n.cli?n.cli={enabled:!0,extend:!0===n.cli_has_entry,export:!0,react:r}:n.cli={enabled:!0,extend:!0===n.cli_has_entry,export:!0,react:r,...n.cli||{}},n.cli.enabled=!0===n.cli.enabled&&(!1===e.doc.features.form_enabled||!0===n.cli.extend||!0===n.cli.enabled),n.cli.format=n.cli.format||"esm",n.cli.folder=n.cli.folder||n.cli.folder||"esm",n.cli.node_options=n.cli.node?.options||n.cli.node_options||"";const c={cjs:{format:"cjs",context:n.form_enabled?"window":"global",babel:!0===n.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!0,string:!0},cjsx:{format:"cjs",context:n.form_enabled?"window":"global",babel:!0===n.src_uses_jsx||!1,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0},esm:{format:"esm",context:n.form_enabled?"window":"global",babel:!0===n.src_uses_jsx||!1,browser:!1,replace:!0,browsersync:!0,terser:!1,enabled:!0,copy:!0,string:!0},esmx:{format:"esm",browser:!0,babel:!0,context:n.form_enabled?"window":"global",replace:!0,browsersync:!1,enabled:!1,terser:!0,string:!0},iife:{format:"iife",context:n.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1!==n.iife,terser:!0,string:!0},umd:{format:"umd",context:n.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1,terser:!0,string:!0}},l={};!0===n.webos&&(c.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",babel_options:{targets:{chrome:"79"}}}),!0===n.electron&&(c.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===n.nextjs&&(c.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===n.ios&&(c.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===n.macos&&(c.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,string:!0,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===n.app.enabled&&(n.app.dir=`./dist/app/${n.app.folder}`,c.app={format:n.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:n.app.dir,terser:!0,output_exports:!1===n.app.export?"none":"auto",string:!0},l.targets=l.targets||[],l.targets.push({src:"./src/app/index.html",dest:n.app.dir})),!0===n.cli.enabled&&(n.cli.dir=`./dist/cli/${n.cli.folder}`,c.cli={format:n.cli.format,context:"global",babel:!0===n.src_uses_jsx||!0===n.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:n.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===n.cli.export?"none":"auto",string:!0});const p={server:".",startPath:`${Y.normalize(n.app.dir||".")}`,files:[Y.normalize("./dist/**/*")],cors:!0,open:!1};n.babel_options=V({targets:{browsers:"last 9 versions, not dead",node:"18"}},n.babel_options||n.babel?.options),n.browsersync_options=V(p,n.browsersync_options||n.browsersync?.options||{}),n.replace_options=V({},n.replace_options||n.replace?.options||{}),n.terser_options=V({},n.terser_options||n.terser?.options||{}),n.css_options=V({},n.css_options||n.css?.options||{}),n.wasm_options=V({},n.wasm_options||n.wasm?.options||{}),n.copy_options=V(l,n.copy_options||n.copy?.options||{}),n.json_options=V({},n.json_options||n.json?.options||{}),n.image_options=V({},n.image_options||n.image?.options||{}),n.analyzer_options=V({summaryOnly:!0,limit:12},n.analyzer_options||n.analyzer?.options||{}),n.visualizer_options=V({},n.visualizer_options||n.visualizer?.options||{}),n.string_options=V({},n.string_options||n.string?.options||{}),n.nunjucks_options=V({},n.nunjucks_options||n.nunjucks?.options||{}),Reflect.has(n.browsersync_options,"proxy")&&delete n.browsersync_options.server,n.rollup=n.rollup||{},n.rollup_output=V(c,n.rollup_output||n.rollup?.output||{}),n.string_enabled=!0===n.string||n.string&&!1!==n.string?.enabled,n.preact_enabled=!0===n.preact||n.preact&&!1!==n.preact?.enabled;const d=Object.keys(c);for(const e of d){const t=c[e];t&&(!1!==n.rollup[e]?(!0===n.rollup[e]&&(t.enabled=!0),t.babel_options=t.babel_options||n.babel_options,t.browsersync_options=V(n.browsersync_options,t.browsersync_options),t.replace_options=V(n.replace_options,t.replace_options),t.terser_options=V(n.terser_options,t.terser_options),t.css_options=V(n.css_options,t.css_options),t.wasm_options=V(n.wasm_options,t.wasm_options),t.copy_options=V(n.copy_options,t.copy_options),t.json_options=V(n.json_options,t.json_options),t.image_options=V(n.image_options,t.image_options),t.analyzer_options=V(n.analyzer_options,t.analyzer_options),t.visualizer_options=V(n.visualizer_options,t.visualizer_options),t.string_options=V(n.string_options,t.string_options),t.string=n.string_enabled&&t.string,t.nunjucks_options=V(n.nunjucks_options,t.nunjucks_options),n.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),n.form_enabled&&(t.babel=!0)):t.enabled=!1)}n.babel_enabled=d.some((e=>!0===n.rollup_output[e].babel)),n.browser_enabled=d.some((e=>!0===n.rollup_output[e].babel)),n.browsersync_enabled=!1!==n.browsersync&&d.some((e=>!0===n.rollup_output[e].browsersync)),n.browsersync_enabled=n.browsersync_enabled&&n.app.enabled,n.wasm_enabled=!0===n.wasm||n.wasm&&!1!==n.wasm?.enabled,n.css_enabled=!0===n.css||n.css&&!1!==n.css?.enabled,n.json_enabled=!0===n.json||n.json&&!1!==n.json?.enabled,n.terser_enabled=!1!==n.terser,n.copy_enabled=n.app.enabled||n.copy_enabled||n.copy&&!1!==n.copy?.enabled,n.image_enabled=!0===n.image||n.image&&!1!==n.image?.enabled,n.analyzer_enabled=!0===n.analyzer||n.analyzer&&!1!==n.analyzer?.enabled,n.visualizer_enabled=!0===n.visualizer||n.visualizer&&!1!==n.visualizer?.enabled,n.dependency_auto_enabled=!1!==n.dependency_auto&&!1!==n.dependency_auto?.enabled,n.npm_install_flags=n.npm_install_flags||"",n.react_version=n.react_version||n.react?.version||18,n.polyfill_enabled=!0===n.polyfill||n.polyfill&&!1!==n.polyfill?.enabled,n.nunjucks_enabled=!0===n.nunjucks||n.nunjucks&&!1!==n.nunjucks?.enabled},_o=async({atom:e,packageDependencies:t,packageDevDependencies:n})=>{if("workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let n="^18.2";n=`^${(await ee({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:n}),t.push({package:"react-dom",version:n}),"workflow"===e.type&&(t.push({package:"@flownet/react-app",version:"^0.1"}),t.push({package:"@flownet/react-app-state",version:"^0.1"}))}if(e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&t.push({package:"yargs",version:"^17"}),n.push({package:"@babel/core",version:"^7"}),n.push({package:"@rollup/plugin-commonjs",version:"^26"}),n.push({package:"@rollup/plugin-node-resolve",version:"^15"}),n.push({package:"@rollup/plugin-replace",version:"^5"}),n.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&n.push({package:"rollup-plugin-dts",version:"^6"}),n.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),n.push({package:"@rollup/plugin-alias",version:"^5"}),n.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(n.push({package:"@rollup/plugin-babel",version:"^6"}),n.push({package:"@babel/preset-env",version:"^7"}),n.push({package:"@babel/preset-react",version:"^7"}),e.doc.features.babel?.plugins?.forEach((e=>{switch(e[0]){case"proposal-decorators":n.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"proposal-class-properties":n.push({package:"@babel/plugin-proposal-class-properties",version:"^7"})}}))),n.push({package:"@fnet/rollup-plugin-delete",version:"0.1.3"}),e.doc.features.nunjucks_enabled&&n.push({package:"@fnet/rollup-plugin-nunjucks",version:"0.1.3"}),e.doc.features.browsersync_enabled&&n.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.4"}),e.doc.features.json_enabled&&n.push({package:"@rollup/plugin-json",version:"^6"}),e.doc.features.terser_enabled&&n.push({package:"@rollup/plugin-terser",version:"^0.4"}),e.doc.features.wasm_enabled&&n.push({package:"@rollup/plugin-wasm",version:"^6"}),e.doc.features.image_enabled&&n.push({package:"@rollup/plugin-image",version:"^3"}),e.doc.features.analyzer_enabled&&n.push({package:"rollup-plugin-analyzer",version:"^3"}),e.doc.features.visualizer_enabled&&n.push({package:"rollup-plugin-visualizer",version:"^5"}),e.doc.features.string_enabled&&n.push({package:"rollup-plugin-string",version:"^3"}),e.doc.features.css_enabled){n.push({package:"rollup-plugin-postcss",version:"^4"}),n.push({package:"sass",version:"^1.66"});(e.doc.features.css_options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":n.push({package:"postcss-import",version:"^15"});break;case"postcss-url":n.push({package:"postcss-url",version:"^10"});break;case"postcss-preset-env":n.push({package:"postcss-preset-env",version:"^9"});break;case"autoprefixer":n.push({package:"autoprefixer",version:"^10"});break;case"cssnano":n.push({package:"cssnano",version:"^6"})}}))}e.doc.features.polyfill_enabled&&n.push({package:"rollup-plugin-node-polyfills",version:"^0.2"}),e.doc.features.copy_enabled&&(n.push({package:"rollup-plugin-copy",version:"^3"}),n.push({package:"chokidar",version:"^3"}))},xo=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{if(!0!==e.doc.features.app.enabled)return;await t({message:"Creating index.html."});const i={atom:e,packageDependencies:o,ts:Date.now()},a=n.templateDir,s=ne.resolve(n.projectDir,"src/app");te.existsSync(s)||te.mkdirSync(s,{recursive:!0}),await oe({pattern:["index.html.njk","index.js.njk"],dir:ne.resolve(a,"src/app"),outDir:s,context:i})},ko=async({atom:e,context:t,packageDependencies:n,packageDevDependencies:o,setInProgress:i})=>{await i({message:"Creating package.json."});n.filter((e=>!0===e.dev)).forEach((e=>{o.find((t=>t.package===e.package))||o.push(e);const t=n.findIndex((t=>t.package===e.package));n.splice(t,1)}));const a=n.find((e=>"react"===e.package)),s=n.find((e=>"react-dom"===e.package));a&&!s?n.push({package:"react-dom",version:a.version}):a&&s&&(s.version=a.version),a&&e.doc.features.react_version>=17&&(n.find((e=>"@emotion/react"===e.package))||n.push({package:"@emotion/react",version:"^11"}),n.find((e=>"@emotion/styled"===e.package))||n.push({package:"@emotion/styled",version:"^11"}));const r=[];!0===e.doc.features.app.enabled&&r.push({file:se.resolve(t.projectDir,"src/app/index.js"),dev:!1!==e.doc.features.app.dev}),!0===e.doc.features.cli.enabled&&r.push({file:se.resolve(t.projectDir,"src/cli/index.js"),dev:!1!==e.doc.features.cli.dev});for await(const t of r){const i=t.file;if(!ae.existsSync(i))throw new Error(`App file not found: ${i}`);const a=await re({file:i,recursive:!0}),s=!0===e.doc.features.all_parsed_imports?a.all:a.required;for await(const e of s){if("npm"!==e.type)continue;if(n.find((t=>t.package===e.package)))continue;if(o.find((t=>t.package===e.package)))continue;const i=(await ce({name:e.package,groupBy:{minor:!0}}))[0][0];(!0===t.dev?o:n).push({package:e.package,subpath:e.subpath,version:`^${i}`,type:"npm"})}}const c={atom:e,packageDependencies:n,packageDevDependencies:o},l=t.templateCommonDir,p=ie.compile(ae.readFileSync(se.resolve(l,"package.json.njk"),"utf8"),ie.configure(l)).render(c),d=t.projectDir,f=se.resolve(d,"package.json");ae.writeFileSync(f,p,"utf8")},jo=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating cli."});const i={atom:e,packageDependencies:o},a=n.templateDir,s=pe.resolve(n.projectDir,"src/cli");le.existsSync(s)||le.mkdirSync(s,{recursive:!0}),await de({pattern:["index.js.njk"],dir:pe.resolve(a,"src/cli"),outDir:s,context:i})},Do=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{await t({message:"Creating rollup file."});const i={atom:e,packageDependencies:o},a=me.resolve(n.projectDir,"src","default/index.js");if(!fe.existsSync(a))throw new Error(`Entry file not found: ${a}`);const s=(await he({file:a,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),r=e.doc.features.rollup_output,c=Object.keys(r);for(let e=0;e<c.length;e++){const t=r[c[e]];if(!0===t.browser&&s.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(s.map((e=>({key:e,value:e})))),t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{};for(let e=0;e<s.length;e++){const n=s[e];t.alias.entries[n]=`node:${n}`,t.alias.entries[`node:${n}`]=n}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(s)}}const l=n.templateCommonDir;let p=ue.compile(fe.readFileSync(me.resolve(l,"rollup.config.mjs.njk"),"utf8"),ue.configure(l)).render(i);const d=n.projectDir;let f=me.resolve(d,"rollup.config.mjs");fe.writeFileSync(f,p,"utf8")},Po=async({atom:e,setInProgress:t,context:n,njEnv:o})=>{if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating yargs."});let i={};const a=e.doc.inputs||[],s=[],r=e.doc.input;r?i=await be({schema:r}):a.forEach((e=>{if(!1===e.cli||!e.name)return;e.import&&s.push(e);const t={};Reflect.has(e,"type")&&(t.type=e.type),Reflect.has(e,"default")&&(t.default=e.default),Reflect.has(e,"choices")&&(t.choices=e.choices),(Reflect.has(e,"describe")||Reflect.has(e,"description"))&&(t.describe=e.describe||e.description),Reflect.has(e,"alias")&&(t.alias=e.alias),Reflect.has(e,"required")&&!0===e.required&&(t.required=!0),Reflect.has(e,"hidden")&&!0===e.hidden&&(t.hidden=!0),Reflect.has(e,"array")&&!0===e.array&&(t.array=!0),Reflect.has(e,"normalize")&&!0===e.normalize&&(t.normalize=!0),Reflect.has(e,"nargs")&&(t.nargs=e.nargs),i[e.name]=t}));const c={options:i,imports:s,atom:e},l=n.templateDir,p=ye.compile(we.readFileSync(ge.resolve(l,"src/default/to.yargs.js.njk"),"utf8"),o).render(c),d=n.projectDir,f=ge.resolve(d,"src/default/to.yargs.js");we.writeFileSync(f,p,"utf8")},So=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{await t({message:"Creating .gitignore"});const i={atom:e,packageDependencies:o},a=n.templateCommonDir,s=xe.compile(ve.readFileSync(_e.resolve(a,".gitignore.njk"),"utf8"),xe.configure(a)).render(i),r=n.projectDir,c=_e.resolve(r,".gitignore");ve.writeFileSync(c,s,"utf8")},Ao=async({atom:e,setInProgress:t,context:n,packageDependencies:o})=>{await t({message:"Creating tsconfig.json."});const i={atom:e,packageDependencies:o},a=n.templateCommonDir,s=De.compile(ke.readFileSync(je.resolve(a,"tsconfig.json.njk"),"utf8"),De.configure(a)).render(i),r=n.projectDir,c=je.resolve(r,"tsconfig.json");ke.writeFileSync(c,s,"utf8")},To=async({atom:e,context:t,setInProgress:n,Atom:o})=>{const i="readme.md",a=`Creating ${i}`;if(await n({message:a}),t.project?.readme){const e={content:t.project.readme.doc.content},n=t.templateCommonDir,o=Pe.compile(Se.readFileSync(Ae.resolve(n,`${i}.njk`),"utf8"),Pe.configure(n)).render(e),a=t.projectDir,s=Ae.resolve(a,`${i}`);Se.writeFileSync(s,o,"utf8")}else if(e.id){const n=await o.first({type:"wiki",parent_id:e.id});if(!n||"markdown"!==n.doc?.["content-type"])return;const{content:a,...s}=n.doc,r={content:a},c=t.templateCommonDir,l=Pe.compile(Se.readFileSync(Ae.resolve(c,`${i}.njk`),"utf8"),Pe.configure(c)).render(r),p=t.projectDir,d=Ae.resolve(p,`${i}`);Se.writeFileSync(d,l,"utf8")}},Eo=async({setInProgress:e,context:t})=>{const n=t.projectDir;await e({message:"Prettifiying source files."});let o=Ee.join("src","**","*");if(0!==Te.exec(`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:n}).code)throw new Error("Couldnt format files.")},$o=async({atom:e,setInProgress:t,context:n})=>{if(!e.doc.features.dts_enabled)return;const o=n.projectDir;await t({message:"Creating .d.ts"});if(0!==$e.exec("tsc",{cwd:o}).code)throw new Error("Couldnt create .d.ts files.")},Io=async({setInProgress:e,atom:t,context:n})=>{const o=n.projectDir;await e({message:"Installing npm packages."});if(0!==Ie.exec(`npm install ${t.doc.features.npm_install_flags}`,{cwd:o}).code)throw new Error("Couldnt install npm packages.")},Oo=async({setInProgress:e,context:t})=>{const n=t.projectDir;await e({message:"Building main project."});if(0!==Oe.exec("npm run build",{cwd:n}).code)throw new Error("Couldnt build project.")},Co=async e=>{const{atom:t,packageDependencies:n,context:o,deploymentProjectTarget:i,setInProgress:a,deploymentProject:s}=e;if(!0===i.enabled)if("lib"===i.name)await en({...e});else if("red"===i.name)await Qt({...e});else if("npm"===i.name)await Zt({...e});else if("gcs"===i.name)await Yt({...e});else if("gitlab"===i.name)await Xt({...e});else if("fnet-package"===i.name)await cn({...e});else if("fnet-form"===i.name)await ln({...e});else if("fnet-node"===i.name)await dn({...e});else if("fnet-flow"===i.name)await pn({...e});else{let e;if("nextjs"===i.name?e=sn:"webos"===i.name?e=an:"electron"===i.name?e=on:"docker"===i.name?e=rn:"ios"===i.name?e=tn:"macos"===i.name?e=nn:"rust"===i.name&&(e=fn),!e)return;await e({atom:t,target:i,onProgress:a,projectDir:o.projectDir,dependencies:n}),s.isDirty=!0}},{Atom:No}=b,Mo=F,Ro=j,Fo=q,qo=t,Uo=k,Bo=U,Lo=c,zo=B,Jo=yn,Wo=_n,Ko=jn,Go=Tn,Ho=hn,Vo=En,Xo=On,Yo=Mn,Zo=qn,Qo=Bn,ei=zn,ti=Wn,ni=Gn,oi=Xn,ii=Qn,ai=no,si=io,ri=so,ci=co,li=({node:e})=>{const t=e.definition;if("end"===t.next);else if("stop"===t.next);else if("none"===t.next);else if(t.next){let n=e.parent;for(;n.parent;){const o=n.childs.find((e=>e.name===t.next));if(o){e.context.next=o;break}n=n.parent}}else{let t=e.parent,n=e.index+1;for(;t.parent&&(!t.blockAutoJumpToParent||!t.blockAutoJumpToSibling);)if(void 0!==t.blockAutoJumpToParent||void 0!==t.blockAutoJumpToSibling){if(t.blockAutoJumpToParent){const o=t.childs.find((e=>e.index===n));o&&(e.context.next=o);break}t.blockAutoJumpToParent||(n=t.index+1,t=t.parent)}else{const o=t.childs.find((e=>e.index===n));if(o){e.context.next=o;break}n=t.index+1,t=t.parent}}};var pi=class{#e;#t;#n;#o;#i;#a;#s;#r;#c;#l;#p;#d;#f;#m;#u;#h;#w;#g;#y;#b;#v;constructor(e){this.#e=new bo,this.#t=e,this.#a=[],this.#s=[],this.#r={},this._expire_ttl=3600,this._expire_ttl_short=300,this.#b={packageDependencies:this.#a,packageDevDependencies:this.#s,setInProgress:this.setInProgress.bind(this),context:this.#t,Atom:No,registerToPackageManager:this.registerToPackageManager.bind(this)},this.#v={initNode:this.initNode.bind(this),cloneDeep:ho,resolveTypeCommon:this.resolveTypeCommon.bind(this),resolveNextBlock:li,transformExpression:this.transformExpression.bind(this),transformValue:this.transformValue.bind(this)}}async _cache_set(e,t,n){this._redis_client&&await this._redis_client.SETEX(e,n||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await go(),this.#p=this.#t.buildId||yo(24),this.#b.buildId=this.#p,this.#u=this.#t.mode,this.#h=["all","deploy","build","file"].includes(this.#u),this.#w=["all","deploy","build"].includes(this.#u),this.#g=["all","deploy"].includes(this.#u),this.#y=["all","deploy","build","file","bpmn"].includes(this.#u),this.#f=this.#t.protocol,this.#d="BUILD:"+this.#p,this.#m=(await qo({optional:!0,name:"atom",dir:this.#t.projectDir}))?.data;try{await this.setInProgress({message:"Initialization started."}),await this.initAuth(),await this.initWorkflow(),await vo(this.#b),await _o(this.#b),await this.transformWorkflow({workflow:this.#o});const e=await this.initNodeTree({workflow:this.#o});await this.initNodeTreeIndex({root:e}),await this.initNodeCalls({root:e}),await this.initNodeCallLibs({root:e}),await this.initNodeForms({root:e}),await this.initNodeFormLibs({root:e}),await this.initAtomLibsAndDeps({libs:e.context.libs,packageDependencies:this.#a}),await this.resolveNodeTree({root:e}),this.#l=e}catch(e){throw await this._cache_set(this.#d,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#t.id&&(this.#c=await this.#e.init({config:this.#m}),this.#b.atomAccessToken=this.#c)}async initWorkflow(){const e=this.#t.id;this.#n=this.#t.project?.workflowAtom||await No.get({id:e}),this.#o="string"==typeof this.#n.doc.content?(await Lo({content:this.#n.doc.content})).parsed:this.#n.doc.content;let t=this.#n.doc.bundleName;t=t||(this.#n.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#n.doc.bundleName=t,this.#n.type=this.#n.type||"workflow",this.#b.atom=this.#n}async initDependencies(){this.#a.push({package:"get-value",version:"^3.0"}),this.#a.push({package:"set-value",version:"^4.1"}),this.#n.doc.features.form_enabled?(this.#a.push({package:"react",version:"^18.2"}),this.#a.push({package:"react-dom",version:"^18.2"}),this.#a.push({package:"@flownet/react-app",version:"^0.1"}),this.#a.push({package:"@flownet/react-app-state",version:"^0.1"})):this.#a.push({package:"yargs",version:"^17"}),this.#a.push({package:"chalk",version:"^4"})}#_(e){console.log("filePath",e),lo.statSync(e).isDirectory()?(lo.readdirSync(e).forEach((t=>{const n=po.join(e,t);this.#_(n)})),lo.rmSync(e)):lo.unlinkSync(e)}#x(e,t){const n=lo.existsSync(e),o=n&&lo.statSync(e);n&&o.isDirectory()?(lo.mkdirSync(t,{recursive:!0}),lo.readdirSync(e).forEach((n=>{this.#x(po.join(e,n),po.join(t,n))}))):lo.copyFileSync(e,t)}async initWorkflowDir(){const e=this.#t.projectDir,t=this.#t.coreDir,n=["node_modules"];if(lo.existsSync(e)){const t=lo.readdirSync(e);for(const o of t)if(!n.includes(o)){const t=po.join(e,o);lo.rmSync(t,{recursive:!0})}}lo.existsSync(e)||lo.mkdirSync(e,{recursive:!0});const o=po.join(e,"src");lo.existsSync(o)||lo.mkdirSync(o,{recursive:!0});const i=po.join(o,"core");this.#x(t,i);const a=po.join(o,"default","blocks");lo.existsSync(a)||lo.mkdirSync(a,{recursive:!0})}async initNunjucks(){const e=this.#t.templateDir;this.#i=uo.configure(e,{watch:!1,dev:!0}),this.#b.njEnv=this.#i}transformWorkflow({workflow:e}){for(const t of Object.values(e))t.steps=t.steps||[],t.steps=t.steps.map((e=>this.transformStep({step:e})))}transformStep({step:e}){if(Array.isArray(e))throw new Error("Step must be an object.");const[t,n]=Object.entries(e)[0];if(n.hasOwnProperty("onerror")){const{onerror:o,...i}=n;e[t]={try:i,except:o}}if(e[t].hasOwnProperty("steps")){const n=e[t].steps;if(!Array.isArray(n))throw new Error("Steps must be an array.");e[t].steps=n.map((e=>this.transformStep({step:e})))}return e}async initNodeTree({workflow:e}){const t=Object.keys(e),n={definition:e,name:void 0,type:"root",parent:void 0,childs:[],blockAutoJumpToParent:!0,blockAutoJumpToSibling:!0,index:0,depth:0,context:{libs:[],atom:this.#n}};t.forEach((t=>{const o={name:t,type:"main"===t?"workflow":"subworkflow",childs:[],parent:n,definition:e[t],index:n.childs.length,depth:n.depth+1,context:{},blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1};n.childs.push(o)}));for await(const e of n.childs)await this.initNode({node:e});return n}async initNode({node:e}){const t={...this.#v,node:e};if(e.workflow=e.parent.workflow||e,e.depth=e.parent.depth+1,await Wo.hits(t))await Wo.init(t);else if(await Go.hits(t))await Go.init(t);else if(await Ho.hits(t))await Ho.init(t);else if(await Jo.hits(t))await Jo.init(t);else if(await Vo.hits(t))await Vo.init(t);else if(await Ko.hits(t))await Ko.init(t);else if(await Xo.hits(t))await Xo.init(t);else if(await Yo.hits(t))await Yo.init(t);else if(await Zo.hits(t))await Zo.init(t);else if(await Qo.hits(t))await Qo.init(t);else if(await ei.hits(t))await ei.init(t);else if(await ti.hits(t))await ti.init(t);else if(await ri.hits(t))await ri.init(t);else if(await ci.hits(t))await ci.init(t);else if(await oi.hits(t))await oi.init(t);else if(await ii.hits(t))await ii.init(t);else if(await si.hits(t))await si.init(t);else if(await ni.hits(t))await ni.init(t);else{if(!await ai.hits(t))throw new Error("Undefined step type.");await ai.init(t)}}async initNodeTreeIndex({root:e}){const t={};e.indexKey="/";for await(const n of e.childs)await this.initNodeIndex({node:n,index:t});return e.context.index=t,t}async initNodeIndex({node:e,index:t}){const n=po.join(e.parent.indexKey,e.name);e.indexKey=n,t[n]=e;const o=[];let i=e;for(;i?.parent;)o.push(i.index),i=i.parent;o.reverse(),e.codeKey=`B_${o.join("_")}_${e.type}`,e.pathKey=`${o.join(".")}`,e.typeId=yo(24);for await(const n of e.childs)await this.initNodeIndex({node:n,index:t})}async initNodeCalls({root:e}){const t=e.context.index,n=[];for await(const e of Object.keys(t)){const o=t[e];"call"===o.type&&n.push(o)}return e.context.calls=n,n}async initNodeCallLibs({root:e}){const t=[],n=e.context.calls;for await(const e of n){const n=e.definition.call,o=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:n,type:"atom"},i=t.find((e=>e.name===o.name&&e.type===o.type));i||t.push(o),e.target=i||o}return e.context.callLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeCallTarget({refNode:e,curNode:t}){if(!t)return;const n=e.definition.call,o=t.childs.find((e=>e.name===n&&"subworkflow"===e.type));return o||await this.findNodeCallTarget({refNode:e,curNode:t.parent})}async initNodeForms({root:e}){const t=e.context.index,n=[];for await(const e of Object.keys(t)){const o=t[e];"form"===o.type&&n.push(o)}return e.context.forms=n,n}async initNodeFormLibs({root:e}){const t=[],n=e.context.forms;for await(const e of n){const n=e.definition.form,o=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:n,type:"atom"},i=t.find((e=>e.name===o.name&&e.type===o.type));i||t.push(o),e.target=i||o}return e.context.formLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeFormTarget({refNode:e,curNode:t}){if(!t)return;const n=e.definition.form,o=t.childs.find((e=>e.name===n&&"subworkflow"===e.type));return o||await this.findNodeFormTarget({refNode:e,curNode:t.parent})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const n=e.filter((e=>"atom"===e.type));for(let e=0;e<n.length;e++){const o=n[e],i=await this.findAtomLibrary({url:o.name});o.atom=i;const a=i.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));a?.forEach((e=>{const n=t.find((t=>t.package===e.package));n?"string"==typeof e.path?(n.path||[]).some((t=>t===e.path))||(n.path=n.path||[],n.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(n.path||[]).some((t=>t===e))||(n.path=n.path||[],n.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const t=Mo({url:e});if(!t)throw new Error(`Invalid package name: ${e}`);if(t.protocol||(t.protocol=this.#f),"ac:"===t.protocol){const n=t.pathname.split("/");if(1===n.length)return await No.first({where:{name:e,parent_id:this.#m.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===n.length){const e=await No.first({where:{name:n[0],parent_id:this.#m.env.ATOM_LIBRARIES_ID,type:"folder"}});return await No.first({where:{name:n[1],parent_id:e.id,type:"workflow.lib"}})}}else{if("local:"===t.protocol){const e=po.resolve(this.#t.projectSrcDir,`${t.pathname}.js`),n=[],o=await Uo({file:e,recursive:!0}),i=!0===this.#n.doc.features.all_parsed_imports?o.all:o.required;for await(const e of i){if("npm"!==e.type)continue;if(n.find((t=>t.package===e.package)))continue;const t=(await Ro({name:e.package,groupBy:{minor:!0}}))[0][0];n.push({package:e.package,subpath:e.subpath,version:`^${t}`,type:"npm"})}return{name:t.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:n},protocol:t.protocol}}if("npm:"===t.protocol){const e=(await Ro({name:t.pathname,groupBy:{minor:!0}}))[0][0];return{name:t.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:[{package:t.pathname,version:`^${e}`,type:"npm"}]},protocol:t.protocol}}}}async resolveNodeTree({root:e}){for await(const t of e.childs)await this.resolveTypeWorkflow({node:t})}async resolveTypeWorkflow({node:e}){e.context.transform=ho(e.definition);const t=e.context.transform;for(let e=0;e<t.params?.length;e++){const n=t.params[e];if("string"==typeof n)t.params[e]={key:n,hasDefault:!1};else{const o=Object.keys(n)[0];t.params[e]={key:o,hasDefault:!0,default:n[o]}}}e.context.next=e.childs[0];for await(const t of e.childs)await this.resolveType({node:t})}async resolveType({node:e}){const t={...this.#v,node:e};"function"==typeof e.resolve&&await e.resolve(t);for await(const t of e.childs)await this.resolveType({node:t})}async resolveTypeCommon({node:e}){const t=e.context.transform;t.hasOwnProperty("operation")&&(t.operation=await this.transformExpression(t.operation)),t.hasOwnProperty("page")&&(t.page=await this.transformExpression(t.page)),t.hasOwnProperty("print")&&(t.print=await this.transformExpression(t.print)),t.hasOwnProperty("sleep")&&(t.sleep=await this.transformExpression(t.sleep)),t.hasOwnProperty("assert")&&(t.assert=await this.transformExpression(t.assert))}async createAtomLibFiles({root:e}){await this.setInProgress({message:"Creating external lib files."}),this.#n.typesDir="./types";const t=e.context.libs.filter((e=>"atom"===e.type));for(let e=0;e<t.length;e++){const n=t[e].atom,o=this.#t.projectDir;if("local:"===n.protocol){const e=po.resolve(this.#t.projectSrcDir,`${n.fileName||n.name}.js`),t=po.relative(`${this.#t.projectDir}/src/default/blocks`,e);if(!lo.existsSync(e)){lo.mkdirSync(po.dirname(e),{recursive:!0});let t="export default async (args)=>{\n";t+="}",lo.writeFileSync(e,t,"utf8")}n.relativePath=t.split(po.sep).join("/"),this.#n.typesDir=`./types/${po.basename(o)}/src`}else if("npm:"===n.protocol)n.relativePath=n.name;else{const e=`${o}/src/libs/${n.id}.js`,t=n.doc.contents?.find((e=>"esm"===e.format))||n.doc;lo.writeFileSync(po.normalize(e),t.content,"utf8")}}}async createEngine({root:e}){await this.setInProgress({message:"Creating engine file."});const t=this.#t.templateDir,n=uo.compile(lo.readFileSync(po.resolve(t,"src/default/engine.js.njk"),"utf8"),this.#i).render({...e,ui:{package:"@flownet/react-app"}}),o=this.#t.projectDir,i=po.resolve(o,"src/default/index.js");lo.writeFileSync(i,n,"utf8")}async createNodeTree({root:e}){await this.setInProgress({message:"Creating block files."});for await(const t of e.childs)await this.createTypeWorkflow({node:t})}async createTypeWorkflow({node:e}){const t=this.#t.templateDir,n=uo.compile(lo.readFileSync(po.resolve(t,"src/default/workflow.js.njk"),"utf8"),this.#i).render(e),o=this.#t.projectDir,i=po.resolve(o,`src/default/${e.codeKey}.js`);lo.writeFileSync(i,n,"utf8");for await(const t of e.childs)await this.createType({node:t})}async createType({node:e}){switch(e.type){case"assign":case"steps":case"return":case"call":case"form":case"raise":case"switch":case"jump":case"tryexcept":case"for":case"operation":this.createBlockFromTemplate({node:e})}for await(const t of e.childs)await this.createType({node:t})}createBlockFromTemplate({node:e}){const t=this.getBlockTemplate({node:e});e.context.render=t.render(e),this.createStepFile({node:e})}getBlockTemplate({node:e}){let t=this.#r[e.type];if(t)return t;const n=this.#t.templateDir;return t=uo.compile(lo.readFileSync(po.resolve(n,`src/default/blocks/${e.type}.js.njk`),"utf8"),this.#i),this.#r[e.type]=t,t}createStepFile({node:e}){const t=this.#t.projectDir,n=`${e.codeKey}.js`,o=po.resolve(t,`src/default/blocks/${n}`);lo.writeFileSync(o,e.context.render,"utf8"),e.context.fileName=n,e.context.filePath=o}async transformExpression(e){let t=await this.transformValue(e);return t=JSON.stringify(t),t=this.replaceSpecialPattern(t),t}async transformValue(e){if(Array.isArray(e))for(let t=0;t<e.length;t++)e[t]=await this.transformValue(e[t]);else if(wo(e)){const t=Object.keys(e);for(let n=0;n<t.length;n++)e[t[n]]=await this.transformValue(e[t[n]])}else if("string"==typeof e){const t=await Bo({expression:e});if(t){const{processor:n,statement:o}=t;switch(n){case"v":e=`$::v.${o}::`;break;case"e":e=`$::${o}::`;break;case"m":e=`$::closure.module['${o}']::`;break;case"f":e=`$::closure.form.${o}::`;break;case"for":e=`$::caller.for.${o}::`}}}return e}replaceSpecialPattern(e){return e.replace(/"\$::(.*?)::"/g,"$1")}replaceExpressionLegacy(e){return e.replaceAll(/(?<outer>"\${(?<inner>[^{]*)}")/g,"$2")}async createProjectYaml(){const e="flow.yaml",t=`Creating ${e}`;await this.setInProgress({message:t});const{content:n,...o}=this.#n.doc,i={content:fo.stringify(o)},a=this.#t.templateDir,s=uo.compile(lo.readFileSync(po.resolve(a,`${e}.njk`),"utf8"),this.#i).render(i),r=this.#t.projectDir,c=po.resolve(r,`${e}`);lo.writeFileSync(c,s,"utf8")}async createProjectMainYaml(){const e="flow.main.yaml",t=`Creating ${e}`;await this.setInProgress({message:t});const n={content:fo.stringify(this.#o)},o=this.#t.templateDir,i=uo.compile(lo.readFileSync(po.resolve(o,`${e}.njk`),"utf8"),this.#i).render(n),a=this.#t.projectDir,s=po.resolve(a,`${e}`);lo.writeFileSync(s,i,"utf8")}async runPrettifier(){const e=this.#t.projectDir,t=mo.exec("prettier --write .",{cwd:po.resolve(e,"src")});if(0!==t.code)throw new Error(t.stderr)}async deploy(){if(await this.setInProgress({message:"Deploying."}),this.#t.project?.devops){const e=[this.#t.project?.devops];for(let t=0;t<e.length;t++){let n=e[t];await this.deployProject({deploymentProject:n}),!0===n.isDirty&&await n.save()}}else if(this.#n.id){const e=await No.list({type:"workflow.deploy",parent_id:this.#n.id});for(let t=0;t<e.length;t++){let n=e[t];await this.deployProject({deploymentProject:n}),!0===n.isDirty&&(n=await No.update(n,{id:n.id}))}}}async deployProject(e){const{deploymentProject:t}=e,n=t.doc.targets;for(let e=0;e<n.length;e++){const o=n[e];await Co({...this.#b,deploymentProject:t,deploymentProjectTarget:o})}}async registerToPackageManager(e){const{target:t,packageJSON:n}=e;if(!this.#t.id)return;let o=await No.first({name:t.params.name,parent_id:this.#m.env.ATOM_PACKAGES_ID});o?(o.doc.versions.splice(0,0,{v:n.version}),await No.update(o,{id:o.id})):o=await No.create({parent_id:this.#m.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:n.version}]}})}async setInProgress({message:e}){console.log(zo.blue(e)),await this._cache_set(this.#d,{status:"IN_PROGRESS",message:e})}async build(){if(this.#y&&!this.#h)return await this.createNetwork();try{const e=this.#y?await Fo({root:this.#l}):void 0;if(this.#h){if(await this.initWorkflowDir(),await this.initNunjucks(),this.#y){const t=this.#t.project?.projectDir||this.#t.projectDir;lo.writeFileSync(po.resolve(t,"./flow.bpmn"),e.diagramXML,"utf8")}await this.createAtomLibFiles({root:this.#l}),await this.createEngine({root:this.#l}),await this.createNodeTree({root:this.#l}),await this.createProjectYaml(),await this.createProjectMainYaml(),await To(this.#b),await Ao(this.#b),await So(this.#b),await Po(this.#b),await jo(this.#b),await xo(this.#b),await Do(this.#b),await ko(this.#b),await Eo(this.#b),await $o(this.#b),this.#w&&(await Io(this.#b),await Oo(this.#b),this.#g&&await this.deploy())}await this._cache_set(this.#d,{status:"COMPLETED",data:{network:e}})}catch(e){throw await this._cache_set(this.#d,{status:"FAILED",message:e.message||e}),e}}async createNetwork(){try{const e=await Fo({root:this.#l});await this._cache_set(this.#d,{status:"COMPLETED",data:{...e}})}catch(e){throw await this._cache_set(this.#d,{status:"FAILED",message:e.message||e}),e}}};const di=d,fi=f;var mi=function({baseDir:e=__dirname}){let t=e;for(;t!==fi.parse(t).root;){const e=fi.join(t,"node_modules");if(di.existsSync(e))return e;t=fi.dirname(t)}return null};const ui=process.cwd(),{spawn:hi}=e;t({name:["redis"],dir:ui,optional:!0});const wi=n,gi=o,{hideBin:yi}=i,bi=a,vi=s,_i=r,xi=c,ki=t,ji=l,Di=p,Pi=pi,Si=mi({baseDir:__dirname}),Ai="win32"===process.platform?";":":";process.env.PATH=`${wi.join(Si,"/.bin")}${Ai}${process.env.PATH}`;let Ti=gi(yi(process.argv)).command("create","Initialize flow node project",(e=>e.option("name",{type:"string"}).option("vscode",{type:"boolean",default:!0,alias:"vs"})),(async e=>{try{const t=wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/project"),n=wi.resolve(ui,e.name);bi.existsSync(n)||bi.mkdirSync(n),await Di({dir:t,outDir:n,context:e,copyUnmatchedAlso:!0});let o=_i.exec("fnet build",{cwd:n});if(0!==o.code)throw new Error("Failed to build project.");if(_i.which("git")&&(o=_i.exec("git init --initial-branch=main",{cwd:n}),0!==o.code))throw new Error("Failed to initialize git.");if(_i.which("code")&&e.vscode&&(o=_i.exec(`cd ${n} && code .`),0!==o.code))throw new Error("Failed to open vscode.");console.log("Creating project succeeded!"),process.exit(0)}catch(e){console.error("Initialization failed!",e.message),process.exit(1)}})).command("project","Flow node project",(e=>e.option("update",{type:"boolean",default:!1,alias:"-u"})),(async e=>{try{const t=wi.resolve(Si,"@fnet/cli-project-flow/dist/template/project"),n=process.cwd();if(e.name=wi.basename(n),e.update){if(await Di({dir:t,outDir:n,context:e,copyUnmatchedAlso:!0}),0!==_i.exec("fnet build",{cwd:n}).code)throw new Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(e){console.error("Project failed.",e.message),process.exit(1)}})).command("build","Build flownet project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("mode",{type:"string",alias:"m",default:"build",choices:["all","file","build","deploy","bpmn"]}).option("target",{type:"string",alias:"t"})),(async e=>{try{const t=await $i(e),n=new Pi(t);await n.init(),await n.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}})).command("deploy","Build and deploy flownet project",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("target",{type:"string",alias:"t"})),(async e=>{try{const t=await $i({...e,mode:"all"}),n=new Pi(t);await n.init(),await n.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}})).command("file","Just create files",(e=>e.option("id",{type:"string"}).option("buildId",{type:"string",alias:"bid"}).option("target",{type:"string",alias:"t"})),(async e=>{try{const t=await $i({...e,mode:"file"}),n=new Pi(t);await n.init(),await n.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}));function Ei(e,{name:t,bin:n,preArgs:o=[]}){return e.command(`${t||n} [commands..]`,`${n} ${o.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await $i(e),{projectDir:i}=t,a=process.argv.slice(3);hi(n,[...o,...a],{cwd:i,stdio:"inherit",shell:!0}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}async function $i(e){if(e.id){return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",projectDir:wi.resolve(ui,`./.output/${e.id}`),templateDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/default"),templateCommonDir:wi.resolve(Si,"./@fnet/cli-project-common/dist/template/default"),coreDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/core"),target:e.target}}{const t=await async function(){const e=wi.resolve(ui,"flow.yaml");if(!bi.existsSync(e))throw new Error("flow.yaml file not found in current directory.");const t=bi.readFileSync(e,"utf8"),{parsed:n}=await xi({content:t}),o=wi.dirname(e),i=n.main||"flow.main.yaml";let a=wi.resolve(o,i);if(!bi.existsSync(a)&&(a=wi.resolve(o,i+".yaml"),!bi.existsSync(a)))throw new Error(`${i} file not found in ${a}.`);const s=bi.readFileSync(a,"utf8"),{parsed:r}=await xi({content:s}),c={workflowAtom:{doc:{...n,"content-type":"yaml",content:s}},projectDir:o,projectFilePath:e,projectFileContent:t,projectFileParsed:n,projectMainFilePath:a,projectMainFileContent:s,projectMainFileParsed:r},l=wi.resolve(o,"flow.devops.yaml");if(bi.existsSync(l)){const e=bi.readFileSync(l,"utf8"),t=vi.parse(e);c.devops={filePath:l,fileContent:e,doc:{...t},type:"workflow.deploy",save:async()=>{bi.writeFileSync(c.devops.filePath,vi.stringify(c.devops.doc))}}}const p=wi.resolve(o,"readme.md");if(bi.existsSync(p)){const e=bi.readFileSync(p,"utf8");c.readme={filePath:p,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return c}();return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/default"),templateCommonDir:wi.resolve(Si,"./@fnet/cli-project-common/dist/template/default"),coreDir:wi.resolve(Si,"./@fnet/cli-project-flow/dist/template/core"),projectDir:wi.resolve(t.projectDir,"./.workspace"),projectSrcDir:wi.resolve(t.projectDir,"./src"),project:t,target:e.target}}}Ti=Ti.command("config create <name>","Create a config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $i(e),{project:n}=t,{projectDir:o,projectFileParsed:i}=n,a=i.config;if(!a)throw new Error("Config schema not found in project file.");const s=await ji({schema:a}),r=wi.resolve(o,".fnet");bi.existsSync(r)||bi.mkdirSync(r);const c=wi.resolve(r,`${e.name}.fnet`);bi.writeFileSync(c,vi.stringify(s))}catch(e){console.error(e.message),process.exit(1)}})),Ti=Ei(Ti,{bin:"npm"}),Ti=Ei(Ti,{bin:"node"}),Ti=Ei(Ti,{name:"serve",bin:"npm",preArgs:["run","serve","--"]}),Ti=Ei(Ti,{name:"watch",bin:"npm",preArgs:["run","watch","--"]}),Ti=Ei(Ti,{name:"app",bin:"npm",preArgs:["run","app","--"]}),Ti=Ei(Ti,{name:"cli",bin:"npm",preArgs:["run","cli","--"]}),Ti=Ei(Ti,{bin:"npx"}),Ti=Ei(Ti,{bin:"cdk"}),Ti=Ei(Ti,{bin:"aws"}),Ti=function(e,{name:t,preArgs:n=[]}){return e.command(`${t} <config> <command> [options..]`,"Run a command with a config context",(e=>e.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $i(e),{projectDir:o}=t,i=e.config,a=await ki({name:i,dir:o,transferEnv:!1,optional:!0}),s=a?.data?.env||void 0,r=e.command,c=process.argv.slice(5);hi(r,[...n,...c],{cwd:o,stdio:"inherit",shell:!0,env:{...process.env,...s}}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}(Ti,{name:"with"}),Ti.demandCommand(1,"You need at least one command before moving on").help().argv,module.exports={};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@fnet/cli",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.48.0",
|
|
4
4
|
"files": [
|
|
5
5
|
"dist"
|
|
6
6
|
],
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
},
|
|
14
14
|
"repository": {
|
|
15
15
|
"type": "git",
|
|
16
|
-
"url": "git+https://
|
|
16
|
+
"url": "git+https://github.com/fnetai/cli.git"
|
|
17
17
|
},
|
|
18
18
|
"license": "MIT",
|
|
19
19
|
"dependencies": {
|
|
@@ -41,7 +41,7 @@
|
|
|
41
41
|
"@fnet/files-to-gcs": "^0.3.6",
|
|
42
42
|
"@fnet/object-from-schema": "^0.1.2",
|
|
43
43
|
"@fnet/shell": "^0.1.13",
|
|
44
|
-
"@fnet/to-rust": "^0.1.
|
|
44
|
+
"@fnet/to-rust": "^0.1.2",
|
|
45
45
|
"@fnet/yaml": "^0.1.12",
|
|
46
46
|
"@fnet/yargs-options-from-schema": "^0.1.1",
|
|
47
47
|
"@node-red/util": "^4.0.2",
|