@fnet/cli 0.70.1 → 0.71.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.
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var e=require("child_process"),t=require("@fnet/config"),r=require("path"),n=require("yargs/yargs"),a=require("fs"),o=require("yaml"),i=require("shelljs"),s=require("@fnet/yaml"),c=require("@fnet/object-from-schema"),p=require("@fnet/shell-flow"),l=require("@flownet/lib-render-templates-dir"),d=require("node:fs"),u=require("node:path"),m=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"),v=require("qs"),b=require("lodash.merge"),_=require("@flownet/lib-parse-imports-js"),j=require("@fnet/npm-list-versions"),D=require("@fnet/npm-pick-versions"),k=require("object-hash"),x=require("ajv/dist/2020"),P=require("ajv/dist/standalone"),S=require("ajv-formats"),A=require("@fnet/shell"),E=require("semver"),$=require("@fnet/up-list-files"),T=require("node:os"),I=require("@node-red/util"),C=require("@flownet/lib-to-ios-app"),O=require("lodash.clonedeep"),R=require("@flownet/lib-to-macos-app"),M=require("@flownet/lib-to-electron"),F=require("@flownet/lib-to-webos"),q=require("@flownet/lib-to-nextjs"),L=require("@flownet/lib-to-docker"),N=require("form-data"),U=require("@fnet/to-rust"),z=require("@flownet/lib-parse-node-url"),B=require("@fnet/list-files"),J=require("chalk");function W(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var K,G,H,X,Y,Z,Q,V,ee,te,re,ne,ae,oe,ie,se,ce,pe,le,de,ue,me,fe,ge,ye,he,we,ve,be,_e,je,De,ke,xe,Pe,Se,Ae,Ee,$e,Te,Ie,Ce,Oe,Re,Me,Fe,qe,Le,Ne,Ue,ze,Be,Je,We,Ke,Ge,He,Xe,Ye,Ze,Qe,Ve,et,tt,rt,nt,at,ot,it,st,ct,pt,lt,dt,ut,mt,ft,gt,yt,ht,wt,vt,bt,_t,jt,Dt,kt,xt,Pt,St,At,Et,$t,Tt,It,Ct,Ot,Rt,Mt,Ft,qt,Lt,Nt,Ut,zt,Bt,Jt,Wt={};function Kt(){if(Z)return Y;Z=1;const e=b;return Y=({feature:t,features:r,packageDevDependencies:n})=>{const{name:a,packages:o,options:i,extraCheck:s,explicit:c}=t,p=`${a}_enabled`,l=r.rollup_output||{},d=Object.keys(l);let u=i||{};const m=r[a]?.options;m&&(u=e(u,m));const f=!r[a]||!1===r[a]?.enabled;d.forEach((e=>{const t=r.rollup_output[e];if(t){if(Reflect.has(t,a)){if(f||!t[a]||!1===t[a]?.enabled)return void delete t[a];!0===t[a]&&(t[a]={enabled:!0,options:u})}else{if(f||c||!1===r[p])return;t[a]={enabled:!0}}t[a]=t[a]||{},t[a].options={...u,...t[a].options}}}));let g=d.some((e=>!0===r.rollup_output[e][a]?.enabled));s&&(g=s()&&g),r[p]=g,g&&o.forEach((e=>n.push({package:e[0],version:e[1]})))}}function Gt(){if(xe)return ke;xe=1;const e=b,t=d,r=u,n=_,a=function(){if(V)return Q;V=1;const e=Kt();return Q=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:a,packageDevDependencies:n})},Q}(),o=function(){if(te)return ee;te=1;const e=Kt();return ee=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:a,packageDevDependencies:n})},ee}(),i=function(){if(ne)return re;ne=1;const e=Kt();return re=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:a,packageDevDependencies:n})},re}(),s=function(){if(oe)return ae;oe=1;const e=Kt();return ae=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:a,packageDevDependencies:n})},ae}(),c=function(){if(se)return ie;se=1;const e=Kt();return ie=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]],expilicit:!0},features:a,packageDevDependencies:n})},ie}(),p=function(){if(pe)return ce;pe=1;const e=Kt();return ce=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:a,packageDevDependencies:n})},ce}(),l=function(){if(de)return le;de=1;const e=Kt();return le=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:a,packageDevDependencies:n})},le}(),m=function(){if(me)return ue;me=1;const e=Kt();return ue=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:a,packageDevDependencies:n})},ue}(),f=function(){if(ge)return fe;ge=1;const e=Kt();return fe=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:a,packageDevDependencies:n})},fe}(),g=function(){if(he)return ye;he=1;const e=Kt();return ye=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:a,packageDevDependencies:n})},ye}(),y=function(){if(ve)return we;ve=1;const e=Kt();return we=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:a,packageDevDependencies:n})},we}(),h=function(){if(_e)return be;_e=1;const e=Kt();return be=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features,o={};!0===a.app?.enabled&&(o.targets=o.targets||[],o.targets.push({src:"./src/app/index.html",dest:a.app.dir}),Reflect.has(a.app,"copy")||Reflect.has(a,"copy")||(a.copy=!0)),e({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:o},features:a,packageDevDependencies:n})},be}(),w=function(){if(De)return je;De=1;const e=Kt();return je=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features,o=a.css&&!1!==a.css.enabled;let i=[];o&&(i.push(["rollup-plugin-postcss","^4"]),i.push(["sass","^1.66"]),(a.css?.options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":i.push(["postcss-import","^15"]);break;case"postcss-url":i.push(["postcss-url","^10"]);break;case"postcss-preset-env":i.push(["postcss-preset-env","^9"]);break;case"autoprefixer":i.push(["autoprefixer","^10"]);break;case"cssnano":i.push(["cssnano","^6"])}}))),e({feature:{name:"css",packages:i},features:a,packageDevDependencies:n})},je}();function v({dir:e,name:n="index"}){let a=r.resolve(e,`./${n}.tsx`);if(t.existsSync(a)||(a=r.resolve(e,`./${n}.ts`)),t.existsSync(a)||(a=r.resolve(e,`./${n}.jsx`)),t.existsSync(a)||(a=r.resolve(e,`./${n}.js`)),!t.existsSync(a))return{};const o=a,i=r.extname(a);return{file:o,ext:i,ts:".ts"===i||".tsx"===i,name:n}}return ke=async t=>{const{atom:d,context:u,setProgress:b}=t;b("Initializing features..."),d.doc.features=d.doc.features||{};const _=d.doc.features;_.project=_.project||{},_.project.format=_.project.format||_.project_format||"esm",_.project_format=_.project.format,_.dts_enabled=!0===_.dts||void 0!==_.dts&&!1!==_.dts,_.hasOwnProperty("all_parsed_imports")||(_.all_parsed_imports=!0);const j=r.resolve(u.project.projectDir),D=v({dir:r.resolve(j,"./app")});if(D.file){b("Parsing app entry imports...");let e=await n({file:D.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));_.app_uses_jsx=t,_.app_has_entry=!0,e=await n({file:D.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),_.app_entry_uses_jsx=t,_.app_entry_is_ts=D.ts,_.app_entry_ext=D.ext}const k=v({dir:r.resolve(j,"./cli")});if(k.file){b("Parsing cli entry imports...");let e=await n({file:k.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));_.cli_uses_jsx=t,_.cli_has_entry=!0,e=await n({file:k.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),_.cli_entry_uses_jsx=t,_.cli_entry_is_ts=k.ts,_.cli_entry_ext=k.ext}if("workflow.lib"===d.type){const e=v({dir:r.resolve(j,"./src")});if(e.file){b("Parsing src entry imports...");let t=await n({file:e.file,recursive:!0}),r=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));_.src_uses_jsx=r,_.src_has_entry=!0,t=await n({file:e.file}),r=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),_.src_entry_uses_jsx=r,_.src_entry_is_ts=e.ts,_.src_entry_ext=e.ext}}const x=Reflect.has(_,"app_entry_uses_jsx")?!0===_.app_entry_uses_jsx:!0===_.src_entry_uses_jsx,P=Reflect.has(_,"cli_entry_uses_jsx")?!0===_.cli_entry_uses_jsx:!0===_.src_entry_uses_jsx;_.form_enabled=!0===d.doc.form||!0===d.doc.form?.enabled||!0===_.form||!0===_.form?.enabled,_.multiple_enabled=_.multiple_enabled||!0===_.multiple||!0===_.multiple?.enabled,!1===_.app?_.app={enabled:!1}:!0===_.app?_.app={enabled:!0,extend:!0===_.app_has_entry,export:!0,react:x}:_.app={enabled:!0,extend:!0===_.app_has_entry,export:!0,react:x,..._.app||{}},_.app.enabled=!0===_.app.enabled&&(!0===d.doc.features.form_enabled||!0===_.app.extend||!0===_.app.enabled),_.app.format=_.app.format||"esm",_.app.folder=_.app.folder||_.app.format||"default",!1===_.cli?_.cli={enabled:!1}:!0===_.cli?_.cli={enabled:!0,extend:!0===_.cli_has_entry,export:!0,react:P}:_.cli={enabled:!0,extend:!0===_.cli_has_entry,export:!0,react:P,..._.cli||{}},_.cli.enabled=!0===_.cli.enabled&&(!1===d.doc.features.form_enabled||!0===_.cli.extend||!0===_.cli.enabled),_.cli.format=_.cli.format||"esm",_.cli.folder=_.cli.folder||_.cli.folder||"esm",_.cli.node_options=_.cli.node?.options||_.cli.node_options||"",_.json=_.cli.enabled||_.json;const S={cjs:{format:"cjs",context:_.form_enabled?"window":"global",babel:!0===_.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!1!==_.cjs,copy:!1},esm:{format:"esm",context:_.form_enabled?"window":"global",babel:!0===_.src_uses_jsx||!1,browser:!1,replace:!0,browsersync:!0,terser:!1,enabled:!1!==_.esm,copy:!0},iife:{format:"iife",context:_.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1!==_.iife,terser:!0,copy:!1}};!0===_.webos&&(S.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}}),!0===_.electron&&(S.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===_.nextjs&&(S.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===_.ios&&(S.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===_.macos&&(S.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===_.app.enabled&&(_.app.dir=`./dist/app/${_.app.folder}`,S.app={format:_.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:_.app.dir,terser:!0,output_exports:!1===_.app.export?"none":"auto"}),!0===_.cli.enabled&&(_.cli.dir=`./dist/cli/${_.cli.folder}`,S.cli={format:_.cli.format,context:"global",babel:!0===_.src_uses_jsx||!0===_.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:_.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===_.cli.export?"none":"auto"});const A={server:".",startPath:`${r.normalize(_.app.dir||".")}`,files:[r.normalize("./dist/**/*")],cors:!0,open:!1};_.babel_options=e({targets:{browsers:"last 9 versions, not dead",node:"18"}},_.babel_options||_.babel?.options),_.browsersync_options=e(A,_.browsersync_options||_.browsersync?.options||{}),_.replace_options=e({},_.replace_options||_.replace?.options||{}),Reflect.has(_.browsersync_options,"proxy")&&delete _.browsersync_options.server,_.rollup=_.rollup||{},_.rollup_output=e(S,_.rollup_output||_.rollup?.output||{}),_.preact_enabled=!0===_.preact||_.preact&&!1!==_.preact?.enabled;let E=Object.keys(S);for(const t of E){const r=S[t];r&&(!1!==_.rollup[t]?(r.babel_options=r.babel_options||_.babel_options,r.browsersync_options=e(_.browsersync_options,r.browsersync_options),r.replace_options=e(_.replace_options,r.replace_options),_.preact_enabled&&(r.alias_enabled=!0,r.alias=r.alias||{},r.alias.entries=r.alias.entries||{},r.alias.entries.react="preact/compat",r.alias.entries["react-dom"]="preact/compat"),_.form_enabled&&(r.babel=!0)):delete _.rollup_output[t])}E=Object.keys(_.rollup_output),_.babel_enabled=E.some((e=>!0===_.rollup_output[e].babel)),_.browser_enabled=E.some((e=>!0===_.rollup_output[e].babel)),_.browsersync_enabled=!1!==_.browsersync&&E.some((e=>!0===_.rollup_output[e].browsersync)),_.browsersync_enabled=_.browsersync_enabled&&_.app.enabled,_.dependency_auto_enabled=!1!==_.dependency_auto&&!1!==_.dependency_auto?.enabled,_.npm_install_flags=_.npm_install_flags||"",_.react_version=_.react_version||_.react?.version||18,w(t),h(t),y(t),g(t),f(t),l(t),m(t),p(t),c(t),s(t),i(t),a(t),o(t)},ke}function Ht(){if(Ee)return Ae;Ee=1;const e=j;return Ae=async({atom:t,packageDependencies:r,packageDevDependencies:n,setProgress:a})=>{if(a("Initializing dependencies"),"workflow"===t.type&&(r.push({package:"get-value",version:"^3"}),r.push({package:"set-value",version:"^4"})),t.doc.features.form_enabled&&t.doc.features.dependency_auto_enabled){let n="^18.2";a("Fetching React versions");n=`^${(await e({name:"react",groupBy:{major:!0}})).find((e=>e[0]===t.doc.features.react_version.toString()))[0]}`,r.push({package:"react",version:n}),r.push({package:"react-dom",version:n}),"workflow"===t.type&&(r.push({package:"@flownet/react-app",version:"^0.1"}),r.push({package:"@flownet/react-app-state",version:"^0.1"}))}t.doc.features.preact_enabled&&r.push({package:"preact",version:"^10"}),!0===t.doc.features.cli.enabled&&(r.push({package:"@fnet/args",version:"^0.1"}),n.push({package:"ajv",version:"^8"}),t.doc.features.cli.fargs&&!1!==t.doc.features.cli.fargs?.enabled&&r.push({package:"@fnet/config",version:"0.2.21"})),t.doc.features.render&&!1!==t.doc.features.render.enabled&&n.push({package:"@flownet/lib-render-templates-dir",version:"0.1.17"}),n.push({package:"@babel/core",version:"^7"}),n.push({package:"@rollup/plugin-commonjs",version:"^28"}),n.push({package:"@rollup/plugin-node-resolve",version:"^15"}),n.push({package:"@rollup/plugin-replace",version:"^6"}),n.push({package:"rollup",version:"^4"}),t.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"}),t.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"}),t.doc.features.babel?.options?.plugins?.forEach((e=>{switch(e[0]){case"@babel/plugin-proposal-decorators":n.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":n.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":n.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":n.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":n.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"})}}))),n.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),t.doc.features.browsersync_enabled&&n.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})},Ae}function Xt(){if(Ce)return Ie;Ce=1;const e=d,t=u,r=l;return Ie=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{if(!0!==n.doc.features.app.enabled)return;await a({message:"Creating app folder"});const s={atom:n,packageDependencies:i,ts:Date.now()},c=o.templateDir,p=t.resolve(o.projectDir,"src/app");e.existsSync(p)||e.mkdirSync(p,{recursive:!0});let l=["index.js.njk"];!1!==n.doc.features.app.html&&l.push("index.html.njk"),await r({pattern:l,dir:t.resolve(c,"src/app"),outDir:p,context:s})},Ie}function Yt(){if(Re)return Oe;Re=1;const e=D,t=k,r=d,n=u;return Oe=async({projectDir:a,name:o,setProgress:i,count:s=1})=>{let c;const p=t(["npm-pick-versions",o,s]),l=n.join(a,".cache"),d=n.join(l,p+".json");return r.existsSync(d)?(i&&i(`Picking npm version of ${o} from cache ...`),c=JSON.parse(r.readFileSync(d,"utf8"))):(i&&i(`Picking npm version of ${o} ...`),c=await e({name:o,count:s}),r.mkdirSync(l,{recursive:!0}),r.writeFileSync(d,JSON.stringify(c),"utf8")),c}}function Zt(){if(Fe)return Me;Fe=1;const e=m,t=d,r=u,n=_,a=Yt();return Me=async({atom:o,context:i,packageDependencies:s,packageDevDependencies:c,setProgress:p})=>{await p({message:"Creating package.json."});s.filter((e=>!0===e.dev)).forEach((e=>{c.find((t=>t.package===e.package))||c.push(e);const t=s.findIndex((t=>t.package===e.package));s.splice(t,1)}));const l=s.find((e=>"react"===e.package)),d=s.find((e=>"react-dom"===e.package));l&&!d?s.push({package:"react-dom",version:l.version}):l&&d&&(d.version=l.version),l&&o.doc.features.react_version>=17&&(s.find((e=>"@emotion/react"===e.package))||s.push({package:"@emotion/react",version:"^11"}),s.find((e=>"@emotion/styled"===e.package))||s.push({package:"@emotion/styled",version:"^11"}));const u=[];!0===o.doc.features.app.enabled&&u.push({file:r.resolve(i.projectDir,"src/app/index.js"),dev:!1!==o.doc.features.app.dev}),!0===o.doc.features.cli.enabled&&u.push({file:r.resolve(i.projectDir,"src/cli/index.js"),dev:!1!==o.doc.features.cli.dev});for await(const e of u){const r=e.file;if(!t.existsSync(r))throw new Error(`App file not found: ${r}`);const l=await n({file:r,recursive:!0}),d=!0===o.doc.features.all_parsed_imports?l.all:l.required;for await(const t of d){if("npm"!==t.type)continue;if(s.find((e=>e.package===t.package)))continue;if(c.find((e=>e.package===t.package)))continue;const r=await a({name:t.package,projectDir:i.projectDir,setProgress:p});(!0===e.dev?c:s).push({package:t.package,subpath:t.subpath,version:r.minorRange,type:"npm"})}}const m={atom:o,packageDependencies:s,packageDevDependencies:c},f=i.templateCommonDir,g=e.compile(t.readFileSync(r.resolve(f,"package.json.njk"),"utf8"),e.configure(f)).render(m),y=i.projectDir,h=r.resolve(y,"package.json");t.writeFileSync(h,g,"utf8");const w=r.resolve(i.project.projectDir,"fnet");if(t.existsSync(w)){const e=r.resolve(i.projectDir,"fnet");t.existsSync(e)||t.mkdirSync(e);const n=t.readdirSync(w);for(const a of n){const n=r.resolve(w,a);if(!t.lstatSync(n).isFile())continue;const o=r.resolve(e,a);t.copyFileSync(n,o)}}},Me}function Qt(){if(Le)return qe;Le=1;const e=d,t=u,r=l;return qe=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{if(!0!==n.doc.features.cli.enabled)return;await a({message:"Creating cli."});const s={atom:n,packageDependencies:i},c=o.templateDir,p=t.resolve(o.projectDir,"src/cli");e.existsSync(p)||e.mkdirSync(p,{recursive:!0}),await r({pattern:["index.js.njk"],dir:t.resolve(c,"src/cli"),outDir:p,context:s})},qe}function Vt(){if(Be)return ze;Be=1;const e=d,t=u,r=m,n=_;return ze=async({atom:a,setProgress:o,context:i,packageDependencies:s})=>{await o({message:"Creating rollup file."});const c={atom:a,packageDependencies:s},p=t.resolve(i.projectDir,"src","default/index.js");if(!e.existsSync(p))throw new Error(`Entry file not found: ${p}`);const l=(await n({file:p,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),d=a.doc.features.rollup_output,u=Object.keys(d);for(let e=0;e<u.length;e++){const t=d[u[e]];if(!0===t.browser&&l.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(l.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<l.length;e++){const r=l[e];t.alias.entries[r]=`node:${r}`,t.alias.entries[`node:${r}`]=r}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(l)}}const m=i.templateCommonDir;let f=r.compile(e.readFileSync(t.resolve(m,"rollup.config.mjs.njk"),"utf8"),r.configure(m)).render(c);const g=i.projectDir;let y=t.resolve(g,"rollup.config.mjs");e.writeFileSync(y,f,"utf8")},ze}function er(){if(We)return Je;We=1;const e=d,t=u,r=m,n=x,a=P,o=S;return Je=async({atom:i,setProgress:s,context:c,njEnv:p})=>{if(!0!==i.doc.features.cli.enabled)return;await s({message:"Creating yargs."});let l={};if(l=i.doc.input?i.doc.input:{type:"object",properties:{},required:[]},i.doc.features.cli.fargs&&!1!==i.doc.features.cli.fargs?.enabled){const e=i.doc.features.cli.fargs,t={type:"string",description:"Config name to load args",hidden:!1},r={type:"array",description:"Tags to filter the config",hidden:!1};Reflect.has(e,"default")&&(t.default=e.default),l.properties&&(l.properties.fargs=t,l.properties.ftag=r)}const d={options:l,imports:[],atom:i},u=c.templateDir,m=r.compile(e.readFileSync(t.resolve(u,"src/default/to.args.js.njk"),"utf8"),p).render(d),f=c.projectDir,g=t.resolve(f,"src/default/to.args.js");e.writeFileSync(g,m,"utf8");const y=new n({allErrors:!0,useDefaults:!0,formats:{email:!0},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});o(y);const h=y.compile(l),w=a(y,h);e.writeFileSync(t.resolve(f,"src/default/validate_input.js"),w,"utf8")},Je}function tr(){if(Ge)return Ke;Ge=1;const e=d,t=u,r=m;return Ke=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{await a({message:"Creating .gitignore"});const s={atom:n,packageDependencies:i},c=o.templateCommonDir,p=r.compile(e.readFileSync(t.resolve(c,".gitignore.njk"),"utf8"),r.configure(c)).render(s),l=o.projectDir,d=t.resolve(l,".gitignore");e.writeFileSync(d,p,"utf8")},Ke}function rr(){if(Xe)return He;Xe=1;const e=d,t=u,r=m;return He=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{await a({message:"Creating tsconfig.json."});const s={atom:n,packageDependencies:i},c=o.templateCommonDir,p=r.compile(e.readFileSync(t.resolve(c,"tsconfig.json.njk"),"utf8"),r.configure(c)).render(s),l=o.projectDir,d=t.resolve(l,"tsconfig.json");e.writeFileSync(d,p,"utf8")},He}function nr(){if(Ze)return Ye;Ze=1;const e=m,t=d,r=u,n=s;return Ye=async({atom:a,context:o,setProgress:i,Atom:s})=>{const c="readme.md",p=`Creating ${c}`;if(await i({message:p}),o.project?.readme){const a=o.projectDir,i={content:o.project.readme.doc.content},s=r.resolve(o.project.projectDir,"fnet/how-to.md");if(t.existsSync(s)){const e=t.readFileSync(s,"utf8");i.howto=e}const p=r.resolve(o.project.projectDir,"fnet/input.yaml");if(t.existsSync(p)){const e=await n({file:p,tags:o.tags});i.input=e.content}const l=o.templateCommonDir,d=e.compile(t.readFileSync(r.resolve(l,`${c}.njk`),"utf8"),e.configure(l)).render(i),u=r.resolve(a,`${c}`);t.writeFileSync(u,d,"utf8")}else if(a.id){const n=await s.first({type:"wiki",parent_id:a.id});if(!n||"markdown"!==n.doc?.["content-type"])return;const{content:i,...p}=n.doc,l={content:i},d=o.templateCommonDir,u=e.compile(t.readFileSync(r.resolve(d,`${c}.njk`),"utf8"),e.configure(d)).render(l),m=o.projectDir,f=r.resolve(m,`${c}`);t.writeFileSync(f,u,"utf8")}},Ye}function ar(){if(Ve)return Qe;Ve=1;const e=r,t=p;return Qe=async({setProgress:r,context:n})=>{const a=n.projectDir;await r({message:"Prettifiying source files."});let o=e.join("src","**","*");await t({commands:{steps:[`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`],wdir:a}})}}function or(){if(tt)return et;tt=1;const e=i;return et=async({atom:t,setProgress:r,context:n})=>{if(!t.doc.features.dts_enabled)return;const a=n.projectDir;await r({message:"Creating .d.ts"});if(0!==e.exec("tsc",{cwd:a}).code)throw new Error("Couldnt create .d.ts files.")},et}function ir(){if(nt)return rt;nt=1;const e=i;return rt=async({setProgress:t,atom:r,context:n})=>{const a=n.projectDir;await t({message:"Installing npm packages."});if(0!==e.exec(`npm install ${r.doc.features.npm_install_flags}`,{cwd:a}).code)throw new Error("Couldnt install npm packages.")},rt}function sr(){if(ot)return at;ot=1;const e=i;return at=async({setProgress:t,context:r})=>{const n=r.projectDir;await t({message:"Building main project."});if(0!==e.exec("npm run build",{cwd:n}).code)throw new Error("Couldnt build project.")}}function cr(){if(Lt)return qt;Lt=1;const e=function(){if(st)return it;st=1;const e=A,r=t;return it=async({setProgress:t,context:n,deploymentProject:a,deploymentProjectTarget:o,buildId:i})=>{await t({message:"Deploying it as gitlab project."});const s=n.projectDir;let c="fnet-to-gitlab";const p=o.params.config||"gitlab",l=await r({name:p,dir:n.projectDir,tags:n.tags});if(!l)throw new Error(`Couldnt load config ${p}`);const{data:d}=l.data;c+=` --projectGroupId=${d.projectGroupId}`,c+=` --projectPath='${s}'`,c+=` --projectName='${o.params.name}'`,c+=` --projectBranch='${o.params.branch||"main"}'`,c+=` --gitlabHost='${d.gitlabHost}'`,c+=` --gitlabToken='${d.gitlabToken}'`,c+=` --gitlabUsername='${d.gitlabUsername}'`,c+=` --gitlabUserEmail='${d.gitlabUserEmail}'`,!0!==o.dryRun&&(await e({cmd:c}),a.isDirty=!0)}}(),n=function(){if(pt)return ct;pt=1;const e=d,r=u,n=E,a=A,o=t;return ct=async({setProgress:t,context:i,deploymentProject:s,deploymentProjectTarget:c,registerToPackageManager:p,yamlTarget:l})=>{await t({message:"Deploying it as gcs package."});const d=i.projectDir,u=r.resolve(d,"package.json"),m=e.readFileSync(u),f=JSON.parse(m);f.name=c.params.name,f.version=n.inc(c.version,"patch"),delete f.scripts,delete f.devDependencies,e.writeFileSync(u,JSON.stringify(f,null,"\t"));const{file:g,data:y}=await o({name:c.config||"gcs",dir:i.projectDir,tags:i.tags});let h="fnet-files-to-gcs";h+=` --projectId='${y.env.GCS_PROJECT_ID}'`,h+=` --bucketName='${y.env.GCS_BUCKET_NAME}'`,h+=` --keyFilename='${r.resolve(r.dirname(g),y.env.GCS_UPLOADER_KEY_FILE)}'`,h+=` --dir='${d}'`,h+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",h+=` --destDir='${f.name}/${f.version}'`,h+=" --metadata.cacheControl='public, max-age=31536000, immutable'",y.env.DOMAIN&&(h+=` --domain='${y.env.DOMAIN}'`),!0!==c.dry_run&&!0!==c.params.dry_run||(h+=" --dryRun"),await a({cmd:h}),e.writeFileSync(u,m),!0!==c.dryRun&&(s.isDirty=!0,c.version=f.version,l.set("version",f.version),await p({target:c,packageJSON:f}))}}(),s=function(){if(dt)return lt;dt=1;const e=d,r=u,n=E,a=i,s=t,p=$,l=c,m=o;return lt=async({atom:t,setProgress:o,context:i,deploymentProject:c,deploymentProjectTarget:d,yamlTarget:u})=>{await o({message:"Deploying it as npm package."});const f=i.projectDir,g=r.resolve(f,"package.json"),y=e.readFileSync(g),h=JSON.parse(y);h.name=d.params.name,h.version=n.inc(d.version,"patch");const w=d.params.bin?.name||d.params.bin;!1!==d.params.bin?.enabled&&w&&"string"==typeof w&&(h.bin={[w]:"dist/cli/esm/index.js",[t.doc.name]:"dist/cli/esm/index.js"}),delete h.scripts,delete h.devDependencies,h.scripts={serve:"npx serve ."},e.writeFileSync(g,JSON.stringify(h,null,"\t"));const v=d.config||"npm";let b=(await s({name:v,dir:i.projectDir,tags:i.tags,optional:!0}))?.data;if(!b){const t=p({dir:__dirname,pattern:"@fnet/cli-project-schemas/dist/schemas/to-npm.yaml",absolute:!0});if(0===t.length)throw new Error("Couldnt find schema to create npm config");const n=await l({schema:t[0],tags:i.tags}),a=i.project.projectDir,o=r.resolve(a,".fnet");e.existsSync(o)||e.mkdirSync(o),e.writeFileSync(r.resolve(o,`${v}.fnet`),m.stringify(n)),b=n}if(e.writeFileSync(r.resolve(f,".npmrc"),`//registry.npmjs.org/:_authToken=${b.env.NPM_TOKEN}`),!0!==d.dryRun){if(0!==a.exec("npm publish --access public",{cwd:f}).code)throw new Error("Couldnt publish to npm");e.writeFileSync(g,y),c.isDirty=!0,d.version=h.version,u.set("version",h.version)}},lt}(),p=function(){if(mt)return ut;mt=1;const e=d,r=u,n=T,a=m,o=I,i=t;return ut=async({atom:t,setProgress:s,context:c,deploymentProject:p,deploymentProjectTarget:l,buildId:d,packageDependencies:u,njEnv:m})=>{await s({message:"Deploying it as node-red flow."});const f=c.projectDir,g=c.templateDir,y="workflow"===t.type?"WF":"LIB";let h;if("simple"===l.deploy.template)h={atom:t,packageDependencies:u,red:{tab:{id:l.deploy.id||o.util.generateId(),label:`${y}/${t.id?t.id:n.hostname()}/${t.name}/${l.deploy.name||l.deploy.template}`},function:{id:o.util.generateId(),name:t.doc.name,initialize:{content:e.readFileSync(r.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:t.doc.bundleName}},inject:{id:o.util.generateId(),...l.params?.inject,payload:"json"===l.params?.inject?.payloadType?`'${JSON.stringify(l.params?.inject?.payload)}'`:l.params?.inject?.payload},debug:{id:o.util.generateId()}}};else if("cronjob"===l.deploy.template){let a=l.params?.schedules?cloneDeep(l.params?.schedules):void 0;a?.forEach((e=>{"json"===e.payloadType&&(e.payload=`'${JSON.stringify(e.payload)}'`)})),h={atom:t,packageDependencies:u,red:{tab:{id:l.deploy.id||o.util.generateId(),label:`${y}/${t.id?t.id:n.hostname()}/${l.deploy.name||l.deploy.template}`},function:{id:o.util.generateId(),name:t.doc.name,initialize:{content:e.readFileSync(r.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:t.doc.bundleName}},cronjob:{id:o.util.generateId(),schedules:a},debug:{id:o.util.generateId()}}}}else{if("http"!==l.deploy.template)return;h={atom:t,packageDependencies:u,red:{tab:{id:l.deploy.id||o.util.generateId(),label:`${y}/${t.id?t.id:n.hostname()}/${l.deploy.name||l.deploy.template}`},function:{id:o.util.generateId(),name:t.doc.name,initialize:{content:e.readFileSync(r.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:t.doc.bundleName}},httpin:{id:o.util.generateId(),method:l.params.method||"get",url:l.params.url},httpout:{id:o.util.generateId()},debug:{id:o.util.generateId()}}}}let w=a.compile(e.readFileSync(r.resolve(g,`deploy/node-red/${l.deploy.template}.yaml.njk`),"utf8"),m).render(h);if(e.writeFileSync(r.resolve(f,"node-red.yaml"),w),w=yaml.load(w),!0===l.dryRun)return;p.isDirty=!0;const v=(await i({name:c.redConfig||"red",dir:c.projectDir,tags:c.tags}))?.data,b=l.deploy.url||v.env.RED_URL,_={};if(!1!==l.deploy.auth&&(_.Authorization="Bearer "+atomAccessToken),l.deploy.id)!0===l.actions?.delete?(await axios({method:"DELETE",url:`${b}/flow/${l.deploy.id}`,headers:_}),delete l.actions.delete,delete l.deploy.id,l.enabled=!1):await axios({method:"PUT",url:`${b}/flow/${l.deploy.id}`,data:w,headers:_});else{const e=await axios({method:"POST",url:`${b}/flow`,data:w,headers:_});l.deploy.id=e.data.id}},ut}(),l=function(){if(gt)return ft;gt=1;const e=a,n=r,o=t;return ft=async({atom:t,Atom:r,setProgress:a,context:i,packageDependencies:s,deploymentProject:c,deploymentProjectTarget:p})=>{await a({message:"Deploying it as workflow lib."});const l=(await o({name:"atom",dir:i.projectDir,tags:i.tags}))?.data;let d,u,m,f=p.deploy.name.split("/");if(1===f.length)u=l.env.ATOM_LIBRARIES_ID,m=p.deploy.name;else{if(2!==f.length)throw new Error("Wrong name path.");{const e=await r.first({where:{name:f[0],parent_id:l.env.ATOM_LIBRARIES_ID,type:"folder"},limit:1});if(!e)throw new Error("Couldnt file lib folder.");u=e.id,m=f[1]}}if(!0===p.dryRun)return;if(c.isDirty=!0,p.deploy.id){if(d=await r.get({id:p.deploy.id}),!d)return}else{if(d=await r.create({parent_id:u,doc:{name:m,type:"workflow.lib","content-type":"javascript",dependencies:[],content:void 0,subtype:"workflow"}}),!d)return;p.deploy.id=d.id}const g=i.projectDir;d.doc.contents=[{content:e.readFileSync(n.resolve(g,"dist/default/esm/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"esm"},{content:e.readFileSync(n.resolve(g,"dist/default/cjs/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"cjs"},{content:e.readFileSync(n.resolve(g,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"iife"}],d.doc.name=m,d.doc.dependencies=s,"workflow.lib"===t.type?d.doc.subtype="library":"workflow"===t.type&&(d.doc.subtype="workflow"),d=await r.update(d,{id:d.id})}}(),f=function(){if(ht)return yt;ht=1;const e=t,r=C,n=O,a=E;return yt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as ios-app package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},yt}(),g=function(){if(vt)return wt;vt=1;const e=t,r=R,n=O,a=E;return wt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as macos-app package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},wt}(),y=function(){if(_t)return bt;_t=1;const e=t,r=M,n=O,a=E;return bt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as electron package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},bt}(),h=function(){if(Dt)return jt;Dt=1;const e=t,r=F,n=O,a=E;return jt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as webos package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},jt}(),v=function(){if(xt)return kt;xt=1;const e=t,r=q,n=O,a=E;return kt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as nextjs package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},kt}(),b=function(){if(St)return Pt;St=1;const e=t,r=L,n=O,a=E;return Pt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as docker package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},Pt}(),_=function(){if(Et)return At;Et=1;const e=d,r=u,n=E,a=A,o=t,i=w.default;return At=async({setProgress:t,context:s,deploymentProject:c,deploymentProjectTarget:p,yamlTarget:l})=>{await t({message:"Deploying it as fnet package."});const d=s.projectDir,u=r.resolve(d,"package.json"),m=e.readFileSync(u),f=JSON.parse(m);f.name=p.params.name,f.version=n.inc(p.version,"patch"),delete f.scripts,delete f.devDependencies,e.writeFileSync(u,JSON.stringify(f,null,"\t"));const{file:g,data:y}=await o({name:p.config||"fnet-package",dir:s.projectDir,tags:s.tags});if(!y.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${g}`);if(!y.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${g}`);if(!y.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${g}`);const h=`${y.env.ATOM_API_URL}/v1/auth/token`,w=y.env.ATOM_API_USERNAME,v=y.env.ATOM_API_PASSWORD;let b=await i({method:"POST",url:h,data:{username:w,password:v},headers:{"Content-Type":"application/json"}});const _=b.data?.access_token;if(!_)throw new Error(`Invalid access_token from ${h}`);let j="fnet-files-to-gcs";if(j+=` --projectId='${y.env.GCS_PROJECT_ID}'`,j+=` --bucketName='${y.env.GCS_BUCKET_NAME}'`,j+=` --keyFilename='${r.resolve(r.dirname(g),y.env.GCS_UPLOADER_KEY_FILE)}'`,j+=` --dir='${d}'`,j+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",j+=` --destDir='${f.name}/${f.version}'`,j+=" --metadata.cacheControl='public, max-age=31536000, immutable'",y.env.DOMAIN&&(j+=` --domain='${y.env.DOMAIN}'`),!0!==p.dry_run&&!0!==p.params.dry_run||(j+=" --dryRun"),await a({cmd:j}),e.writeFileSync(u,m),!0===p.dryRun)return;c.isDirty=!0,p.version=f.version,l.set("version",f.version);const D=`${y.env.ATOM_API_URL}/v1/service/fnet-package/publish`;if(b=await i({method:"POST",url:D,data:{name:f.name,version:f.version,version_domain:y.env.DOMAIN,docs:p.params.docs,configs:p.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${_}`}}),b.data?.error)throw new Error("Failed to publish fnet package.")}}(),j=function(){if(Tt)return $t;Tt=1;const e=E,r=t,n=w.default;return $t=async({setProgress:t,context:a,deploymentProject:o,deploymentProjectTarget:i,yamlTarget:s})=>{await t({message:"Deploying it as fnet form."});const{file:c,data:p}=await r({name:i.config||"fnet-form",dir:a.projectDir,tags:a.tags});if(!p.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${c}`);if(!p.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${c}`);if(!p.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${c}`);const l=`${p.env.ATOM_API_URL}/v1/auth/token`,d=p.env.ATOM_API_USERNAME,u=p.env.ATOM_API_PASSWORD;let m=await n({method:"POST",url:l,data:{username:d,password:u},headers:{"Content-Type":"application/json"}});const f=m.data?.access_token;if(!f)throw new Error(`Invalid access_token from ${l}`);o.isDirty=!0;const g=e.inc(i.version,"patch");i.params.version=g,i.version=g,s.set("version",g);const y=`${p.env.ATOM_API_URL}/v1/service/fnet-form/publish`;if(m=await n({method:"POST",url:y,data:{name:i.params.name,version:i.params.version,docs:i.params.docs,configs:i.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${f}`}}),m.data?.error)throw new Error("Error publishing fnet form.")}}(),D=function(){if(Ct)return It;Ct=1;const e=E,r=t,n=w.default,o=a,i=A,s=N;return It=async({setProgress:t,context:a,deploymentProject:c,deploymentProjectTarget:p,yamlTarget:l})=>{await t({message:"Deploying it as fnet flow."});const{file:d,data:u}=await r({name:p.config||"fnet-flow",dir:a.project.projectDir,tags:a.tags});if(!u.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${d}`);if(!u.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${d}`);if(!u.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${d}`);const m=`${u.env.ATOM_API_URL}/v1/auth/token`,f=u.env.ATOM_API_USERNAME,g=u.env.ATOM_API_PASSWORD;let y=await n({method:"POST",url:m,data:{username:f,password:g},headers:{"Content-Type":"application/json"}});const h=y.data?.access_token;if(!h)throw new Error(`Invalid access_token from ${m}`);c.isDirty=!0;const w=e.inc(p.version,"patch");p.params.version=w,p.version=w,l.set("version",w);const v=`${u.env.ATOM_API_URL}/v1/service/fnet-flow/publish`;if(y=await n({method:"POST",url:v,data:{name:p.params.name,version:p.params.version,docs:p.params.docs,configs:p.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${h}`}}),y.data?.error)throw new Error("Error publishing fnet flow.");const b=y.data?.upload.id;let _="fnet-dir-zipper";_+=` --sourceDir='${a.project.projectDir}'`,_+=" -p=**/*",_+=" -g",_+=" --stdout_format=json";const j=await i({cmd:_});if(0!==j.code)throw new Error(j.stderr);const D=JSON.parse(j.stdout).path;let k=new s;k.append("file",o.createReadStream(D));const x=await n.request({method:"POST",maxBodyLength:1/0,url:`${u.env.ATOM_API_URL}/v1/service/upload/single/${b}`,headers:{...k.getHeaders(),Authorization:`Bearer ${h}`},data:k});if(x.data?.error)throw new Error("Error uploading fnet flow.")}}(),k=function(){if(Rt)return Ot;Rt=1;const e=E,r=t,n=w.default,o=a,i=A,s=N;return Ot=async({setProgress:t,context:a,deploymentProject:c,deploymentProjectTarget:p,yamlTarget:l})=>{await t({message:"Deploying it as fnet node."});const{file:d,data:u}=await r({name:p.config||"fnet-node",dir:a.project.projectDir,tags:a.tags});if(!u.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${d}`);if(!u.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${d}`);if(!u.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${d}`);const m=`${u.env.ATOM_API_URL}/v1/auth/token`,f=u.env.ATOM_API_USERNAME,g=u.env.ATOM_API_PASSWORD;let y=await n({method:"POST",url:m,data:{username:f,password:g},headers:{"Content-Type":"application/json"}});const h=y.data?.access_token;if(!h)throw new Error(`Invalid access_token from ${m}`);c.isDirty=!0;const w=e.inc(p.version,"patch");p.params.version=w,p.version=w,l.set("version",w);const v=`${u.env.ATOM_API_URL}/v1/service/fnet-node/publish`;if(y=await n({method:"POST",url:v,data:{name:p.params.name,version:p.params.version,docs:p.params.docs,configs:p.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${h}`}}),y.data?.error)throw new Error("Error publishing fnet node.");const b=y.data?.upload.id;let _="fnet-dir-zipper";_+=` --sourceDir='${a.project.projectDir}'`,_+=" -p=**/*",_+=" -g",_+=" --stdout_format=json";const j=await i({cmd:_});if(0!==j.code)throw new Error(j.stderr);const D=JSON.parse(j.stdout).path;let k=new s;k.append("file",o.createReadStream(D));const x=await n.request({method:"POST",maxBodyLength:1/0,url:`${u.env.ATOM_API_URL}/v1/service/upload/single/${b}`,headers:{...k.getHeaders(),Authorization:`Bearer ${h}`},data:k});if(x.data?.error)throw new Error("Error uploading fnet node.")}}(),x=function(){if(Ft)return Mt;Ft=1;const e=t,r=U,n=O,a=E;return Mt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as Rust package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},Mt}();return qt=async t=>{const{atom:r,packageDependencies:a,context:o,deploymentProjectTarget:i,setProgress:c,deploymentProject:d,yamlTarget:u}=t;if(!0===i.enabled)if("lib"===i.type)await l({...t});else if("red"===i.type)await p({...t});else if("npm"===i.type)await s({...t});else if("gcs"===i.type)await n({...t});else if("gitlab"===i.type)await e({...t});else if("fnet-package"===i.type)await _({...t});else if("fnet-form"===i.type)await j({...t});else if("fnet-node"===i.type)await k({...t});else if("fnet-flow"===i.type)await D({...t});else{let e;if("nextjs"===i.type?e=v:"webos"===i.type?e=h:"electron"===i.type?e=y:"docker"===i.type?e=b:"ios"===i.type?e=f:"macos"===i.type?e=g:"rust"===i.type&&(e=x),!e)return;await e({atom:r,target:i,onProgress:c,projectDir:o.projectDir,dependencies:a,context:o,yamlTarget:u}),d.isDirty=!0}},qt}function pr(){if(Ut)return Nt;Ut=1;const e=d,r=u,n=o,a=i,s=m,c=function(){if(G)return K;G=1;const e=f,t=g;return K=async()=>{if(!await t({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const r=e.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await r.connect(),r}}(),{nanoid:p}=y,b=function(){if(X)return H;X=1;const{Api:e}=h,t=w.default,r=v;return H=class{init({config:n,accessToken:a}){return new Promise(((o,i)=>{if(e.set_api_url(n.data.url),a)return e.set_req_token(a),void o(a);t({method:"POST",url:`${n.data.issuer}/protocol/openid-connect/token`,data:r.stringify(n.data.grant.params),headers:{"Content-Type":"application/x-www-form-urlencoded"}}).then((t=>{e.set_req_token(t.data.access_token),o(t.data.access_token)})).catch((t=>{e.set_req_token(),i(t)}))}))}}}(),j=Gt(),D=(Se||(Se=1,Pe=async e=>{const{atom:t,context:r,setProgress:n}=e;n("Initializing features..."),t.doc.features=t.doc.features||{};const a=t.doc.features;!1===a.cli?a.cli={enabled:!1}:(a.cli,a.cli={enabled:!0}),a.cli.enabled=!0===a.cli.enabled&&(!1===t.doc.features.form_enabled||!0===a.cli.extend||!0===a.cli.enabled)}),Pe),k=Ht(),x=Te?$e:(Te=1,$e=async({atom:e,packageDependencies:t,packageDevDependencies:r,setProgress:n})=>{n("Initializing dependencies")}),P=Xt(),S=Zt(),A=Qt(),E=function(){if(Ue)return Ne;Ue=1;const e=d,t=u,r=l;return Ne=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{if(!0!==n.doc.features.cli.enabled)return;await a({message:"Creating cli."});const s={atom:n,packageDependencies:i},c=o.templateDir,p=t.resolve(o.projectDir,"cli");e.existsSync(p)||e.mkdirSync(p,{recursive:!0}),await r({pattern:["index.py.njk"],dir:t.resolve(c,"cli"),outDir:p,context:s})},Ne}(),$=Vt(),T=er(),I=tr(),C=rr(),O=nr(),R=ar(),M=or(),F=ir(),q=sr(),L=Yt(),N=cr(),{Atom:U}=h,W=z,Y=t,Z=_,Q=B,V=J;return Nt=class{#e;#t;#r;#n;#a;#o;#i;#s;#c;#p;#l;#d;#u;#m;#f;#g;#y;constructor(e){this.#e=new b,this.#t=e,this.#o=[],this.#i=[],this._expire_ttl=3600,this._expire_ttl_short=300,this.#y={packageDependencies:this.#o,packageDevDependencies:this.#i,setProgress:this.setProgress.bind(this),context:this.#t,Atom:U,registerToPackageManager:this.registerToPackageManager.bind(this)}}async _cache_set(e,t,r){this._redis_client&&await this._redis_client.SETEX(e,r||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async initAuth(){this.#t.id&&(this.#s=await this.#e.init({config:this.#d}),this.#y.atomAccessToken=this.#s)}async initLibrary(){const e=this.#t.id;this.#r=this.#t.project?.libraryAtom||await U.get({id:e});let t=this.#r.doc.bundleName;t=t||(this.#r.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#r.doc.bundleName=t,this.#r.type=this.#r.type||"workflow.lib",this.#y.atom=this.#r}async initLibraryDir(){this.setProgress({message:"Initializing library directory."});const t=this.#t.projectDir;let n;this.setProgress({message:"Cleaning project directory."});const o=Q({dir:t,ignore:["node_modules",".cache"],absolute:!0});for(const t of o)e.rmSync(t,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."});let i=t;if(!e.existsSync(i)&&(n=a.exec(`mkdir "${t}"`),0!==n.code))throw new Error("Couldnt create workflow dir.");if(i=r.join(t,"src"),!e.existsSync(i)&&(n=a.exec(`mkdir "${i}"`),0!==n.code))throw new Error("Couldnt create library/src dir.");if(i=r.join(t,"src","default"),!e.existsSync()&&(n=a.exec(`mkdir "${i}"`),0!==n.code))throw new Error("Couldnt create library/src/default dir.")}async initLibraryDirPython(){this.setProgress({message:"Initializing library directory."});const t=this.#t.projectDir;let n;this.setProgress({message:"Cleaning project directory."});const o=Q({dir:t,ignore:[".cache","src"],absolute:!0});for(const t of o)e.rmSync(t,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."});let i=t;if(e.existsSync(i)||e.mkdirSync(i,{recursive:!0}),i=r.join(t,"src"),!e.existsSync(i)&&(n=a.exec(`ln -s "${this.#t.projectSrcDir}" "${i}" `),0!==n.code))throw new Error("Couldnt link src.")}async initNunjucks(){this.setProgress({message:"Initializing nunjucks."});const e=this.#t.templateDir;this.#n=s.configure(e,{watch:!1,dev:!0}),this.#y.njEnv=this.#n}async initLibs(){this.setProgress({message:"Initializing external libs."});const e=[{name:this.#r.doc.name,type:"atom",parent_id:this.#r.parent_id}];this.#a=e,await this.initAtomLibsAndDeps({libs:e,packageDependencies:this.#o})}async initLibsPython(){this.setProgress({message:"Initializing external libs."});const e=this.#r;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const t=[{name:this.#r.doc.name,type:"atom",parent_id:this.#r.parent_id,atom:e}];this.#a=t}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const r=e.filter((e=>"atom"===e.type));for(let e=0;e<r.length;e++){const n=r[e],a=await this.findAtomLibrary({url:n.name});n.atom=a;const o=a.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));o?.forEach((e=>{const r=t.find((t=>t.package===e.package));r?"string"==typeof e.path?(r.path||[]).some((t=>t===e.path))||(r.path=r.path||[],r.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(r.path||[]).some((t=>t===e))||(r.path=r.path||[],r.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const t=W({url:e});if(!t)throw new Error(`Invalid package name: ${e}`);if(t.protocol||(t.protocol=this.#l),"ac:"===t.protocol){const r=t.pathname.split("/");if(1===r.length)return await U.first({where:{name:e,parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===r.length){const e=await U.first({where:{name:r[0],parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"folder"}});return await U.first({where:{name:r[1],parent_id:e.id,type:"workflow.lib"}})}}else if("local:"===t.protocol){const e=this.#r;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const t=r.resolve(this.#t.projectSrcDir,"index.js"),n=await Z({file:t,recursive:!0}),a=e.doc.dependencies,o=!0===this.#r.doc.features.all_parsed_imports?n.all:n.required;for await(const e of o){if("npm"!==e.type)continue;if(a.find((t=>t.package===e.package)))continue;const t=await L({name:e.package,projectDir:this.#t.projectDir,setProgress:this.#y.setProgress});a.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return e}}async createAtomLibFiles({libs:t}){await this.setProgress({message:"Creating external lib files."}),this.#r.typesDir="./types";const n=t.filter((e=>"atom"===e.type));for(let t=0;t<n.length;t++){const a=n[t].atom,o=this.#t.projectDir;if("local:"===a.protocol){const t=r.resolve(this.#t.projectSrcDir,`${a.fileName||a.name}.js`),n=r.relative(r.join(this.#t.projectDir,"src","default"),t);if(!e.existsSync(t)){e.mkdirSync(r.dirname(t),{recursive:!0});let n="export default async (args)=>{\n";n+="}",e.writeFileSync(t,n,"utf8")}a.relativePath=n.split(r.sep).join("/"),this.#r.typesDir=`./types/${r.basename(o)}/src`}else{const t=r.join(o,"src","libs",`${a.id}.js`),n=a.doc.contents?.find((e=>"esm"===e.format))||a.doc;e.writeFileSync(t,n.content,"utf8")}}}async createAtomLibFilesPython({libs:t}){await this.setProgress({message:"Creating external lib files."});const n=t.filter((e=>"atom"===e.type));for(let t=0;t<n.length;t++){const a=n[t].atom;if("local:"===a.protocol){const t=r.resolve(this.#t.projectSrcDir,`${a.fileName||a.name}.py`);if(!e.existsSync(t)){e.mkdirSync(r.dirname(t),{recursive:!0});let n="def default():\n";n+=' print("Hello world!")\n',e.writeFileSync(t,n,"utf8")}}}}async createEngine(){await this.setProgress({message:"Creating engine file."});const t={libs:this.#a.filter((e=>"atom"===e.type)),libraryAtom:this.#r,atom:this.#r},n=this.#t.templateDir,a=s.compile(e.readFileSync(r.resolve(n,r.join("src","default","engine.js.njk")),"utf8"),this.#n).render(t),o=this.#t.projectDir,i=r.resolve(o,r.join("src","default","index.js"));e.writeFileSync(i,a,"utf8")}async createProjectYaml(){const t="node.yaml",a=`Creating ${t}`;await this.setProgress({message:a});const{content:o,...i}=this.#r.doc,c={content:n.stringify(i)},p=this.#t.templateDir,l=s.compile(e.readFileSync(r.resolve(p,`${t}.njk`),"utf8"),this.#n).render(c),d=this.#t.projectDir,u=r.resolve(d,`${t}`);e.writeFileSync(u,l,"utf8")}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#t.project?.devops){const e=[this.#t.project?.devops];for(let t=0;t<e.length;t++){let r=e[t];await this.deployProject({deploymentProject:r}),!0===r.isDirty&&await r.save()}}else if(this.#r.id){const e=await U.list({type:"library.deploy",parent_id:this.#r.id});for(let t=0;t<e.length;t++){let r=e[t];await this.deployProject({deploymentProject:r}),!0===r.isDirty&&(r=await U.update(r,{id:r.id}))}}}async deployProject(e){const{deploymentProject:t}=e,{yamlDocument:r}=t;if(t.doc.targets&&Array.isArray(t.doc.targets))throw new Error("Deployment project targets are deprecated. Please update targets in the yaml file.");const n=Object.keys(t.doc||{}),a=r||{};for(let e=0;e<n.length;e++){const r=t.doc[n[e]];r.name=n[e];const o=a.get(n[e]);await N({...this.#y,deploymentProject:t,deploymentProjectTarget:r,yamlTarget:o})}}async registerToPackageManager(e){const{target:t,packageJSON:r}=e;if(!this.#t.id)return;let n=await U.first({name:t.params.name,parent_id:this.#d.env.ATOM_PACKAGES_ID});n?(n.doc.versions.splice(0,0,{v:r.version}),await U.update(n,{id:n.id})):n=await U.create({parent_id:this.#d.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:r.version}]}})}async setProgress(e){const t="string"==typeof e?e:e?.message;console.log(V.blue(t)),await this._cache_set(this.#p,{status:"IN_PROGRESS",message:t})}async initNode(){await j(this.#y),await k(this.#y),await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}async initPython(){await D(this.#y),await x(this.#y),await this.initLibraryDirPython(),await this.initNunjucks(),await this.initLibsPython()}async nodeBuild(){this.#m&&(await this.createAtomLibFiles({libs:this.#a}),await this.createEngine(),await this.createProjectYaml(),await O(this.#y),await C(this.#y),await I(this.#y),await T(this.#y),await A(this.#y),await P(this.#y),await $(this.#y),await S(this.#y),await R(this.#y),await M(this.#y),this.#f&&(await F(this.#y),await q(this.#y),this.#g&&await this.deploy()))}async pythonBuild(){this.#m&&(await this.createAtomLibFilesPython({libs:this.#a}),await this.createProjectYaml(),await O(this.#y),await I(this.#y),await E(this.#y),this.#f)}async init(){this._redis_client=await c(),this.#c=this.#t.buildId||p(24),this.#y.buildId=this.#c,this.#u=this.#t.mode,this.#m=["all","deploy","build","file"].includes(this.#u),this.#f=["all","deploy","build"].includes(this.#u),this.#g=["all","deploy"].includes(this.#u),this.#l=this.#t.protocol,this.#p="BUILD:"+this.#c,this.#d=(await Y({optional:!0,name:this.#t.atomConfig||"atom",dir:this.#t.projectDir,tags:this.#t.tags}))?.data;try{await this.setProgress({message:"Initialization started."}),await this.initAuth(),await this.initLibrary(),"node"===this.#r.doc.features.runtime.type?await this.initNode():"python"===this.#r.doc.features.runtime.type&&await this.initPython()}catch(e){throw await this._cache_set(this.#p,{status:"FAILED",message:e?.message||e}),e}}async build(){try{"node"===this.#r.doc.features.runtime.type?await this.nodeBuild():"python"===this.#r.doc.features.runtime.type&&await this.pythonBuild(),await this._cache_set(this.#p,{status:"COMPLETED"})}catch(e){throw await this._cache_set(this.#p,{status:"FAILED",message:e.message||e}),console.log(e),e}}},Nt}var lr=W(function(){if(Jt)return Wt;Jt=1;const m=process.cwd(),{spawn:f}=e;t({name:["redis"],dir:m,optional:!0});const g=r,y=n,h=a,w=o,v=i,b=s,_=t,j=c,D=p,k=l,x=pr(),P=function(){if(Bt)return zt;Bt=1;const e=d,t=u;return zt=function({baseDir:r=__dirname}){let n=r;for(;n!==t.parse(n).root;){const r=t.join(n,"node_modules");if(e.existsSync(r))return r;n=t.dirname(n)}return null}}()({baseDir:__dirname}),S="win32"===process.platform?";":":";process.env.PATH=`${g.join(P,"/.bin")}${S}${process.env.PATH}`;let A=y(process.argv.slice(2)).command("create","Create flow node project",(e=>e.option("name",{type:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs"}).option("runtime",{type:"string",default:"node",choices:["node","python"]})),(async e=>{try{const t=g.resolve(P,"@fnet/cli-project-node/dist/template/project"),r=g.resolve(m,e.name);h.existsSync(r)||h.mkdirSync(r),await k({dir:t,outDir:r,context:e,copyUnmatchedAlso:!0});let n=v.exec("fnode build",{cwd:r});if(0!==n.code)throw new Error("Failed to build project.");if(v.which("git")&&(n=v.exec("git init --initial-branch=main",{cwd:r}),0!==n.code))throw new Error("Failed to initialize git.");if(v.which("code")&&e.vscode&&(n=v.exec(`cd ${r} && code .`),0!==n.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=g.resolve(P,"@fnet/cli-project-node/dist/template/project"),r=process.cwd(),n=await $(e);if(e.update){if(await k({dir:t,outDir:r,context:{name:n.project.projectFileParsed.name,runtime:n.project.runtime.type},copyUnmatchedAlso:!0}),0!==v.exec("fnode build",{cwd:r}).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",default:"build",choices:["all","file","build","deploy","bpmn"]}).option("ftag",{type:"array"})),(async e=>{try{const t=await $(e),r=new x(t);await r.init(),await r.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("ftag",{type:"array"})),(async e=>{try{const t=await $({...e,mode:"all"}),r=new x(t);await r.init(),await r.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("ftag",{type:"array"})),(async e=>{try{const t=await $({...e,mode:"file"}),r=new x(t);await r.init(),await r.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}));function E(e,{name:t,bin:r,preArgs:n=[]}){return e.command(`${t||r} [commands..]`,`${r} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await $(e),{projectDir:a}=t,o=process.argv.slice(3);f(r,[...n,...o],{cwd:a,stdio:"inherit",shell:!0}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}async function $(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:g.resolve(P,"./@fnet/cli-project-node/dist/template/default"),templateCommonDir:g.resolve(P,"./@fnet/cli-project-common/dist/template/default"),projectDir:g.resolve(m,`./.output/${e.id}`),tags:e.ftag};{const t=await async function({tags:e}){const t=g.resolve(m,"node.yaml");if(!h.existsSync(t))throw new Error("node.yaml file not found in current directory.");const{raw:r,parsed:n}=await b({file:t,tags:e}),a=g.dirname(t);n.features=n.features||{};const o=n.features;o.runtime=o.runtime||{},o.runtime.type=o.runtime.type||"node","python"===o.runtime.type?o.runtime.template=o.runtime.template||"python":o.runtime.template=o.runtime.template||"default";const i={libraryAtom:{doc:{...n},fileName:"index"},projectDir:a,projectFilePath:t,projectFileContent:r,projectFileParsed:n,runtime:o.runtime};let s=g.resolve(a,"fnet/targets.yaml");if(!h.existsSync(s)&&(s=g.resolve(a,"node.devops.yaml"),h.existsSync(s))){const e=g.resolve(a,"fnet");h.existsSync(e)||h.mkdirSync(e),h.copyFileSync(s,g.resolve(a,"fnet/targets.yaml")),h.unlinkSync(s)}if(h.existsSync(s)){const{raw:t,parsed:r}=await b({file:s,tags:e}),n=w.parseDocument(t);i.devops={filePath:s,fileContent:t,yamlDocument:n,doc:{...r},type:"library.deploy",save:async()=>{h.writeFileSync(i.devops.filePath,n.toString())}}}const c=g.resolve(a,"readme.md");if(h.existsSync(c)){const e=h.readFileSync(c,"utf8");i.readme={filePath:c,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return i}({tags:e.ftag});return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:g.resolve(P,`./@fnet/cli-project-node/dist/template/${t.runtime.template}`),templateCommonDir:g.resolve(P,`./@fnet/cli-project-common/dist/template/${t.runtime.template}`),projectDir:g.resolve(t.projectDir,"./.workspace"),projectSrcDir:g.resolve(t.projectDir,"./src"),project:t,tags:e.ftag}}}return A=A.command("create-input <name>","Create an input config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $(e),{project:r}=t,{projectDir:n,projectFileParsed:a}=r,o=a.input;if(!o)throw new Error("Config schema not found in project file.");const i=await j({schema:o,format:"yaml"}),s=g.resolve(n,".fnet");h.existsSync(s)||h.mkdirSync(s);const c=g.resolve(s,`${e.name}.fnet`);h.writeFileSync(c,i)}catch(e){console.error(e.message),process.exit(1)}})),A=function(e){return e.command("update-input <name>","Update an input config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $(e),{project:r}=t,{projectDir:n,projectFileParsed:a}=r,o=a.input;if(!o)throw new Error("Config schema not found in project file.");const i=g.resolve(n,".fnet"),s=g.resolve(i,`${e.name}.fnet`),c=await j({schema:o,format:"yaml",ref:s});h.existsSync(i)||h.mkdirSync(i),h.writeFileSync(s,c)}catch(e){console.error(e.message),process.exit(1)}}))}(A),A=E(A,{bin:"npm"}),A=E(A,{bin:"node"}),A=E(A,{name:"serve",bin:"npm",preArgs:["run","serve","--"]}),A=E(A,{name:"watch",bin:"npm",preArgs:["run","watch","--"]}),A=E(A,{name:"app",bin:"npm",preArgs:["run","app","--"]}),A=E(A,{name:"cli",bin:"npm",preArgs:["run","cli","--"]}),A=E(A,{bin:"npx"}),A=E(A,{bin:"cdk"}),A=E(A,{bin:"aws"}),A=function(e,{name:t,preArgs:r=[]}){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 $(e),{projectDir:n}=t,a=e.config,o=await _({name:a,dir:n,transferEnv:!1,optional:!0,tags:t.tags}),i=o?.data?.env||void 0,s=e.command,c=process.argv.slice(5);f(s,[...r,...c],{cwd:n,stdio:"inherit",shell:!0,env:{...process.env,...i}}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}(A,{name:"with"}),A=function(e,{name:t,preArgs:r=[]}){return e.command(`${t} group [options..]`,"Run a command group.",(e=>e.positional("group",{type:"string"}).option("ftag",{type:"array"}).help(!1).version(!1)),(async e=>{try{const t=await $(e),{project:r}=t,{projectFileParsed:n}=r,a=n.commands;if(!a)throw new Error("Commands not found in project file.");const o=a[e.group];if(!o)throw new Error(`Command group '${e.group}' not found in project file.`);await D({commands:o})}catch(e){console.error(e.message),process.exit(1)}}))}(A,{name:"run"}),A.demandCommand(1,"You need at least one command before moving on").help().argv,Wt}());module.exports=lr;
2
+ "use strict";var e=require("child_process"),t=require("@fnet/config"),r=require("path"),n=require("yargs/yargs"),a=require("fs"),o=require("yaml"),i=require("shelljs"),s=require("@fnet/yaml"),c=require("@fnet/object-from-schema"),p=require("@fnet/shell-flow"),l=require("@flownet/lib-render-templates-dir"),d=require("node:fs"),u=require("node:path"),m=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"),v=require("qs"),b=require("lodash.merge"),_=require("@flownet/lib-parse-imports-js"),j=require("@fnet/npm-list-versions"),D=require("@fnet/npm-pick-versions"),k=require("object-hash"),x=require("ajv/dist/2020"),P=require("ajv/dist/standalone"),S=require("ajv-formats"),A=require("@fnet/auto-conda-env"),E=require("@fnet/shell"),$=require("semver"),T=require("@fnet/up-list-files"),I=require("node:os"),C=require("@node-red/util"),O=require("@flownet/lib-to-ios-app"),R=require("lodash.clonedeep"),M=require("@flownet/lib-to-macos-app"),F=require("@flownet/lib-to-electron"),q=require("@flownet/lib-to-webos"),L=require("@flownet/lib-to-nextjs"),N=require("@flownet/lib-to-docker"),U=require("form-data"),z=require("@fnet/to-rust"),B=require("@flownet/lib-parse-node-url"),J=require("@fnet/list-files"),W=require("chalk");function K(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}var G,H,X,Y,V,Z,Q,ee,te,re,ne,ae,oe,ie,se,ce,pe,le,de,ue,me,fe,ge,ye,he,we,ve,be,_e,je,De,ke,xe,Pe,Se,Ae,Ee,$e,Te,Ie,Ce,Oe,Re,Me,Fe,qe,Le,Ne,Ue,ze,Be,Je,We,Ke,Ge,He,Xe,Ye,Ve,Ze,Qe,et,tt,rt,nt,at,ot,it,st,ct,pt,lt,dt,ut,mt,ft,gt,yt,ht,wt,vt,bt,_t,jt,Dt,kt,xt,Pt,St,At,Et,$t,Tt,It,Ct,Ot,Rt,Mt,Ft,qt,Lt,Nt,Ut,zt,Bt,Jt,Wt,Kt,Gt,Ht={};function Xt(){if(Z)return V;Z=1;const e=b;return V=({feature:t,features:r,packageDevDependencies:n})=>{const{name:a,packages:o,options:i,extraCheck:s,explicit:c}=t,p=`${a}_enabled`,l=r.rollup_output||{},d=Object.keys(l);let u=i||{};const m=r[a]?.options;m&&(u=e(u,m));const f=!r[a]||!1===r[a]?.enabled;d.forEach((e=>{const t=r.rollup_output[e];if(t){if(Reflect.has(t,a)){if(f||!t[a]||!1===t[a]?.enabled)return void delete t[a];!0===t[a]&&(t[a]={enabled:!0,options:u})}else{if(f||c||!1===r[p])return;t[a]={enabled:!0}}t[a]=t[a]||{},t[a].options={...u,...t[a].options}}}));let g=d.some((e=>!0===r.rollup_output[e][a]?.enabled));s&&(g=s()&&g),r[p]=g,g&&o.forEach((e=>n.push({package:e[0],version:e[1]})))}}function Yt(){if(Pe)return xe;Pe=1;const e=b,t=d,r=u,n=_,a=function(){if(ee)return Q;ee=1;const e=Xt();return Q=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:a,packageDevDependencies:n})},Q}(),o=function(){if(re)return te;re=1;const e=Xt();return te=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:a,packageDevDependencies:n})},te}(),i=function(){if(ae)return ne;ae=1;const e=Xt();return ne=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:a,packageDevDependencies:n})},ne}(),s=function(){if(ie)return oe;ie=1;const e=Xt();return oe=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:a,packageDevDependencies:n})},oe}(),c=function(){if(ce)return se;ce=1;const e=Xt();return se=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]],expilicit:!0},features:a,packageDevDependencies:n})},se}(),p=function(){if(le)return pe;le=1;const e=Xt();return pe=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:a,packageDevDependencies:n})},pe}(),l=function(){if(ue)return de;ue=1;const e=Xt();return de=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:a,packageDevDependencies:n})},de}(),m=function(){if(fe)return me;fe=1;const e=Xt();return me=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:a,packageDevDependencies:n})},me}(),f=function(){if(ye)return ge;ye=1;const e=Xt();return ge=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:a,packageDevDependencies:n})},ge}(),g=function(){if(we)return he;we=1;const e=Xt();return he=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:a,packageDevDependencies:n})},he}(),y=function(){if(be)return ve;be=1;const e=Xt();return ve=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features;e({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:a,packageDevDependencies:n})},ve}(),h=function(){if(je)return _e;je=1;const e=Xt();return _e=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features,o={};!0===a.app?.enabled&&(o.targets=o.targets||[],o.targets.push({src:"./src/app/index.html",dest:a.app.dir}),Reflect.has(a.app,"copy")||Reflect.has(a,"copy")||(a.copy=!0)),e({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:o},features:a,packageDevDependencies:n})},_e}(),w=function(){if(ke)return De;ke=1;const e=Xt();return De=t=>{const{atom:r,packageDevDependencies:n}=t,a=r.doc.features,o=a.css&&!1!==a.css.enabled;let i=[];o&&(i.push(["rollup-plugin-postcss","^4"]),i.push(["sass","^1.66"]),(a.css?.options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":i.push(["postcss-import","^15"]);break;case"postcss-url":i.push(["postcss-url","^10"]);break;case"postcss-preset-env":i.push(["postcss-preset-env","^9"]);break;case"autoprefixer":i.push(["autoprefixer","^10"]);break;case"cssnano":i.push(["cssnano","^6"])}}))),e({feature:{name:"css",packages:i},features:a,packageDevDependencies:n})},De}();function v({dir:e,name:n="index"}){let a=r.resolve(e,`./${n}.tsx`);if(t.existsSync(a)||(a=r.resolve(e,`./${n}.ts`)),t.existsSync(a)||(a=r.resolve(e,`./${n}.jsx`)),t.existsSync(a)||(a=r.resolve(e,`./${n}.js`)),!t.existsSync(a))return{};const o=a,i=r.extname(a);return{file:o,ext:i,ts:".ts"===i||".tsx"===i,name:n}}return xe=async t=>{const{atom:d,context:u,setProgress:b}=t;b("Initializing features..."),d.doc.features=d.doc.features||{};const _=d.doc.features;_.project=_.project||{},_.project.format=_.project.format||_.project_format||"esm",_.project_format=_.project.format,_.dts_enabled=!0===_.dts||void 0!==_.dts&&!1!==_.dts,_.hasOwnProperty("all_parsed_imports")||(_.all_parsed_imports=!0);const j=r.resolve(u.project.projectDir),D=v({dir:r.resolve(j,"./app")});if(D.file){b("Parsing app entry imports...");let e=await n({file:D.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));_.app_uses_jsx=t,_.app_has_entry=!0,e=await n({file:D.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),_.app_entry_uses_jsx=t,_.app_entry_is_ts=D.ts,_.app_entry_ext=D.ext}const k=v({dir:r.resolve(j,"./cli")});if(k.file){b("Parsing cli entry imports...");let e=await n({file:k.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));_.cli_uses_jsx=t,_.cli_has_entry=!0,e=await n({file:k.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),_.cli_entry_uses_jsx=t,_.cli_entry_is_ts=k.ts,_.cli_entry_ext=k.ext}if("workflow.lib"===d.type){const e=v({dir:r.resolve(j,"./src")});if(e.file){b("Parsing src entry imports...");let t=await n({file:e.file,recursive:!0}),r=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));_.src_uses_jsx=r,_.src_has_entry=!0,t=await n({file:e.file}),r=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),_.src_entry_uses_jsx=r,_.src_entry_is_ts=e.ts,_.src_entry_ext=e.ext}}const x=Reflect.has(_,"app_entry_uses_jsx")?!0===_.app_entry_uses_jsx:!0===_.src_entry_uses_jsx,P=Reflect.has(_,"cli_entry_uses_jsx")?!0===_.cli_entry_uses_jsx:!0===_.src_entry_uses_jsx;_.form_enabled=!0===d.doc.form||!0===d.doc.form?.enabled||!0===_.form||!0===_.form?.enabled,_.multiple_enabled=_.multiple_enabled||!0===_.multiple||!0===_.multiple?.enabled,!1===_.app?_.app={enabled:!1}:!0===_.app?_.app={enabled:!0,extend:!0===_.app_has_entry,export:!0,react:x}:_.app={enabled:!0,extend:!0===_.app_has_entry,export:!0,react:x,..._.app||{}},_.app.enabled=!0===_.app.enabled&&(!0===d.doc.features.form_enabled||!0===_.app.extend||!0===_.app.enabled),_.app.format=_.app.format||"esm",_.app.folder=_.app.folder||_.app.format||"default",!1===_.cli?_.cli={enabled:!1}:!0===_.cli?_.cli={enabled:!0,extend:!0===_.cli_has_entry,export:!0,react:P}:_.cli={enabled:!0,extend:!0===_.cli_has_entry,export:!0,react:P,..._.cli||{}},_.cli.enabled=!0===_.cli.enabled&&(!1===d.doc.features.form_enabled||!0===_.cli.extend||!0===_.cli.enabled),_.cli.format=_.cli.format||"esm",_.cli.folder=_.cli.folder||_.cli.folder||"esm",_.cli.node_options=_.cli.node?.options||_.cli.node_options||"",_.json=_.cli.enabled||_.json;const S={cjs:{format:"cjs",context:_.form_enabled?"window":"global",babel:!0===_.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!1!==_.cjs,copy:!1},esm:{format:"esm",context:_.form_enabled?"window":"global",babel:!0===_.src_uses_jsx||!1,browser:!1,replace:!0,browsersync:!0,terser:!1,enabled:!1!==_.esm,copy:!0},iife:{format:"iife",context:_.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!1!==_.iife,terser:!0,copy:!1}};!0===_.webos&&(S.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}}),!0===_.electron&&(S.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===_.nextjs&&(S.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===_.ios&&(S.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===_.macos&&(S.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===_.app.enabled&&(_.app.dir=`./dist/app/${_.app.folder}`,S.app={format:_.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:_.app.dir,terser:!0,output_exports:!1===_.app.export?"none":"auto"}),!0===_.cli.enabled&&(_.cli.dir=`./dist/cli/${_.cli.folder}`,S.cli={format:_.cli.format,context:"global",babel:!0===_.src_uses_jsx||!0===_.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:_.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===_.cli.export?"none":"auto"});const A={server:".",startPath:`${r.normalize(_.app.dir||".")}`,files:[r.normalize("./dist/**/*")],cors:!0,open:!1};_.babel_options=e({targets:{browsers:"last 9 versions, not dead",node:"18"}},_.babel_options||_.babel?.options),_.browsersync_options=e(A,_.browsersync_options||_.browsersync?.options||{}),_.replace_options=e({},_.replace_options||_.replace?.options||{}),Reflect.has(_.browsersync_options,"proxy")&&delete _.browsersync_options.server,_.rollup=_.rollup||{},_.rollup_output=e(S,_.rollup_output||_.rollup?.output||{}),_.preact_enabled=!0===_.preact||_.preact&&!1!==_.preact?.enabled;let E=Object.keys(S);for(const t of E){const r=S[t];r&&(!1!==_.rollup[t]?(r.babel_options=r.babel_options||_.babel_options,r.browsersync_options=e(_.browsersync_options,r.browsersync_options),r.replace_options=e(_.replace_options,r.replace_options),_.preact_enabled&&(r.alias_enabled=!0,r.alias=r.alias||{},r.alias.entries=r.alias.entries||{},r.alias.entries.react="preact/compat",r.alias.entries["react-dom"]="preact/compat"),_.form_enabled&&(r.babel=!0)):delete _.rollup_output[t])}E=Object.keys(_.rollup_output),_.babel_enabled=E.some((e=>!0===_.rollup_output[e].babel)),_.browser_enabled=E.some((e=>!0===_.rollup_output[e].babel)),_.browsersync_enabled=!1!==_.browsersync&&E.some((e=>!0===_.rollup_output[e].browsersync)),_.browsersync_enabled=_.browsersync_enabled&&_.app.enabled,_.dependency_auto_enabled=!1!==_.dependency_auto&&!1!==_.dependency_auto?.enabled,_.npm_install_flags=_.npm_install_flags||"",_.react_version=_.react_version||_.react?.version||18,w(t),h(t),y(t),g(t),f(t),l(t),m(t),p(t),c(t),s(t),i(t),a(t),o(t)},xe}function Vt(){if($e)return Ee;$e=1;const e=j;return Ee=async({atom:t,packageDependencies:r,packageDevDependencies:n,setProgress:a})=>{if(a("Initializing dependencies"),"workflow"===t.type&&(r.push({package:"get-value",version:"^3"}),r.push({package:"set-value",version:"^4"})),t.doc.features.form_enabled&&t.doc.features.dependency_auto_enabled){let n="^18.2";a("Fetching React versions");n=`^${(await e({name:"react",groupBy:{major:!0}})).find((e=>e[0]===t.doc.features.react_version.toString()))[0]}`,r.push({package:"react",version:n}),r.push({package:"react-dom",version:n}),"workflow"===t.type&&(r.push({package:"@flownet/react-app",version:"^0.1"}),r.push({package:"@flownet/react-app-state",version:"^0.1"}))}t.doc.features.preact_enabled&&r.push({package:"preact",version:"^10"}),!0===t.doc.features.cli.enabled&&(r.push({package:"@fnet/args",version:"^0.1"}),n.push({package:"ajv",version:"^8"}),t.doc.features.cli.fargs&&!1!==t.doc.features.cli.fargs?.enabled&&r.push({package:"@fnet/config",version:"0.2.21"})),t.doc.features.render&&!1!==t.doc.features.render.enabled&&n.push({package:"@flownet/lib-render-templates-dir",version:"0.1.17"}),n.push({package:"@babel/core",version:"^7"}),n.push({package:"@rollup/plugin-commonjs",version:"^28"}),n.push({package:"@rollup/plugin-node-resolve",version:"^15"}),n.push({package:"@rollup/plugin-replace",version:"^6"}),n.push({package:"rollup",version:"^4"}),t.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"}),t.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"}),t.doc.features.babel?.options?.plugins?.forEach((e=>{switch(e[0]){case"@babel/plugin-proposal-decorators":n.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":n.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":n.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":n.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":n.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"})}}))),n.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),t.doc.features.browsersync_enabled&&n.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})},Ee}function Zt(){if(Oe)return Ce;Oe=1;const e=d,t=u,r=l;return Ce=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{if(!0!==n.doc.features.app.enabled)return;await a({message:"Creating app folder"});const s={atom:n,packageDependencies:i,ts:Date.now()},c=o.templateDir,p=t.resolve(o.projectDir,"src/app");e.existsSync(p)||e.mkdirSync(p,{recursive:!0});let l=["index.js.njk"];!1!==n.doc.features.app.html&&l.push("index.html.njk"),await r({pattern:l,dir:t.resolve(c,"src/app"),outDir:p,context:s})},Ce}function Qt(){if(Me)return Re;Me=1;const e=D,t=k,r=d,n=u;return Re=async({projectDir:a,name:o,setProgress:i,count:s=1})=>{let c;const p=t(["npm-pick-versions",o,s]),l=n.join(a,".cache"),d=n.join(l,p+".json");return r.existsSync(d)?(i&&i(`Picking npm version of ${o} from cache ...`),c=JSON.parse(r.readFileSync(d,"utf8"))):(i&&i(`Picking npm version of ${o} ...`),c=await e({name:o,count:s}),r.mkdirSync(l,{recursive:!0}),r.writeFileSync(d,JSON.stringify(c),"utf8")),c}}function er(){if(qe)return Fe;qe=1;const e=m,t=d,r=u,n=_,a=Qt();return Fe=async({atom:o,context:i,packageDependencies:s,packageDevDependencies:c,setProgress:p})=>{await p({message:"Creating package.json."});s.filter((e=>!0===e.dev)).forEach((e=>{c.find((t=>t.package===e.package))||c.push(e);const t=s.findIndex((t=>t.package===e.package));s.splice(t,1)}));const l=s.find((e=>"react"===e.package)),d=s.find((e=>"react-dom"===e.package));l&&!d?s.push({package:"react-dom",version:l.version}):l&&d&&(d.version=l.version),l&&o.doc.features.react_version>=17&&(s.find((e=>"@emotion/react"===e.package))||s.push({package:"@emotion/react",version:"^11"}),s.find((e=>"@emotion/styled"===e.package))||s.push({package:"@emotion/styled",version:"^11"}));const u=[];!0===o.doc.features.app.enabled&&u.push({file:r.resolve(i.projectDir,"src/app/index.js"),dev:!1!==o.doc.features.app.dev}),!0===o.doc.features.cli.enabled&&u.push({file:r.resolve(i.projectDir,"src/cli/index.js"),dev:!1!==o.doc.features.cli.dev});for await(const e of u){const r=e.file;if(!t.existsSync(r))throw new Error(`App file not found: ${r}`);const l=await n({file:r,recursive:!0}),d=!0===o.doc.features.all_parsed_imports?l.all:l.required;for await(const t of d){if("npm"!==t.type)continue;if(s.find((e=>e.package===t.package)))continue;if(c.find((e=>e.package===t.package)))continue;const r=await a({name:t.package,projectDir:i.projectDir,setProgress:p});(!0===e.dev?c:s).push({package:t.package,subpath:t.subpath,version:r.minorRange,type:"npm"})}}const m={atom:o,packageDependencies:s,packageDevDependencies:c},f=i.templateCommonDir,g=e.compile(t.readFileSync(r.resolve(f,"package.json.njk"),"utf8"),e.configure(f)).render(m),y=i.projectDir,h=r.resolve(y,"package.json");t.writeFileSync(h,g,"utf8");const w=r.resolve(i.project.projectDir,"fnet");if(t.existsSync(w)){const e=r.resolve(i.projectDir,"fnet");t.existsSync(e)||t.mkdirSync(e);const n=t.readdirSync(w);for(const a of n){const n=r.resolve(w,a);if(!t.lstatSync(n).isFile())continue;const o=r.resolve(e,a);t.copyFileSync(n,o)}}},Fe}function tr(){if(Ne)return Le;Ne=1;const e=d,t=u,r=l;return Le=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{if(!0!==n.doc.features.cli.enabled)return;await a({message:"Creating cli."});const s={atom:n,packageDependencies:i},c=o.templateDir,p=t.resolve(o.projectDir,"src/cli");e.existsSync(p)||e.mkdirSync(p,{recursive:!0}),await r({pattern:["index.js.njk"],dir:t.resolve(c,"src/cli"),outDir:p,context:s})},Le}function rr(){if(Je)return Be;Je=1;const e=d,t=u,r=m,n=_;return Be=async({atom:a,setProgress:o,context:i,packageDependencies:s})=>{await o({message:"Creating rollup file."});const c={atom:a,packageDependencies:s},p=t.resolve(i.projectDir,"src","default/index.js");if(!e.existsSync(p))throw new Error(`Entry file not found: ${p}`);const l=(await n({file:p,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),d=a.doc.features.rollup_output,u=Object.keys(d);for(let e=0;e<u.length;e++){const t=d[u[e]];if(!0===t.browser&&l.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(l.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<l.length;e++){const r=l[e];t.alias.entries[r]=`node:${r}`,t.alias.entries[`node:${r}`]=r}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(l)}}const m=i.templateCommonDir;let f=r.compile(e.readFileSync(t.resolve(m,"rollup.config.mjs.njk"),"utf8"),r.configure(m)).render(c);const g=i.projectDir;let y=t.resolve(g,"rollup.config.mjs");e.writeFileSync(y,f,"utf8")},Be}function nr(){if(Ke)return We;Ke=1;const e=d,t=u,r=m,n=x,a=P,o=S;return We=async({atom:i,setProgress:s,context:c,njEnv:p})=>{if(!0!==i.doc.features.cli.enabled)return;await s({message:"Creating yargs."});let l={};if(l=i.doc.input?i.doc.input:{type:"object",properties:{},required:[]},i.doc.features.cli.fargs&&!1!==i.doc.features.cli.fargs?.enabled){const e=i.doc.features.cli.fargs,t={type:"string",description:"Config name to load args",hidden:!1},r={type:"array",description:"Tags to filter the config",hidden:!1};Reflect.has(e,"default")&&(t.default=e.default),l.properties&&(l.properties.fargs=t,l.properties.ftag=r)}const d={options:l,imports:[],atom:i},u=c.templateDir,m=r.compile(e.readFileSync(t.resolve(u,"src/default/to.args.js.njk"),"utf8"),p).render(d),f=c.projectDir,g=t.resolve(f,"src/default/to.args.js");e.writeFileSync(g,m,"utf8");const y=new n({allErrors:!0,useDefaults:!0,formats:{email:!0},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});o(y);const h=y.compile(l),w=a(y,h);e.writeFileSync(t.resolve(f,"src/default/validate_input.js"),w,"utf8")},We}function ar(){if(He)return Ge;He=1;const e=d,t=u,r=m;return Ge=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{await a({message:"Creating .gitignore"});const s={atom:n,packageDependencies:i},c=o.templateCommonDir,p=r.compile(e.readFileSync(t.resolve(c,".gitignore.njk"),"utf8"),r.configure(c)).render(s),l=o.projectDir,d=t.resolve(l,".gitignore");e.writeFileSync(d,p,"utf8")},Ge}function or(){if(Ye)return Xe;Ye=1;const e=d,t=u,r=m;return Xe=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{await a({message:"Creating tsconfig.json."});const s={atom:n,packageDependencies:i},c=o.templateCommonDir,p=r.compile(e.readFileSync(t.resolve(c,"tsconfig.json.njk"),"utf8"),r.configure(c)).render(s),l=o.projectDir,d=t.resolve(l,"tsconfig.json");e.writeFileSync(d,p,"utf8")},Xe}function ir(){if(Ze)return Ve;Ze=1;const e=m,t=d,r=u,n=s;return Ve=async({atom:a,context:o,setProgress:i,Atom:s})=>{const c="readme.md",p=`Creating ${c}`;if(await i({message:p}),o.project?.readme){const a=o.projectDir,i={content:o.project.readme.doc.content},s=r.resolve(o.project.projectDir,"fnet/how-to.md");if(t.existsSync(s)){const e=t.readFileSync(s,"utf8");i.howto=e}const p=r.resolve(o.project.projectDir,"fnet/input.yaml");if(t.existsSync(p)){const e=await n({file:p,tags:o.tags});i.input=e.content}const l=o.templateCommonDir,d=e.compile(t.readFileSync(r.resolve(l,`${c}.njk`),"utf8"),e.configure(l)).render(i),u=r.resolve(a,`${c}`);t.writeFileSync(u,d,"utf8")}else if(a.id){const n=await s.first({type:"wiki",parent_id:a.id});if(!n||"markdown"!==n.doc?.["content-type"])return;const{content:i,...p}=n.doc,l={content:i},d=o.templateCommonDir,u=e.compile(t.readFileSync(r.resolve(d,`${c}.njk`),"utf8"),e.configure(d)).render(l),m=o.projectDir,f=r.resolve(m,`${c}`);t.writeFileSync(f,u,"utf8")}},Ve}function sr(){if(et)return Qe;et=1;const e=r,t=p;return Qe=async({setProgress:r,context:n})=>{const a=n.projectDir;await r({message:"Prettifiying source files."});let o=e.join("src","**","*");await t({commands:{steps:[`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`],wdir:a}})}}function cr(){if(rt)return tt;rt=1;const e=i;return tt=async({atom:t,setProgress:r,context:n})=>{if(!t.doc.features.dts_enabled)return;const a=n.projectDir;await r({message:"Creating .d.ts"});if(0!==e.exec("tsc",{cwd:a}).code)throw new Error("Couldnt create .d.ts files.")},tt}function pr(){if(at)return nt;at=1;const e=i;return nt=async({setProgress:t,atom:r,context:n})=>{const a=n.projectDir;await t({message:"Installing npm packages."});if(0!==e.exec(`npm install ${r.doc.features.npm_install_flags}`,{cwd:a}).code)throw new Error("Couldnt install npm packages.")},nt}function lr(){if(it)return ot;it=1;const e=A,t=r;return ot=async({setProgress:r,atom:n,context:a})=>{const o=a.projectDir,i=t.join(o,".conda"),s=await e({envDir:i,pythonVersion:n.doc.features.runtime.version||"3.12",packages:n.doc.dependencies});a.pythonEnv=s},ot}function dr(){if(ct)return st;ct=1;const e=i;return st=async({setProgress:t,context:r})=>{const n=r.projectDir;await t({message:"Building main project."});if(0!==e.exec("npm run build",{cwd:n}).code)throw new Error("Couldnt build project.")}}function ur(){if(zt)return Ut;zt=1;const e=function(){if(lt)return pt;lt=1;const e=E,r=t;return pt=async({setProgress:t,context:n,deploymentProject:a,deploymentProjectTarget:o,buildId:i})=>{await t({message:"Deploying it as gitlab project."});const s=n.projectDir;let c="fnet-to-gitlab";const p=o.params.config||"gitlab",l=await r({name:p,dir:n.projectDir,tags:n.tags});if(!l)throw new Error(`Couldnt load config ${p}`);const{data:d}=l.data;c+=` --projectGroupId=${d.projectGroupId}`,c+=` --projectPath='${s}'`,c+=` --projectName='${o.params.name}'`,c+=` --projectBranch='${o.params.branch||"main"}'`,c+=` --gitlabHost='${d.gitlabHost}'`,c+=` --gitlabToken='${d.gitlabToken}'`,c+=` --gitlabUsername='${d.gitlabUsername}'`,c+=` --gitlabUserEmail='${d.gitlabUserEmail}'`,!0!==o.dryRun&&(await e({cmd:c}),a.isDirty=!0)}}(),n=function(){if(ut)return dt;ut=1;const e=d,r=u,n=$,a=E,o=t;return dt=async({setProgress:t,context:i,deploymentProject:s,deploymentProjectTarget:c,registerToPackageManager:p,yamlTarget:l})=>{await t({message:"Deploying it as gcs package."});const d=i.projectDir,u=r.resolve(d,"package.json"),m=e.readFileSync(u),f=JSON.parse(m);f.name=c.params.name,f.version=n.inc(c.version,"patch"),delete f.scripts,delete f.devDependencies,e.writeFileSync(u,JSON.stringify(f,null,"\t"));const{file:g,data:y}=await o({name:c.config||"gcs",dir:i.projectDir,tags:i.tags});let h="fnet-files-to-gcs";h+=` --projectId='${y.env.GCS_PROJECT_ID}'`,h+=` --bucketName='${y.env.GCS_BUCKET_NAME}'`,h+=` --keyFilename='${r.resolve(r.dirname(g),y.env.GCS_UPLOADER_KEY_FILE)}'`,h+=` --dir='${d}'`,h+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",h+=` --destDir='${f.name}/${f.version}'`,h+=" --metadata.cacheControl='public, max-age=31536000, immutable'",y.env.DOMAIN&&(h+=` --domain='${y.env.DOMAIN}'`),!0!==c.dry_run&&!0!==c.params.dry_run||(h+=" --dryRun"),await a({cmd:h}),e.writeFileSync(u,m),!0!==c.dryRun&&(s.isDirty=!0,c.version=f.version,l.set("version",f.version),await p({target:c,packageJSON:f}))}}(),s=function(){if(ft)return mt;ft=1;const e=d,r=u,n=$,a=i,s=t,p=T,l=c,m=o;return mt=async({atom:t,setProgress:o,context:i,deploymentProject:c,deploymentProjectTarget:d,yamlTarget:u})=>{await o({message:"Deploying it as npm package."});const f=i.projectDir,g=r.resolve(f,"package.json"),y=e.readFileSync(g),h=JSON.parse(y);h.name=d.params.name,h.version=n.inc(d.version,"patch");const w=d.params.bin?.name||d.params.bin;!1!==d.params.bin?.enabled&&w&&"string"==typeof w&&(h.bin={[w]:"dist/cli/esm/index.js",[t.doc.name]:"dist/cli/esm/index.js"}),delete h.scripts,delete h.devDependencies,h.scripts={serve:"npx serve ."},e.writeFileSync(g,JSON.stringify(h,null,"\t"));const v=d.config||"npm";let b=(await s({name:v,dir:i.projectDir,tags:i.tags,optional:!0}))?.data;if(!b){const t=p({dir:__dirname,pattern:"@fnet/cli-project-schemas/dist/schemas/to-npm.yaml",absolute:!0});if(0===t.length)throw new Error("Couldnt find schema to create npm config");const n=await l({schema:t[0],tags:i.tags}),a=i.project.projectDir,o=r.resolve(a,".fnet");e.existsSync(o)||e.mkdirSync(o),e.writeFileSync(r.resolve(o,`${v}.fnet`),m.stringify(n)),b=n}if(e.writeFileSync(r.resolve(f,".npmrc"),`//registry.npmjs.org/:_authToken=${b.env.NPM_TOKEN}`),!0!==d.dryRun){if(0!==a.exec("npm publish --access public",{cwd:f}).code)throw new Error("Couldnt publish to npm");e.writeFileSync(g,y),c.isDirty=!0,d.version=h.version,u.set("version",h.version)}},mt}(),p=function(){if(yt)return gt;yt=1;const e=d,r=u,n=I,a=m,o=C,i=t;return gt=async({atom:t,setProgress:s,context:c,deploymentProject:p,deploymentProjectTarget:l,buildId:d,packageDependencies:u,njEnv:m})=>{await s({message:"Deploying it as node-red flow."});const f=c.projectDir,g=c.templateDir,y="workflow"===t.type?"WF":"LIB";let h;if("simple"===l.deploy.template)h={atom:t,packageDependencies:u,red:{tab:{id:l.deploy.id||o.util.generateId(),label:`${y}/${t.id?t.id:n.hostname()}/${t.name}/${l.deploy.name||l.deploy.template}`},function:{id:o.util.generateId(),name:t.doc.name,initialize:{content:e.readFileSync(r.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:t.doc.bundleName}},inject:{id:o.util.generateId(),...l.params?.inject,payload:"json"===l.params?.inject?.payloadType?`'${JSON.stringify(l.params?.inject?.payload)}'`:l.params?.inject?.payload},debug:{id:o.util.generateId()}}};else if("cronjob"===l.deploy.template){let a=l.params?.schedules?cloneDeep(l.params?.schedules):void 0;a?.forEach((e=>{"json"===e.payloadType&&(e.payload=`'${JSON.stringify(e.payload)}'`)})),h={atom:t,packageDependencies:u,red:{tab:{id:l.deploy.id||o.util.generateId(),label:`${y}/${t.id?t.id:n.hostname()}/${l.deploy.name||l.deploy.template}`},function:{id:o.util.generateId(),name:t.doc.name,initialize:{content:e.readFileSync(r.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:t.doc.bundleName}},cronjob:{id:o.util.generateId(),schedules:a},debug:{id:o.util.generateId()}}}}else{if("http"!==l.deploy.template)return;h={atom:t,packageDependencies:u,red:{tab:{id:l.deploy.id||o.util.generateId(),label:`${y}/${t.id?t.id:n.hostname()}/${l.deploy.name||l.deploy.template}`},function:{id:o.util.generateId(),name:t.doc.name,initialize:{content:e.readFileSync(r.resolve(f,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),var:t.doc.bundleName}},httpin:{id:o.util.generateId(),method:l.params.method||"get",url:l.params.url},httpout:{id:o.util.generateId()},debug:{id:o.util.generateId()}}}}let w=a.compile(e.readFileSync(r.resolve(g,`deploy/node-red/${l.deploy.template}.yaml.njk`),"utf8"),m).render(h);if(e.writeFileSync(r.resolve(f,"node-red.yaml"),w),w=yaml.load(w),!0===l.dryRun)return;p.isDirty=!0;const v=(await i({name:c.redConfig||"red",dir:c.projectDir,tags:c.tags}))?.data,b=l.deploy.url||v.env.RED_URL,_={};if(!1!==l.deploy.auth&&(_.Authorization="Bearer "+atomAccessToken),l.deploy.id)!0===l.actions?.delete?(await axios({method:"DELETE",url:`${b}/flow/${l.deploy.id}`,headers:_}),delete l.actions.delete,delete l.deploy.id,l.enabled=!1):await axios({method:"PUT",url:`${b}/flow/${l.deploy.id}`,data:w,headers:_});else{const e=await axios({method:"POST",url:`${b}/flow`,data:w,headers:_});l.deploy.id=e.data.id}},gt}(),l=function(){if(wt)return ht;wt=1;const e=a,n=r,o=t;return ht=async({atom:t,Atom:r,setProgress:a,context:i,packageDependencies:s,deploymentProject:c,deploymentProjectTarget:p})=>{await a({message:"Deploying it as workflow lib."});const l=(await o({name:"atom",dir:i.projectDir,tags:i.tags}))?.data;let d,u,m,f=p.deploy.name.split("/");if(1===f.length)u=l.env.ATOM_LIBRARIES_ID,m=p.deploy.name;else{if(2!==f.length)throw new Error("Wrong name path.");{const e=await r.first({where:{name:f[0],parent_id:l.env.ATOM_LIBRARIES_ID,type:"folder"},limit:1});if(!e)throw new Error("Couldnt file lib folder.");u=e.id,m=f[1]}}if(!0===p.dryRun)return;if(c.isDirty=!0,p.deploy.id){if(d=await r.get({id:p.deploy.id}),!d)return}else{if(d=await r.create({parent_id:u,doc:{name:m,type:"workflow.lib","content-type":"javascript",dependencies:[],content:void 0,subtype:"workflow"}}),!d)return;p.deploy.id=d.id}const g=i.projectDir;d.doc.contents=[{content:e.readFileSync(n.resolve(g,"dist/default/esm/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"esm"},{content:e.readFileSync(n.resolve(g,"dist/default/cjs/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"cjs"},{content:e.readFileSync(n.resolve(g,"dist/default/iife/index.js"),{encoding:"utf8",flag:"r"}),"content-type":"javascript",format:"iife"}],d.doc.name=m,d.doc.dependencies=s,"workflow.lib"===t.type?d.doc.subtype="library":"workflow"===t.type&&(d.doc.subtype="workflow"),d=await r.update(d,{id:d.id})}}(),f=function(){if(bt)return vt;bt=1;const e=t,r=O,n=R,a=$;return vt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as ios-app package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},vt}(),g=function(){if(jt)return _t;jt=1;const e=t,r=M,n=R,a=$;return _t=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as macos-app package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},_t}(),y=function(){if(kt)return Dt;kt=1;const e=t,r=F,n=R,a=$;return Dt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as electron package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},Dt}(),h=function(){if(Pt)return xt;Pt=1;const e=t,r=q,n=R,a=$;return xt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as webos package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},xt}(),v=function(){if(At)return St;At=1;const e=t,r=L,n=R,a=$;return St=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as nextjs package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},St}(),b=function(){if($t)return Et;$t=1;const e=t,r=N,n=R,a=$;return Et=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as docker package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},Et}(),_=function(){if(It)return Tt;It=1;const e=d,r=u,n=$,a=E,o=t,i=w.default;return Tt=async({setProgress:t,context:s,deploymentProject:c,deploymentProjectTarget:p,yamlTarget:l})=>{await t({message:"Deploying it as fnet package."});const d=s.projectDir,u=r.resolve(d,"package.json"),m=e.readFileSync(u),f=JSON.parse(m);f.name=p.params.name,f.version=n.inc(p.version,"patch"),delete f.scripts,delete f.devDependencies,e.writeFileSync(u,JSON.stringify(f,null,"\t"));const{file:g,data:y}=await o({name:p.config||"fnet-package",dir:s.projectDir,tags:s.tags});if(!y.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${g}`);if(!y.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${g}`);if(!y.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${g}`);const h=`${y.env.ATOM_API_URL}/v1/auth/token`,w=y.env.ATOM_API_USERNAME,v=y.env.ATOM_API_PASSWORD;let b=await i({method:"POST",url:h,data:{username:w,password:v},headers:{"Content-Type":"application/json"}});const _=b.data?.access_token;if(!_)throw new Error(`Invalid access_token from ${h}`);let j="fnet-files-to-gcs";if(j+=` --projectId='${y.env.GCS_PROJECT_ID}'`,j+=` --bucketName='${y.env.GCS_BUCKET_NAME}'`,j+=` --keyFilename='${r.resolve(r.dirname(g),y.env.GCS_UPLOADER_KEY_FILE)}'`,j+=` --dir='${d}'`,j+=" --pattern={'dist/**/**','bin/**/**','test/**/**','*.html'}",j+=` --destDir='${f.name}/${f.version}'`,j+=" --metadata.cacheControl='public, max-age=31536000, immutable'",y.env.DOMAIN&&(j+=` --domain='${y.env.DOMAIN}'`),!0!==p.dry_run&&!0!==p.params.dry_run||(j+=" --dryRun"),await a({cmd:j}),e.writeFileSync(u,m),!0===p.dryRun)return;c.isDirty=!0,p.version=f.version,l.set("version",f.version);const D=`${y.env.ATOM_API_URL}/v1/service/fnet-package/publish`;if(b=await i({method:"POST",url:D,data:{name:f.name,version:f.version,version_domain:y.env.DOMAIN,docs:p.params.docs,configs:p.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${_}`}}),b.data?.error)throw new Error("Failed to publish fnet package.")}}(),j=function(){if(Ot)return Ct;Ot=1;const e=$,r=t,n=w.default;return Ct=async({setProgress:t,context:a,deploymentProject:o,deploymentProjectTarget:i,yamlTarget:s})=>{await t({message:"Deploying it as fnet form."});const{file:c,data:p}=await r({name:i.config||"fnet-form",dir:a.projectDir,tags:a.tags});if(!p.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${c}`);if(!p.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${c}`);if(!p.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${c}`);const l=`${p.env.ATOM_API_URL}/v1/auth/token`,d=p.env.ATOM_API_USERNAME,u=p.env.ATOM_API_PASSWORD;let m=await n({method:"POST",url:l,data:{username:d,password:u},headers:{"Content-Type":"application/json"}});const f=m.data?.access_token;if(!f)throw new Error(`Invalid access_token from ${l}`);o.isDirty=!0;const g=e.inc(i.version,"patch");i.params.version=g,i.version=g,s.set("version",g);const y=`${p.env.ATOM_API_URL}/v1/service/fnet-form/publish`;if(m=await n({method:"POST",url:y,data:{name:i.params.name,version:i.params.version,docs:i.params.docs,configs:i.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${f}`}}),m.data?.error)throw new Error("Error publishing fnet form.")}}(),D=function(){if(Mt)return Rt;Mt=1;const e=$,r=t,n=w.default,o=a,i=E,s=U;return Rt=async({setProgress:t,context:a,deploymentProject:c,deploymentProjectTarget:p,yamlTarget:l})=>{await t({message:"Deploying it as fnet flow."});const{file:d,data:u}=await r({name:p.config||"fnet-flow",dir:a.project.projectDir,tags:a.tags});if(!u.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${d}`);if(!u.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${d}`);if(!u.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${d}`);const m=`${u.env.ATOM_API_URL}/v1/auth/token`,f=u.env.ATOM_API_USERNAME,g=u.env.ATOM_API_PASSWORD;let y=await n({method:"POST",url:m,data:{username:f,password:g},headers:{"Content-Type":"application/json"}});const h=y.data?.access_token;if(!h)throw new Error(`Invalid access_token from ${m}`);c.isDirty=!0;const w=e.inc(p.version,"patch");p.params.version=w,p.version=w,l.set("version",w);const v=`${u.env.ATOM_API_URL}/v1/service/fnet-flow/publish`;if(y=await n({method:"POST",url:v,data:{name:p.params.name,version:p.params.version,docs:p.params.docs,configs:p.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${h}`}}),y.data?.error)throw new Error("Error publishing fnet flow.");const b=y.data?.upload.id;let _="fnet-dir-zipper";_+=` --sourceDir='${a.project.projectDir}'`,_+=" -p=**/*",_+=" -g",_+=" --stdout_format=json";const j=await i({cmd:_});if(0!==j.code)throw new Error(j.stderr);const D=JSON.parse(j.stdout).path;let k=new s;k.append("file",o.createReadStream(D));const x=await n.request({method:"POST",maxBodyLength:1/0,url:`${u.env.ATOM_API_URL}/v1/service/upload/single/${b}`,headers:{...k.getHeaders(),Authorization:`Bearer ${h}`},data:k});if(x.data?.error)throw new Error("Error uploading fnet flow.")}}(),k=function(){if(qt)return Ft;qt=1;const e=$,r=t,n=w.default,o=a,i=E,s=U;return Ft=async({setProgress:t,context:a,deploymentProject:c,deploymentProjectTarget:p,yamlTarget:l})=>{await t({message:"Deploying it as fnet node."});const{file:d,data:u}=await r({name:p.config||"fnet-node",dir:a.project.projectDir,tags:a.tags});if(!u.env.ATOM_API_URL)throw new Error(`ATOM_API_URL is required in ${d}`);if(!u.env.ATOM_API_USERNAME)throw new Error(`ATOM_API_USERNAME is required in ${d}`);if(!u.env.ATOM_API_PASSWORD)throw new Error(`ATOM_API_PASSWORD is required in ${d}`);const m=`${u.env.ATOM_API_URL}/v1/auth/token`,f=u.env.ATOM_API_USERNAME,g=u.env.ATOM_API_PASSWORD;let y=await n({method:"POST",url:m,data:{username:f,password:g},headers:{"Content-Type":"application/json"}});const h=y.data?.access_token;if(!h)throw new Error(`Invalid access_token from ${m}`);c.isDirty=!0;const w=e.inc(p.version,"patch");p.params.version=w,p.version=w,l.set("version",w);const v=`${u.env.ATOM_API_URL}/v1/service/fnet-node/publish`;if(y=await n({method:"POST",url:v,data:{name:p.params.name,version:p.params.version,docs:p.params.docs,configs:p.params.configs},headers:{"Content-Type":"application/json",Authorization:`Bearer ${h}`}}),y.data?.error)throw new Error("Error publishing fnet node.");const b=y.data?.upload.id;let _="fnet-dir-zipper";_+=` --sourceDir='${a.project.projectDir}'`,_+=" -p=**/*",_+=" -g",_+=" --stdout_format=json";const j=await i({cmd:_});if(0!==j.code)throw new Error(j.stderr);const D=JSON.parse(j.stdout).path;let k=new s;k.append("file",o.createReadStream(D));const x=await n.request({method:"POST",maxBodyLength:1/0,url:`${u.env.ATOM_API_URL}/v1/service/upload/single/${b}`,headers:{...k.getHeaders(),Authorization:`Bearer ${h}`},data:k});if(x.data?.error)throw new Error("Error uploading fnet node.")}}(),x=function(){if(Nt)return Lt;Nt=1;const e=t,r=z,n=R,a=$;return Lt=async({atom:t,target:o,onProgress:i,projectDir:s,dependencies:c,context:p,yamlTarget:l})=>{i&&await i({message:"Deploying it as Rust package."});const d=o?.config?await e({name:o.config,dir:s,optional:!0,transferEnv:!1,tags:p.tags}):void 0,u=a.inc(o.version||"0.1.0","patch");o.params.version=u,o.version=u,l.set("version",u);const m=n(o.params);m.dependencies=n(c);const f={atom:t,params:m,config:d?.config,src:s,dest:s};return{deployer:await r(f)}},Lt}();return Ut=async t=>{const{atom:r,packageDependencies:a,context:o,deploymentProjectTarget:i,setProgress:c,deploymentProject:d,yamlTarget:u}=t;if(!0===i.enabled)if("lib"===i.type)await l({...t});else if("red"===i.type)await p({...t});else if("npm"===i.type)await s({...t});else if("gcs"===i.type)await n({...t});else if("gitlab"===i.type)await e({...t});else if("fnet-package"===i.type)await _({...t});else if("fnet-form"===i.type)await j({...t});else if("fnet-node"===i.type)await k({...t});else if("fnet-flow"===i.type)await D({...t});else{let e;if("nextjs"===i.type?e=v:"webos"===i.type?e=h:"electron"===i.type?e=y:"docker"===i.type?e=b:"ios"===i.type?e=f:"macos"===i.type?e=g:"rust"===i.type&&(e=x),!e)return;await e({atom:r,target:i,onProgress:c,projectDir:o.projectDir,dependencies:a,context:o,yamlTarget:u}),d.isDirty=!0}},Ut}function mr(){if(Jt)return Bt;Jt=1;const e=d,r=u,n=o,a=i,s=m,c=function(){if(H)return G;H=1;const e=f,t=g;return G=async()=>{if(!await t({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const r=e.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await r.connect(),r}}(),{nanoid:p}=y,b=function(){if(Y)return X;Y=1;const{Api:e}=h,t=w.default,r=v;return X=class{init({config:n,accessToken:a}){return new Promise(((o,i)=>{if(e.set_api_url(n.data.url),a)return e.set_req_token(a),void o(a);t({method:"POST",url:`${n.data.issuer}/protocol/openid-connect/token`,data:r.stringify(n.data.grant.params),headers:{"Content-Type":"application/x-www-form-urlencoded"}}).then((t=>{e.set_req_token(t.data.access_token),o(t.data.access_token)})).catch((t=>{e.set_req_token(),i(t)}))}))}}}(),j=Yt(),D=(Ae||(Ae=1,Se=async e=>{const{atom:t,context:r,setProgress:n}=e;n("Initializing features..."),t.doc.features=t.doc.features||{};const a=t.doc.features;!1===a.cli?a.cli={enabled:!1}:(a.cli,a.cli={enabled:!0}),a.cli.enabled=!0===a.cli.enabled&&(!1===t.doc.features.form_enabled||!0===a.cli.extend||!0===a.cli.enabled)}),Se),k=Vt(),x=Ie?Te:(Ie=1,Te=async({atom:e,packageDependencies:t,packageDevDependencies:r,setProgress:n})=>{n("Initializing dependencies")}),P=Zt(),S=er(),A=tr(),E=function(){if(ze)return Ue;ze=1;const e=d,t=u,r=l;return Ue=async({atom:n,setProgress:a,context:o,packageDependencies:i})=>{if(!0!==n.doc.features.cli.enabled)return;await a({message:"Creating cli."});const s={atom:n,packageDependencies:i},c=o.templateDir,p=t.resolve(o.projectDir,"cli");e.existsSync(p)||e.mkdirSync(p,{recursive:!0}),await r({pattern:["index.py.njk"],dir:t.resolve(c,"cli"),outDir:p,context:s})},Ue}(),$=rr(),T=nr(),I=ar(),C=or(),O=ir(),R=sr(),M=cr(),F=pr(),q=lr(),L=dr(),N=Qt(),U=ur(),{Atom:z}=h,K=B,V=t,Z=_,Q=J,ee=W;return Bt=class{#e;#t;#r;#n;#a;#o;#i;#s;#c;#p;#l;#d;#u;#m;#f;#g;#y;constructor(e){this.#e=new b,this.#t=e,this.#o=[],this.#i=[],this._expire_ttl=3600,this._expire_ttl_short=300,this.#y={packageDependencies:this.#o,packageDevDependencies:this.#i,setProgress:this.setProgress.bind(this),context:this.#t,Atom:z,registerToPackageManager:this.registerToPackageManager.bind(this)}}async _cache_set(e,t,r){this._redis_client&&await this._redis_client.SETEX(e,r||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async initAuth(){this.#t.id&&(this.#s=await this.#e.init({config:this.#d}),this.#y.atomAccessToken=this.#s)}async initLibrary(){const e=this.#t.id;this.#r=this.#t.project?.libraryAtom||await z.get({id:e});let t=this.#r.doc.bundleName;t=t||(this.#r.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#r.doc.bundleName=t,this.#r.type=this.#r.type||"workflow.lib",this.#y.atom=this.#r}async initLibraryDir(){this.setProgress({message:"Initializing library directory."});const t=this.#t.projectDir;let n;this.setProgress({message:"Cleaning project directory."});const o=Q({dir:t,ignore:["node_modules",".cache"],absolute:!0});for(const t of o)e.rmSync(t,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."});let i=t;if(!e.existsSync(i)&&(n=a.exec(`mkdir "${t}"`),0!==n.code))throw new Error("Couldnt create workflow dir.");if(i=r.join(t,"src"),!e.existsSync(i)&&(n=a.exec(`mkdir "${i}"`),0!==n.code))throw new Error("Couldnt create library/src dir.");if(i=r.join(t,"src","default"),!e.existsSync()&&(n=a.exec(`mkdir "${i}"`),0!==n.code))throw new Error("Couldnt create library/src/default dir.")}async initLibraryDirPython(){this.setProgress({message:"Initializing library directory."});const t=this.#t.projectDir;let n;this.setProgress({message:"Cleaning project directory."});const o=Q({dir:t,ignore:[".cache",".conda","src"],absolute:!0});for(const t of o)e.rmSync(t,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."});let i=t;if(e.existsSync(i)||e.mkdirSync(i,{recursive:!0}),i=r.join(t,"src"),!e.existsSync(i)&&(n=a.exec(`ln -s "${this.#t.projectSrcDir}" "${i}" `),0!==n.code))throw new Error("Couldnt link src.")}async initNunjucks(){this.setProgress({message:"Initializing nunjucks."});const e=this.#t.templateDir;this.#n=s.configure(e,{watch:!1,dev:!0}),this.#y.njEnv=this.#n}async initLibs(){this.setProgress({message:"Initializing external libs."});const e=[{name:this.#r.doc.name,type:"atom",parent_id:this.#r.parent_id}];this.#a=e,await this.initAtomLibsAndDeps({libs:e,packageDependencies:this.#o})}async initLibsPython(){this.setProgress({message:"Initializing external libs."});const e=this.#r;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const t=[{name:this.#r.doc.name,type:"atom",parent_id:this.#r.parent_id,atom:e}];this.#a=t}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const r=e.filter((e=>"atom"===e.type));for(let e=0;e<r.length;e++){const n=r[e],a=await this.findAtomLibrary({url:n.name});n.atom=a;const o=a.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));o?.forEach((e=>{const r=t.find((t=>t.package===e.package));r?"string"==typeof e.path?(r.path||[]).some((t=>t===e.path))||(r.path=r.path||[],r.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(r.path||[]).some((t=>t===e))||(r.path=r.path||[],r.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const t=K({url:e});if(!t)throw new Error(`Invalid package name: ${e}`);if(t.protocol||(t.protocol=this.#l),"ac:"===t.protocol){const r=t.pathname.split("/");if(1===r.length)return await z.first({where:{name:e,parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===r.length){const e=await z.first({where:{name:r[0],parent_id:this.#d.env.ATOM_LIBRARIES_ID,type:"folder"}});return await z.first({where:{name:r[1],parent_id:e.id,type:"workflow.lib"}})}}else if("local:"===t.protocol){const e=this.#r;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const t=r.resolve(this.#t.projectSrcDir,"index.js"),n=await Z({file:t,recursive:!0}),a=e.doc.dependencies,o=!0===this.#r.doc.features.all_parsed_imports?n.all:n.required;for await(const e of o){if("npm"!==e.type)continue;if(a.find((t=>t.package===e.package)))continue;const t=await N({name:e.package,projectDir:this.#t.projectDir,setProgress:this.#y.setProgress});a.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return e}}async createAtomLibFiles({libs:t}){await this.setProgress({message:"Creating external lib files."}),this.#r.typesDir="./types";const n=t.filter((e=>"atom"===e.type));for(let t=0;t<n.length;t++){const a=n[t].atom,o=this.#t.projectDir;if("local:"===a.protocol){const t=r.resolve(this.#t.projectSrcDir,`${a.fileName||a.name}.js`),n=r.relative(r.join(this.#t.projectDir,"src","default"),t);if(!e.existsSync(t)){e.mkdirSync(r.dirname(t),{recursive:!0});let n="export default async (args)=>{\n";n+="}",e.writeFileSync(t,n,"utf8")}a.relativePath=n.split(r.sep).join("/"),this.#r.typesDir=`./types/${r.basename(o)}/src`}else{const t=r.join(o,"src","libs",`${a.id}.js`),n=a.doc.contents?.find((e=>"esm"===e.format))||a.doc;e.writeFileSync(t,n.content,"utf8")}}}async createAtomLibFilesPython({libs:t}){await this.setProgress({message:"Creating external lib files."});const n=t.filter((e=>"atom"===e.type));for(let t=0;t<n.length;t++){const a=n[t].atom;if("local:"===a.protocol){const t=r.resolve(this.#t.projectSrcDir,`${a.fileName||a.name}.py`);if(!e.existsSync(t)){e.mkdirSync(r.dirname(t),{recursive:!0});let n="def default():\n";n+=' print("Hello world!")\n',e.writeFileSync(t,n,"utf8")}}}}async createEngine(){await this.setProgress({message:"Creating engine file."});const t={libs:this.#a.filter((e=>"atom"===e.type)),libraryAtom:this.#r,atom:this.#r},n=this.#t.templateDir,a=s.compile(e.readFileSync(r.resolve(n,r.join("src","default","engine.js.njk")),"utf8"),this.#n).render(t),o=this.#t.projectDir,i=r.resolve(o,r.join("src","default","index.js"));e.writeFileSync(i,a,"utf8")}async createProjectYaml(){const t="node.yaml",a=`Creating ${t}`;await this.setProgress({message:a});const{content:o,...i}=this.#r.doc,c={content:n.stringify(i)},p=this.#t.templateDir,l=s.compile(e.readFileSync(r.resolve(p,`${t}.njk`),"utf8"),this.#n).render(c),d=this.#t.projectDir,u=r.resolve(d,`${t}`);e.writeFileSync(u,l,"utf8")}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#t.project?.devops){const e=[this.#t.project?.devops];for(let t=0;t<e.length;t++){let r=e[t];await this.deployProject({deploymentProject:r}),!0===r.isDirty&&await r.save()}}else if(this.#r.id){const e=await z.list({type:"library.deploy",parent_id:this.#r.id});for(let t=0;t<e.length;t++){let r=e[t];await this.deployProject({deploymentProject:r}),!0===r.isDirty&&(r=await z.update(r,{id:r.id}))}}}async deployProject(e){const{deploymentProject:t}=e,{yamlDocument:r}=t;if(t.doc.targets&&Array.isArray(t.doc.targets))throw new Error("Deployment project targets are deprecated. Please update targets in the yaml file.");const n=Object.keys(t.doc||{}),a=r||{};for(let e=0;e<n.length;e++){const r=t.doc[n[e]];r.name=n[e];const o=a.get(n[e]);await U({...this.#y,deploymentProject:t,deploymentProjectTarget:r,yamlTarget:o})}}async registerToPackageManager(e){const{target:t,packageJSON:r}=e;if(!this.#t.id)return;let n=await z.first({name:t.params.name,parent_id:this.#d.env.ATOM_PACKAGES_ID});n?(n.doc.versions.splice(0,0,{v:r.version}),await z.update(n,{id:n.id})):n=await z.create({parent_id:this.#d.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:r.version}]}})}async setProgress(e){const t="string"==typeof e?e:e?.message;console.log(ee.blue(t)),await this._cache_set(this.#p,{status:"IN_PROGRESS",message:t})}async initNode(){await j(this.#y),await k(this.#y),await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}async initPython(){await D(this.#y),await x(this.#y),await this.initLibraryDirPython(),await this.initNunjucks(),await this.initLibsPython()}async nodeBuild(){this.#m&&(await this.createAtomLibFiles({libs:this.#a}),await this.createEngine(),await this.createProjectYaml(),await O(this.#y),await C(this.#y),await I(this.#y),await T(this.#y),await A(this.#y),await P(this.#y),await $(this.#y),await S(this.#y),await R(this.#y),await M(this.#y),this.#f&&(await F(this.#y),await L(this.#y),this.#g&&await this.deploy()))}async pythonBuild(){this.#m&&(await this.createAtomLibFilesPython({libs:this.#a}),await this.createProjectYaml(),await O(this.#y),await I(this.#y),await E(this.#y),this.#f&&await q(this.#y))}async init(){this._redis_client=await c(),this.#c=this.#t.buildId||p(24),this.#y.buildId=this.#c,this.#u=this.#t.mode,this.#m=["all","deploy","build","file"].includes(this.#u),this.#f=["all","deploy","build"].includes(this.#u),this.#g=["all","deploy"].includes(this.#u),this.#l=this.#t.protocol,this.#p="BUILD:"+this.#c,this.#d=(await V({optional:!0,name:this.#t.atomConfig||"atom",dir:this.#t.projectDir,tags:this.#t.tags}))?.data;try{await this.setProgress({message:"Initialization started."}),await this.initAuth(),await this.initLibrary(),"node"===this.#r.doc.features.runtime.type?await this.initNode():"python"===this.#r.doc.features.runtime.type&&await this.initPython()}catch(e){throw await this._cache_set(this.#p,{status:"FAILED",message:e?.message||e}),e}}async build(){try{"node"===this.#r.doc.features.runtime.type?await this.nodeBuild():"python"===this.#r.doc.features.runtime.type&&await this.pythonBuild(),await this._cache_set(this.#p,{status:"COMPLETED"})}catch(e){throw await this._cache_set(this.#p,{status:"FAILED",message:e.message||e}),console.log(e),e}}},Bt}var fr=K(function(){if(Gt)return Ht;Gt=1;const m=process.cwd(),{spawn:f}=e;t({name:["redis"],dir:m,optional:!0});const g=r,y=n,h=a,w=o,v=i,b=s,_=t,j=c,D=p,k=l,x=mr(),P=function(){if(Kt)return Wt;Kt=1;const e=d,t=u;return Wt=function({baseDir:r=__dirname}){let n=r;for(;n!==t.parse(n).root;){const r=t.join(n,"node_modules");if(e.existsSync(r))return r;n=t.dirname(n)}return null}}()({baseDir:__dirname}),S="win32"===process.platform?";":":";process.env.PATH=`${g.join(P,"/.bin")}${S}${process.env.PATH}`;let A=y(process.argv.slice(2)).command("create","Create flow node project",(e=>e.option("name",{type:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs"}).option("runtime",{type:"string",default:"node",choices:["node","python"]})),(async e=>{try{const t=g.resolve(P,"@fnet/cli-project-node/dist/template/project"),r=g.resolve(m,e.name);h.existsSync(r)||h.mkdirSync(r),await k({dir:t,outDir:r,context:e,copyUnmatchedAlso:!0});let n=v.exec("fnode build",{cwd:r});if(0!==n.code)throw new Error("Failed to build project.");if(v.which("git")&&(n=v.exec("git init --initial-branch=main",{cwd:r}),0!==n.code))throw new Error("Failed to initialize git.");if(v.which("code")&&e.vscode&&(n=v.exec(`cd ${r} && code .`),0!==n.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=g.resolve(P,"@fnet/cli-project-node/dist/template/project"),r=process.cwd(),n=await $(e);if(e.update){if(await k({dir:t,outDir:r,context:{name:n.project.projectFileParsed.name,runtime:n.project.runtime.type},copyUnmatchedAlso:!0}),0!==v.exec("fnode build",{cwd:r}).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",default:"build",choices:["all","file","build","deploy","bpmn"]}).option("ftag",{type:"array"})),(async e=>{try{const t=await $(e),r=new x(t);await r.init(),await r.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("ftag",{type:"array"})),(async e=>{try{const t=await $({...e,mode:"all"}),r=new x(t);await r.init(),await r.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("ftag",{type:"array"})),(async e=>{try{const t=await $({...e,mode:"file"}),r=new x(t);await r.init(),await r.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}));function E(e,{name:t,bin:r,preArgs:n=[]}){return e.command(`${t||r} [commands..]`,`${r} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await $(e),{projectDir:a}=t,o=process.argv.slice(3);f(r,[...n,...o],{cwd:a,stdio:"inherit",shell:!0}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}async function $(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:g.resolve(P,"./@fnet/cli-project-node/dist/template/default"),templateCommonDir:g.resolve(P,"./@fnet/cli-project-common/dist/template/default"),projectDir:g.resolve(m,`./.output/${e.id}`),tags:e.ftag};{const t=await async function({tags:e}){const t=g.resolve(m,"node.yaml");if(!h.existsSync(t))throw new Error("node.yaml file not found in current directory.");const{raw:r,parsed:n}=await b({file:t,tags:e}),a=g.dirname(t);n.features=n.features||{};const o=n.features;o.runtime=o.runtime||{},o.runtime.type=o.runtime.type||"node","python"===o.runtime.type?o.runtime.template=o.runtime.template||"python":o.runtime.template=o.runtime.template||"default";const i={libraryAtom:{doc:{...n},fileName:"index"},projectDir:a,projectFilePath:t,projectFileContent:r,projectFileParsed:n,runtime:o.runtime};let s=g.resolve(a,"fnet/targets.yaml");if(!h.existsSync(s)&&(s=g.resolve(a,"node.devops.yaml"),h.existsSync(s))){const e=g.resolve(a,"fnet");h.existsSync(e)||h.mkdirSync(e),h.copyFileSync(s,g.resolve(a,"fnet/targets.yaml")),h.unlinkSync(s)}if(h.existsSync(s)){const{raw:t,parsed:r}=await b({file:s,tags:e}),n=w.parseDocument(t);i.devops={filePath:s,fileContent:t,yamlDocument:n,doc:{...r},type:"library.deploy",save:async()=>{h.writeFileSync(i.devops.filePath,n.toString())}}}const c=g.resolve(a,"readme.md");if(h.existsSync(c)){const e=h.readFileSync(c,"utf8");i.readme={filePath:c,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return i}({tags:e.ftag});return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:g.resolve(P,`./@fnet/cli-project-node/dist/template/${t.runtime.template}`),templateCommonDir:g.resolve(P,`./@fnet/cli-project-common/dist/template/${t.runtime.template}`),projectDir:g.resolve(t.projectDir,"./.workspace"),projectSrcDir:g.resolve(t.projectDir,"./src"),project:t,tags:e.ftag}}}return A=A.command("create-input <name>","Create an input config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $(e),{project:r}=t,{projectDir:n,projectFileParsed:a}=r,o=a.input;if(!o)throw new Error("Config schema not found in project file.");const i=await j({schema:o,format:"yaml"}),s=g.resolve(n,".fnet");h.existsSync(s)||h.mkdirSync(s);const c=g.resolve(s,`${e.name}.fnet`);h.writeFileSync(c,i)}catch(e){console.error(e.message),process.exit(1)}})),A=function(e){return e.command("update-input <name>","Update an input config file",(e=>e.positional("name",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await $(e),{project:r}=t,{projectDir:n,projectFileParsed:a}=r,o=a.input;if(!o)throw new Error("Config schema not found in project file.");const i=g.resolve(n,".fnet"),s=g.resolve(i,`${e.name}.fnet`),c=await j({schema:o,format:"yaml",ref:s});h.existsSync(i)||h.mkdirSync(i),h.writeFileSync(s,c)}catch(e){console.error(e.message),process.exit(1)}}))}(A),A=E(A,{bin:"npm"}),A=E(A,{bin:"node"}),A=E(A,{name:"serve",bin:"npm",preArgs:["run","serve","--"]}),A=E(A,{name:"watch",bin:"npm",preArgs:["run","watch","--"]}),A=E(A,{name:"app",bin:"npm",preArgs:["run","app","--"]}),A=E(A,{name:"cli",bin:"npm",preArgs:["run","cli","--"]}),A=E(A,{bin:"npx"}),A=E(A,{bin:"cdk"}),A=E(A,{bin:"aws"}),A=function(e,{name:t,preArgs:r=[]}){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 $(e),{projectDir:n}=t,a=e.config,o=await _({name:a,dir:n,transferEnv:!1,optional:!0,tags:t.tags}),i=o?.data?.env||void 0,s=e.command,c=process.argv.slice(5);f(s,[...r,...c],{cwd:n,stdio:"inherit",shell:!0,env:{...process.env,...i}}).on("close",(e=>{process.exit(e)}))}catch(e){console.error(e.message),process.exit(1)}}))}(A,{name:"with"}),A=function(e,{name:t,preArgs:r=[]}){return e.command(`${t} group [options..]`,"Run a command group.",(e=>e.positional("group",{type:"string"}).option("ftag",{type:"array"}).help(!1).version(!1)),(async e=>{try{const t=await $(e),{project:r}=t,{projectFileParsed:n}=r,a=n.commands;if(!a)throw new Error("Commands not found in project file.");const o=a[e.group];if(!o)throw new Error(`Command group '${e.group}' not found in project file.`);await D({commands:o})}catch(e){console.error(e.message),process.exit(1)}}))}(A,{name:"run"}),A.demandCommand(1,"You need at least one command before moving on").help().argv,Ht}());module.exports=fr;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fnet/cli",
3
- "version": "0.70.1",
3
+ "version": "0.71.0",
4
4
  "files": [
5
5
  "dist"
6
6
  ],
@@ -30,9 +30,10 @@
30
30
  "@flownet/lib-to-macos-app": "^0.3.1",
31
31
  "@flownet/lib-to-nextjs": "^0.3.1",
32
32
  "@flownet/lib-to-webos": "^0.3.1",
33
+ "@fnet/auto-conda-env": "^0.1.10",
33
34
  "@fnet/cli-project-common": "^0.3.1",
34
35
  "@fnet/cli-project-flow": "^0.2.13",
35
- "@fnet/cli-project-node": "^0.3.2",
36
+ "@fnet/cli-project-node": "^0.3.4",
36
37
  "@fnet/cli-project-schemas": "^0.1.1",
37
38
  "@fnet/config": "^0.2.8",
38
39
  "@fnet/dir-zipper": "^0.1.5",
@@ -43,7 +44,7 @@
43
44
  "@fnet/object-from-schema": "^0.1.2",
44
45
  "@fnet/prompt": "^0.2.10",
45
46
  "@fnet/shell": "^0.1.13",
46
- "@fnet/shell-flow": "^0.1.2",
47
+ "@fnet/shell-flow": "^0.1.10",
47
48
  "@fnet/to-rust": "^0.1.2",
48
49
  "@fnet/up-list-files": "^0.1.9",
49
50
  "@fnet/yaml": "^0.1.23",