@fnet/cli 0.114.0 → 0.115.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.
Files changed (42) hide show
  1. package/dist/fnet/index.js +1 -1
  2. package/dist/fnode/{index.mC936qdY.js → index.Brxbka97.js} +1 -1
  3. package/dist/fnode/{index.Cl6LPgIY.js → index.CoRsFBwp.js} +1 -1
  4. package/dist/fnode/index.DIZA_GzC.js +1 -0
  5. package/dist/fnode/{index.CLPC6OJN.js → index.Dg0hAD29.js} +1 -1
  6. package/dist/fnode/index.js +1 -1
  7. package/dist/fnode/{index.qJ6fWMSj.js → index.uPDSav7E.js} +1 -1
  8. package/package.json +1 -1
  9. package/template/fnet/bun/src/cli/index.js.njk +1 -1
  10. package/template/fnet/node/rollup.config.mjs.njk +144 -11
  11. package/template/fnet/node/src/cli/index.js.njk +195 -16
  12. package/template/fnode/bun/src/cli/index.js.njk +2 -2
  13. package/template/fnode/node/rollup.config.mjs.njk +144 -11
  14. package/template/fnode/node/src/cli/index.js.njk +388 -23
  15. package/dist/fnode/index.BlhtGEKB.js +0 -1
  16. package/template/fnet/bun/fnet/flows.yaml.njk +0 -1
  17. package/template/fnet/bun/fnet.yaml.njk +0 -1
  18. package/template/fnet/node/fnet/flows.yaml.njk +0 -1
  19. package/template/fnet/node/fnet.yaml.njk +0 -1
  20. package/template/fnet/node/rollup_config_external.njk +0 -8
  21. package/template/fnet/node/rollup_config_onwarn.njk +0 -9
  22. package/template/fnet/node/rollup_config_output_banner.njk +0 -3
  23. package/template/fnet/node/rollup_config_output_footer.njk +0 -5
  24. package/template/fnet/node/rollup_config_output_globals.njk +0 -9
  25. package/template/fnet/node/rollup_config_output_name.njk +0 -3
  26. package/template/fnet/node/rollup_config_plugins.njk +0 -90
  27. package/template/fnode/bun/fnode.yaml.njk +0 -1
  28. package/template/fnode/node/fnode.yaml.njk +0 -1
  29. package/template/fnode/node/rollup_config_external.njk +0 -8
  30. package/template/fnode/node/rollup_config_onwarn.njk +0 -9
  31. package/template/fnode/node/rollup_config_output_banner.njk +0 -3
  32. package/template/fnode/node/rollup_config_output_footer.njk +0 -5
  33. package/template/fnode/node/rollup_config_output_globals.njk +0 -9
  34. package/template/fnode/node/rollup_config_output_name.njk +0 -3
  35. package/template/fnode/node/rollup_config_plugins.njk +0 -90
  36. package/template/fnode/python/fnode.yaml.njk +0 -1
  37. /package/template/fnet/bun/src/default/{to.args.js.njk → input.args.js.njk} +0 -0
  38. /package/template/fnet/node/src/default/{to.args.js.njk → input.args.js.njk} +0 -0
  39. /package/template/fnet/project/.vscode/{launch.json → launch.json.njk} +0 -0
  40. /package/template/fnet/project/.vscode/{tasks.json → tasks.json.njk} +0 -0
  41. /package/template/fnode/bun/src/default/{to.args.js.njk → input.args.js.njk} +0 -0
  42. /package/template/fnode/node/src/default/{to.args.js.njk → input.args.js.njk} +0 -0
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import e,{delimiter as t,join as o}from"node:path";import{fileURLToPath as n}from"node:url";import i from"yargs";import s from"chalk";import{promisify as r}from"node:util";import a from"tree-kill";import{spawn as c}from"node:child_process";import l,{existsSync as p}from"node:fs";import d from"@fnet/config";import f from"node:os";import m from"@flownet/lib-render-templates-dir";import u from"@fnet/shelljs";import h from"@fnet/yaml";import y from"yaml";import g from"nunjucks";import w from"lodash.clonedeep";import b from"isobject";import x from"redis";import j from"@flownet/lib-is-redis-online";import{randomUUID as v}from"node:crypto";import{Api as k,Atom as D}from"@flownet/lib-atom-api-js";import _ from"lodash.merge";import S from"@flownet/lib-parse-imports-js";import E from"@fnet/npm-list-versions";import $ from"@fnet/npm-pick-versions";import P from"object-hash";import N from"ajv/dist/2020.js";import T from"ajv/dist/standalone/index.js";import C from"ajv-formats";import F from"@flownet/lib-parse-node-url";import I from"bpmn-moddle";import O from"dagre";import A from"@fnet/expression";import B from"@fnet/list-files";import K from"@fnet/key-value-transformer";import R from"lodash.pick";import M from"lodash.omit";import L from"@fnet/prompt";import"fs";import"path";import"@fnet/shell-flow";const J=r(a);let W=!1;async function z(e,t){if(W)return;if(W=!0,!e.killed&&e.pid)try{await J(e.pid,"SIGTERM").catch((()=>{})),await new Promise((e=>setTimeout(e,500))),e.killed||await J(e.pid,"SIGKILL").catch((()=>{}))}catch(e){}await new Promise((e=>setTimeout(e,100)));const o="SIGINT"===t?130:"SIGTERM"===t?143:1;process.exit(o)}function G(e){["SIGINT","SIGTERM","SIGQUIT"].forEach((t=>{process.once(t,(async()=>{await z(e,t)}))})),process.on("uncaughtException",(async t=>{await z(e)})),process.on("unhandledRejection",(async t=>{await z(e)})),e.on("close",(e=>{W||process.exit(e)}))}function q(e,{name:t,bin:o,preArgs:n=[]}){return"function"==typeof o&&(o=o()),e.command(`${t||o} [commands..]`,`${o} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await U(e),{projectDir:i}=t,s=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,r=process.argv.slice(3).map(s);G(c(o,[...n,...r],{cwd:i,stdio:"inherit",shell:!0,detached:!0}))}catch(e){console.error(e.message),process.exit(1)}}))}async function U(e){try{const t=process.argv[1].split("/").pop().split(".")[0];if("fnode"===t){const{createContext:t}=await import("./index.PNP2oTpU.js");return t(e)}if("fnet"===t){const{createContext:t}=await Promise.resolve().then((function(){return ee}));return t(e)}if("frun"===t){const{createContext:t}=await import("./index.CuMyez3E.js");return t(e)}if("fbin"===t){const{createContext:t}=await import("./index.DWpw12No.js");return t(e)}}catch(e){console.warn(`Warning: Could not import context from CLI tool: ${e.message}`)}return{projectDir:process.cwd(),tags:e.ftag}}var V=e=>{const n=process.env.PATH||"",i="win32"===process.platform?(process.env.PATHEXT||".EXE;.CMD;.BAT;.COM").split(";"):[""],s=n.split(t);for(const t of s)for(const n of i){const i=o(t,"win32"===process.platform?e+n:e);if(p(i))return i}return null};const X=e.dirname(n(import.meta.url)),H=process.cwd();function Y(t){const o=e.resolve(H,t);if(l.existsSync(o))return o;const n=e.resolve(X,"../..",t);if(l.existsSync(n))return n;throw new Error(`Template path not found: ${t}`)}const Q={command:"create",describe:"Initialize a new fnet project",builder:e=>e.option("name",{type:"string",describe:"Project name"}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node"],describe:"Runtime environment"}),handler:async t=>{try{const o=process.cwd(),n=Y("./template/fnet/project"),i=e.resolve(o,t.name);l.existsSync(i)||l.mkdirSync(i),await m({dir:n,outDir:i,context:t,copyUnmatchedAlso:!0,platform:f.platform()});let s=await u("fnet build",{cwd:i});if(0!==s.code)throw new Error("Failed to build project.");if(V("git")&&(s=await u("git init --initial-branch=main",{cwd:i}),0!==s.code))throw new Error("Failed to initialize git.");if(V("code")&&t.vscode&&(s=await u(`cd ${i} && code .`),0!==s.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)}}};async function Z(t){if(t.id)return{id:t.id,buildId:t.buildId,mode:t.mode,protocol:t.protocol||"ac:",templateDir:Y("./template/fnet/node"),coreDir:Y("./template/fnet/core"),projectDir:e.resolve(process.cwd(),`./.output/${t.id}`),tags:t.ftag};try{const o=await async function({tags:t}){let o=(n=process.cwd(),e.resolve(n,"fnet.yaml"));var n;if(!l.existsSync(o))throw new Error("fnet.yaml file not found in current directory.");const{raw:i,parsed:s}=await h({file:o,tags:t}),r=e.dirname(o);s.features=s.features||{};const a=s.features;let c;if(a.runtime=a.runtime||{},a.runtime.type=a.runtime.type||"node","object"==typeof s.flows)c=s.flows;else{let o="flow.main.yaml";l.existsSync(e.join(r,"fnet","flows.yaml"))&&(o=e.join("fnet","flows.yaml"));const n=s.main||o;let i=e.resolve(r,n);if(l.existsSync(i)){const{parsed:e}=await h({file:i,tags:t});c=e}else c={main:{steps:[]}}}const p={workflowAtom:{doc:{...s,content:c}},projectDir:r,projectFilePath:o,projectFileContent:i,projectFileParsed:s,runtime:a.runtime};let d=e.resolve(r,"fnet/targets.yaml");if(l.existsSync(d)){const{raw:e,parsed:o}=await h({file:d,tags:t}),n=y.parseDocument(e);p.devops={filePath:d,fileContent:e,yamlDocument:n,doc:{...o},type:"workflow.deploy",save:async()=>{l.writeFileSync(p.devops.filePath,n.toString())}}}const f=e.resolve(r,"readme.md");if(l.existsSync(f)){const e=l.readFileSync(f,"utf8");p.readme={filePath:f,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return p}({tags:t.ftag});return{buildId:t.buildId,mode:t.mode,protocol:t.protocol||"local:",templateDir:Y("./template/fnet/node"),coreDir:Y("./template/fnet/core"),projectDir:e.resolve(o.projectDir,"./.workspace"),projectSrcDir:e.resolve(o.projectDir,"./src"),project:o,tags:t.ftag}}catch(e){return console.warn(`Warning: Could not load project: ${e.message}`),{projectDir:process.cwd(),tags:t.ftag}}}var ee=Object.freeze({__proto__:null,createContext:Z});const te={command:"project",describe:"Manage fnet project",builder:e=>e.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"}),handler:async e=>{try{const t=Y("./template/fnet/project"),o=process.cwd(),n=await Z(e);if(e.update){if(await m({dir:t,outDir:o,context:{name:n.project.projectFileParsed.name,runtime:"node"},copyUnmatchedAlso:!0,platform:f.platform()}),0!==(await u("fnet build",{cwd:o})).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)}}};class oe{init({config:e,accessToken:t}){return new Promise(((o,n)=>{if(k.set_api_url(e.data.url),t)return k.set_req_token(t),void o(t);fetch(`${e.data.issuer}/protocol/openid-connect/token`,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams(e.data.grant.params)}).then((async e=>{if(!e.ok)throw new Error(await e.text());return e.json()})).then((e=>{k.set_req_token(e.access_token),o(e.access_token)})).catch((e=>{k.set_req_token(),n(e)}))}))}}function ne({feature:e,features:t,packageDevDependencies:o}){const{name:n,packages:i,options:s,extraCheck:r,explicit:a}=e,c=`${n}_enabled`,l=t.rollup_output||{},p=Object.keys(l);let d=s||{};const f=t[n]?.options;f&&(d=_(d,f));const m=!t[n]||!1===t[n]?.enabled;p.forEach((e=>{const o=t.rollup_output[e];if(o){if(Reflect.has(o,n)){if(m||!o[n]||!1===o[n]?.enabled)return void delete o[n];!0===o[n]&&(o[n]={enabled:!0,options:d})}else{if(m||a||!1===t[c])return;o[n]={enabled:!0}}o[n]=o[n]||{},o[n].options={...d,...o[n].options}}}));let u=p.some((e=>!0===t.rollup_output[e][n]?.enabled));r&&(u=r()&&u),t[c]=u,u&&i.forEach((e=>o.push({package:e[0],version:e[1]})))}function ie({dir:t,name:o="index"}){let n=e.resolve(t,`./${o}.tsx`);if(l.existsSync(n)||(n=e.resolve(t,`./${o}.ts`)),l.existsSync(n)||(n=e.resolve(t,`./${o}.jsx`)),l.existsSync(n)||(n=e.resolve(t,`./${o}.js`)),!l.existsSync(n))return{};const i=n,s=e.extname(n);return{file:i,ext:s,ts:".ts"===s||".tsx"===s,name:o}}async function se(t){const{atom:o,context:n,setProgress:i}=t;i("Initializing features..."),o.doc.features=o.doc.features||{};const s=o.doc.features;s.project=s.project||{},s.project.format=s.project.format||s.project_format||"esm",s.project_format=s.project.format,s.dts_enabled=!0===s.dts||void 0!==s.dts&&!1!==s.dts;const r=e.resolve(n.project.projectDir),a=ie({dir:e.resolve(r,"./app")});if(a.file){i("Parsing app entry imports...");let e=await S({file:a.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.app_uses_jsx=t,s.app_has_entry=!0,e=await S({file:a.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.app_entry_uses_jsx=t,s.app_entry_is_ts=a.ts,s.app_entry_ext=a.ext}const c=ie({dir:e.resolve(r,"./cli")});if(c.file){i("Parsing cli entry imports...");let e=await S({file:c.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.cli_uses_jsx=t,s.cli_has_entry=!0,e=await S({file:c.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.cli_entry_uses_jsx=t,s.cli_entry_is_ts=c.ts,s.cli_entry_ext=c.ext}if("workflow.lib"===o.type){const t=ie({dir:e.resolve(r,"./src")});if(t.file){i("Parsing src entry imports...");let e=await S({file:t.file,recursive:!0}),o=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.src_uses_jsx=o,s.src_has_entry=!0,e=await S({file:t.file}),o=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.src_entry_uses_jsx=o,s.src_entry_is_ts=t.ts,s.src_entry_ext=t.ext}}const l=Reflect.has(s,"app_entry_uses_jsx")?!0===s.app_entry_uses_jsx:!0===s.src_entry_uses_jsx,p=Reflect.has(s,"cli_entry_uses_jsx")?!0===s.cli_entry_uses_jsx:!0===s.src_entry_uses_jsx;s.form_enabled=l||p||!0===s.form||!0===s.form?.enabled,s.multiple_enabled=s.multiple_enabled||!0===s.multiple||!0===s.multiple?.enabled,!1===s.app?s.app={enabled:!1}:!0===s.app?s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l}:s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l,...s.app||{}},s.app.enabled=!0===s.app.enabled&&(!0===o.doc.features.form_enabled||!0===s.app.extend||!0===s.app.enabled),s.app.format=s.app.format||"esm",s.app.folder=s.app.folder||s.app.format||"default",!1===s.cli?s.cli={enabled:!1}:!0===s.cli?s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p}:s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p,...s.cli||{}},s.cli.enabled=!0===s.cli.enabled&&(!1===o.doc.features.form_enabled||!0===s.cli.extend||!0===s.cli.enabled),s.cli.format=s.cli.format||"esm",s.cli.folder=s.cli.folder||s.cli.folder||"esm",s.cli.node_options=s.cli.node?.options||s.cli.node_options||"",s.cli.bin=s.cli.bin||o.doc.name,s.cli.installable=!0===s.cli.installable,s.cli.enabled&&(o.doc["npm::bin"]=s.cli.bin,console.log(`Setting npm::bin to ${s.cli.bin} from features.cli.bin`)),s.json=s.cli.enabled||s.json;const d={cjs:{format:"cjs",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!1!==s.cjs,copy:!1},esm:{format:"esm",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!1,enabled:!1!==s.esm,copy:!0},iife:{format:"iife",context:s.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!0===s.iife,terser:!0,copy:!1}};!0===s.webos&&(d.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===s.electron&&(d.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===s.nextjs&&(d.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===s.ios&&(d.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===s.macos&&(d.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===s.app.enabled&&(s.app.dir=`./dist/app/${s.app.folder}`,d.app={format:s.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:s.app.dir,terser:!0,output_exports:!1===s.app.export?"none":"auto",browsersync:!0}),!0===s.cli.enabled&&(s.cli.dir=`./dist/cli/${s.cli.folder}`,d.cli={format:s.cli.format,context:"global",babel:!0===s.src_uses_jsx||!0===s.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:s.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===s.cli.export?"none":"auto"});const f={server:".",startPath:`${e.normalize(s.app.dir||".")}`,files:[e.normalize("./dist/**/*")],cors:!0,open:!1};s.babel_options=_({targets:{browsers:"last 9 versions, not dead",node:"18"}},s.babel_options||s.babel?.options),s.browsersync_options=_(f,s.browsersync_options||s.browsersync?.options||{}),s.replace_options=_({},s.replace_options||s.replace?.options||{}),Reflect.has(s.browsersync_options,"proxy")&&delete s.browsersync_options.server,s.rollup=s.rollup||{},s.rollup_output=_(d,s.rollup_output||s.rollup?.output||{}),s.preact_enabled=!0===s.preact||s.preact&&!1!==s.preact?.enabled;let m=Object.keys(d);for(const e of m){const t=d[e];t&&(!1!==s.rollup[e]?(t.babel_options=t.babel_options||s.babel_options,t.browsersync_options=_(s.browsersync_options,t.browsersync_options),t.replace_options=_(s.replace_options,t.replace_options),s.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),(s.form_enabled||s.babel)&&(t.babel=!0)):delete s.rollup_output[e])}m=Object.keys(s.rollup_output),s.babel_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browser_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browsersync_enabled=!1!==s.browsersync&&m.some((e=>!0===s.rollup_output[e].browsersync)),s.browsersync_enabled=s.browsersync_enabled&&s.app.enabled,s.dependency_auto_enabled=!1!==s.dependency_auto&&!1!==s.dependency_auto?.enabled,s.npm_install_flags=s.npm_install_flags||"",s.react_version=s.react_version||s.react?.version||18,function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features,i=n.css&&!1!==n.css.enabled;let s=[];i&&(s.push(["rollup-plugin-postcss","^4"]),s.push(["sass","^1.66"]),(n.css?.options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":s.push(["postcss-import","^15"]);break;case"postcss-url":s.push(["postcss-url","^10"]);break;case"postcss-preset-env":s.push(["postcss-preset-env","^9"]);break;case"autoprefixer":s.push(["autoprefixer","^10"]);break;case"cssnano":s.push(["cssnano","^6"])}})));ne({feature:{name:"css",packages:s},features:n,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features,i={};!0===n.app?.enabled&&(i.targets=i.targets||[],i.targets.push({src:"./src/app/index.html",dest:n.app.dir}),Reflect.has(n.app,"copy")||Reflect.has(n,"copy")||(n.copy=!0)),ne({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:i},features:n,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({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:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:t.doc.features,packageDevDependencies:o})}(t)}async function re({projectDir:t,name:o,setProgress:n,count:i=1}){let s;const r=P(["npm-pick-versions",o,i]),a=e.join(t,".cache"),c=e.join(a,r+".json");return l.existsSync(c)?(n&&n(`Picking npm version of ${o} from cache ...`),s=JSON.parse(l.readFileSync(c,"utf8"))):(n&&n(`Picking npm version of ${o} ...`),s=await $({name:o,count:i}),l.mkdirSync(a,{recursive:!0}),l.writeFileSync(c,JSON.stringify(s),"utf8")),s}var ae=async e=>{const{atom:t,packageDependencies:o,context:n,deploymentProjectTarget:i,setProgress:s,deploymentProject:r,yamlTarget:a}=e;if(!0!==i.enabled)return;const c=i.type;try{if("lib"===c)await(await import("./index.DG8TqL-1.js")).default({...e});else if("red"===c)await(await import("./index.CmMM-Ek9.js")).default({...e});else if("npm"===c)await(await import("./index.BraqWHnP.js")).default({...e});else if("gcs"===c)await(await import("./index.UOds5XLl.js")).default({...e});else if("gitlab"===c)await(await import("./index.DI3yyTtl.js")).default({...e});else if("fnet-package"===c)await(await import("./index.Bfg4lyu-.js")).default({...e});else if("fnet-form"===c)await(await import("./index.Q-CYRcna.js")).default({...e});else if("fnet-node"===c)await(await import("./index.C2S9JYhS.js")).default({...e});else if("fnet-flow"===c)await(await import("./index.BuYxdKtK.js")).default({...e});else if("nextjs"===c)await(await import("./index.CDct_kkF.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("webos"===c)await(await import("./index.CMC8mlye.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("electron"===c)await(await import("./index.xd8c7XMr.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("docker"===c)await(await import("./index.D2N9YZmA.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("ios"===c)await(await import("./index.B5XE4ChJ.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("macos"===c)await(await import("./index.W6RYgypK.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("rust"===c)await(await import("./index.CzAV0S36.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else{if("pypi"!==c)return void console.warn(`No deployer found for type: ${c}`);await(await import("./index.C7saWH6d.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0}}catch(e){throw console.error(`Error during deployment for type "${c}":`,e),e}},ce={name:"ATOM",uri:"http://atom.org/bpmn",prefix:"atom",types:[{name:"AtomExtension",extends:["bpmn:BaseElement"],properties:[{name:"atom",type:"atom:Atom",isMany:!1}]},{name:"Atom",properties:[{name:"type",type:"String",isAttr:!0}]}]};function le(e,t){return e.filter(((e,o,n)=>n.map((e=>e[t])).indexOf(e[t])===o))}function pe(e){const{nodes:t,nodeIndex:o,root:n}=e,i=e.targetNodes||n.childs;i.forEach((t=>{const o="workflow"===t.type||"subworkflow"===t.type,n=!o&&t.childs.filter((e=>!e.virtual)).length>0;if(n&&(t.bpmn.type="bpmn:SubProcess"),o||n){const o=t.childs.filter((e=>!0!==e.module))[0];t.childs.filter((e=>!0===e.module)).forEach((o=>{const n=de({...e,parent:t,bpmnType:"bpmn:IntermediateCatchEvent",type:"inter",definitions:[{type:"bpmn:SignalEventDefinition"}]});n.bpmn.edges=[{from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const n=t.childs.find((e=>"try"===e.name&&"tryexcept"===t.type)),s=t.childs.filter((e=>"except"===e.name&&"tryexcept"===t.type));n&&s.length&&s.forEach((o=>{const i=de({location:t.childs.indexOf(o),...e,parent:t,bpmnType:"bpmn:BoundaryEvent",type:"boundary",attrs:{attachedToRef:n},definitions:[{type:"bpmn:ErrorEventDefinition"}]});i.bpmn.edges=[{from:i.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const r=t.childs.find((e=>"raise"===e.type));if(r){const o=de({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:"ERROR",definitions:[{type:"bpmn:ErrorEventDefinition"}]});r.bpmn.edges=[{from:r.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}if(o)if(t.bpmn.starts.length>1){const o=de({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"}),n=de({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch"});o.bpmn.edges=[{from:o.indexKey,to:n.indexKey,type:"bpmn:SequenceFlow"}],n.bpmn.edges=t.bpmn.starts.map((e=>({...e,from:n.indexKey})));const i=n.bpmn.edges.find((e=>!0===e.next));if(i){const o=de({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:i.to});i.to=o.indexKey}}else{const n=de({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"});n.bpmn.edges.push({from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"})}t.childs.filter((e=>!0!==e.virtual&&e.bpmn.outside.length&&"bpmn:EndEvent"!==e.bpmn.type)).forEach((o=>{o.bpmn.outside.forEach((n=>{const s=i.indexOf(t),r=de({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:n.to,location:s+1});o.bpmn.edges.push({from:o.indexKey,to:r.indexKey,type:"bpmn:SequenceFlow"})}))}));t.childs.filter((e=>!0!==e.virtual&&e.bpmn.edges.length>1)).forEach((o=>{const n=i.indexOf(o),s=de({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch",location:n+1});s.bpmn.edges=o.bpmn.edges.map((e=>({...e,from:s.indexKey}))),o.bpmn.edges=[{from:o.indexKey,to:s.indexKey,type:"bpmn:SequenceFlow"}],o.bpmn.outside=[]}))}pe({...e,targetNodes:t.childs})}))}function de(e){const{parent:t,nodes:o,nodeIndex:n,bpmnType:i,type:s,name:r,outside:a,location:c,definitions:l,attrs:p}=e,d=t.childs.filter((e=>e.type===`v${s}`)).length,f={indexKey:`${t.indexKey}/_${s}${d}`,pathKey:`${t.pathKey}._${s}${d}`,type:`v${s}`,name:r,bpmn:{edges:[],outside:[],type:i,width:36,height:36,fill:"#c8e6c9",stroke:"#205022",definitions:l,attrs:p},virtual:!0,childs:[]};return t.childs.splice(c||0,0,f),o.push(f),n[f.indexKey]=f,f}function fe(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a,nodes:c}=e;!function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,nodes:a}=e,c=o.get("flowElements");o.$nodes=o.$nodes||[],t.childs.forEach((e=>{const t=i.create(e.bpmn.type,{id:`node.${e.pathKey}`,name:e.definition?.title||e.name});if(s[t.id]=t,t.$isNode=!0,t.$node=e,e.$flow=t,o.$nodes.push(t),c.push(t),e.bpmn.attrs){Object.keys(e.bpmn.attrs).forEach((o=>{"attachedToRef"===o&&t.set(o,e.bpmn.attrs[o].$flow)}))}if(e.bpmn.definitions){const o=e.bpmn.definitions.map((e=>{const t=i.create(e.type);return Object.keys(e.attrs||{}).forEach((o=>{t.set(o,e.attrs[o])})),t}));t.eventDefinitions=o}}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=o.get("flowElements");o.$edges=o.$edges||[],t.childs.forEach((e=>{e.bpmn.edges.forEach((t=>{const n=e,c=r[t.to],l=`edge.${n.pathKey}_${c.pathKey}`;if(s[l])return;const p=s[`node.${n.pathKey}`],d=s[`node.${c.pathKey}`],f=i.create(t.type,{id:l,sourceRef:p,targetRef:d});s[f.id]=f,f.$is_edge=!0,p.get("outgoing").push(f),d.get("incoming").push(f),o.$edges.push({from:p,to:d,flow:f}),a.push(f)}))}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=120,c=80,l=160,p=160,d=new O.graphlib.Graph;d.setDefaultEdgeLabel((()=>({}))),d.setGraph({rankdir:"TB",nodesep:a,ranksep:c,xranker:"longest-path"}),o.$nodes.forEach((e=>{d.setNode(e.id,{width:e.$node?.bpmn.width||a,height:e.$node?.bpmn.height||c,label:e.id})})),o.$edges.forEach((e=>{d.setEdge(e.from.id,e.to.id)})),O.layout(d),o.$nodes.forEach((e=>{const t=d.node(e.id);let o=t.width,s=t.height;const r=i.create("bpmndi:BPMNShape",{id:`shape.${e.id}`,bpmnElement:e,bounds:i.create("dc:Bounds",{x:l+t.x-t.width/2,y:p+t.y-t.height/2,width:o,height:s}),label:i.create("bpmndi:BPMNLabel")});e.$node.bpmn.fill&&r.set("bioc:fill",e.$node.bpmn.fill),e.$node.bpmn.stroke&&r.set("bioc:stroke",e.$node.bpmn.stroke);n.get("planeElement").push(r)})),o.$edges.forEach((e=>{const t=d.edge(e.from.id,e.to.id),o=i.create("bpmndi:BPMNEdge",{id:`edge.${e.from.id}_${e.to.id}`,bpmnElement:e.flow,label:i.create("bpmndi:BPMNLabel")});t.points.forEach((e=>{const t=i.create("dc:Point",{x:l+e.x,y:p+e.y});o.get("waypoint").push(t)}));n.get("planeElement").push(o)}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a}=e,c=t.childs.filter((e=>"bpmn:SubProcess"===e.bpmn.type));c.forEach((t=>{const o=s[`node.${t.pathKey}`],n=i.create("bpmndi:BPMNDiagram",{id:`diagram_${t.pathKey}`});s[n.id]=n,a.push(n);const r=i.create("bpmndi:BPMNPlane",{id:`plane_${t.pathKey}`});s[r.id]=r,n.plane=r,r.bpmnElement=o,fe({...e,targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:r})}))}(e)}async function me(e){const t=e.root,o=t.context.index,n=Object.keys(o).map((e=>o[e]));!function(e){const{nodes:t}=e;t.forEach((e=>{const t=[],o=[],n=i=>{i.context.next&&(t.push({from:i,to:i.context.next,type:"bpmn:SequenceFlow"}),i===e&&o.push({to:i.context.next,type:"bpmn:SequenceFlow",next:!0})),i.childs.forEach((t=>{i===e&&"switch"===e.type&&o.push({to:t,type:"bpmn:SequenceFlow"}),n(t)}))};n(e);const i=t.filter((t=>t.to.parent.indexKey===e.parent.indexKey)).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),s=t.filter((t=>t.to.parent.indexKey!==e.parent.indexKey&&!t.to.indexKey.startsWith(e.indexKey+"/"))).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),r=o.map((e=>({...e,to:e.to.indexKey})));e.bpmn=e.bpmn||{},e.bpmn.edges=le(i,"to"),e.bpmn.outside=le(s,"to"),e.bpmn.starts=le(r,"to"),e.bpmn.type=function(e){return"call"===e.type?"bpmn:ServiceTask":"form"===e.type?"bpmn:UserTask":"return"===e.type?"bpmn:EndEvent":"bpmn:Task"}(e),e.bpmn.width=120,e.bpmn.height=80,"return"===e.type&&(e.bpmn.width=36,e.bpmn.height=36)}))}({nodes:n}),pe({nodes:n,nodeIndex:o,root:t});const i=new I({atom:ce}),s={},r=i.create("bpmn:Definitions",{id:"definitions_0"});s[r.id]=r;for await(const e of t.childs){const a=r.get("rootElements"),c=r.get("diagrams"),l=i.create("bpmn:Process",{id:`process_${e.pathKey}`,documentation:[i.create("bpmn:Documentation",{text:`Atom Workflow - ${t.context.atom.name}`})]});s[l.id]=l,l.isExecutable=!0,a.push(l);const p=i.create("bpmndi:BPMNDiagram",{id:`diagram_${e.pathKey}`});s[p.id]=p,c.push(p);const d=i.create("bpmndi:BPMNPlane",{id:`plane_${e.pathKey}`});s[d.id]=d,p.plane=d,d.bpmnElement=l;fe({targetNode:e,targetFlowElementsContainer:l,targetPlaneElement:d,moddle:i,elementIndex:s,nodeIndex:o,nodes:n,diagrams:c})}return{diagramXML:(await i.toXML(r,{format:!0})).xml}}async function ue(e={}){return await me(w(e))}async function he({node:e,initNode:t}){if(Reflect.has(e.definition,"modules")&&!Array.isArray(e.definition.modules)){const t=e.definition.modules;e.definition.modules=[],Object.keys(t).forEach((o=>{const n={...t[o]};"modules"===e.type&&(n.export=n.export||o),e.definition.modules.push({[o]:n})}))}const o=[],n=await K({data:e.definition,callback:(e,t,n)=>{const i=A({expression:e});if("m"===i?.processor){const e=n.slice(0,-1);e.push(i.statement);const s=e.join("_");return o.push({[s]:t}),[i.statement,`m::${s}`]}return[e,t]}});o.length>0&&(e.definition=n,e.definition.modules=e.definition.modules||[],e.definition.modules=e.definition.modules.concat(o)),e.hasModules=e.definition.modules?.length>0;for(let o=0;o<e.definition.modules?.length;o++){const n=e.definition.modules[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}}async function ye({node:e,transformExpression:t}){const o=e.context.transform;Reflect.has(o,"export")&&(o.export=await t(o.export)),Reflect.has(o,"return")&&(e.hasReturn=!0,o.return=await t(o.return)),o.hasOwnProperty("nextArgs")&&(e.hasNextArgs=!0,o.nextArgs=await t(o.nextArgs))}async function ge({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform;for(const t of e.childs)t.context.transform=t.context.transform||w(t.definition),t.definition.hasOwnProperty("condition")&&(t.context.transform.condition=await n(t.definition.condition));await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var we={hits:async function({node:e}){return!!e.definition.hasOwnProperty("switch")},init:async function({node:e,initNode:t}){e.type="switch";const o=e.definition.switch||[];if(!o.every((e=>e.hasOwnProperty("condition")||e.hasOwnProperty("default"))))throw new Error("Switch must have condition or default");if(0===o.filter((e=>e.hasOwnProperty("condition"))).length)throw new Error("Switch must have at least one condition");const n=o.filter((e=>e.hasOwnProperty("default")));if(n.length>1)throw new Error("Switch must have only one default");if(1===n.length&&!o[o.length-1].hasOwnProperty("default"))throw new Error("Switch default must be the last child");e.hasDefaultCondition=1===n.length,await he({node:e,initNode:t}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0;for(let o=0;o<e.definition.switch.length;o++){let n=e.definition.switch[o],i=`${o}`;n.hasOwnProperty("default")&&(i="default",n=n.default);const s={name:n.condition||i,childs:[],parent:e,definition:n,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=ge},resolve:ge};var be={hits:async function({node:e}){return 1===Object.keys(e.definition).map((e=>A({expression:e}))).filter((e=>"if"===e?.processor)).length},init:async function(e){const{node:t}=e,o=Object.keys(t.definition).map((e=>A({expression:e}))),n=[],i=o.find((e=>"if"===e?.processor)),s=t.definition[i.expression];n.push({name:`${t.name}_if`,definition:s,processor:i}),delete t.definition[i.expression];const r=o.filter((e=>"elseif"===e?.processor));let a=0;for(const e of r){const o=t.definition[e.expression];n.push({name:`${t.name}_elseif_${a++}`,definition:o,processor:e}),delete t.definition[e.expression]}t.definition.switch=[];for(const e of n)t.definition.switch.push({condition:e.processor.statement,...e.definition});if(t.definition?.else){const e=t.definition.else;t.definition.switch.push({default:e}),delete t.definition.else}await we.init(e)}};async function xe({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){if(e.context.transform=e.context.transform||w(e.definition),e.context.transform,e.context.try=e.childs.find((e=>"try"===e.name)),e.context.except=e.childs.find((e=>"except"===e.name)),e.context.except){const t=e.context.except;t.context.transform=t.context.transform||w(t.definition),t.context.transform.hasOwnProperty("as")||(t.context.transform.as="error")}await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var je={hits:async function({node:e}){return e.definition.hasOwnProperty("try")&&e.definition.hasOwnProperty("except")},init:async function({node:e,initNode:t}){if(e.type="tryexcept",await he({node:e,initNode:t}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0,e.definition.try){const o="try",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}if(e.definition.except){const o="except",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}e.resolve=xe},resolve:xe};async function ve({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;for(let e=0;e<i.assign?.length;e++){let t=i.assign[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.assign[e]=r}await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var ke={hits:async function({node:e}){return e.definition.hasOwnProperty("assign")},init:async function({node:e,initNode:t}){e.type="assign",await he({node:e,initNode:t}),e.resolve=ve},resolve:ve};async function De({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);e.context.transform.for.in=await n(e.definition.for.in),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var _e={hits:async function({node:e}){return e.definition.hasOwnProperty("for")},init:async function({node:e,initNode:t}){if(e.type="for",await he({node:e,initNode:t}),e.blockAutoJumpToParent=!0,e.blockAutoJumpToSibling=!1,!e.definition.for.hasOwnProperty("steps")){const t=["value","in"],[o,n]=[R(e.definition.for,t),M(e.definition.for,t)];e.definition.for=o,e.definition.for.steps=[{[`${e.name}_step`]:n}]}Array.isArray(e.definition.for.steps)||(e.definition.for.steps=[{[`${e.name}_step`]:e.definition.for.steps}]);for(let o=0;o<e.definition.for.steps.length;o++){const n=e.definition.for.steps[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=De},resolve:De};var Se={hits:async function({node:e}){return!1},init:async function({node:e,initNode:t}){},resolve:async function({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){}};async function Ee({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;n.raise=await o(n.raise),await t({node:e})}var $e={hits:async function({node:e}){return e.definition.hasOwnProperty("raise")},init:async function({node:e,initNode:t}){e.type="raise",e.resolve=Ee},resolve:Ee};async function Pe({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;e.hasReturn=!0,n.return=await o(n.return),await t({node:e})}var Ne={hits:async function({node:e}){return e.definition.hasOwnProperty("return")},init:async function({node:e,initNode:t}){e.type="return",e.resolve=Pe},resolve:Pe};async function Te({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;if("function"===e.target?.atom?.doc?.type&&(i.call=await n(e.target.atom.name)),i.args&&(i.args=await n(i.args)),i.result){"string"==typeof i.result&&(i.result=[{[i.result]:"e::result"}]);for(let e=0;e<i.result?.length;e++){let t=i.result[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.result[e]=r}}const s=e.workflow.parent;i.import?e.context.lib=s.context.libs.find((e=>e.name===i.import)):e.context.lib=s.context.libs.find((e=>e.name===i.call)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Ce={hits:async function({node:e}){return e.definition.hasOwnProperty("call")},init:async function({node:e,initNode:t}){e.type="call",await he({node:e,initNode:t}),e.resolve=Te},resolve:Te};async function Fe({node:e,transformExpression:t}){e.context.next=e.childs[0],e.context.transform=e.context.transform||w(e.definition),await ye({node:e,transformExpression:t})}var Ie={hits:async function({node:e}){return e.definition.hasOwnProperty("steps")},init:async function({node:e,initNode:t}){e.type||(e.type="steps");const o=e.definition.steps||[];for await(const n of o){const o=Object.keys(n)[0],i={name:o,childs:[],parent:e,definition:n[o],index:e.childs.length,context:{}};e.childs.push(i),await t({node:i})}e.resolve=Fe},resolve:Fe};async function Oe({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.props&&(i.props=await n(i.props));const s=e.workflow.parent;e.context.lib=s.context.libs.find((e=>e.name===i.form)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Ae={hits:async function({node:e}){return e.definition.hasOwnProperty("form")},init:async function({node:e,initNode:t}){e.type="form",await he({node:e,initNode:t}),e.resolve=Oe},resolve:Oe};async function Be({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){e.context.transform=e.context.transform||w(e.definition),await t({node:e})}var Ke={hits:async function({node:e}){return e.definition.hasOwnProperty("operation")},init:async function({node:e,initNode:t}){e.type="operation",e.resolve=Be},resolve:Be};async function Re({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.next=await n(i.next),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Me={hits:async function({node:e}){return e.definition.hasOwnProperty("next")},init:async function({node:e,initNode:t}){e.type="jump",e.resolve=Re},resolve:Re};async function Le({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform,await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Je={hits:async function({node:e}){return e.definition.hasOwnProperty("modules")},init:async function({node:e,initNode:t}){e.type="modules",await he({node:e,initNode:t}),e.resolve=Le},resolve:Le};function We({node:e}){const t=e.definition;if(!e.hasReturn)if("end"===t.next);else if("stop"===t.next);else if("none"===t.next);else if(t.next){let o=e.parent;for(;o.parent;){const n=o.childs.find((e=>e.name===t.next));if(n){e.context.next=n;break}o=o.parent}}else{if(!0===e.module)return;let t=e.parent,o=e.index+1;for(;t.parent&&(!t.blockAutoJumpToParent||!t.blockAutoJumpToSibling);)if(Reflect.has(t,"blockAutoJumpToParent")||Reflect.has(t,"blockAutoJumpToSibling")){if(t.blockAutoJumpToParent){const n=t.childs.find((e=>e.index===o));n&&(e.context.next=n);break}t.blockAutoJumpToParent||(o=t.index+1,t=t.parent)}else{const n=t.childs.find((e=>e.index===o));if(n){e.context.next=n;break}o=t.index+1,t=t.parent}}}class ze{#e;#t;#o;#n;constructor({key:e,npm:t,master:o,extras:n}){this.#e=e,this.#t=t,this.#o=o,this.#n=n}hits({node:e}){return e.definition.hasOwnProperty(this.#e)}async init(e){const{node:t}=e,o=this.#e,n=t.definition,i=typeof n[o];if(n.call=`npm:${this.#t}`,n.args="object"!==i?{...n.args,[`${this.#o}`]:n[o]}:n[o],delete n[o],this.#n)for(const e in this.#n)n[e]=this.#n[e];console.log(`[npm-block] ${this.#e} --\x3e ${this.#t}`),await Ce.init(e)}}function Ge(e){return new ze(e)}class qe{#i;#s;#r;#a;#c;#l;#p;#d;#f;#m;#u;#h;#y;#g;#w;#b;#x;#j;#v;#k;#D;#_=[];constructor(e){this.#i=new oe,this.#s=e,this.#l=[],this.#p=[],this.#d={},this._expire_ttl=3600,this._expire_ttl_short=300,this.#_.push(Ge({key:"config",npm:"@fnet/config",master:"name"})),this.#_.push(Ge({key:"yaml",npm:"@fnet/yaml",master:"file"})),this.#_.push(Ge({key:"prompt",npm:"@fnet/prompt",master:"message"})),this.#_.push(Ge({key:"html-link",npm:"@flownet/lib-load-browser-link-url",master:"src"})),this.#_.push(Ge({key:"html-script",npm:"@flownet/lib-load-browser-script-url",master:"src"})),this.#_.push(Ge({key:"http-server",npm:"@fnet/node-express",master:"server_port"})),this.#_.push(Ge({key:"shell",npm:"@fnet/shell-flow",master:"commands"})),this.#_.push(Ge({key:"list-files",npm:"@fnet/list-files",master:"pattern"})),this.#_.push(Ge({key:"up-list-files",npm:"@fnet/up-list-files",master:"pattern"})),this.#_.push(Ge({key:"auto-conda-env",npm:"@fnet/auto-conda-env",master:"envDir"})),this.#_.push(Ge({key:"ollama-chat",npm:"@fnet/ollama-chat",master:"model"})),this.#_.push(Ge({key:"ai",npm:"@fnet/ai",master:"prompt",extras:{subtype:"flow"}})),this.#_.push(Ge({key:"invoke",npm:"@fnet/invoke",master:"method",extras:{}})),this.#_.push(Ge({key:"fetch",npm:"@fnet/fetch",master:"url",extras:{}})),this.#_.push(Ge({key:"filemap",npm:"@fnet/filemap",master:"target",extras:{}})),this.#k={packageDependencies:this.#l,packageDevDependencies:this.#p,setProgress:this.setProgress.bind(this),context:this.#s,Atom:D,registerToPackageManager:this.registerToPackageManager.bind(this)},this.#D={initNode:this.initNode.bind(this),cloneDeep:w,resolveTypeCommon:this.resolveTypeCommon.bind(this),resolveNextBlock:We,transformExpression:this.transformExpression.bind(this),transformValue:this.transformValue.bind(this)}}async _cache_set(e,t,o){this._redis_client&&await this._redis_client.SETEX(e,o||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await async function(){if(!await j({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=x.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e}(),this.#u=this.#s.buildId||v(),this.#k.buildId=this.#u,this.#w=this.#s.mode,this.#b=["all","deploy","build","file"].includes(this.#w),this.#x=["all","deploy","build"].includes(this.#w),this.#j=["all","deploy"].includes(this.#w),this.#v=["all","deploy","build","file","bpmn"].includes(this.#w),this.#y=this.#s.protocol,this.#h="BUILD:"+this.#u,this.#g=(await d({optional:!0,name:"atom",dir:this.#s.projectDir,tags:this.#s.tags}))?.data;try{await this.setProgress({message:"Initialization started."}),await this.initAuth(),await this.initWorkflow(),this.transformWorkflow({workflow:this.#a});const e=await this.initNodeTree({workflow:this.#a});await this.initNodeTreeIndex({root:e}),await this.initNodeCalls({root:e}),await this.initNodeCallLibs({root:e}),await this.initNodeForms({root:e}),await this.initNodeFormLibs({root:e}),await this.initEntryFiles({root:e,features:this.#r.doc.features}),await this.initFeaturesFromNodes({childs:e.childs,features:this.#r.doc.features}),await se(this.#k),await async function({atom:e,packageDependencies:t,packageDevDependencies:o,setProgress:n}){n("Initializing dependencies");const i=e.doc.dependencies||[];if(i.filter((e=>!e.dev)).forEach((e=>t.push(e))),i.filter((e=>e.dev)).forEach((e=>o.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let o="^18.2";n("Fetching React versions"),o=`^${(await E({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:o}),t.push({package:"react-dom",version:o}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),o.push({package:"ajv",version:"^8"}),e.doc.features.cli.fargs&&!1!==e.doc.features.cli.fargs?.enabled&&t.push({package:"@fnet/config",version:"0.2.21"})),e.doc.features.render&&!1!==e.doc.features.render.enabled&&o.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"}),o.push({package:"@babel/core",version:"^7"}),o.push({package:"@rollup/plugin-commonjs",version:"^28"}),o.push({package:"@rollup/plugin-node-resolve",version:"^16"}),o.push({package:"@rollup/plugin-replace",version:"^6"}),o.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&o.push({package:"rollup-plugin-dts",version:"^6"}),o.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),o.push({package:"@rollup/plugin-alias",version:"^5"}),o.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(o.push({package:"@rollup/plugin-babel",version:"^6"}),o.push({package:"@babel/preset-env",version:"^7"}),o.push({package:"@babel/preset-react",version:"^7"}),e.doc.features.babel?.options?.plugins?.forEach((e=>{switch(e[0]){case"@babel/plugin-proposal-decorators":o.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":o.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":o.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":o.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":o.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"})}}))),o.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),e.doc.features.browsersync_enabled&&o.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}(this.#k),await this.initAtomLibsAndDeps({libs:e.context.libs,packageDependencies:this.#l}),await this.resolveNodeTree({root:e}),this.#m=e}catch(e){throw await this._cache_set(this.#h,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#s.id&&(this.#f=await this.#i.init({config:this.#g}),this.#k.atomAccessToken=this.#f)}async initWorkflow(){const e=this.#s.id;this.#r=this.#s.project?.workflowAtom||await D.get({id:e}),this.#a="string"==typeof this.#r.doc.content?(await h({content:this.#r.doc.content,tags:this.#s.tags})).parsed:this.#r.doc.content;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",this.#k.atom=this.#r,this.#r.doc.features=this.#r.doc.features||{}}#S(t){console.log("filePath",t),l.statSync(t).isDirectory()?(l.readdirSync(t).forEach((o=>{const n=e.join(t,o);this.#S(n)})),l.rmSync(t)):l.unlinkSync(t)}#E(t,o){const n=l.existsSync(t),i=n&&l.statSync(t);n&&i.isDirectory()?(l.mkdirSync(o,{recursive:!0}),l.readdirSync(t).forEach((n=>{this.#E(e.join(t,n),e.join(o,n))}))):l.copyFileSync(t,o)}async initWorkflowDir(){this.setProgress({message:"Initializing library directory."});const t=this.#s.projectDir,o=this.#s.coreDir;this.setProgress({message:"Cleaning project directory."});const n=B({dir:t,ignore:[".cache","node_modules",".conda",".bin"],absolute:!0});for(const e of n)l.rmSync(e,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."}),l.existsSync(t)||l.mkdirSync(t,{recursive:!0});const i=e.join(t,"src");l.existsSync(i)||l.mkdirSync(i,{recursive:!0});const s=e.join(i,"core");this.#E(o,s);const r=e.join(i,"default","blocks");l.existsSync(r)||l.mkdirSync(r,{recursive:!0})}async initNunjucks(){this.setProgress({message:"Initializing nunjucks."});const e=this.#s.templateDir;this.#c=g.configure(e,{watch:!1,dev:!0}),this.#k.njEnv=this.#c}transformWorkflow({workflow:e}){for(const t of Object.values(e))t.steps=t.steps||[],t.steps=t.steps.filter((e=>Object.keys(e).length>0)),t.steps=t.steps.map((e=>this.transformStep({step:e})))}transformStep({step:e}){if(Array.isArray(e))throw new Error("Step must be an object.");const[t,o]=Object.entries(e)[0];if(o.hasOwnProperty("onerror")){const{onerror:n,...i}=o;e[t]={try:i,except:n}}if(e[t].hasOwnProperty("steps")){const o=e[t].steps;if(!Array.isArray(o))throw new Error("Steps must be an array.");e[t].steps=o.map((e=>this.transformStep({step:e})))}return e}async initNodeTree({workflow:e}){const t=Object.keys(e),o={definition:e,name:void 0,type:"root",parent:void 0,childs:[],blockAutoJumpToParent:!0,blockAutoJumpToSibling:!0,index:0,depth:0,context:{libs:[],atom:this.#r}};t.forEach((t=>{const n={name:t,type:"main"===t?"workflow":"subworkflow",childs:[],parent:o,definition:e[t],index:o.childs.length,depth:o.depth+1,context:{},blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1};o.childs.push(n)}));for await(const e of o.childs)await this.initNode({node:e});return o}async initNode({node:e}){const t={...this.#D,node:e};if(e.workflow=e.parent.workflow||e,e.depth=e.parent.depth+1,await je.hits(t))await je.init(t);else if(await _e.hits(t))await _e.init(t);else if(await we.hits(t))await we.init(t);else if(await be.hits(t))await be.init(t);else if(await Se.hits(t))await Se.init(t);else if(await ke.hits(t))await ke.init(t);else if(await $e.hits(t))await $e.init(t);else if(await Ce.hits(t))await Ce.init(t);else if(this.#_.find((e=>e.hits(t))))await this.#_.find((e=>e.hits(t))).init(t);else if(await Ae.hits(t))await Ae.init(t);else if(await Ke.hits(t))await Ke.init(t);else if(await Ie.hits(t))await Ie.init(t);else if(await Me.hits(t))await Me.init(t);else if(await Je.hits(t))await Je.init(t);else{if(!await Ne.hits(t))throw new Error("Undefined step type.");await Ne.init(t)}}async initNodeTreeIndex({root:e}){const t={};e.indexKey="/";for await(const o of e.childs)await this.initNodeIndex({node:o,index:t});return e.context.index=t,t}async initNodeIndex({node:t,index:o}){const n=e.join(t.parent.indexKey,t.name);t.indexKey=n,o[n]=t;const i=[];let s=t;for(;s?.parent;)i.push(s.index),s=s.parent;i.reverse(),t.codeKey=`B_${i.join("_")}_${t.type}`,t.pathKey=`${i.join(".")}`,t.typeId=v();for await(const e of t.childs)await this.initNodeIndex({node:e,index:o})}async initNodeCalls({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"call"===n.type&&o.push(n)}return e.context.calls=o,o}async initNodeCallLibs({root:e}){const t=[],o=e.context.calls;for await(const e of o){const o=e.definition.import||e.definition.call,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom",definition:e.definition},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.callLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeCallTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.call,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeCallTarget({refNode:e,curNode:t.parent})}async initNodeForms({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"form"===n.type&&o.push(n)}return e.context.forms=o,o}async initNodeFormLibs({root:e}){const t=[],o=e.context.forms;for await(const e of o){const o=e.definition.import||e.definition.form,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom"},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.formLibs=t,e.context.libs=[...e.context.libs,...t],t}async initFeaturesFromNodes({childs:e,features:t}){for await(const o of e)"form"!==o.type||Reflect.has(t,"form")||(t.form=!0),await this.initFeaturesFromNodes({childs:o.childs,features:t})}async initEntryFiles({root:e,features:t}){for await(const o of e.childs){let e;if("main"===o.name)e="index.js";else if("cli"===o.name)e="cli.js";else if("app"===o.name)e="app.js";else{if("api"!==o.name)continue;e="api.js"}t[`${o.name}_default_entry_file`]=e,o.entryFile=e}}async findNodeFormTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.form,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeFormTarget({refNode:e,curNode:t.parent})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const o=e.filter((e=>"atom"===e.type));for(let e=0;e<o.length;e++){const n=o[e],i=await this.findAtomLibrary({url:n.name,libRef:n});n.atom=i;const s=i.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));s?.forEach((e=>{const o=t.find((t=>t.package===e.package));o?"string"==typeof e.path?(o.path||[]).some((t=>t===e.path))||(o.path=o.path||[],o.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(o.path||[]).some((t=>t===e))||(o.path=o.path||[],o.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:t,libRef:o}){const n=F({url:t});if(!n)throw new Error(`Invalid package name: ${t}`);if(n.protocol||(n.protocol=this.#y),"ac:"===n.protocol){const e=n.pathname.split("/");if(1===e.length)return await D.first({where:{name:t,parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===e.length){const t=await D.first({where:{name:e[0],parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"folder"}});return await D.first({where:{name:e[1],parent_id:t.id,type:"workflow.lib"}})}}else{if("local:"===n.protocol){const t=e.resolve(this.#s.projectSrcDir,`${n.pathname}.js`),o=[],i=(await S({file:t,recursive:!0})).all;for await(const e of i){if("npm"!==e.type)continue;if(o.find((t=>t.package===e.package)))continue;const t=await re({name:e.package,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});o.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return{name:n.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:o},protocol:n.protocol}}if("npm:"===n.protocol){const e=await re({name:n.pathname,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});return{name:n.pathname,doc:{type:"workflow.lib",subtype:"flow"===o?.definition?.subtype?"workflow":null,"content-type":"javascript",language:"js",dependencies:[{package:n.pathname,version:e.minorRange,type:"npm"}]},protocol:n.protocol}}if("use:"===n.protocol){return{name:n.pathname,doc:{type:"function",dependencies:[]},protocol:n.protocol}}}}async resolveNodeTree({root:e}){for await(const t of e.childs)await this.resolveTypeWorkflow({node:t})}async resolveTypeWorkflow({node:e}){e.context.transform=e.context.transform||w(e.definition);const t=e.context.transform;for(let e=0;e<t.params?.length;e++){const o=t.params[e];if("string"==typeof o)t.params[e]={key:o,hasDefault:!1};else{const n=Object.keys(o)[0];t.params[e]={key:n,hasDefault:!0,default:o[n],type:typeof o[n]}}}e.context.next=e.childs[0];for await(const t of e.childs)await this.resolveType({node:t})}async resolveType({node:e}){const t={...this.#D,node:e};"function"==typeof e.resolve&&await e.resolve(t);for await(const t of e.childs)await this.resolveType({node:t})}async resolveTypeCommon({node:e}){const t=e.context.transform;t.hasOwnProperty("operation")&&(t.operation=await this.transformExpression(t.operation)),t.hasOwnProperty("page")&&(t.page=await this.transformExpression(t.page)),t.hasOwnProperty("print")&&(t.print=await this.transformExpression(t.print)),t.hasOwnProperty("sleep")&&(t.sleep=await this.transformExpression(t.sleep)),t.hasOwnProperty("assert")&&(t.assert=await this.transformExpression(t.assert))}async createAtomLibFiles({root:t}){await this.setProgress({message:"Creating external lib files."}),this.#r.typesDir="./types";const o=t.context.libs.filter((e=>"atom"===e.type));for(let t=0;t<o.length;t++){const n=o[t].atom,i=this.#s.projectDir;if("local:"===n.protocol){const t=e.resolve(this.#s.projectSrcDir,`${n.fileName||n.name}.js`),o=e.relative(`${this.#s.projectDir}/src/default/blocks`,t);if(!l.existsSync(t)){l.mkdirSync(e.dirname(t),{recursive:!0});let o="export default async (args)=>{\n";o+="}",l.writeFileSync(t,o,"utf8")}n.relativePath=o.split(e.sep).join("/"),this.#r.typesDir=`./types/${e.basename(i)}/src`}else if("npm:"===n.protocol)n.relativePath=n.name;else if("use:"===n.protocol);else{const t=`${i}/src/libs/${n.id}.js`,o=n.doc.contents?.find((e=>"esm"===e.format))||n.doc;l.writeFileSync(e.normalize(t),o.content,"utf8")}}}async createEngine({root:t}){await this.setProgress({message:"Creating engine file."});const o=this.#s.templateDir,n=g.compile(l.readFileSync(e.resolve(o,"src/default/engine.js.njk"),"utf8"),this.#c);for(let o=0;o<t.childs.length;o++){const i=t.childs[o];if(!i.entryFile)continue;const s=n.render({flow:i,ui:{package:"@fnet/react-app"}}),r=this.#s.projectDir,a=e.resolve(r,`src/default/${i.entryFile}`);l.writeFileSync(a,s,"utf8")}}async createNodeTree({root:e}){await this.setProgress({message:"Creating block files."});for await(const t of e.childs)await this.createTypeWorkflow({node:t})}async createTypeWorkflow({node:t}){const o=this.#s.templateDir,n=g.compile(l.readFileSync(e.resolve(o,"src/default/workflow.js.njk"),"utf8"),this.#c).render(t),i=this.#s.projectDir,s=e.resolve(i,`src/default/${t.codeKey}.js`);l.writeFileSync(s,n,"utf8");for await(const e of t.childs)await this.createType({node:e})}async createType({node:e}){switch(e.type){case"assign":case"steps":case"return":case"call":case"form":case"raise":case"switch":case"jump":case"tryexcept":case"for":case"operation":case"modules":this.createBlockFromTemplate({node:e})}for await(const t of e.childs)await this.createType({node:t})}createBlockFromTemplate({node:e}){const t=this.getBlockTemplate({node:e});e.context.render=t.render(e),this.createStepFile({node:e})}getBlockTemplate({node:t}){let o=this.#d[t.type];if(o)return o;const n=this.#s.templateDir;return o=g.compile(l.readFileSync(e.resolve(n,`src/default/blocks/${t.type}.js.njk`),"utf8"),this.#c),this.#d[t.type]=o,o}createStepFile({node:t}){const o=this.#s.projectDir,n=`${t.codeKey}.js`,i=e.resolve(o,`src/default/blocks/${n}`);l.writeFileSync(i,t.context.render,"utf8"),t.context.fileName=n,t.context.filePath=i}async transformExpression(e){let t=await this.transformValue(e);return t=JSON.stringify(t),t=this.replaceSpecialPattern(t),t}async transformValue(e){if(Array.isArray(e))for(let t=0;t<e.length;t++)e[t]=await this.transformValue(e[t]);else if(b(e)){const t=Object.keys(e);for(let o=0;o<t.length;o++){const n=t[o],i=A({expression:n});if(i)if("e"===i.processor){const t=e[n].replace(/(\r\n|\n|\r)/g,"");e[i.statement]=`$::${t}::`,delete e[n]}else e[n]=await this.transformValue(e[n]);else e[n]=await this.transformValue(e[n])}}else if("string"==typeof e){const t=A({expression:e});if(t){const{processor:o,statement:n}=t;switch(o){case"v":e=`$::v.${n}::`;break;case"e":e=`$::${n}::`;break;case"m":e=`$::c.module['${n}']::`;break;case"fm":e=`$::flow.getModule('${n}')::`;break;case"f":e=`$::c.form.${n}::`;break;case"for":e=`$::caller.for.${n}::`}}}return e}replaceSpecialPattern(e){return e.replace(/"\$::(.*?)::"/g,"$1")}replaceExpressionLegacy(e){return e.replaceAll(/(?<outer>"\${(?<inner>[^{]*)}")/g,"$2")}async createProjectYaml(){const t="fnet.yaml",o=`Creating ${t}`;await this.setProgress({message:o});const{content:n,...i}=this.#r.doc,s={content:y.stringify(i)},r=this.#s.templateDir,a=g.compile(l.readFileSync(e.resolve(r,`${t}.njk`),"utf8"),this.#c).render(s),c=this.#s.projectDir,p=e.resolve(c,`${t}`);l.writeFileSync(p,a,"utf8")}async createProjectMainYaml(){const t="flow.main.yaml",o=`Creating ${t}`;await this.setProgress({message:o});const n={content:y.stringify(this.#a)},i=this.#s.templateDir,s=g.compile(l.readFileSync(e.resolve(i,`${t}.njk`),"utf8"),this.#c).render(n),r=this.#s.projectDir,a=e.resolve(r,`${t}`);l.writeFileSync(a,s,"utf8")}async runPrettifier(){const t=this.#s.projectDir;if(V("bun")){const o=await u("prettier --write .",{cwd:e.resolve(t,"src")});if(0!==o.code)throw new Error(o.stderr)}else{const o=await u("prettier --write .",{cwd:e.resolve(t,"src")});if(0!==o.code)throw new Error(o.stderr)}}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#s.project?.devops){const e=[this.#s.project?.devops];for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&await o.save()}}else if(this.#r.id){const e=await D.list({type:"workflow.deploy",parent_id:this.#r.id});for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&(o=await D.update(o,{id:o.id}))}}}async deployProject(e){const{deploymentProject:t}=e,{yamlDocument:o}=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||{}),i=o||{};for(let e=0;e<n.length;e++){const o=t.doc[n[e]];o.name=n[e];const s=i.get(n[e]);await ae({...this.#k,deploymentProject:t,deploymentProjectTarget:o,yamlTarget:s})}}async registerToPackageManager(e){const{target:t,packageJSON:o}=e;if(!this.#s.id)return;let n=await D.first({name:t.params.name,parent_id:this.#g.env.ATOM_PACKAGES_ID});n?(n.doc.versions.splice(0,0,{v:o.version}),await D.update(n,{id:n.id})):n=await D.create({parent_id:this.#g.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:o.version}]}})}async setProgress(e){const t="string"==typeof e?e:e?.message;console.log(s.blue(t)),await this._cache_set(this.#h,{status:"IN_PROGRESS",message:t})}async build(){if(this.#v&&!this.#b)return await this.createNetwork();try{const t=this.#v?await ue({root:this.#m}):void 0;if(this.#b){if(await this.initWorkflowDir(),await this.initNunjucks(),this.#v){let o=this.#s.project?.projectDir||this.#s.projectDir;o=e.resolve(o,"fnet"),l.existsSync(o)&&l.writeFileSync(e.resolve(o,"flow.bpmn"),t.diagramXML,"utf8")}await this.createAtomLibFiles({root:this.#m}),await this.createEngine({root:this.#m}),await this.createNodeTree({root:this.#m}),await this.createProjectYaml(),await async function({atom:t,context:o,setProgress:n,Atom:i}){const s="readme.md",r=`Creating ${s}`;if(await n({message:r}),o.project?.readme){const t=o.projectDir,n={content:o.project.readme.doc.content},i=e.resolve(o.project.projectDir,"fnet/how-to.md");if(l.existsSync(i)){const e=l.readFileSync(i,"utf8");n.howto=e}const r=e.resolve(o.project.projectDir,"fnet/input.yaml");if(l.existsSync(r)){const e=await h({file:r,tags:o.tags});n.input=e.content}const a=e.resolve(o.project.projectDir,"fnet/output.yaml");if(l.existsSync(a)){const e=await h({file:a,tags:o.tags});n.output=e.content}const c=o.templateDir,p=g.compile(l.readFileSync(e.resolve(c,`${s}.njk`),"utf8"),g.configure(c)).render(n),d=e.resolve(t,`${s}`);l.writeFileSync(d,p,"utf8")}else if(t.id){const n=await i.first({type:"wiki",parent_id:t.id});if(!n||"markdown"!==n.doc?.["content-type"])return;const{content:r,...a}=n.doc,c={content:r},p=o.templateDir,d=g.compile(l.readFileSync(e.resolve(p,`${s}.njk`),"utf8"),g.configure(p)).render(c),f=o.projectDir,m=e.resolve(f,`${s}`);l.writeFileSync(m,d,"utf8")}}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){await o({message:"Creating tsconfig.json."});const s={atom:t,packageDependencies:i},r=n.templateDir,a=g.compile(l.readFileSync(e.resolve(r,"tsconfig.json.njk"),"utf8"),g.configure(r)).render(s),c=n.projectDir,p=e.resolve(c,"tsconfig.json");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){await o({message:"Creating .gitignore"});const s={atom:t,packageDependencies:i},r=n.templateDir,a=g.compile(l.readFileSync(e.resolve(r,".gitignore.njk"),"utf8"),g.configure(r)).render(s),c=n.projectDir,p=e.resolve(c,".gitignore");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:t,setProgress:o,context:n,njEnv:i}){if(!0!==t.doc.features.cli.enabled)return;await o({message:"Creating yargs."});let s={};if(s=t.doc.input?t.doc.input:{type:"object",properties:{},required:[]},t.doc.features.cli.fargs&&!1!==t.doc.features.cli.fargs?.enabled){const e=t.doc.features.cli.fargs,o={type:"string",description:"Config name to load args",hidden:!1},n={type:"array",description:"Tags to filter the config",hidden:!1};Reflect.has(e,"default")&&(o.default=e.default),s.properties&&(s.properties.fargs=o,s.properties.ftag=n)}const r={options:s,imports:[],atom:t},a=n.templateDir,c=g.compile(l.readFileSync(e.resolve(a,"src/default/to.args.js.njk"),"utf8"),i).render(r),p=n.projectDir,d=e.resolve(p,"src/default/to.args.js");l.writeFileSync(d,c,"utf8");const f=new N({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});C(f);const m=f.compile(s),u=T(f,m);l.writeFileSync(e.resolve(p,"src/default/validate_input.js"),u,"utf8")}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){if(!0!==t.doc.features.cli.enabled)return;await o({message:"Creating cli."});const s={atom:t,packageDependencies:i},r=n.templateDir,a=e.resolve(n.projectDir,"src/cli");l.existsSync(a)||l.mkdirSync(a,{recursive:!0}),await m({pattern:["index.js.njk"],dir:e.resolve(r,"src/cli"),outDir:a,context:s})}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){if(!0!==t.doc.features.app.enabled)return;await o({message:"Creating app folder"});const s={atom:t,packageDependencies:i,ts:Date.now()},r=n.templateDir,a=e.resolve(n.projectDir,"src/app");l.existsSync(a)||l.mkdirSync(a,{recursive:!0});let c=["index.js.njk"];!1!==t.doc.features.app.html&&c.push("index.html.njk"),await m({pattern:c,dir:e.resolve(r,"src/app"),outDir:a,context:s})}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){await o({message:"Creating rollup file."});const s={atom:t,packageDependencies:i},r=e.resolve(n.projectDir,"src","default/index.js");if(!l.existsSync(r))throw new Error(`Entry file not found: ${r}`);const a=(await S({file:r,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),c=t.doc.features.rollup_output,p=Object.keys(c);for(let e=0;e<p.length;e++){const t=c[p[e]];if(!0===t.browser&&a.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(a.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<a.length;e++){const o=a[e];t.alias.entries[o]=`node:${o}`,t.alias.entries[`node:${o}`]=o}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(a)}}const d=n.templateDir;let f=g.compile(l.readFileSync(e.resolve(d,"rollup.config.mjs.njk"),"utf8"),g.configure(d)).render(s);const m=n.projectDir;let u=e.resolve(m,"rollup.config.mjs");l.writeFileSync(u,f,"utf8")}(this.#k),await async function({atom:t,context:o,packageDependencies:n,packageDevDependencies:i,setProgress:s}){await s({message:"Creating package.json."}),n.filter((e=>!0===e.dev)).forEach((e=>{i.find((t=>t.package===e.package))||i.push(e);const t=n.findIndex((t=>t.package===e.package));n.splice(t,1)}));const r=n.find((e=>"react"===e.package)),a=n.find((e=>"react-dom"===e.package));r&&!a?n.push({package:"react-dom",version:r.version}):r&&a&&(a.version=r.version),r&&t.doc.features.react_version>=17&&(n.find((e=>"@emotion/react"===e.package))||n.push({package:"@emotion/react",version:"^11"}),n.find((e=>"@emotion/styled"===e.package))||n.push({package:"@emotion/styled",version:"^11"}));const c=[];!0===t.doc.features.app.enabled&&c.push({file:e.resolve(o.projectDir,"src/app/index.js"),dev:!1!==t.doc.features.app.dev}),!0===t.doc.features.cli.enabled&&c.push({file:e.resolve(o.projectDir,"src/cli/index.js"),dev:!1!==t.doc.features.cli.dev});for await(const e of c){const t=e.file;if(!l.existsSync(t))throw new Error(`App file not found: ${t}`);const r=(await S({file:t,recursive:!0})).all;for await(const t of r){if("npm"!==t.type)continue;if(n.find((e=>e.package===t.package)))continue;if(i.find((e=>e.package===t.package)))continue;const r=await re({name:t.package,projectDir:o.projectDir,setProgress:s});(!0===e.dev?i:n).push({package:t.package,subpath:t.subpath,version:r.minorRange,type:"npm"})}}const p={atom:t,packageDependencies:n,packageDevDependencies:i},d=o.templateDir,f=g.compile(l.readFileSync(e.resolve(d,"package.json.njk"),"utf8"),g.configure(d)).render(p),m=o.projectDir,u=e.resolve(m,"package.json");l.writeFileSync(u,f,"utf8");const h=e.resolve(o.project.projectDir,"fnet");if(l.existsSync(h)){const t=e.resolve(o.projectDir,"fnet");l.existsSync(t)||l.mkdirSync(t);const n=l.readdirSync(h);for(const o of n){const n=e.resolve(h,o);if(!l.lstatSync(n).isFile())continue;const i=e.resolve(t,o);l.copyFileSync(n,i)}}}(this.#k),await async function({setProgress:t,context:o}){const n=o.projectDir;await t({message:"Prettifiying source files."});let i=e.join("src","**","*");if(V("bun")){const e=await u(`prettier --write ${i} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:n});if(0!==e.code)throw new Error(e.stderr)}else{const e=await u(`prettier --write ${i} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:n});if(0!==e.code)throw new Error(e.stderr)}}(this.#k),await async function({atom:e,setProgress:t,context:o}){if(!e.doc.features.dts_enabled)return;const n=o.projectDir;if(await t({message:"Creating .d.ts"}),0!==(await u("tsc",{cwd:n})).code)throw new Error("Couldnt create .d.ts files.")}(this.#k),this.#x&&(await async function({setProgress:e,atom:t,context:o}){const n=o.projectDir;if(await e({message:"Installing npm packages."}),V("bun")){if(0!==(await u(`bun install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}else if(0!==(await u(`npm install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}(this.#k),await async function({setProgress:e,context:t}){const o=t.projectDir;if(await e({message:"Building main project."}),0!==(await u("npm run build",{cwd:o})).code)throw new Error("Couldnt build project.")}(this.#k),this.#j&&await this.deploy())}await this._cache_set(this.#h,{status:"COMPLETED",data:{network:t}})}catch(e){throw await this._cache_set(this.#h,{status:"FAILED",message:e.message||e}),e}}async createNetwork(){try{const e=await ue({root:this.#m});await this._cache_set(this.#h,{status:"COMPLETED",data:{...e}})}catch(e){throw await this._cache_set(this.#h,{status:"FAILED",message:e.message||e}),e}}}const Ue={command:"build",describe:"Build flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Z(e),o=new qe(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},Ve={command:"deploy",describe:"Build and deploy flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Z({...e,mode:"all"}),o=new qe(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},Xe={command:"file",describe:"Just create files",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Z({...e,mode:"file"}),o=new qe(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},He={command:"input [name]",describe:"Create or modify an input config file",builder:e=>e.positional("name",{type:"string",demandOption:!1,describe:"Input name"}),handler:async t=>{try{const o=await Z(t),{project:n}=o,{projectDir:i,projectFileParsed:s}=n,r=s.input;if(!r)throw new Error("Config schema not found in project file.");if(!Reflect.has(t,"name")){const{inputName:e}=await L({type:"input",name:"inputName",message:"Input name:",initial:"dev"});t.name=e}const a=e.resolve(i,".fnet");l.existsSync(a)||l.mkdirSync(a);const c=e.resolve(a,`${t.name}.fnet`),p=l.existsSync(c),d=(await import("@fnet/object-from-schema")).default,f=await d({schema:r,format:"yaml",ref:p?c:void 0});l.writeFileSync(c,f)}catch(e){console.error(e.message),process.exit(1)}}},Ye=e.join(f.homedir(),".fnet","express");async function Qe(t){t.command(["$0 [project-name]","create [project-name]"],"Create a new express project",(e=>e.positional("project-name",{describe:"Name of the project",type:"string"}).option("yes",{alias:"y",describe:"Skip all prompts and use defaults",type:"boolean",default:!1}).option("runtime",{describe:"Runtime to use (node)",type:"string",choices:["node"],default:"node"})),(async t=>{await async function(t){try{l.existsSync(Ye)||l.mkdirSync(Ye,{recursive:!0});const o=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=e.join(Ye,o);l.existsSync(n)||l.mkdirSync(n,{recursive:!0});let i,r=t.projectName,a=t.runtime;if(t.yes){if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=e.length>0?Math.max(...e)+1:1;r=`fnet-${t}`}a||(a="node")}else{if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=`fnet-${e.length>0?Math.max(...e)+1:1}`,o=await L([{type:"input",name:"projectName",message:"Enter project name:",default:t}]);r=o.projectName}const e=a||"node";a=(await L({type:"select",name:"runtime",message:"Select runtime:",choices:["node"],initial:e})).runtime}if(i=e.join(n,r),l.existsSync(i)){let t=1;for(;l.existsSync(e.join(n,`${r}-${t}`));)t++;r=`${r}-${t}`,i=e.join(n,r)}if(!t.yes){if(!(await L([{type:"confirm",name:"proceed",message:`Create express project "${r}" in ${i}?`,default:!0}])).proceed)return void console.log(s.yellow("Project creation cancelled."))}console.log(s.blue(`Creating express project "${r}" in ${i}...`));const p=e.dirname(i),d=["create","--name",e.basename(i)];d.push("--runtime",a),t.yes&&d.push("--yes"),l.existsSync(p)||l.mkdirSync(p,{recursive:!0});const f=c("fnet",d,{stdio:"inherit",shell:!0,cwd:p});return new Promise(((e,o)=>{f.on("close",(n=>{0===n?(console.log(s.green(`\nExpress project "${r}" created successfully!`)),console.log(s.blue(`\nProject location: ${i}`)),t.yes?e():async function(e){try{(await L({type:"confirm",name:"openIDE",message:"Would you like to open the project in an IDE?",initial:!0})).openIDE&&await ot(e)}catch(e){console.error(s.red(`Error opening IDE: ${e.message}`))}}(i)):(console.error(s.red(`\nFailed to create express project "${r}".`)),o(new Error(`Process exited with code ${n}`)))}))}))}catch(e){console.error(s.red(`Error creating express project: ${e.message}`)),process.exit(1)}}(t)})).command("list","List express projects",(e=>e.option("today",{describe:"Show only projects created today",type:"boolean",default:!1}).option("type",{describe:"Filter by project type (fnode or fnet)",type:"string",choices:["fnode","fnet"]}).option("name",{describe:"Filter by project name",type:"string"})),(async t=>{await async function(t){try{if(!l.existsSync(Ye))return void console.log(s.yellow("No express projects found."));const o=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(t.today){const e=(new Date).toISOString().slice(0,10).replace(/-/g,""),t=o.indexOf(e);if(-1===t)return void console.log(s.yellow("No express projects found for today."));o.splice(0,t),o.splice(1)}const n=[];for(const i of o){const o=e.join(Ye,i),s=l.readdirSync(o);for(const r of s){const s=e.join(o,r),a=l.statSync(s);let c="unknown";if(r.startsWith("fnode-")||l.existsSync(e.join(s,"fnode.yaml"))?c="fnode":(r.startsWith("fnet-")||l.existsSync(e.join(s,"fnet.yaml")))&&(c="fnet"),t.type&&c!==t.type)continue;if(t.name&&!r.includes(t.name))continue;const p=`${i.slice(0,4)}-${i.slice(4,6)}-${i.slice(6,8)}`;n.push({name:r,type:c,date:p,path:s,created:a.birthtime})}}if(n.sort(((e,t)=>t.created-e.created)),0===n.length)return void console.log(s.yellow("No express projects found matching the criteria."));console.log(s.blue("\nExpress Projects:")),console.log(s.blue("=================\n"));const i=n.map((e=>{let t=e.path;return t.startsWith(f.homedir())&&(t="~"+t.substring(f.homedir().length)),{Name:e.name,Type:e.type,Date:e.date,Path:t}}));console.table(i),console.log(s.blue(`\nTotal: ${n.length} projects`))}catch(e){console.error(s.red(`Error listing express projects: ${e.message}`)),process.exit(1)}}(t)})).command("open [project-name]","Open an express project",(e=>e.positional("project-name",{describe:"Name of the project to open",type:"string"}).option("latest",{describe:"Open the most recent project",type:"boolean",default:!1})),(async t=>{await async function(t){try{if(!l.existsSync(Ye))return void console.log(s.yellow("No express projects found."));let o;if(t.latest){if(o=await Ze(),!o)return void console.log(s.yellow("No express projects found."))}else if(t.projectName){if(o=await et(t.projectName),!o)return void console.log(s.yellow(`Project "${t.projectName}" not found.`))}else{const t=await tt();if(!t)return void console.log(s.yellow("No project selected."));o=e.join(Ye,t)}await ot(o)}catch(e){console.error(s.red(`Error opening express project: ${e.message}`)),process.exit(1)}}(t)})).command("move [project-name] [destination]","Move an express project to a real project location",(e=>e.positional("project-name",{describe:"Name of the project to move",type:"string"}).positional("destination",{describe:"Destination directory",type:"string"}).option("latest",{describe:"Move the most recent project",type:"boolean",default:!1})),(async t=>{await async function(t){try{const o=process.cwd();let n;if(o.includes(Ye))n=o,console.log(s.blue(`Using current express project: ${e.basename(n)}`));else if(t.latest){if(n=await Ze(),!n)return void console.log(s.yellow("No express projects found."))}else if(t.projectName){if(n=await et(t.projectName),!n)return void console.log(s.yellow(`Project "${t.projectName}" not found.`))}else{const t=await tt();if(!t)return void console.log(s.yellow("No project selected."));n=e.join(Ye,t)}let i=t.destination;if(!i){i=(await L({type:"input",name:"destination",message:"Enter destination directory:",initial:e.join(process.cwd(),e.basename(n))})).destination}if(i.startsWith("~")&&(i=e.join(f.homedir(),i.slice(1))),i=e.resolve(i),i.startsWith(n+e.sep)||i===n)return void console.log(s.red("Destination cannot be inside the source directory."));if(l.existsSync(i)){if(!l.statSync(i).isDirectory())return void console.log(s.red(`Destination "${i}" is not a directory.`));if(l.readdirSync(i).length>0){if(!(await L({type:"confirm",name:"overwrite",message:`Destination "${i}" is not empty. Continue anyway?`,initial:!1})).overwrite)return void console.log(s.yellow("Project move cancelled."))}}else l.mkdirSync(i,{recursive:!0});console.log(s.blue(`Moving project from ${n} to ${i}...`)),it(n,i),console.log(s.green(`\nProject moved successfully to ${i}`));(await L({type:"confirm",name:"deleteOriginal",message:"Delete the original express project?",initial:!1})).deleteOriginal&&(l.rmSync(n,{recursive:!0,force:!0}),console.log(s.green("Original project deleted."))),await ot(i)}catch(e){console.error(s.red(`Error moving express project: ${e.message}`)),process.exit(1)}}(t)})).demandCommand(1,"You need to specify a command").help()}async function Ze(){const t=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(0===t.length)return null;const o=t[0],n=e.join(Ye,o),i=l.readdirSync(n);if(0===i.length)return null;let s=null,r=0;for(const t of i){const o=e.join(n,t),i=l.statSync(o);i.birthtimeMs>r&&(r=i.birthtimeMs,s=o)}return s}async function et(t){const o=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const n of o){const o=e.join(Ye,n),i=l.readdirSync(o);if(i.includes(t))return e.join(o,t);const s=i.filter((e=>e.includes(t)));if(s.length>0){if(1===s.length)return e.join(o,s[0]);{const i=await L({type:"select",name:"selectedProject",message:`Multiple projects match "${t}". Please select one:`,choices:s.map((t=>({name:`${t} (${n})`,value:e.join(o,t)})))});return i.selectedProject}}}return null}async function tt(){const t=[],o=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const n of o){const o=e.join(Ye,n),i=l.readdirSync(o);for(const s of i){const i=e.join(o,s),r=l.statSync(i),a=`${n}/${s}`;t.push({name:a,value:a,created:r.birthtime})}}if(t.sort(((e,t)=>t.created-e.created)),0===t.length)return null;return(await L({type:"select",name:"selectedProject",message:"Select a project:",choices:t})).selectedProject}async function ot(e){const t=await nt("code --version"),o=await nt("code-insiders --version");let n=null;if(t&&o){const e=await L({type:"select",name:"ide",message:"Which IDE would you like to use?",choices:[{name:"Visual Studio Code",value:"code"},{name:"Visual Studio Code Insiders",value:"code-insiders"}]});n=e.ide}else if(t)n="code";else{if(!o)return console.log(s.yellow("No supported IDE found. Please open the project manually.")),void console.log(s.blue(`Project path: ${e}`));n="code-insiders"}console.log(s.blue(`Opening project in ${n}...`)),console.log(s.blue(`Project path: ${e}`));const i=c(n,[e],{stdio:"inherit",shell:!0});return new Promise(((e,t)=>{i.on("close",(o=>{0===o?(console.log(s.green(`Project opened in ${n}.`)),e()):(console.error(s.red(`Failed to open project in ${n}.`)),t(new Error(`Process exited with code ${o}`)))}))}))}async function nt(e){return new Promise((t=>{c(e,{shell:!0,stdio:"ignore"}).on("close",(e=>{t(0===e)}))}))}function it(t,o){l.existsSync(o)||l.mkdirSync(o,{recursive:!0});const n=l.readdirSync(t,{withFileTypes:!0});for(const i of n){const n=e.join(t,i.name),s=e.join(o,i.name);if(i.isDirectory()){if(".git"===i.name||".workspace"===i.name)continue;it(n,s)}else l.copyFileSync(n,s)}}const st=e.dirname(n(import.meta.url));const rt=e.dirname(n(import.meta.url)),at=process.cwd();process.on("uncaughtException",(e=>{W||(W=!0,setTimeout((()=>process.exit(1)),500))})),process.on("unhandledRejection",(e=>{W||(W=!0,setTimeout((()=>process.exit(1)),500))})),function(){d({name:["redis"],dir:at,optional:!0});const t=function({baseDir:t}){let o=t=t||st;for(;o!==e.parse(o).root;){const t=e.join(o,"node_modules");if(l.existsSync(t))return t;o=e.dirname(o)}return null}({baseDir:rt}),o="win32"===process.platform?";":":";t&&(process.env.PATH=`${e.join(t,"/.bin")}${o}${process.env.PATH}`)}(),async function(){try{let t=i(process.argv.slice(2)).usage("Usage: $0 <command> [options]").command(Q).command(te).command(Ue).command(Ve).command(Xe).command(He).command("express","Create and manage express projects",Qe);t=q(t,{bin:"npm"}),t=q(t,{bin:"node"}),t=q(t,{bin:"bun"}),t=q(t,{name:"serve",bin:"bun",preArgs:["run","serve","--"]}),t=q(t,{name:"watch",bin:"bun",preArgs:["run","watch","--"]}),t=q(t,{name:"app",bin:"bun",preArgs:["run","app","--"]}),t=q(t,{name:"cli",bin:"bun",preArgs:["run","cli","--"]}),t=q(t,{name:"compile",bin:"bun",preArgs:["run","compile","--"]}),t=function(t,{name:o}){return t.command(`${o} [options]`,"Install the project as a binary",(e=>e.option("name",{alias:"n",describe:"Name to use for the installed binary",type:"string"}).option("force",{alias:"f",describe:"Force overwrite if binary already exists",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Automatically answer yes to all prompts",type:"boolean",default:!1})),(async t=>{try{const o=await U(t),{projectDir:n}=o;console.log(s.blue("Compiling project..."));const i=e.join(n,".bin");l.existsSync(i)||l.mkdirSync(i,{recursive:!0});const r=e.basename(e.dirname(n)),a=o.project?.projectFileParsed?.features?.cli?.bin,c=t.name||a||r;console.log(s.blue(`Using binary name: ${c}`));const p=e.join(i,c),{spawn:d}=await import("child_process"),f=d("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${p}`],{cwd:n,stdio:"inherit",shell:!0});await new Promise(((e,t)=>{f.on("close",(o=>{0===o?e():t(new Error(`Compilation failed with code ${o}`))})),f.on("error",(e=>{t(e)}))})),"win32"!==process.platform&&l.chmodSync(p,493),console.log(s.green(`Binary compiled successfully: ${p}`)),console.log(s.blue("Installing binary..."));const m=["install",p];t.name&&m.push("--name",t.name),t.force&&m.push("--force"),t.yes&&m.push("--yes");const u=d("fbin",m,{stdio:"inherit",shell:!0});await new Promise(((e,t)=>{u.on("close",(o=>{0===o?e():t(new Error(`Installation failed with code ${o}`))})),u.on("error",(e=>{t(e)}))}))}catch(e){console.error(s.red(`Failed to install binary: ${e.message}`)),process.exit(1)}}))}(t,{name:"install"}),t=q(t,{bin:"npx"}),t=q(t,{bin:"cdk"}),t=q(t,{bin:"aws"}),t=function(e,{name:t,preArgs:o=[]}){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 U(e),{projectDir:n}=t,i=e.config,s=await d({name:i,dir:n,transferEnv:!1,optional:!0,tags:t.tags}),r=s?.data?.env||void 0,a=e.command,p=process.argv.slice(5);G(c(a,[...o,...p],{cwd:l.existsSync(n)?n:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...r}}))}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"with"}),t=function(e,{name:t,projectType:o="auto"}){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{runCommandGroup:t}=await import("./index.DrwlOzAe.js");await t({projectType:o,group:e.group,tags:e.ftag,args:e,argv:process.argv})}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"run",projectType:"fnet"}),t.demandCommand(1,"You need at least one command before moving on").help().version().argv}catch(e){console.error(s.red(`Fatal error: ${e.message}`)),process.exit(1)}}().catch((e=>{console.error(s.red(`Fatal error: ${e.message}`)),process.exit(1)}));export{Y as r,V as w};
2
+ import e,{delimiter as t,join as o}from"node:path";import{fileURLToPath as n}from"node:url";import i from"yargs";import s from"chalk";import{promisify as r}from"node:util";import a from"tree-kill";import{spawn as c}from"node:child_process";import l,{existsSync as p}from"node:fs";import d from"@fnet/config";import f from"node:os";import m from"@flownet/lib-render-templates-dir";import u from"@fnet/shelljs";import h from"@fnet/yaml";import y from"yaml";import g from"nunjucks";import w from"lodash.clonedeep";import b from"isobject";import x from"redis";import j from"@flownet/lib-is-redis-online";import{randomUUID as v}from"node:crypto";import{Api as k,Atom as D}from"@flownet/lib-atom-api-js";import _ from"lodash.merge";import S from"@flownet/lib-parse-imports-js";import E from"@fnet/npm-list-versions";import $ from"@fnet/npm-pick-versions";import P from"object-hash";import N from"ajv/dist/2020.js";import T from"ajv/dist/standalone/index.js";import C from"ajv-formats";import F from"@flownet/lib-parse-node-url";import I from"bpmn-moddle";import O from"dagre";import A from"@fnet/expression";import B from"@fnet/list-files";import K from"@fnet/key-value-transformer";import R from"lodash.pick";import M from"lodash.omit";import L from"@fnet/prompt";import"fs";import"path";import"@fnet/shell-flow";const J=r(a);let W=!1;async function z(e,t){if(W)return;if(W=!0,!e.killed&&e.pid)try{await J(e.pid,"SIGTERM").catch((()=>{})),await new Promise((e=>setTimeout(e,500))),e.killed||await J(e.pid,"SIGKILL").catch((()=>{}))}catch(e){}await new Promise((e=>setTimeout(e,100)));const o="SIGINT"===t?130:"SIGTERM"===t?143:1;process.exit(o)}function G(e){["SIGINT","SIGTERM","SIGQUIT"].forEach((t=>{process.once(t,(async()=>{await z(e,t)}))})),process.on("uncaughtException",(async t=>{await z(e)})),process.on("unhandledRejection",(async t=>{await z(e)})),e.on("close",(e=>{W||process.exit(e)}))}function q(e,{name:t,bin:o,preArgs:n=[]}){return"function"==typeof o&&(o=o()),e.command(`${t||o} [commands..]`,`${o} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await U(e),{projectDir:i}=t,s=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,r=process.argv.slice(3).map(s);G(c(o,[...n,...r],{cwd:i,stdio:"inherit",shell:!0,detached:!0}))}catch(e){console.error(e.message),process.exit(1)}}))}async function U(e){try{const t=process.argv[1].split("/").pop().split(".")[0];if("fnode"===t){const{createContext:t}=await import("./index.PNP2oTpU.js");return t(e)}if("fnet"===t){const{createContext:t}=await Promise.resolve().then((function(){return ee}));return t(e)}if("frun"===t){const{createContext:t}=await import("./index.CuMyez3E.js");return t(e)}if("fbin"===t){const{createContext:t}=await import("./index.DWpw12No.js");return t(e)}}catch(e){console.warn(`Warning: Could not import context from CLI tool: ${e.message}`)}return{projectDir:process.cwd(),tags:e.ftag}}var V=e=>{const n=process.env.PATH||"",i="win32"===process.platform?(process.env.PATHEXT||".EXE;.CMD;.BAT;.COM").split(";"):[""],s=n.split(t);for(const t of s)for(const n of i){const i=o(t,"win32"===process.platform?e+n:e);if(p(i))return i}return null};const X=e.dirname(n(import.meta.url)),H=process.cwd();function Y(t){const o=e.resolve(H,t);if(l.existsSync(o))return o;const n=e.resolve(X,"../..",t);if(l.existsSync(n))return n;throw new Error(`Template path not found: ${t}`)}const Q={command:"create",describe:"Initialize a new fnet project",builder:e=>e.option("name",{type:"string",describe:"Project name"}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node"],describe:"Runtime environment"}),handler:async t=>{try{const o=process.cwd(),n=Y("./template/fnet/project"),i=e.resolve(o,t.name);l.existsSync(i)||l.mkdirSync(i),await m({dir:n,outDir:i,context:t,copyUnmatchedAlso:!0,platform:f.platform()});let s=await u("fnet build",{cwd:i});if(0!==s.code)throw new Error("Failed to build project.");if(V("git")&&(s=await u("git init --initial-branch=main",{cwd:i}),0!==s.code))throw new Error("Failed to initialize git.");if(V("code")&&t.vscode&&(s=await u(`cd ${i} && code .`),0!==s.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)}}};async function Z(t){if(t.id)return{id:t.id,buildId:t.buildId,mode:t.mode,protocol:t.protocol||"ac:",templateDir:Y("./template/fnet/node"),coreDir:Y("./template/fnet/core"),projectDir:e.resolve(process.cwd(),`./.output/${t.id}`),tags:t.ftag};try{const o=await async function({tags:t}){let o=(n=process.cwd(),e.resolve(n,"fnet.yaml"));var n;if(!l.existsSync(o))throw new Error("fnet.yaml file not found in current directory.");const{raw:i,parsed:s}=await h({file:o,tags:t}),r=e.dirname(o);s.features=s.features||{};const a=s.features;let c;if(a.runtime=a.runtime||{},a.runtime.type=a.runtime.type||"node","object"==typeof s.flows)c=s.flows;else{let o="flow.main.yaml";l.existsSync(e.join(r,"fnet","flows.yaml"))&&(o=e.join("fnet","flows.yaml"));const n=s.main||o;let i=e.resolve(r,n);if(l.existsSync(i)){const{parsed:e}=await h({file:i,tags:t});c=e}else c={main:{steps:[]}}}const p={workflowAtom:{doc:{...s,content:c}},projectDir:r,projectFilePath:o,projectFileContent:i,projectFileParsed:s,runtime:a.runtime};let d=e.resolve(r,"fnet/targets.yaml");if(l.existsSync(d)){const{raw:e,parsed:o}=await h({file:d,tags:t}),n=y.parseDocument(e);p.devops={filePath:d,fileContent:e,yamlDocument:n,doc:{...o},type:"workflow.deploy",save:async()=>{l.writeFileSync(p.devops.filePath,n.toString())}}}const f=e.resolve(r,"readme.md");if(l.existsSync(f)){const e=l.readFileSync(f,"utf8");p.readme={filePath:f,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return p}({tags:t.ftag});return{buildId:t.buildId,mode:t.mode,protocol:t.protocol||"local:",templateDir:Y("./template/fnet/node"),coreDir:Y("./template/fnet/core"),projectDir:e.resolve(o.projectDir,"./.workspace"),projectSrcDir:e.resolve(o.projectDir,"./src"),project:o,tags:t.ftag}}catch(e){return console.warn(`Warning: Could not load project: ${e.message}`),{projectDir:process.cwd(),tags:t.ftag}}}var ee=Object.freeze({__proto__:null,createContext:Z});const te={command:"project",describe:"Manage fnet project",builder:e=>e.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"}),handler:async e=>{try{const t=Y("./template/fnet/project"),o=process.cwd(),n=await Z(e);if(e.update){if(await m({dir:t,outDir:o,context:{name:n.project.projectFileParsed.name,runtime:"node"},copyUnmatchedAlso:!0,platform:f.platform()}),0!==(await u("fnet build",{cwd:o})).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)}}};class oe{init({config:e,accessToken:t}){return new Promise(((o,n)=>{if(k.set_api_url(e.data.url),t)return k.set_req_token(t),void o(t);fetch(`${e.data.issuer}/protocol/openid-connect/token`,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams(e.data.grant.params)}).then((async e=>{if(!e.ok)throw new Error(await e.text());return e.json()})).then((e=>{k.set_req_token(e.access_token),o(e.access_token)})).catch((e=>{k.set_req_token(),n(e)}))}))}}function ne({feature:e,features:t,packageDevDependencies:o}){const{name:n,packages:i,options:s,extraCheck:r,explicit:a}=e,c=`${n}_enabled`,l=t.rollup_output||{},p=Object.keys(l);let d=s||{};const f=t[n]?.options;f&&(d=_(d,f));const m=!t[n]||!1===t[n]?.enabled;p.forEach((e=>{const o=t.rollup_output[e];if(o){if(Reflect.has(o,n)){if(m||!o[n]||!1===o[n]?.enabled)return void delete o[n];!0===o[n]&&(o[n]={enabled:!0,options:d})}else{if(m||a||!1===t[c])return;o[n]={enabled:!0}}o[n]=o[n]||{},o[n].options={...d,...o[n].options}}}));let u=p.some((e=>!0===t.rollup_output[e][n]?.enabled));r&&(u=r()&&u),t[c]=u,u&&i.forEach((e=>o.push({package:e[0],version:e[1]})))}function ie({dir:t,name:o="index"}){let n=e.resolve(t,`./${o}.tsx`);if(l.existsSync(n)||(n=e.resolve(t,`./${o}.ts`)),l.existsSync(n)||(n=e.resolve(t,`./${o}.jsx`)),l.existsSync(n)||(n=e.resolve(t,`./${o}.js`)),!l.existsSync(n))return{};const i=n,s=e.extname(n);return{file:i,ext:s,ts:".ts"===s||".tsx"===s,name:o}}async function se(t){const{atom:o,context:n,setProgress:i}=t;i("Initializing features..."),o.doc.features=o.doc.features||{};const s=o.doc.features;s.project=s.project||{},s.project.format=s.project.format||s.project_format||"esm",s.project_format=s.project.format,s.dts_enabled=!0===s.dts||void 0!==s.dts&&!1!==s.dts;const r=e.resolve(n.project.projectDir),a=ie({dir:e.resolve(r,"./app")});if(a.file){i("Parsing app entry imports...");let e=await S({file:a.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.app_uses_jsx=t,s.app_has_entry=!0,e=await S({file:a.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.app_entry_uses_jsx=t,s.app_entry_is_ts=a.ts,s.app_entry_ext=a.ext}const c=ie({dir:e.resolve(r,"./cli")});if(c.file){i("Parsing cli entry imports...");let e=await S({file:c.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.cli_uses_jsx=t,s.cli_has_entry=!0,e=await S({file:c.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.cli_entry_uses_jsx=t,s.cli_entry_is_ts=c.ts,s.cli_entry_ext=c.ext}if("workflow.lib"===o.type){const t=ie({dir:e.resolve(r,"./src")});if(t.file){i("Parsing src entry imports...");let e=await S({file:t.file,recursive:!0}),o=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.src_uses_jsx=o,s.src_has_entry=!0,e=await S({file:t.file}),o=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.src_entry_uses_jsx=o,s.src_entry_is_ts=t.ts,s.src_entry_ext=t.ext}}const l=Reflect.has(s,"app_entry_uses_jsx")?!0===s.app_entry_uses_jsx:!0===s.src_entry_uses_jsx,p=Reflect.has(s,"cli_entry_uses_jsx")?!0===s.cli_entry_uses_jsx:!0===s.src_entry_uses_jsx;s.form_enabled=l||p||!0===s.form||!0===s.form?.enabled,s.multiple_enabled=s.multiple_enabled||!0===s.multiple||!0===s.multiple?.enabled,!1===s.app?s.app={enabled:!1}:!0===s.app?s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l}:s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l,...s.app||{}},s.app.enabled=!0===s.app.enabled&&(!0===o.doc.features.form_enabled||!0===s.app.extend||!0===s.app.enabled),s.app.format=s.app.format||"esm",s.app.folder=s.app.folder||s.app.format||"default",!1===s.cli?s.cli={enabled:!1}:!0===s.cli?s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p}:s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p,...s.cli||{}},s.cli.enabled=!0===s.cli.enabled&&(!1===o.doc.features.form_enabled||!0===s.cli.extend||!0===s.cli.enabled),s.cli.format=s.cli.format||"esm",s.cli.folder=s.cli.folder||s.cli.folder||"esm",s.cli.node_options=s.cli.node?.options||s.cli.node_options||"",s.cli.bin=s.cli.bin||o.doc.name,s.cli.installable=!0===s.cli.installable,s.cli.enabled&&(o.doc["npm::bin"]=s.cli.bin,console.log(`Setting npm::bin to ${s.cli.bin} from features.cli.bin`)),s.json=s.cli.enabled||s.json;const d={cjs:{format:"cjs",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!1!==s.cjs,copy:!1},esm:{format:"esm",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!1,enabled:!1!==s.esm,copy:!0},iife:{format:"iife",context:s.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!0===s.iife,terser:!0,copy:!1}};!0===s.webos&&(d.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===s.electron&&(d.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===s.nextjs&&(d.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===s.ios&&(d.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===s.macos&&(d.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===s.app.enabled&&(s.app.dir=`./dist/app/${s.app.folder}`,d.app={format:s.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:"./src/app/index.js",output_dir:s.app.dir,terser:!0,output_exports:!1===s.app.export?"none":"auto",browsersync:!0}),!0===s.cli.enabled&&(s.cli.dir=`./dist/cli/${s.cli.folder}`,d.cli={format:s.cli.format,context:"global",babel:!0===s.src_uses_jsx||!0===s.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:"./src/cli/index.js",output_dir:s.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===s.cli.export?"none":"auto"});const f={server:".",startPath:`${e.normalize(s.app.dir||".")}`,files:[e.normalize("./dist/**/*")],cors:!0,open:!1};s.babel_options=_({targets:{browsers:"last 9 versions, not dead",node:"18"}},s.babel_options||s.babel?.options),s.browsersync_options=_(f,s.browsersync_options||s.browsersync?.options||{}),s.replace_options=_({},s.replace_options||s.replace?.options||{}),Reflect.has(s.browsersync_options,"proxy")&&delete s.browsersync_options.server,s.rollup=s.rollup||{},s.rollup_output=_(d,s.rollup_output||s.rollup?.output||{}),s.preact_enabled=!0===s.preact||s.preact&&!1!==s.preact?.enabled;let m=Object.keys(d);for(const e of m){const t=d[e];t&&(!1!==s.rollup[e]?(t.babel_options=t.babel_options||s.babel_options,t.browsersync_options=_(s.browsersync_options,t.browsersync_options),t.replace_options=_(s.replace_options,t.replace_options),s.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),(s.form_enabled||s.babel)&&(t.babel=!0)):delete s.rollup_output[e])}m=Object.keys(s.rollup_output),s.babel_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browser_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browsersync_enabled=!1!==s.browsersync&&m.some((e=>!0===s.rollup_output[e].browsersync)),s.browsersync_enabled=s.browsersync_enabled&&s.app.enabled,s.dependency_auto_enabled=!1!==s.dependency_auto&&!1!==s.dependency_auto?.enabled,s.npm_install_flags=s.npm_install_flags||"",s.react_version=s.react_version||s.react?.version||18,function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features,i=n.css&&!1!==n.css.enabled;let s=[];i&&(s.push(["rollup-plugin-postcss","^4"]),s.push(["sass","^1.66"]),(n.css?.options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":s.push(["postcss-import","^15"]);break;case"postcss-url":s.push(["postcss-url","^10"]);break;case"postcss-preset-env":s.push(["postcss-preset-env","^9"]);break;case"autoprefixer":s.push(["autoprefixer","^10"]);break;case"cssnano":s.push(["cssnano","^6"])}})));ne({feature:{name:"css",packages:s},features:n,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features,i={};!0===n.app?.enabled&&(i.targets=i.targets||[],i.targets.push({src:"./src/app/index.html",dest:n.app.dir}),Reflect.has(n.app,"copy")||Reflect.has(n,"copy")||(n.copy=!0)),ne({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:i},features:n,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({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:t.doc.features,packageDevDependencies:o})}(t),function(e){const{atom:t,packageDevDependencies:o}=e;ne({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:t.doc.features,packageDevDependencies:o})}(t)}async function re({projectDir:t,name:o,setProgress:n,count:i=1}){let s;const r=P(["npm-pick-versions",o,i]),a=e.join(t,".cache"),c=e.join(a,r+".json");return l.existsSync(c)?(n&&n(`Picking npm version of ${o} from cache ...`),s=JSON.parse(l.readFileSync(c,"utf8"))):(n&&n(`Picking npm version of ${o} ...`),s=await $({name:o,count:i}),l.mkdirSync(a,{recursive:!0}),l.writeFileSync(c,JSON.stringify(s),"utf8")),s}var ae=async e=>{const{atom:t,packageDependencies:o,context:n,deploymentProjectTarget:i,setProgress:s,deploymentProject:r,yamlTarget:a}=e;if(!0!==i.enabled)return;const c=i.type;try{if("lib"===c)await(await import("./index.DG8TqL-1.js")).default({...e});else if("red"===c)await(await import("./index.CmMM-Ek9.js")).default({...e});else if("npm"===c)await(await import("./index.BraqWHnP.js")).default({...e});else if("gcs"===c)await(await import("./index.UOds5XLl.js")).default({...e});else if("gitlab"===c)await(await import("./index.DI3yyTtl.js")).default({...e});else if("fnet-package"===c)await(await import("./index.Bfg4lyu-.js")).default({...e});else if("fnet-form"===c)await(await import("./index.Q-CYRcna.js")).default({...e});else if("fnet-node"===c)await(await import("./index.C2S9JYhS.js")).default({...e});else if("fnet-flow"===c)await(await import("./index.BuYxdKtK.js")).default({...e});else if("nextjs"===c)await(await import("./index.CDct_kkF.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("webos"===c)await(await import("./index.CMC8mlye.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("electron"===c)await(await import("./index.xd8c7XMr.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("docker"===c)await(await import("./index.D2N9YZmA.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("ios"===c)await(await import("./index.B5XE4ChJ.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("macos"===c)await(await import("./index.W6RYgypK.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("rust"===c)await(await import("./index.CzAV0S36.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else{if("pypi"!==c)return void console.warn(`No deployer found for type: ${c}`);await(await import("./index.C7saWH6d.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0}}catch(e){throw console.error(`Error during deployment for type "${c}":`,e),e}},ce={name:"ATOM",uri:"http://atom.org/bpmn",prefix:"atom",types:[{name:"AtomExtension",extends:["bpmn:BaseElement"],properties:[{name:"atom",type:"atom:Atom",isMany:!1}]},{name:"Atom",properties:[{name:"type",type:"String",isAttr:!0}]}]};function le(e,t){return e.filter(((e,o,n)=>n.map((e=>e[t])).indexOf(e[t])===o))}function pe(e){const{nodes:t,nodeIndex:o,root:n}=e,i=e.targetNodes||n.childs;i.forEach((t=>{const o="workflow"===t.type||"subworkflow"===t.type,n=!o&&t.childs.filter((e=>!e.virtual)).length>0;if(n&&(t.bpmn.type="bpmn:SubProcess"),o||n){const o=t.childs.filter((e=>!0!==e.module))[0];t.childs.filter((e=>!0===e.module)).forEach((o=>{const n=de({...e,parent:t,bpmnType:"bpmn:IntermediateCatchEvent",type:"inter",definitions:[{type:"bpmn:SignalEventDefinition"}]});n.bpmn.edges=[{from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const n=t.childs.find((e=>"try"===e.name&&"tryexcept"===t.type)),s=t.childs.filter((e=>"except"===e.name&&"tryexcept"===t.type));n&&s.length&&s.forEach((o=>{const i=de({location:t.childs.indexOf(o),...e,parent:t,bpmnType:"bpmn:BoundaryEvent",type:"boundary",attrs:{attachedToRef:n},definitions:[{type:"bpmn:ErrorEventDefinition"}]});i.bpmn.edges=[{from:i.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const r=t.childs.find((e=>"raise"===e.type));if(r){const o=de({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:"ERROR",definitions:[{type:"bpmn:ErrorEventDefinition"}]});r.bpmn.edges=[{from:r.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}if(o)if(t.bpmn.starts.length>1){const o=de({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"}),n=de({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch"});o.bpmn.edges=[{from:o.indexKey,to:n.indexKey,type:"bpmn:SequenceFlow"}],n.bpmn.edges=t.bpmn.starts.map((e=>({...e,from:n.indexKey})));const i=n.bpmn.edges.find((e=>!0===e.next));if(i){const o=de({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:i.to});i.to=o.indexKey}}else{const n=de({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"});n.bpmn.edges.push({from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"})}t.childs.filter((e=>!0!==e.virtual&&e.bpmn.outside.length&&"bpmn:EndEvent"!==e.bpmn.type)).forEach((o=>{o.bpmn.outside.forEach((n=>{const s=i.indexOf(t),r=de({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:n.to,location:s+1});o.bpmn.edges.push({from:o.indexKey,to:r.indexKey,type:"bpmn:SequenceFlow"})}))}));t.childs.filter((e=>!0!==e.virtual&&e.bpmn.edges.length>1)).forEach((o=>{const n=i.indexOf(o),s=de({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch",location:n+1});s.bpmn.edges=o.bpmn.edges.map((e=>({...e,from:s.indexKey}))),o.bpmn.edges=[{from:o.indexKey,to:s.indexKey,type:"bpmn:SequenceFlow"}],o.bpmn.outside=[]}))}pe({...e,targetNodes:t.childs})}))}function de(e){const{parent:t,nodes:o,nodeIndex:n,bpmnType:i,type:s,name:r,outside:a,location:c,definitions:l,attrs:p}=e,d=t.childs.filter((e=>e.type===`v${s}`)).length,f={indexKey:`${t.indexKey}/_${s}${d}`,pathKey:`${t.pathKey}._${s}${d}`,type:`v${s}`,name:r,bpmn:{edges:[],outside:[],type:i,width:36,height:36,fill:"#c8e6c9",stroke:"#205022",definitions:l,attrs:p},virtual:!0,childs:[]};return t.childs.splice(c||0,0,f),o.push(f),n[f.indexKey]=f,f}function fe(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a,nodes:c}=e;!function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,nodes:a}=e,c=o.get("flowElements");o.$nodes=o.$nodes||[],t.childs.forEach((e=>{const t=i.create(e.bpmn.type,{id:`node.${e.pathKey}`,name:e.definition?.title||e.name});if(s[t.id]=t,t.$isNode=!0,t.$node=e,e.$flow=t,o.$nodes.push(t),c.push(t),e.bpmn.attrs){Object.keys(e.bpmn.attrs).forEach((o=>{"attachedToRef"===o&&t.set(o,e.bpmn.attrs[o].$flow)}))}if(e.bpmn.definitions){const o=e.bpmn.definitions.map((e=>{const t=i.create(e.type);return Object.keys(e.attrs||{}).forEach((o=>{t.set(o,e.attrs[o])})),t}));t.eventDefinitions=o}}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=o.get("flowElements");o.$edges=o.$edges||[],t.childs.forEach((e=>{e.bpmn.edges.forEach((t=>{const n=e,c=r[t.to],l=`edge.${n.pathKey}_${c.pathKey}`;if(s[l])return;const p=s[`node.${n.pathKey}`],d=s[`node.${c.pathKey}`],f=i.create(t.type,{id:l,sourceRef:p,targetRef:d});s[f.id]=f,f.$is_edge=!0,p.get("outgoing").push(f),d.get("incoming").push(f),o.$edges.push({from:p,to:d,flow:f}),a.push(f)}))}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=120,c=80,l=160,p=160,d=new O.graphlib.Graph;d.setDefaultEdgeLabel((()=>({}))),d.setGraph({rankdir:"TB",nodesep:a,ranksep:c,xranker:"longest-path"}),o.$nodes.forEach((e=>{d.setNode(e.id,{width:e.$node?.bpmn.width||a,height:e.$node?.bpmn.height||c,label:e.id})})),o.$edges.forEach((e=>{d.setEdge(e.from.id,e.to.id)})),O.layout(d),o.$nodes.forEach((e=>{const t=d.node(e.id);let o=t.width,s=t.height;const r=i.create("bpmndi:BPMNShape",{id:`shape.${e.id}`,bpmnElement:e,bounds:i.create("dc:Bounds",{x:l+t.x-t.width/2,y:p+t.y-t.height/2,width:o,height:s}),label:i.create("bpmndi:BPMNLabel")});e.$node.bpmn.fill&&r.set("bioc:fill",e.$node.bpmn.fill),e.$node.bpmn.stroke&&r.set("bioc:stroke",e.$node.bpmn.stroke);n.get("planeElement").push(r)})),o.$edges.forEach((e=>{const t=d.edge(e.from.id,e.to.id),o=i.create("bpmndi:BPMNEdge",{id:`edge.${e.from.id}_${e.to.id}`,bpmnElement:e.flow,label:i.create("bpmndi:BPMNLabel")});t.points.forEach((e=>{const t=i.create("dc:Point",{x:l+e.x,y:p+e.y});o.get("waypoint").push(t)}));n.get("planeElement").push(o)}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a}=e,c=t.childs.filter((e=>"bpmn:SubProcess"===e.bpmn.type));c.forEach((t=>{const o=s[`node.${t.pathKey}`],n=i.create("bpmndi:BPMNDiagram",{id:`diagram_${t.pathKey}`});s[n.id]=n,a.push(n);const r=i.create("bpmndi:BPMNPlane",{id:`plane_${t.pathKey}`});s[r.id]=r,n.plane=r,r.bpmnElement=o,fe({...e,targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:r})}))}(e)}async function me(e){const t=e.root,o=t.context.index,n=Object.keys(o).map((e=>o[e]));!function(e){const{nodes:t}=e;t.forEach((e=>{const t=[],o=[],n=i=>{i.context.next&&(t.push({from:i,to:i.context.next,type:"bpmn:SequenceFlow"}),i===e&&o.push({to:i.context.next,type:"bpmn:SequenceFlow",next:!0})),i.childs.forEach((t=>{i===e&&"switch"===e.type&&o.push({to:t,type:"bpmn:SequenceFlow"}),n(t)}))};n(e);const i=t.filter((t=>t.to.parent.indexKey===e.parent.indexKey)).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),s=t.filter((t=>t.to.parent.indexKey!==e.parent.indexKey&&!t.to.indexKey.startsWith(e.indexKey+"/"))).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),r=o.map((e=>({...e,to:e.to.indexKey})));e.bpmn=e.bpmn||{},e.bpmn.edges=le(i,"to"),e.bpmn.outside=le(s,"to"),e.bpmn.starts=le(r,"to"),e.bpmn.type=function(e){return"call"===e.type?"bpmn:ServiceTask":"form"===e.type?"bpmn:UserTask":"return"===e.type?"bpmn:EndEvent":"bpmn:Task"}(e),e.bpmn.width=120,e.bpmn.height=80,"return"===e.type&&(e.bpmn.width=36,e.bpmn.height=36)}))}({nodes:n}),pe({nodes:n,nodeIndex:o,root:t});const i=new I({atom:ce}),s={},r=i.create("bpmn:Definitions",{id:"definitions_0"});s[r.id]=r;for await(const e of t.childs){const a=r.get("rootElements"),c=r.get("diagrams"),l=i.create("bpmn:Process",{id:`process_${e.pathKey}`,documentation:[i.create("bpmn:Documentation",{text:`Atom Workflow - ${t.context.atom.name}`})]});s[l.id]=l,l.isExecutable=!0,a.push(l);const p=i.create("bpmndi:BPMNDiagram",{id:`diagram_${e.pathKey}`});s[p.id]=p,c.push(p);const d=i.create("bpmndi:BPMNPlane",{id:`plane_${e.pathKey}`});s[d.id]=d,p.plane=d,d.bpmnElement=l;fe({targetNode:e,targetFlowElementsContainer:l,targetPlaneElement:d,moddle:i,elementIndex:s,nodeIndex:o,nodes:n,diagrams:c})}return{diagramXML:(await i.toXML(r,{format:!0})).xml}}async function ue(e={}){return await me(w(e))}async function he({node:e,initNode:t}){if(Reflect.has(e.definition,"modules")&&!Array.isArray(e.definition.modules)){const t=e.definition.modules;e.definition.modules=[],Object.keys(t).forEach((o=>{const n={...t[o]};"modules"===e.type&&(n.export=n.export||o),e.definition.modules.push({[o]:n})}))}const o=[],n=await K({data:e.definition,callback:(e,t,n)=>{const i=A({expression:e});if("m"===i?.processor){const e=n.slice(0,-1);e.push(i.statement);const s=e.join("_");return o.push({[s]:t}),[i.statement,`m::${s}`]}return[e,t]}});o.length>0&&(e.definition=n,e.definition.modules=e.definition.modules||[],e.definition.modules=e.definition.modules.concat(o)),e.hasModules=e.definition.modules?.length>0;for(let o=0;o<e.definition.modules?.length;o++){const n=e.definition.modules[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}}async function ye({node:e,transformExpression:t}){const o=e.context.transform;Reflect.has(o,"export")&&(o.export=await t(o.export)),Reflect.has(o,"return")&&(e.hasReturn=!0,o.return=await t(o.return)),o.hasOwnProperty("nextArgs")&&(e.hasNextArgs=!0,o.nextArgs=await t(o.nextArgs))}async function ge({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform;for(const t of e.childs)t.context.transform=t.context.transform||w(t.definition),t.definition.hasOwnProperty("condition")&&(t.context.transform.condition=await n(t.definition.condition));await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var we={hits:async function({node:e}){return!!e.definition.hasOwnProperty("switch")},init:async function({node:e,initNode:t}){e.type="switch";const o=e.definition.switch||[];if(!o.every((e=>e.hasOwnProperty("condition")||e.hasOwnProperty("default"))))throw new Error("Switch must have condition or default");if(0===o.filter((e=>e.hasOwnProperty("condition"))).length)throw new Error("Switch must have at least one condition");const n=o.filter((e=>e.hasOwnProperty("default")));if(n.length>1)throw new Error("Switch must have only one default");if(1===n.length&&!o[o.length-1].hasOwnProperty("default"))throw new Error("Switch default must be the last child");e.hasDefaultCondition=1===n.length,await he({node:e,initNode:t}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0;for(let o=0;o<e.definition.switch.length;o++){let n=e.definition.switch[o],i=`${o}`;n.hasOwnProperty("default")&&(i="default",n=n.default);const s={name:n.condition||i,childs:[],parent:e,definition:n,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=ge},resolve:ge};var be={hits:async function({node:e}){return 1===Object.keys(e.definition).map((e=>A({expression:e}))).filter((e=>"if"===e?.processor)).length},init:async function(e){const{node:t}=e,o=Object.keys(t.definition).map((e=>A({expression:e}))),n=[],i=o.find((e=>"if"===e?.processor)),s=t.definition[i.expression];n.push({name:`${t.name}_if`,definition:s,processor:i}),delete t.definition[i.expression];const r=o.filter((e=>"elseif"===e?.processor));let a=0;for(const e of r){const o=t.definition[e.expression];n.push({name:`${t.name}_elseif_${a++}`,definition:o,processor:e}),delete t.definition[e.expression]}t.definition.switch=[];for(const e of n)t.definition.switch.push({condition:e.processor.statement,...e.definition});if(t.definition?.else){const e=t.definition.else;t.definition.switch.push({default:e}),delete t.definition.else}await we.init(e)}};async function xe({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){if(e.context.transform=e.context.transform||w(e.definition),e.context.transform,e.context.try=e.childs.find((e=>"try"===e.name)),e.context.except=e.childs.find((e=>"except"===e.name)),e.context.except){const t=e.context.except;t.context.transform=t.context.transform||w(t.definition),t.context.transform.hasOwnProperty("as")||(t.context.transform.as="error")}await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var je={hits:async function({node:e}){return e.definition.hasOwnProperty("try")&&e.definition.hasOwnProperty("except")},init:async function({node:e,initNode:t}){if(e.type="tryexcept",await he({node:e,initNode:t}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0,e.definition.try){const o="try",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}if(e.definition.except){const o="except",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}e.resolve=xe},resolve:xe};async function ve({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;for(let e=0;e<i.assign?.length;e++){let t=i.assign[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.assign[e]=r}await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var ke={hits:async function({node:e}){return e.definition.hasOwnProperty("assign")},init:async function({node:e,initNode:t}){e.type="assign",await he({node:e,initNode:t}),e.resolve=ve},resolve:ve};async function De({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);e.context.transform.for.in=await n(e.definition.for.in),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var _e={hits:async function({node:e}){return e.definition.hasOwnProperty("for")},init:async function({node:e,initNode:t}){if(e.type="for",await he({node:e,initNode:t}),e.blockAutoJumpToParent=!0,e.blockAutoJumpToSibling=!1,!e.definition.for.hasOwnProperty("steps")){const t=["value","in"],[o,n]=[R(e.definition.for,t),M(e.definition.for,t)];e.definition.for=o,e.definition.for.steps=[{[`${e.name}_step`]:n}]}Array.isArray(e.definition.for.steps)||(e.definition.for.steps=[{[`${e.name}_step`]:e.definition.for.steps}]);for(let o=0;o<e.definition.for.steps.length;o++){const n=e.definition.for.steps[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=De},resolve:De};var Se={hits:async function({node:e}){return!1},init:async function({node:e,initNode:t}){},resolve:async function({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){}};async function Ee({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;n.raise=await o(n.raise),await t({node:e})}var $e={hits:async function({node:e}){return e.definition.hasOwnProperty("raise")},init:async function({node:e,initNode:t}){e.type="raise",e.resolve=Ee},resolve:Ee};async function Pe({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;e.hasReturn=!0,n.return=await o(n.return),await t({node:e})}var Ne={hits:async function({node:e}){return e.definition.hasOwnProperty("return")},init:async function({node:e,initNode:t}){e.type="return",e.resolve=Pe},resolve:Pe};async function Te({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;if("function"===e.target?.atom?.doc?.type&&(i.call=await n(e.target.atom.name)),i.args&&(i.args=await n(i.args)),i.result){"string"==typeof i.result&&(i.result=[{[i.result]:"e::result"}]);for(let e=0;e<i.result?.length;e++){let t=i.result[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.result[e]=r}}const s=e.workflow.parent;i.import?e.context.lib=s.context.libs.find((e=>e.name===i.import)):e.context.lib=s.context.libs.find((e=>e.name===i.call)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Ce={hits:async function({node:e}){return e.definition.hasOwnProperty("call")},init:async function({node:e,initNode:t}){e.type="call",await he({node:e,initNode:t}),e.resolve=Te},resolve:Te};async function Fe({node:e,transformExpression:t}){e.context.next=e.childs[0],e.context.transform=e.context.transform||w(e.definition),await ye({node:e,transformExpression:t})}var Ie={hits:async function({node:e}){return e.definition.hasOwnProperty("steps")},init:async function({node:e,initNode:t}){e.type||(e.type="steps");const o=e.definition.steps||[];for await(const n of o){const o=Object.keys(n)[0],i={name:o,childs:[],parent:e,definition:n[o],index:e.childs.length,context:{}};e.childs.push(i),await t({node:i})}e.resolve=Fe},resolve:Fe};async function Oe({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.props&&(i.props=await n(i.props));const s=e.workflow.parent;e.context.lib=s.context.libs.find((e=>e.name===i.form)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Ae={hits:async function({node:e}){return e.definition.hasOwnProperty("form")},init:async function({node:e,initNode:t}){e.type="form",await he({node:e,initNode:t}),e.resolve=Oe},resolve:Oe};async function Be({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){e.context.transform=e.context.transform||w(e.definition),await t({node:e})}var Ke={hits:async function({node:e}){return e.definition.hasOwnProperty("operation")},init:async function({node:e,initNode:t}){e.type="operation",e.resolve=Be},resolve:Be};async function Re({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.next=await n(i.next),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Me={hits:async function({node:e}){return e.definition.hasOwnProperty("next")},init:async function({node:e,initNode:t}){e.type="jump",e.resolve=Re},resolve:Re};async function Le({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform,await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Je={hits:async function({node:e}){return e.definition.hasOwnProperty("modules")},init:async function({node:e,initNode:t}){e.type="modules",await he({node:e,initNode:t}),e.resolve=Le},resolve:Le};function We({node:e}){const t=e.definition;if(!e.hasReturn)if("end"===t.next);else if("stop"===t.next);else if("none"===t.next);else if(t.next){let o=e.parent;for(;o.parent;){const n=o.childs.find((e=>e.name===t.next));if(n){e.context.next=n;break}o=o.parent}}else{if(!0===e.module)return;let t=e.parent,o=e.index+1;for(;t.parent&&(!t.blockAutoJumpToParent||!t.blockAutoJumpToSibling);)if(Reflect.has(t,"blockAutoJumpToParent")||Reflect.has(t,"blockAutoJumpToSibling")){if(t.blockAutoJumpToParent){const n=t.childs.find((e=>e.index===o));n&&(e.context.next=n);break}t.blockAutoJumpToParent||(o=t.index+1,t=t.parent)}else{const n=t.childs.find((e=>e.index===o));if(n){e.context.next=n;break}o=t.index+1,t=t.parent}}}class ze{#e;#t;#o;#n;constructor({key:e,npm:t,master:o,extras:n}){this.#e=e,this.#t=t,this.#o=o,this.#n=n}hits({node:e}){return e.definition.hasOwnProperty(this.#e)}async init(e){const{node:t}=e,o=this.#e,n=t.definition,i=typeof n[o];if(n.call=`npm:${this.#t}`,n.args="object"!==i?{...n.args,[`${this.#o}`]:n[o]}:n[o],delete n[o],this.#n)for(const e in this.#n)n[e]=this.#n[e];console.log(`[npm-block] ${this.#e} --\x3e ${this.#t}`),await Ce.init(e)}}function Ge(e){return new ze(e)}class qe{#i;#s;#r;#a;#c;#l;#p;#d;#f;#m;#u;#h;#y;#g;#w;#b;#x;#j;#v;#k;#D;#_=[];constructor(e){this.#i=new oe,this.#s=e,this.#l=[],this.#p=[],this.#d={},this._expire_ttl=3600,this._expire_ttl_short=300,this.#_.push(Ge({key:"config",npm:"@fnet/config",master:"name"})),this.#_.push(Ge({key:"yaml",npm:"@fnet/yaml",master:"file"})),this.#_.push(Ge({key:"prompt",npm:"@fnet/prompt",master:"message"})),this.#_.push(Ge({key:"html-link",npm:"@flownet/lib-load-browser-link-url",master:"src"})),this.#_.push(Ge({key:"html-script",npm:"@flownet/lib-load-browser-script-url",master:"src"})),this.#_.push(Ge({key:"http-server",npm:"@fnet/node-express",master:"server_port"})),this.#_.push(Ge({key:"shell",npm:"@fnet/shell-flow",master:"commands"})),this.#_.push(Ge({key:"list-files",npm:"@fnet/list-files",master:"pattern"})),this.#_.push(Ge({key:"up-list-files",npm:"@fnet/up-list-files",master:"pattern"})),this.#_.push(Ge({key:"auto-conda-env",npm:"@fnet/auto-conda-env",master:"envDir"})),this.#_.push(Ge({key:"ollama-chat",npm:"@fnet/ollama-chat",master:"model"})),this.#_.push(Ge({key:"ai",npm:"@fnet/ai",master:"prompt",extras:{subtype:"flow"}})),this.#_.push(Ge({key:"invoke",npm:"@fnet/invoke",master:"method",extras:{}})),this.#_.push(Ge({key:"fetch",npm:"@fnet/fetch",master:"url",extras:{}})),this.#_.push(Ge({key:"filemap",npm:"@fnet/filemap",master:"target",extras:{}})),this.#k={packageDependencies:this.#l,packageDevDependencies:this.#p,setProgress:this.setProgress.bind(this),context:this.#s,Atom:D,registerToPackageManager:this.registerToPackageManager.bind(this)},this.#D={initNode:this.initNode.bind(this),cloneDeep:w,resolveTypeCommon:this.resolveTypeCommon.bind(this),resolveNextBlock:We,transformExpression:this.transformExpression.bind(this),transformValue:this.transformValue.bind(this)}}async _cache_set(e,t,o){this._redis_client&&await this._redis_client.SETEX(e,o||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await async function(){if(!await j({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=x.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e}(),this.#u=this.#s.buildId||v(),this.#k.buildId=this.#u,this.#w=this.#s.mode,this.#b=["all","deploy","build","file"].includes(this.#w),this.#x=["all","deploy","build"].includes(this.#w),this.#j=["all","deploy"].includes(this.#w),this.#v=["all","deploy","build","file","bpmn"].includes(this.#w),this.#y=this.#s.protocol,this.#h="BUILD:"+this.#u,this.#g=(await d({optional:!0,name:"atom",dir:this.#s.projectDir,tags:this.#s.tags}))?.data;try{await this.setProgress({message:"Initialization started."}),await this.initAuth(),await this.initWorkflow(),this.transformWorkflow({workflow:this.#a});const e=await this.initNodeTree({workflow:this.#a});await this.initNodeTreeIndex({root:e}),await this.initNodeCalls({root:e}),await this.initNodeCallLibs({root:e}),await this.initNodeForms({root:e}),await this.initNodeFormLibs({root:e}),await this.initEntryFiles({root:e,features:this.#r.doc.features}),await this.initFeaturesFromNodes({childs:e.childs,features:this.#r.doc.features}),await se(this.#k),await async function({atom:e,packageDependencies:t,packageDevDependencies:o,setProgress:n}){n("Initializing dependencies");const i=e.doc.dependencies||[];if(i.filter((e=>!e.dev)).forEach((e=>t.push(e))),i.filter((e=>e.dev)).forEach((e=>o.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let o="^18.2";n("Fetching React versions"),o=`^${(await E({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:o}),t.push({package:"react-dom",version:o}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),o.push({package:"ajv",version:"^8"}),e.doc.features.cli.fargs&&!1!==e.doc.features.cli.fargs?.enabled&&t.push({package:"@fnet/config",version:"0.2.21"}),e.doc.features.cli.mcp&&!0===e.doc.features.cli.mcp.enabled&&t.push({package:"@modelcontextprotocol/sdk",version:"^1.10"})),e.doc.features.render&&!1!==e.doc.features.render.enabled&&o.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"}),o.push({package:"@babel/core",version:"^7"}),o.push({package:"@rollup/plugin-commonjs",version:"^28"}),o.push({package:"@rollup/plugin-node-resolve",version:"^16"}),o.push({package:"@rollup/plugin-replace",version:"^6"}),o.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&o.push({package:"rollup-plugin-dts",version:"^6"}),o.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),o.push({package:"@rollup/plugin-alias",version:"^5"}),o.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(o.push({package:"@rollup/plugin-babel",version:"^6"}),o.push({package:"@babel/preset-env",version:"^7"}),o.push({package:"@babel/preset-react",version:"^7"}),e.doc.features.babel?.options?.plugins?.forEach((e=>{switch(e[0]){case"@babel/plugin-proposal-decorators":o.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":o.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":o.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":o.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":o.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"})}}))),o.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),e.doc.features.browsersync_enabled&&o.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}(this.#k),await this.initAtomLibsAndDeps({libs:e.context.libs,packageDependencies:this.#l}),await this.resolveNodeTree({root:e}),this.#m=e}catch(e){throw await this._cache_set(this.#h,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#s.id&&(this.#f=await this.#i.init({config:this.#g}),this.#k.atomAccessToken=this.#f)}async initWorkflow(){const e=this.#s.id;this.#r=this.#s.project?.workflowAtom||await D.get({id:e}),this.#a="string"==typeof this.#r.doc.content?(await h({content:this.#r.doc.content,tags:this.#s.tags})).parsed:this.#r.doc.content;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",this.#k.atom=this.#r,this.#r.doc.features=this.#r.doc.features||{}}#S(t){console.log("filePath",t),l.statSync(t).isDirectory()?(l.readdirSync(t).forEach((o=>{const n=e.join(t,o);this.#S(n)})),l.rmSync(t)):l.unlinkSync(t)}#E(t,o){const n=l.existsSync(t),i=n&&l.statSync(t);n&&i.isDirectory()?(l.mkdirSync(o,{recursive:!0}),l.readdirSync(t).forEach((n=>{this.#E(e.join(t,n),e.join(o,n))}))):l.copyFileSync(t,o)}async initWorkflowDir(){this.setProgress({message:"Initializing library directory."});const t=this.#s.projectDir,o=this.#s.coreDir;this.setProgress({message:"Cleaning project directory."});const n=B({dir:t,ignore:[".cache","node_modules",".conda",".bin"],absolute:!0});for(const e of n)l.rmSync(e,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."}),l.existsSync(t)||l.mkdirSync(t,{recursive:!0});const i=e.join(t,"src");l.existsSync(i)||l.mkdirSync(i,{recursive:!0});const s=e.join(i,"core");this.#E(o,s);const r=e.join(i,"default","blocks");l.existsSync(r)||l.mkdirSync(r,{recursive:!0})}async initNunjucks(){this.setProgress({message:"Initializing nunjucks."});const e=this.#s.templateDir;this.#c=g.configure(e,{watch:!1,dev:!0}),this.#k.njEnv=this.#c}transformWorkflow({workflow:e}){for(const t of Object.values(e))t.steps=t.steps||[],t.steps=t.steps.filter((e=>Object.keys(e).length>0)),t.steps=t.steps.map((e=>this.transformStep({step:e})))}transformStep({step:e}){if(Array.isArray(e))throw new Error("Step must be an object.");const[t,o]=Object.entries(e)[0];if(o.hasOwnProperty("onerror")){const{onerror:n,...i}=o;e[t]={try:i,except:n}}if(e[t].hasOwnProperty("steps")){const o=e[t].steps;if(!Array.isArray(o))throw new Error("Steps must be an array.");e[t].steps=o.map((e=>this.transformStep({step:e})))}return e}async initNodeTree({workflow:e}){const t=Object.keys(e),o={definition:e,name:void 0,type:"root",parent:void 0,childs:[],blockAutoJumpToParent:!0,blockAutoJumpToSibling:!0,index:0,depth:0,context:{libs:[],atom:this.#r}};t.forEach((t=>{const n={name:t,type:"main"===t?"workflow":"subworkflow",childs:[],parent:o,definition:e[t],index:o.childs.length,depth:o.depth+1,context:{},blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1};o.childs.push(n)}));for await(const e of o.childs)await this.initNode({node:e});return o}async initNode({node:e}){const t={...this.#D,node:e};if(e.workflow=e.parent.workflow||e,e.depth=e.parent.depth+1,await je.hits(t))await je.init(t);else if(await _e.hits(t))await _e.init(t);else if(await we.hits(t))await we.init(t);else if(await be.hits(t))await be.init(t);else if(await Se.hits(t))await Se.init(t);else if(await ke.hits(t))await ke.init(t);else if(await $e.hits(t))await $e.init(t);else if(await Ce.hits(t))await Ce.init(t);else if(this.#_.find((e=>e.hits(t))))await this.#_.find((e=>e.hits(t))).init(t);else if(await Ae.hits(t))await Ae.init(t);else if(await Ke.hits(t))await Ke.init(t);else if(await Ie.hits(t))await Ie.init(t);else if(await Me.hits(t))await Me.init(t);else if(await Je.hits(t))await Je.init(t);else{if(!await Ne.hits(t))throw new Error("Undefined step type.");await Ne.init(t)}}async initNodeTreeIndex({root:e}){const t={};e.indexKey="/";for await(const o of e.childs)await this.initNodeIndex({node:o,index:t});return e.context.index=t,t}async initNodeIndex({node:t,index:o}){const n=e.join(t.parent.indexKey,t.name);t.indexKey=n,o[n]=t;const i=[];let s=t;for(;s?.parent;)i.push(s.index),s=s.parent;i.reverse(),t.codeKey=`B_${i.join("_")}_${t.type}`,t.pathKey=`${i.join(".")}`,t.typeId=v();for await(const e of t.childs)await this.initNodeIndex({node:e,index:o})}async initNodeCalls({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"call"===n.type&&o.push(n)}return e.context.calls=o,o}async initNodeCallLibs({root:e}){const t=[],o=e.context.calls;for await(const e of o){const o=e.definition.import||e.definition.call,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom",definition:e.definition},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.callLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeCallTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.call,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeCallTarget({refNode:e,curNode:t.parent})}async initNodeForms({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"form"===n.type&&o.push(n)}return e.context.forms=o,o}async initNodeFormLibs({root:e}){const t=[],o=e.context.forms;for await(const e of o){const o=e.definition.import||e.definition.form,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom"},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.formLibs=t,e.context.libs=[...e.context.libs,...t],t}async initFeaturesFromNodes({childs:e,features:t}){for await(const o of e)"form"!==o.type||Reflect.has(t,"form")||(t.form=!0),await this.initFeaturesFromNodes({childs:o.childs,features:t})}async initEntryFiles({root:e,features:t}){for await(const o of e.childs){let e;if("main"===o.name)e="index.js";else if("cli"===o.name)e="cli.js";else if("app"===o.name)e="app.js";else{if("api"!==o.name)continue;e="api.js"}t[`${o.name}_default_entry_file`]=e,o.entryFile=e}}async findNodeFormTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.form,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeFormTarget({refNode:e,curNode:t.parent})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const o=e.filter((e=>"atom"===e.type));for(let e=0;e<o.length;e++){const n=o[e],i=await this.findAtomLibrary({url:n.name,libRef:n});n.atom=i;const s=i.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));s?.forEach((e=>{const o=t.find((t=>t.package===e.package));o?"string"==typeof e.path?(o.path||[]).some((t=>t===e.path))||(o.path=o.path||[],o.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(o.path||[]).some((t=>t===e))||(o.path=o.path||[],o.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:t,libRef:o}){const n=F({url:t});if(!n)throw new Error(`Invalid package name: ${t}`);if(n.protocol||(n.protocol=this.#y),"ac:"===n.protocol){const e=n.pathname.split("/");if(1===e.length)return await D.first({where:{name:t,parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===e.length){const t=await D.first({where:{name:e[0],parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"folder"}});return await D.first({where:{name:e[1],parent_id:t.id,type:"workflow.lib"}})}}else{if("local:"===n.protocol){const t=e.resolve(this.#s.projectSrcDir,`${n.pathname}.js`),o=[],i=(await S({file:t,recursive:!0})).all;for await(const e of i){if("npm"!==e.type)continue;if(o.find((t=>t.package===e.package)))continue;const t=await re({name:e.package,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});o.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return{name:n.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:o},protocol:n.protocol}}if("npm:"===n.protocol){const e=await re({name:n.pathname,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});return{name:n.pathname,doc:{type:"workflow.lib",subtype:"flow"===o?.definition?.subtype?"workflow":null,"content-type":"javascript",language:"js",dependencies:[{package:n.pathname,version:e.minorRange,type:"npm"}]},protocol:n.protocol}}if("use:"===n.protocol){return{name:n.pathname,doc:{type:"function",dependencies:[]},protocol:n.protocol}}}}async resolveNodeTree({root:e}){for await(const t of e.childs)await this.resolveTypeWorkflow({node:t})}async resolveTypeWorkflow({node:e}){e.context.transform=e.context.transform||w(e.definition);const t=e.context.transform;for(let e=0;e<t.params?.length;e++){const o=t.params[e];if("string"==typeof o)t.params[e]={key:o,hasDefault:!1};else{const n=Object.keys(o)[0];t.params[e]={key:n,hasDefault:!0,default:o[n],type:typeof o[n]}}}e.context.next=e.childs[0];for await(const t of e.childs)await this.resolveType({node:t})}async resolveType({node:e}){const t={...this.#D,node:e};"function"==typeof e.resolve&&await e.resolve(t);for await(const t of e.childs)await this.resolveType({node:t})}async resolveTypeCommon({node:e}){const t=e.context.transform;t.hasOwnProperty("operation")&&(t.operation=await this.transformExpression(t.operation)),t.hasOwnProperty("page")&&(t.page=await this.transformExpression(t.page)),t.hasOwnProperty("print")&&(t.print=await this.transformExpression(t.print)),t.hasOwnProperty("sleep")&&(t.sleep=await this.transformExpression(t.sleep)),t.hasOwnProperty("assert")&&(t.assert=await this.transformExpression(t.assert))}async createAtomLibFiles({root:t}){await this.setProgress({message:"Creating external lib files."}),this.#r.typesDir="./types";const o=t.context.libs.filter((e=>"atom"===e.type));for(let t=0;t<o.length;t++){const n=o[t].atom,i=this.#s.projectDir;if("local:"===n.protocol){const t=e.resolve(this.#s.projectSrcDir,`${n.fileName||n.name}.js`),o=e.relative(`${this.#s.projectDir}/src/default/blocks`,t);if(!l.existsSync(t)){l.mkdirSync(e.dirname(t),{recursive:!0});let o="export default async (args)=>{\n";o+="}",l.writeFileSync(t,o,"utf8")}n.relativePath=o.split(e.sep).join("/"),this.#r.typesDir=`./types/${e.basename(i)}/src`}else if("npm:"===n.protocol)n.relativePath=n.name;else if("use:"===n.protocol);else{const t=`${i}/src/libs/${n.id}.js`,o=n.doc.contents?.find((e=>"esm"===e.format))||n.doc;l.writeFileSync(e.normalize(t),o.content,"utf8")}}}async createEngine({root:t}){await this.setProgress({message:"Creating engine file."});const o=this.#s.templateDir,n=g.compile(l.readFileSync(e.resolve(o,"src/default/engine.js.njk"),"utf8"),this.#c);for(let o=0;o<t.childs.length;o++){const i=t.childs[o];if(!i.entryFile)continue;const s=n.render({flow:i,ui:{package:"@fnet/react-app"}}),r=this.#s.projectDir,a=e.resolve(r,`src/default/${i.entryFile}`);l.writeFileSync(a,s,"utf8")}}async createNodeTree({root:e}){await this.setProgress({message:"Creating block files."});for await(const t of e.childs)await this.createTypeWorkflow({node:t})}async createTypeWorkflow({node:t}){const o=this.#s.templateDir,n=g.compile(l.readFileSync(e.resolve(o,"src/default/workflow.js.njk"),"utf8"),this.#c).render(t),i=this.#s.projectDir,s=e.resolve(i,`src/default/${t.codeKey}.js`);l.writeFileSync(s,n,"utf8");for await(const e of t.childs)await this.createType({node:e})}async createType({node:e}){switch(e.type){case"assign":case"steps":case"return":case"call":case"form":case"raise":case"switch":case"jump":case"tryexcept":case"for":case"operation":case"modules":this.createBlockFromTemplate({node:e})}for await(const t of e.childs)await this.createType({node:t})}createBlockFromTemplate({node:e}){const t=this.getBlockTemplate({node:e});e.context.render=t.render(e),this.createStepFile({node:e})}getBlockTemplate({node:t}){let o=this.#d[t.type];if(o)return o;const n=this.#s.templateDir;return o=g.compile(l.readFileSync(e.resolve(n,`src/default/blocks/${t.type}.js.njk`),"utf8"),this.#c),this.#d[t.type]=o,o}createStepFile({node:t}){const o=this.#s.projectDir,n=`${t.codeKey}.js`,i=e.resolve(o,`src/default/blocks/${n}`);l.writeFileSync(i,t.context.render,"utf8"),t.context.fileName=n,t.context.filePath=i}async transformExpression(e){let t=await this.transformValue(e);return t=JSON.stringify(t),t=this.replaceSpecialPattern(t),t}async transformValue(e){if(Array.isArray(e))for(let t=0;t<e.length;t++)e[t]=await this.transformValue(e[t]);else if(b(e)){const t=Object.keys(e);for(let o=0;o<t.length;o++){const n=t[o],i=A({expression:n});if(i)if("e"===i.processor){const t=e[n].replace(/(\r\n|\n|\r)/g,"");e[i.statement]=`$::${t}::`,delete e[n]}else e[n]=await this.transformValue(e[n]);else e[n]=await this.transformValue(e[n])}}else if("string"==typeof e){const t=A({expression:e});if(t){const{processor:o,statement:n}=t;switch(o){case"v":e=`$::v.${n}::`;break;case"e":e=`$::${n}::`;break;case"m":e=`$::c.module['${n}']::`;break;case"fm":e=`$::flow.getModule('${n}')::`;break;case"f":e=`$::c.form.${n}::`;break;case"for":e=`$::caller.for.${n}::`}}}return e}replaceSpecialPattern(e){return e.replace(/"\$::(.*?)::"/g,"$1")}replaceExpressionLegacy(e){return e.replaceAll(/(?<outer>"\${(?<inner>[^{]*)}")/g,"$2")}async createProjectYaml(){const t="fnet.yaml",o=`Creating ${t}`;await this.setProgress({message:o});const{content:n,...i}=this.#r.doc,s=this.#s.projectDir,r=e.resolve(s,`${t}`);l.writeFileSync(r,y.stringify(i),"utf8")}async createProjectMainYaml(){const t="flow.main.yaml",o=`Creating ${t}`;await this.setProgress({message:o});const n={content:y.stringify(this.#a)},i=this.#s.templateDir,s=g.compile(l.readFileSync(e.resolve(i,`${t}.njk`),"utf8"),this.#c).render(n),r=this.#s.projectDir,a=e.resolve(r,`${t}`);l.writeFileSync(a,s,"utf8")}async runPrettifier(){const t=this.#s.projectDir;if(V("bun")){const o=await u("prettier --write .",{cwd:e.resolve(t,"src")});if(0!==o.code)throw new Error(o.stderr)}else{const o=await u("prettier --write .",{cwd:e.resolve(t,"src")});if(0!==o.code)throw new Error(o.stderr)}}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#s.project?.devops){const e=[this.#s.project?.devops];for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&await o.save()}}else if(this.#r.id){const e=await D.list({type:"workflow.deploy",parent_id:this.#r.id});for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&(o=await D.update(o,{id:o.id}))}}}async deployProject(e){const{deploymentProject:t}=e,{yamlDocument:o}=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||{}),i=o||{};for(let e=0;e<n.length;e++){const o=t.doc[n[e]];o.name=n[e];const s=i.get(n[e]);await ae({...this.#k,deploymentProject:t,deploymentProjectTarget:o,yamlTarget:s})}}async registerToPackageManager(e){const{target:t,packageJSON:o}=e;if(!this.#s.id)return;let n=await D.first({name:t.params.name,parent_id:this.#g.env.ATOM_PACKAGES_ID});n?(n.doc.versions.splice(0,0,{v:o.version}),await D.update(n,{id:n.id})):n=await D.create({parent_id:this.#g.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:o.version}]}})}async setProgress(e){const t="string"==typeof e?e:e?.message;console.log(s.blue(t)),await this._cache_set(this.#h,{status:"IN_PROGRESS",message:t})}async build(){if(this.#v&&!this.#b)return await this.createNetwork();try{const t=this.#v?await ue({root:this.#m}):void 0;if(this.#b){if(await this.initWorkflowDir(),await this.initNunjucks(),this.#v){let o=this.#s.project?.projectDir||this.#s.projectDir;o=e.resolve(o,"fnet"),l.existsSync(o)&&(l.existsSync(e.resolve(o,"flow.bpmn"))&&l.unlinkSync(e.resolve(o,"flow.bpmn")),l.writeFileSync(e.resolve(o,"flows.bpmn"),t.diagramXML,"utf8"))}await this.createAtomLibFiles({root:this.#m}),await this.createEngine({root:this.#m}),await this.createNodeTree({root:this.#m}),await this.createProjectYaml(),await async function({atom:t,context:o,setProgress:n,Atom:i}){const s="readme.md",r=`Creating ${s}`;if(await n({message:r}),o.project?.readme){const t=o.projectDir,n={content:o.project.readme.doc.content},i=e.resolve(o.project.projectDir,"fnet/how-to.md");if(l.existsSync(i)){const e=l.readFileSync(i,"utf8");n.howto=e}const r=e.resolve(o.project.projectDir,"fnet/input.yaml");if(l.existsSync(r)){const e=await h({file:r,tags:o.tags});n.input=e.content}const a=e.resolve(o.project.projectDir,"fnet/output.yaml");if(l.existsSync(a)){const e=await h({file:a,tags:o.tags});n.output=e.content}const c=o.templateDir,p=g.compile(l.readFileSync(e.resolve(c,`${s}.njk`),"utf8"),g.configure(c)).render(n),d=e.resolve(t,`${s}`);l.writeFileSync(d,p,"utf8")}else if(t.id){const n=await i.first({type:"wiki",parent_id:t.id});if(!n||"markdown"!==n.doc?.["content-type"])return;const{content:r,...a}=n.doc,c={content:r},p=o.templateDir,d=g.compile(l.readFileSync(e.resolve(p,`${s}.njk`),"utf8"),g.configure(p)).render(c),f=o.projectDir,m=e.resolve(f,`${s}`);l.writeFileSync(m,d,"utf8")}}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){await o({message:"Creating tsconfig.json."});const s={atom:t,packageDependencies:i},r=n.templateDir,a=g.compile(l.readFileSync(e.resolve(r,"tsconfig.json.njk"),"utf8"),g.configure(r)).render(s),c=n.projectDir,p=e.resolve(c,"tsconfig.json");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){await o({message:"Creating .gitignore"});const s={atom:t,packageDependencies:i},r=n.templateDir,a=g.compile(l.readFileSync(e.resolve(r,".gitignore.njk"),"utf8"),g.configure(r)).render(s),c=n.projectDir,p=e.resolve(c,".gitignore");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:t,setProgress:o,context:n,njEnv:i}){if(!0!==t.doc.features.cli.enabled)return;await o({message:"Creating input args."});let s={};if(s=t.doc.input?t.doc.input:{type:"object",properties:{},required:[]},t.doc.features.cli.fargs&&!1!==t.doc.features.cli.fargs?.enabled){const e=t.doc.features.cli.fargs,o={type:"string",description:"Config name to load args",hidden:!1},n={type:"array",description:"Tags to filter the config",hidden:!1};Reflect.has(e,"default")&&(o.default=e.default),s.properties&&(s.properties.fargs=o,s.properties.ftag=n)}const r={options:s,imports:[],atom:t},a=n.templateDir,c=g.compile(l.readFileSync(e.resolve(a,"src/default/input.args.js.njk"),"utf8"),i).render(r),p=n.projectDir,d=e.resolve(p,"src/default/input.args.js");l.writeFileSync(d,c,"utf8");const f=new N({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});C(f);const m=f.compile(s),u=T(f,m);l.writeFileSync(e.resolve(p,"src/default/validate_input.js"),u,"utf8")}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){if(!0!==t.doc.features.cli.enabled)return;await o({message:"Creating cli."});const s={atom:t,packageDependencies:i},r=n.templateDir,a=e.resolve(n.projectDir,"src/cli");l.existsSync(a)||l.mkdirSync(a,{recursive:!0}),await m({pattern:["index.js.njk"],dir:e.resolve(r,"src/cli"),outDir:a,context:s})}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){if(!0!==t.doc.features.app.enabled)return;await o({message:"Creating app folder"});const s={atom:t,packageDependencies:i,ts:Date.now()},r=n.templateDir,a=e.resolve(n.projectDir,"src/app");l.existsSync(a)||l.mkdirSync(a,{recursive:!0});let c=["index.js.njk"];!1!==t.doc.features.app.html&&c.push("index.html.njk"),await m({pattern:c,dir:e.resolve(r,"src/app"),outDir:a,context:s})}(this.#k),await async function({atom:t,setProgress:o,context:n,packageDependencies:i}){await o({message:"Creating rollup file."});const s={atom:t,packageDependencies:i},r=e.resolve(n.projectDir,"src","default/index.js");if(!l.existsSync(r))throw new Error(`Entry file not found: ${r}`);const a=(await S({file:r,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),c=t.doc.features.rollup_output,p=Object.keys(c);for(let e=0;e<p.length;e++){const t=c[p[e]];if(!0===t.browser&&a.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(a.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<a.length;e++){const o=a[e];t.alias.entries[o]=`node:${o}`,t.alias.entries[`node:${o}`]=o}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(a)}}const d=n.templateDir;let f=g.compile(l.readFileSync(e.resolve(d,"rollup.config.mjs.njk"),"utf8"),g.configure(d)).render(s);const m=n.projectDir;let u=e.resolve(m,"rollup.config.mjs");l.writeFileSync(u,f,"utf8")}(this.#k),await async function({atom:t,context:o,packageDependencies:n,packageDevDependencies:i,setProgress:s}){await s({message:"Creating package.json."}),n.filter((e=>!0===e.dev)).forEach((e=>{i.find((t=>t.package===e.package))||i.push(e);const t=n.findIndex((t=>t.package===e.package));n.splice(t,1)}));const r=n.find((e=>"react"===e.package)),a=n.find((e=>"react-dom"===e.package));r&&!a?n.push({package:"react-dom",version:r.version}):r&&a&&(a.version=r.version),r&&t.doc.features.react_version>=17&&(n.find((e=>"@emotion/react"===e.package))||n.push({package:"@emotion/react",version:"^11"}),n.find((e=>"@emotion/styled"===e.package))||n.push({package:"@emotion/styled",version:"^11"}));const c=[];!0===t.doc.features.app.enabled&&c.push({file:e.resolve(o.projectDir,"src/app/index.js"),dev:!1!==t.doc.features.app.dev}),!0===t.doc.features.cli.enabled&&c.push({file:e.resolve(o.projectDir,"src/cli/index.js"),dev:!1!==t.doc.features.cli.dev});for await(const e of c){const t=e.file;if(!l.existsSync(t))throw new Error(`App file not found: ${t}`);const r=(await S({file:t,recursive:!0})).all;for await(const t of r){if("npm"!==t.type)continue;if(n.find((e=>e.package===t.package)))continue;if(i.find((e=>e.package===t.package)))continue;const r=await re({name:t.package,projectDir:o.projectDir,setProgress:s});(!0===e.dev?i:n).push({package:t.package,subpath:t.subpath,version:r.minorRange,type:"npm"})}}const p={atom:t,packageDependencies:n,packageDevDependencies:i},d=o.templateDir,f=g.compile(l.readFileSync(e.resolve(d,"package.json.njk"),"utf8"),g.configure(d)).render(p),m=o.projectDir,u=e.resolve(m,"package.json");l.writeFileSync(u,f,"utf8");const h=e.resolve(o.project.projectDir,"fnet");if(l.existsSync(h)){const t=e.resolve(o.projectDir,"fnet");l.existsSync(t)||l.mkdirSync(t);const n=l.readdirSync(h);for(const o of n){const n=e.resolve(h,o);if(!l.lstatSync(n).isFile())continue;const i=e.resolve(t,o);l.copyFileSync(n,i)}}}(this.#k),await async function({setProgress:t,context:o}){const n=o.projectDir;await t({message:"Prettifiying source files."});let i=e.join("src","**","*");if(V("bun")){const e=await u(`prettier --write ${i} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:n});if(0!==e.code)throw new Error(e.stderr)}else{const e=await u(`prettier --write ${i} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:n});if(0!==e.code)throw new Error(e.stderr)}}(this.#k),await async function({atom:e,setProgress:t,context:o}){if(!e.doc.features.dts_enabled)return;const n=o.projectDir;if(await t({message:"Creating .d.ts"}),0!==(await u("tsc",{cwd:n})).code)throw new Error("Couldnt create .d.ts files.")}(this.#k),this.#x&&(await async function({setProgress:e,atom:t,context:o}){const n=o.projectDir;if(await e({message:"Installing npm packages."}),V("bun")){if(0!==(await u(`bun install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}else if(0!==(await u(`npm install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}(this.#k),await async function({setProgress:e,context:t}){const o=t.projectDir;if(await e({message:"Building main project."}),0!==(await u("npm run build",{cwd:o})).code)throw new Error("Couldnt build project.")}(this.#k),this.#j&&await this.deploy())}await this._cache_set(this.#h,{status:"COMPLETED",data:{network:t}})}catch(e){throw await this._cache_set(this.#h,{status:"FAILED",message:e.message||e}),e}}async createNetwork(){try{const e=await ue({root:this.#m});await this._cache_set(this.#h,{status:"COMPLETED",data:{...e}})}catch(e){throw await this._cache_set(this.#h,{status:"FAILED",message:e.message||e}),e}}}const Ue={command:"build",describe:"Build flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Z(e),o=new qe(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},Ve={command:"deploy",describe:"Build and deploy flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Z({...e,mode:"all"}),o=new qe(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},Xe={command:"file",describe:"Just create files",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Z({...e,mode:"file"}),o=new qe(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},He={command:"input [name]",describe:"Create or modify an input config file",builder:e=>e.positional("name",{type:"string",demandOption:!1,describe:"Input name"}),handler:async t=>{try{const o=await Z(t),{project:n}=o,{projectDir:i,projectFileParsed:s}=n,r=s.input;if(!r)throw new Error("Config schema not found in project file.");if(!Reflect.has(t,"name")){const{inputName:e}=await L({type:"input",name:"inputName",message:"Input name:",initial:"dev"});t.name=e}const a=e.resolve(i,".fnet");l.existsSync(a)||l.mkdirSync(a);const c=e.resolve(a,`${t.name}.fnet`),p=l.existsSync(c),d=(await import("@fnet/object-from-schema")).default,f=await d({schema:r,format:"yaml",ref:p?c:void 0});l.writeFileSync(c,f)}catch(e){console.error(e.message),process.exit(1)}}},Ye=e.join(f.homedir(),".fnet","express");async function Qe(t){t.command(["$0 [project-name]","create [project-name]"],"Create a new express project",(e=>e.positional("project-name",{describe:"Name of the project",type:"string"}).option("yes",{alias:"y",describe:"Skip all prompts and use defaults",type:"boolean",default:!1}).option("runtime",{describe:"Runtime to use (node)",type:"string",choices:["node"],default:"node"})),(async t=>{await async function(t){try{l.existsSync(Ye)||l.mkdirSync(Ye,{recursive:!0});const o=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=e.join(Ye,o);l.existsSync(n)||l.mkdirSync(n,{recursive:!0});let i,r=t.projectName,a=t.runtime;if(t.yes){if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=e.length>0?Math.max(...e)+1:1;r=`fnet-${t}`}a||(a="node")}else{if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=`fnet-${e.length>0?Math.max(...e)+1:1}`,o=await L([{type:"input",name:"projectName",message:"Enter project name:",default:t}]);r=o.projectName}const e=a||"node";a=(await L({type:"select",name:"runtime",message:"Select runtime:",choices:["node"],initial:e})).runtime}if(i=e.join(n,r),l.existsSync(i)){let t=1;for(;l.existsSync(e.join(n,`${r}-${t}`));)t++;r=`${r}-${t}`,i=e.join(n,r)}if(!t.yes){if(!(await L([{type:"confirm",name:"proceed",message:`Create express project "${r}" in ${i}?`,default:!0}])).proceed)return void console.log(s.yellow("Project creation cancelled."))}console.log(s.blue(`Creating express project "${r}" in ${i}...`));const p=e.dirname(i),d=["create","--name",e.basename(i)];d.push("--runtime",a),t.yes&&d.push("--yes"),l.existsSync(p)||l.mkdirSync(p,{recursive:!0});const f=c("fnet",d,{stdio:"inherit",shell:!0,cwd:p});return new Promise(((e,o)=>{f.on("close",(n=>{0===n?(console.log(s.green(`\nExpress project "${r}" created successfully!`)),console.log(s.blue(`\nProject location: ${i}`)),t.yes?e():async function(e){try{(await L({type:"confirm",name:"openIDE",message:"Would you like to open the project in an IDE?",initial:!0})).openIDE&&await ot(e)}catch(e){console.error(s.red(`Error opening IDE: ${e.message}`))}}(i)):(console.error(s.red(`\nFailed to create express project "${r}".`)),o(new Error(`Process exited with code ${n}`)))}))}))}catch(e){console.error(s.red(`Error creating express project: ${e.message}`)),process.exit(1)}}(t)})).command("list","List express projects",(e=>e.option("today",{describe:"Show only projects created today",type:"boolean",default:!1}).option("type",{describe:"Filter by project type (fnode or fnet)",type:"string",choices:["fnode","fnet"]}).option("name",{describe:"Filter by project name",type:"string"})),(async t=>{await async function(t){try{if(!l.existsSync(Ye))return void console.log(s.yellow("No express projects found."));const o=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(t.today){const e=(new Date).toISOString().slice(0,10).replace(/-/g,""),t=o.indexOf(e);if(-1===t)return void console.log(s.yellow("No express projects found for today."));o.splice(0,t),o.splice(1)}const n=[];for(const i of o){const o=e.join(Ye,i),s=l.readdirSync(o);for(const r of s){const s=e.join(o,r),a=l.statSync(s);let c="unknown";if(r.startsWith("fnode-")||l.existsSync(e.join(s,"fnode.yaml"))?c="fnode":(r.startsWith("fnet-")||l.existsSync(e.join(s,"fnet.yaml")))&&(c="fnet"),t.type&&c!==t.type)continue;if(t.name&&!r.includes(t.name))continue;const p=`${i.slice(0,4)}-${i.slice(4,6)}-${i.slice(6,8)}`;n.push({name:r,type:c,date:p,path:s,created:a.birthtime})}}if(n.sort(((e,t)=>t.created-e.created)),0===n.length)return void console.log(s.yellow("No express projects found matching the criteria."));console.log(s.blue("\nExpress Projects:")),console.log(s.blue("=================\n"));const i=n.map((e=>{let t=e.path;return t.startsWith(f.homedir())&&(t="~"+t.substring(f.homedir().length)),{Name:e.name,Type:e.type,Date:e.date,Path:t}}));console.table(i),console.log(s.blue(`\nTotal: ${n.length} projects`))}catch(e){console.error(s.red(`Error listing express projects: ${e.message}`)),process.exit(1)}}(t)})).command("open [project-name]","Open an express project",(e=>e.positional("project-name",{describe:"Name of the project to open",type:"string"}).option("latest",{describe:"Open the most recent project",type:"boolean",default:!1})),(async t=>{await async function(t){try{if(!l.existsSync(Ye))return void console.log(s.yellow("No express projects found."));let o;if(t.latest){if(o=await Ze(),!o)return void console.log(s.yellow("No express projects found."))}else if(t.projectName){if(o=await et(t.projectName),!o)return void console.log(s.yellow(`Project "${t.projectName}" not found.`))}else{const t=await tt();if(!t)return void console.log(s.yellow("No project selected."));o=e.join(Ye,t)}await ot(o)}catch(e){console.error(s.red(`Error opening express project: ${e.message}`)),process.exit(1)}}(t)})).command("move [project-name] [destination]","Move an express project to a real project location",(e=>e.positional("project-name",{describe:"Name of the project to move",type:"string"}).positional("destination",{describe:"Destination directory",type:"string"}).option("latest",{describe:"Move the most recent project",type:"boolean",default:!1})),(async t=>{await async function(t){try{const o=process.cwd();let n;if(o.includes(Ye))n=o,console.log(s.blue(`Using current express project: ${e.basename(n)}`));else if(t.latest){if(n=await Ze(),!n)return void console.log(s.yellow("No express projects found."))}else if(t.projectName){if(n=await et(t.projectName),!n)return void console.log(s.yellow(`Project "${t.projectName}" not found.`))}else{const t=await tt();if(!t)return void console.log(s.yellow("No project selected."));n=e.join(Ye,t)}let i=t.destination;if(!i){i=(await L({type:"input",name:"destination",message:"Enter destination directory:",initial:e.join(process.cwd(),e.basename(n))})).destination}if(i.startsWith("~")&&(i=e.join(f.homedir(),i.slice(1))),i=e.resolve(i),i.startsWith(n+e.sep)||i===n)return void console.log(s.red("Destination cannot be inside the source directory."));if(l.existsSync(i)){if(!l.statSync(i).isDirectory())return void console.log(s.red(`Destination "${i}" is not a directory.`));if(l.readdirSync(i).length>0){if(!(await L({type:"confirm",name:"overwrite",message:`Destination "${i}" is not empty. Continue anyway?`,initial:!1})).overwrite)return void console.log(s.yellow("Project move cancelled."))}}else l.mkdirSync(i,{recursive:!0});console.log(s.blue(`Moving project from ${n} to ${i}...`)),it(n,i),console.log(s.green(`\nProject moved successfully to ${i}`));(await L({type:"confirm",name:"deleteOriginal",message:"Delete the original express project?",initial:!1})).deleteOriginal&&(l.rmSync(n,{recursive:!0,force:!0}),console.log(s.green("Original project deleted."))),await ot(i)}catch(e){console.error(s.red(`Error moving express project: ${e.message}`)),process.exit(1)}}(t)})).demandCommand(1,"You need to specify a command").help()}async function Ze(){const t=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(0===t.length)return null;const o=t[0],n=e.join(Ye,o),i=l.readdirSync(n);if(0===i.length)return null;let s=null,r=0;for(const t of i){const o=e.join(n,t),i=l.statSync(o);i.birthtimeMs>r&&(r=i.birthtimeMs,s=o)}return s}async function et(t){const o=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const n of o){const o=e.join(Ye,n),i=l.readdirSync(o);if(i.includes(t))return e.join(o,t);const s=i.filter((e=>e.includes(t)));if(s.length>0){if(1===s.length)return e.join(o,s[0]);{const i=await L({type:"select",name:"selectedProject",message:`Multiple projects match "${t}". Please select one:`,choices:s.map((t=>({name:`${t} (${n})`,value:e.join(o,t)})))});return i.selectedProject}}}return null}async function tt(){const t=[],o=l.readdirSync(Ye).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const n of o){const o=e.join(Ye,n),i=l.readdirSync(o);for(const s of i){const i=e.join(o,s),r=l.statSync(i),a=`${n}/${s}`;t.push({name:a,value:a,created:r.birthtime})}}if(t.sort(((e,t)=>t.created-e.created)),0===t.length)return null;return(await L({type:"select",name:"selectedProject",message:"Select a project:",choices:t})).selectedProject}async function ot(e){const t=await nt("code --version"),o=await nt("code-insiders --version");let n=null;if(t&&o){const e=await L({type:"select",name:"ide",message:"Which IDE would you like to use?",choices:[{name:"Visual Studio Code",value:"code"},{name:"Visual Studio Code Insiders",value:"code-insiders"}]});n=e.ide}else if(t)n="code";else{if(!o)return console.log(s.yellow("No supported IDE found. Please open the project manually.")),void console.log(s.blue(`Project path: ${e}`));n="code-insiders"}console.log(s.blue(`Opening project in ${n}...`)),console.log(s.blue(`Project path: ${e}`));const i=c(n,[e],{stdio:"inherit",shell:!0});return new Promise(((e,t)=>{i.on("close",(o=>{0===o?(console.log(s.green(`Project opened in ${n}.`)),e()):(console.error(s.red(`Failed to open project in ${n}.`)),t(new Error(`Process exited with code ${o}`)))}))}))}async function nt(e){return new Promise((t=>{c(e,{shell:!0,stdio:"ignore"}).on("close",(e=>{t(0===e)}))}))}function it(t,o){l.existsSync(o)||l.mkdirSync(o,{recursive:!0});const n=l.readdirSync(t,{withFileTypes:!0});for(const i of n){const n=e.join(t,i.name),s=e.join(o,i.name);if(i.isDirectory()){if(".git"===i.name||".workspace"===i.name)continue;it(n,s)}else l.copyFileSync(n,s)}}const st=e.dirname(n(import.meta.url));const rt=e.dirname(n(import.meta.url)),at=process.cwd();process.on("uncaughtException",(e=>{W||(W=!0,setTimeout((()=>process.exit(1)),500))})),process.on("unhandledRejection",(e=>{W||(W=!0,setTimeout((()=>process.exit(1)),500))})),function(){d({name:["redis"],dir:at,optional:!0});const t=function({baseDir:t}){let o=t=t||st;for(;o!==e.parse(o).root;){const t=e.join(o,"node_modules");if(l.existsSync(t))return t;o=e.dirname(o)}return null}({baseDir:rt}),o="win32"===process.platform?";":":";t&&(process.env.PATH=`${e.join(t,"/.bin")}${o}${process.env.PATH}`)}(),async function(){try{let t=i(process.argv.slice(2)).usage("Usage: $0 <command> [options]").command(Q).command(te).command(Ue).command(Ve).command(Xe).command(He).command("express","Create and manage express projects",Qe);t=q(t,{bin:"npm"}),t=q(t,{bin:"node"}),t=q(t,{bin:"bun"}),t=q(t,{name:"serve",bin:"bun",preArgs:["run","serve","--"]}),t=q(t,{name:"watch",bin:"bun",preArgs:["run","watch","--"]}),t=q(t,{name:"app",bin:"bun",preArgs:["run","app","--"]}),t=q(t,{name:"cli",bin:"bun",preArgs:["run","cli","--"]}),t=q(t,{name:"compile",bin:"bun",preArgs:["run","compile","--"]}),t=function(t,{name:o}){return t.command(`${o} [options]`,"Install the project as a binary",(e=>e.option("name",{alias:"n",describe:"Name to use for the installed binary",type:"string"}).option("force",{alias:"f",describe:"Force overwrite if binary already exists",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Automatically answer yes to all prompts",type:"boolean",default:!1})),(async t=>{try{const o=await U(t),{projectDir:n}=o;console.log(s.blue("Compiling project..."));const i=e.join(n,".bin");l.existsSync(i)||l.mkdirSync(i,{recursive:!0});const r=e.basename(e.dirname(n)),a=o.project?.projectFileParsed?.features?.cli?.bin,c=t.name||a||r;console.log(s.blue(`Using binary name: ${c}`));const p=e.join(i,c),{spawn:d}=await import("child_process"),f=d("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${p}`],{cwd:n,stdio:"inherit",shell:!0});await new Promise(((e,t)=>{f.on("close",(o=>{0===o?e():t(new Error(`Compilation failed with code ${o}`))})),f.on("error",(e=>{t(e)}))})),"win32"!==process.platform&&l.chmodSync(p,493),console.log(s.green(`Binary compiled successfully: ${p}`)),console.log(s.blue("Installing binary..."));const m=["install",p];t.name&&m.push("--name",t.name),t.force&&m.push("--force"),t.yes&&m.push("--yes");const u=d("fbin",m,{stdio:"inherit",shell:!0});await new Promise(((e,t)=>{u.on("close",(o=>{0===o?e():t(new Error(`Installation failed with code ${o}`))})),u.on("error",(e=>{t(e)}))}))}catch(e){console.error(s.red(`Failed to install binary: ${e.message}`)),process.exit(1)}}))}(t,{name:"install"}),t=q(t,{bin:"npx"}),t=q(t,{bin:"cdk"}),t=q(t,{bin:"aws"}),t=function(e,{name:t,preArgs:o=[]}){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 U(e),{projectDir:n}=t,i=e.config,s=await d({name:i,dir:n,transferEnv:!1,optional:!0,tags:t.tags}),r=s?.data?.env||void 0,a=e.command,p=process.argv.slice(5);G(c(a,[...o,...p],{cwd:l.existsSync(n)?n:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...r}}))}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"with"}),t=function(e,{name:t,projectType:o="auto"}){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{runCommandGroup:t}=await import("./index.DrwlOzAe.js");await t({projectType:o,group:e.group,tags:e.ftag,args:e,argv:process.argv})}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"run",projectType:"fnet"}),t.demandCommand(1,"You need at least one command before moving on").help().version().argv}catch(e){console.error(s.red(`Fatal error: ${e.message}`)),process.exit(1)}}().catch((e=>{console.error(s.red(`Fatal error: ${e.message}`)),process.exit(1)}));export{Y as r,V as w};
@@ -1 +1 @@
1
- import e from"node:fs";import t from"node:path";import a from"nunjucks";import i from"@flownet/lib-parse-imports-js";import s from"@flownet/lib-parse-node-url";import{B as r,c as o,a as n}from"./index.BlhtGEKB.js";import p from"lodash.merge";import{i as l,a as c,b as d,c as m,d as f,p as u,e as h,g as _,h as y,j as b,k as x,l as g,m as j,r as w}from"./index.CLPC6OJN.js";import v from"@fnet/npm-list-versions";import"node:crypto";import"yaml";import"chalk";import"@flownet/lib-atom-api-js";import"@fnet/config";import"@fnet/list-files";import"redis";import"@flownet/lib-is-redis-online";import"@fnet/yaml";import"@flownet/lib-render-templates-dir";import"@fnet/npm-pick-versions";import"object-hash";import"ajv/dist/2020.js";import"ajv/dist/standalone/index.js";import"ajv-formats";import"@fnet/shelljs";import"./index.js";import"node:url";import"yargs";import"node:util";import"tree-kill";import"node:child_process";import"node:os";import"@fnet/prompt";import"fs";import"path";import"@fnet/shell-flow";function k({dir:a,name:i="index"}){let s=t.resolve(a,`./${i}.tsx`);if(e.existsSync(s)||(s=t.resolve(a,`./${i}.ts`)),e.existsSync(s)||(s=t.resolve(a,`./${i}.jsx`)),e.existsSync(s)||(s=t.resolve(a,`./${i}.js`)),!e.existsSync(s))return{};const r=s,o=t.extname(s);return{file:r,ext:o,ts:".ts"===o||".tsx"===o,name:i}}class D extends r{async initRuntime(){await async function({atom:e,context:a,setProgress:s}){await s({message:"Initializing features..."}),e.doc.features=e.doc.features||{};const r=e.doc.features;r.project=r.project||{},r.project.format=r.project.format||r.project_format||"esm",r.project_format=r.project.format,r.dts_enabled=!0===r.dts||void 0!==r.dts&&!1!==r.dts;const o=t.resolve(a.project.projectDir),n=k({dir:t.resolve(o,"./app")});if(n.file){s("Parsing app entry imports...");let e=await i({file:n.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));r.app_uses_jsx=t,r.app_has_entry=!0,e=await i({file:n.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.app_entry_uses_jsx=t,r.app_entry_is_ts=n.ts,r.app_entry_ext=n.ext}const u=k({dir:t.resolve(o,"./cli")});if(u.file){s("Parsing cli entry imports...");let e=await i({file:u.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));r.cli_uses_jsx=t,r.cli_has_entry=!0,e=await i({file:u.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.cli_entry_uses_jsx=t,r.cli_entry_is_ts=u.ts,r.cli_entry_ext=u.ext}if("workflow.lib"===e.type){const e=k({dir:t.resolve(o,"./src")});if(e.file){s("Parsing src entry imports...");let t=await i({file:e.file,recursive:!0}),a=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));r.src_uses_jsx=a,r.src_has_entry=!0,t=await i({file:e.file}),a=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.src_entry_uses_jsx=a,r.src_entry_is_ts=e.ts,r.src_entry_ext=e.ext}}const h=Reflect.has(r,"app_entry_uses_jsx")?!0===r.app_entry_uses_jsx:!0===r.src_entry_uses_jsx,_=Reflect.has(r,"cli_entry_uses_jsx")?!0===r.cli_entry_uses_jsx:!0===r.src_entry_uses_jsx;r.form_enabled=h||_||!0===r.form||!0===r.form?.enabled,r.multiple_enabled=r.multiple_enabled||!0===r.multiple||!0===r.multiple?.enabled,!1===r.app?r.app={enabled:!1}:!0===r.app?r.app={enabled:!0,extend:!0===r.app_has_entry,export:!0,react:h}:r.app={enabled:!0,extend:!0===r.app_has_entry,export:!0,react:h,...r.app||{}},r.app.enabled=!0===r.app.enabled&&(!0===e.doc.features.form_enabled||!0===r.app.extend||!0===r.app.enabled),r.app.format=r.app.format||"esm",r.app.folder=r.app.folder||r.app.format||"esm",r.app.dir=`./dist/app/${r.app.folder}`,r.app.html=!1!==r.app.html,!1===r.cli?r.cli={enabled:!1}:!0===r.cli?r.cli={enabled:!0,extend:!0===r.cli_has_entry,export:!0,react:_}:r.cli={enabled:!0,extend:!0===r.cli_has_entry,export:!0,react:_,...r.cli||{}},r.cli.enabled=!0===r.cli.enabled&&(!1===e.doc.features.form_enabled||!0===r.cli.extend||!0===r.cli.enabled),r.cli.format=r.cli.format||"esm",r.cli.folder=r.cli.folder||r.cli.folder||"esm",r.cli.dir=`./dist/cli/${r.cli.folder}`,r.cli.node_options=r.cli.node?.options||r.cli.node_options||"",r.json=r.cli.enabled||r.json,r.bun=r.bun||{},r.bun.build=r.bun.build||{};const y={default:{format:"esm",target:"browser",minify:!1,sourcemap:"external",entrypoints:["./src/default/index.js"],outdir:"./dist/default/esm"},defaultCjs:{format:"cjs",target:"node",minify:!1,sourcemap:"external",entrypoints:["./src/default/index.js"],outdir:"./dist/default/cjs"}};r.cli.enabled&&(y.cli={format:"esm",target:"node",minify:!1,sourcemap:"external",entrypoints:["./src/cli/index.js"],outdir:r.cli.dir}),r.app.enabled&&(y.app={format:"esm",target:"browser",minify:!1,sourcemap:"external",entrypoints:["./src/app/index.js"],outdir:r.app.dir}),r.bun.build=p(y,r.bun.build||{}),r.preact_enabled=!0===r.preact||r.preact&&!1!==r.preact?.enabled,r.dependency_auto_enabled=!1!==r.dependency_auto&&!1!==r.dependency_auto?.enabled,r.npm_install_flags=r.npm_install_flags||"",r.react_version=r.react_version||r.react?.version||18,r.runtime=r.runtime||{},r.runtime.type="bun",r.runtime.template="bun",l({atom:e}),c({atom:e}),d({atom:e}),m({atom:e}),f({atom:e})}(this.apiContext),await async function({atom:e,packageDependencies:t,packageDevDependencies:a,setProgress:i}){i("Initializing dependencies for Bun");const s=e.doc.dependencies||[];if(s.filter((e=>!e.dev)).forEach((e=>t.push(e))),s.filter((e=>e.dev)).forEach((e=>a.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let a="^18.2";i("Fetching React versions"),a=`^${(await v({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:a}),t.push({package:"react-dom",version:a}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),a.push({package:"ajv",version:"^8"}),e.doc.features.cli.fargs&&!1!==e.doc.features.cli.fargs?.enabled&&t.push({package:"@fnet/config",version:"0.2.21"})),e.doc.features.render&&!1!==e.doc.features.render.enabled&&a.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}(this.apiContext),await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}async initLibs(){this.setProgress({message:"Initializing external libs."});const e=[{name:this.atom.doc.name,type:"atom",parent_id:this.atom.parent_id}];this.libs=e,await this.initAtomLibsAndDeps({libs:e,packageDependencies:this.apiContext.packageDependencies})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const a=e.filter((e=>"atom"===e.type));for(let e=0;e<a.length;e++){const i=a[e],s=await this.findAtomLibrary({url:i.name});i.atom=s;const r=s.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));r?.forEach((e=>{const a=t.find((t=>t.package===e.package));a?"string"==typeof e.path?(a.path||[]).some((t=>t===e.path))||(a.path=a.path||[],a.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(a.path||[]).some((t=>t===e))||(a.path=a.path||[],a.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const a=s({url:e});if(!a)throw new Error(`Invalid package name: ${e}`);if(a.protocol||(a.protocol=this.context.protocol),"ac:"===a.protocol){const t=a.pathname.split("/");if(1===t.length)return await this.apiContext.Atom.first({where:{name:e,parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===t.length){const e=await this.apiContext.Atom.first({where:{name:t[0],parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"folder"}});return await this.apiContext.Atom.first({where:{name:t[1],parent_id:e.id,type:"workflow.lib"}})}}else if("local:"===a.protocol){const e=this.atom;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const a=t.resolve(this.context.projectSrcDir,"index.js"),s=await i({file:a,recursive:!0}),r=e.doc.dependencies,o=s.all;for await(const e of o){if("npm"!==e.type)continue;if(r.find((t=>t.package===e.package)))continue;const t=await u({name:e.package,projectDir:this.context.projectDir,setProgress:this.apiContext.setProgress});r.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return e}}async createAtomLibFiles({libs:a}){await this.setProgress({message:"Creating external lib files."}),this.atom.typesDir="./types";const i=a.filter((e=>"atom"===e.type));for(let a=0;a<i.length;a++){const s=i[a].atom,r=this.context.projectDir;if("local:"===s.protocol){const a=t.resolve(this.context.projectSrcDir,`${s.fileName||s.name}.js`),i=t.relative(t.join(this.context.projectDir,"src","default"),a);if(!e.existsSync(a)){e.mkdirSync(t.dirname(a),{recursive:!0});let i="export default async (args)=>{\n";i+="}",e.writeFileSync(a,i,"utf8")}s.relativePath=i.split(t.sep).join("/"),this.atom.typesDir=`./types/${t.basename(r)}/src`}else{const a=t.join(r,"src","libs",`${s.id}.js`),i=s.doc.contents?.find((e=>"esm"===e.format))||s.doc;e.writeFileSync(a,i.content,"utf8")}}}async createEngine(){await this.setProgress({message:"Creating engine file."});const i={libs:this.libs.filter((e=>"atom"===e.type)),libraryAtom:this.atom,atom:this.atom},s=this.context.templateDir,r=a.compile(e.readFileSync(t.resolve(s,t.join("src","default","engine.js.njk")),"utf8"),this.apiContext.njEnv).render(i),o=this.context.projectDir,n=t.resolve(o,t.join("src","default","index.js"));e.writeFileSync(n,r,"utf8")}async build(){try{this.fileMode&&(await this.createAtomLibFiles({libs:this.libs}),await this.createEngine(),await this.createProjectYaml(),await o(this.apiContext),await h(this.apiContext),await n(this.apiContext),await _(this.apiContext),await y(this.apiContext),await b(this.apiContext),await async function({atom:i,setProgress:s,context:r,packageDependencies:o}){await s({message:"Creating build.js file."});const n={atom:i,packageDependencies:o},p=r.templateDir,l=a.compile(e.readFileSync(t.resolve(p,"build.js.njk"),"utf8"),a.configure(p)).render(n),c=r.projectDir,d=t.resolve(c,"build.js");e.writeFileSync(d,l,"utf8"),e.chmodSync(d,"755")}(this.apiContext),await x(this.apiContext),await g(this.apiContext),this.buildMode&&(await j(this.apiContext),await w(this.apiContext),this.deployMode&&await this.deploy())),await this._cache_set(this.buildKey,{status:"COMPLETED"})}catch(e){throw await this._cache_set(this.buildKey,{status:"FAILED",message:e.message||e}),console.log(e),e}}}export{D as default};
1
+ import e from"node:fs";import t from"node:path";import a from"nunjucks";import i from"@flownet/lib-parse-imports-js";import s from"@flownet/lib-parse-node-url";import{B as r,c as o,a as n}from"./index.DIZA_GzC.js";import p from"lodash.merge";import{i as l,a as c,b as d,c as m,d as f,p as u,e as h,g as _,h as y,j as b,k as x,l as g,m as j,r as w}from"./index.Dg0hAD29.js";import v from"@fnet/npm-list-versions";import"node:crypto";import"yaml";import"chalk";import"@flownet/lib-atom-api-js";import"@fnet/config";import"@fnet/list-files";import"redis";import"@flownet/lib-is-redis-online";import"@fnet/yaml";import"@flownet/lib-render-templates-dir";import"@fnet/npm-pick-versions";import"object-hash";import"ajv/dist/2020.js";import"ajv/dist/standalone/index.js";import"ajv-formats";import"@fnet/shelljs";import"./index.js";import"node:url";import"yargs";import"node:util";import"tree-kill";import"node:child_process";import"node:os";import"@fnet/prompt";import"fs";import"path";import"@fnet/shell-flow";function k({dir:a,name:i="index"}){let s=t.resolve(a,`./${i}.tsx`);if(e.existsSync(s)||(s=t.resolve(a,`./${i}.ts`)),e.existsSync(s)||(s=t.resolve(a,`./${i}.jsx`)),e.existsSync(s)||(s=t.resolve(a,`./${i}.js`)),!e.existsSync(s))return{};const r=s,o=t.extname(s);return{file:r,ext:o,ts:".ts"===o||".tsx"===o,name:i}}class D extends r{async initRuntime(){await async function({atom:e,context:a,setProgress:s}){await s({message:"Initializing features..."}),e.doc.features=e.doc.features||{};const r=e.doc.features;r.project=r.project||{},r.project.format=r.project.format||r.project_format||"esm",r.project_format=r.project.format,r.dts_enabled=!0===r.dts||void 0!==r.dts&&!1!==r.dts;const o=t.resolve(a.project.projectDir),n=k({dir:t.resolve(o,"./app")});if(n.file){s("Parsing app entry imports...");let e=await i({file:n.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));r.app_uses_jsx=t,r.app_has_entry=!0,e=await i({file:n.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.app_entry_uses_jsx=t,r.app_entry_is_ts=n.ts,r.app_entry_ext=n.ext}const u=k({dir:t.resolve(o,"./cli")});if(u.file){s("Parsing cli entry imports...");let e=await i({file:u.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));r.cli_uses_jsx=t,r.cli_has_entry=!0,e=await i({file:u.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.cli_entry_uses_jsx=t,r.cli_entry_is_ts=u.ts,r.cli_entry_ext=u.ext}if("workflow.lib"===e.type){const e=k({dir:t.resolve(o,"./src")});if(e.file){s("Parsing src entry imports...");let t=await i({file:e.file,recursive:!0}),a=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));r.src_uses_jsx=a,r.src_has_entry=!0,t=await i({file:e.file}),a=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.src_entry_uses_jsx=a,r.src_entry_is_ts=e.ts,r.src_entry_ext=e.ext}}const h=Reflect.has(r,"app_entry_uses_jsx")?!0===r.app_entry_uses_jsx:!0===r.src_entry_uses_jsx,_=Reflect.has(r,"cli_entry_uses_jsx")?!0===r.cli_entry_uses_jsx:!0===r.src_entry_uses_jsx;r.form_enabled=h||_||!0===r.form||!0===r.form?.enabled,r.multiple_enabled=r.multiple_enabled||!0===r.multiple||!0===r.multiple?.enabled,!1===r.app?r.app={enabled:!1}:!0===r.app?r.app={enabled:!0,extend:!0===r.app_has_entry,export:!0,react:h}:r.app={enabled:!0,extend:!0===r.app_has_entry,export:!0,react:h,...r.app||{}},r.app.enabled=!0===r.app.enabled&&(!0===e.doc.features.form_enabled||!0===r.app.extend||!0===r.app.enabled),r.app.format=r.app.format||"esm",r.app.folder=r.app.folder||r.app.format||"esm",r.app.dir=`./dist/app/${r.app.folder}`,r.app.html=!1!==r.app.html,!1===r.cli?r.cli={enabled:!1}:!0===r.cli?r.cli={enabled:!0,extend:!0===r.cli_has_entry,export:!0,react:_}:r.cli={enabled:!0,extend:!0===r.cli_has_entry,export:!0,react:_,...r.cli||{}},r.cli.enabled=!0===r.cli.enabled&&(!1===e.doc.features.form_enabled||!0===r.cli.extend||!0===r.cli.enabled),r.cli.format=r.cli.format||"esm",r.cli.folder=r.cli.folder||r.cli.folder||"esm",r.cli.dir=`./dist/cli/${r.cli.folder}`,r.cli.node_options=r.cli.node?.options||r.cli.node_options||"",r.json=r.cli.enabled||r.json,r.bun=r.bun||{},r.bun.build=r.bun.build||{};const y={default:{format:"esm",target:"browser",minify:!1,sourcemap:"external",entrypoints:["./src/default/index.js"],outdir:"./dist/default/esm"},defaultCjs:{format:"cjs",target:"node",minify:!1,sourcemap:"external",entrypoints:["./src/default/index.js"],outdir:"./dist/default/cjs"}};r.cli.enabled&&(y.cli={format:"esm",target:"node",minify:!1,sourcemap:"external",entrypoints:["./src/cli/index.js"],outdir:r.cli.dir}),r.app.enabled&&(y.app={format:"esm",target:"browser",minify:!1,sourcemap:"external",entrypoints:["./src/app/index.js"],outdir:r.app.dir}),r.bun.build=p(y,r.bun.build||{}),r.preact_enabled=!0===r.preact||r.preact&&!1!==r.preact?.enabled,r.dependency_auto_enabled=!1!==r.dependency_auto&&!1!==r.dependency_auto?.enabled,r.npm_install_flags=r.npm_install_flags||"",r.react_version=r.react_version||r.react?.version||18,r.runtime=r.runtime||{},r.runtime.type="bun",r.runtime.template="bun",l({atom:e}),c({atom:e}),d({atom:e}),m({atom:e}),f({atom:e})}(this.apiContext),await async function({atom:e,packageDependencies:t,packageDevDependencies:a,setProgress:i}){i("Initializing dependencies for Bun");const s=e.doc.dependencies||[];if(s.filter((e=>!e.dev)).forEach((e=>t.push(e))),s.filter((e=>e.dev)).forEach((e=>a.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let a="^18.2";i("Fetching React versions"),a=`^${(await v({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:a}),t.push({package:"react-dom",version:a}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),a.push({package:"ajv",version:"^8"}),e.doc.features.cli.fargs&&!1!==e.doc.features.cli.fargs?.enabled&&t.push({package:"@fnet/config",version:"0.2.21"}),e.doc.features.cli.mcp&&!0===e.doc.features.cli.mcp.enabled&&t.push({package:"@modelcontextprotocol/sdk",version:"^1.10"})),e.doc.features.render&&!1!==e.doc.features.render.enabled&&a.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}(this.apiContext),await this.initLibraryDir(),await this.initNunjucks(),await this.initLibs()}async initLibs(){this.setProgress({message:"Initializing external libs."});const e=[{name:this.atom.doc.name,type:"atom",parent_id:this.atom.parent_id}];this.libs=e,await this.initAtomLibsAndDeps({libs:e,packageDependencies:this.apiContext.packageDependencies})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const a=e.filter((e=>"atom"===e.type));for(let e=0;e<a.length;e++){const i=a[e],s=await this.findAtomLibrary({url:i.name});i.atom=s;const r=s.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));r?.forEach((e=>{const a=t.find((t=>t.package===e.package));a?"string"==typeof e.path?(a.path||[]).some((t=>t===e.path))||(a.path=a.path||[],a.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(a.path||[]).some((t=>t===e))||(a.path=a.path||[],a.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e}){const a=s({url:e});if(!a)throw new Error(`Invalid package name: ${e}`);if(a.protocol||(a.protocol=this.context.protocol),"ac:"===a.protocol){const t=a.pathname.split("/");if(1===t.length)return await this.apiContext.Atom.first({where:{name:e,parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===t.length){const e=await this.apiContext.Atom.first({where:{name:t[0],parent_id:this.atomConfig.env.ATOM_LIBRARIES_ID,type:"folder"}});return await this.apiContext.Atom.first({where:{name:t[1],parent_id:e.id,type:"workflow.lib"}})}}else if("local:"===a.protocol){const e=this.atom;e.protocol="local:",e.doc.dependencies=e.doc.dependencies||[],e.name=e.doc.name;const a=t.resolve(this.context.projectSrcDir,"index.js"),s=await i({file:a,recursive:!0}),r=e.doc.dependencies,o=s.all;for await(const e of o){if("npm"!==e.type)continue;if(r.find((t=>t.package===e.package)))continue;const t=await u({name:e.package,projectDir:this.context.projectDir,setProgress:this.apiContext.setProgress});r.push({package:e.package,subpath:e.subpath,version:t.minorRange,type:"npm"})}return e}}async createAtomLibFiles({libs:a}){await this.setProgress({message:"Creating external lib files."}),this.atom.typesDir="./types";const i=a.filter((e=>"atom"===e.type));for(let a=0;a<i.length;a++){const s=i[a].atom,r=this.context.projectDir;if("local:"===s.protocol){const a=t.resolve(this.context.projectSrcDir,`${s.fileName||s.name}.js`),i=t.relative(t.join(this.context.projectDir,"src","default"),a);if(!e.existsSync(a)){e.mkdirSync(t.dirname(a),{recursive:!0});let i="export default async (args)=>{\n";i+="}",e.writeFileSync(a,i,"utf8")}s.relativePath=i.split(t.sep).join("/"),this.atom.typesDir=`./types/${t.basename(r)}/src`}else{const a=t.join(r,"src","libs",`${s.id}.js`),i=s.doc.contents?.find((e=>"esm"===e.format))||s.doc;e.writeFileSync(a,i.content,"utf8")}}}async createEngine(){await this.setProgress({message:"Creating engine file."});const i={libs:this.libs.filter((e=>"atom"===e.type)),libraryAtom:this.atom,atom:this.atom},s=this.context.templateDir,r=a.compile(e.readFileSync(t.resolve(s,t.join("src","default","engine.js.njk")),"utf8"),this.apiContext.njEnv).render(i),o=this.context.projectDir,n=t.resolve(o,t.join("src","default","index.js"));e.writeFileSync(n,r,"utf8")}async build(){try{this.fileMode&&(await this.createAtomLibFiles({libs:this.libs}),await this.createEngine(),await this.createProjectYaml(),await o(this.apiContext),await h(this.apiContext),await n(this.apiContext),await _(this.apiContext),await y(this.apiContext),await b(this.apiContext),await async function({atom:i,setProgress:s,context:r,packageDependencies:o}){await s({message:"Creating build.js file."});const n={atom:i,packageDependencies:o},p=r.templateDir,l=a.compile(e.readFileSync(t.resolve(p,"build.js.njk"),"utf8"),a.configure(p)).render(n),c=r.projectDir,d=t.resolve(c,"build.js");e.writeFileSync(d,l,"utf8"),e.chmodSync(d,"755")}(this.apiContext),await x(this.apiContext),await g(this.apiContext),this.buildMode&&(await j(this.apiContext),await w(this.apiContext),this.deployMode&&await this.deploy())),await this._cache_set(this.buildKey,{status:"COMPLETED"})}catch(e){throw await this._cache_set(this.buildKey,{status:"FAILED",message:e.message||e}),console.log(e),e}}}export{D as default};