@fnet/cli 0.129.2 → 0.130.2

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.
@@ -0,0 +1 @@
1
+ import e from"node:fs";import t from"node:path";import a from"nunjucks";import s from"@flownet/lib-parse-imports-js";import o from"@flownet/lib-parse-node-url";import{B as n,c as r,a as i}from"./index.BTXKZRR5.js";import p from"lodash.merge";import c from"@fnet/npm-list-versions";import l from"@flownet/lib-render-templates-dir";import u from"@fnet/npm-pick-versions";import d from"object-hash";import f from"ajv/dist/2020.js";import m from"ajv/dist/standalone/index.js";import g from"ajv-formats";import b from"@fnet/shelljs";import{w as h}from"./index.js";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"yargs";import"node:util";import"tree-kill";import"node:url";import"node:child_process";import"node:os";import"@fnet/prompt";function y({feature:e,features:t,packageDevDependencies:a}){const{name:s,packages:o,options:n,extraCheck:r,explicit:i}=e,c=`${s}_enabled`,l=t.rollup_output||{},u=Object.keys(l);let d=n||{};const f=t[s]?.options;f&&(d=p(d,f));const m=!t[s]||!1===t[s]?.enabled;u.forEach((e=>{const a=t.rollup_output[e];if(a){if(Reflect.has(a,s)){if(m||!a[s]||!1===a[s]?.enabled)return void delete a[s];!0===a[s]&&(a[s]={enabled:!0,options:d})}else{if(m||i||!1===t[c])return;a[s]={enabled:!0}}a[s]=a[s]||{},a[s].options={...d,...a[s].options}}}));let g=u.some((e=>!0===t.rollup_output[e][s]?.enabled));r&&(g=r()&&g),t[c]=g,g&&o.forEach((e=>a.push({package:e[0],version:e[1]})))}function w({dir:a,name:s="index"}){let o=t.resolve(a,`./${s}.tsx`);if(e.existsSync(o)||(o=t.resolve(a,`./${s}.ts`)),e.existsSync(o)||(o=t.resolve(a,`./${s}.jsx`)),e.existsSync(o)||(o=t.resolve(a,`./${s}.js`)),!e.existsSync(o))return{};const n=o,r=t.extname(o);return{file:n,ext:r,ts:".ts"===r||".tsx"===r,name:s}}async function k(e){const{atom:a,context:o,setProgress:n}=e;n("Initializing features..."),a.doc.features=a.doc.features||{};const r=a.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 i=t.resolve(o.project.projectDir),c=w({dir:t.resolve(i,"./app")});if(c.file){n("Parsing app entry imports...");let e=await s({file:c.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 s({file:c.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.app_entry_uses_jsx=t,r.app_entry_is_ts=c.ts,r.app_entry_ext=c.ext}const l=w({dir:t.resolve(i,"./cli")});if(l.file){n("Parsing cli entry imports...");let e=await s({file:l.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 s({file:l.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),r.cli_entry_uses_jsx=t,r.cli_entry_is_ts=l.ts,r.cli_entry_ext=l.ext}if("workflow.lib"===a.type){const e=w({dir:t.resolve(i,"./src")});if(e.file){n("Parsing src entry imports...");let t=await s({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 s({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 u=Reflect.has(r,"app_entry_uses_jsx")?!0===r.app_entry_uses_jsx:!0===r.src_entry_uses_jsx,d=Reflect.has(r,"cli_entry_uses_jsx")?!0===r.cli_entry_uses_jsx:!0===r.src_entry_uses_jsx;r.form_enabled=u||d||!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:u}:r.app={enabled:!0,extend:!0===r.app_has_entry,export:!0,react:u,...r.app||{}},r.app.enabled=!0===r.app.enabled&&(!0===a.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||"default",!1===r.cli?r.cli={enabled:!1}:!0===r.cli?r.cli={enabled:!0,extend:!0===r.cli_has_entry,export:!0,react:d}:r.cli={enabled:!0,extend:!0===r.cli_has_entry,export:!0,react:d,...r.cli||{}},r.cli.enabled=!0===r.cli.enabled&&(!1===a.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.node_options=r.cli.node?.options||r.cli.node_options||"",r.cli.bin=r.cli.bin||a.doc.name,r.cli.installable=!0===r.cli.installable,r.cli.enabled&&(a.doc["npm::bin"]=r.cli.bin),r.json=r.cli.enabled||r.json;const f={cjs:{format:"cjs",context:r.form_enabled?"window":"global",babel:!0===r.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!1!==r.cjs,copy:!1},esm:{format:"esm",context:r.form_enabled?"window":"global",babel:!0===r.src_uses_jsx||!1,browser:!1,replace:!0,terser:!1,enabled:!1!==r.esm,copy:!0},iife:{format:"iife",context:r.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!0===r.iife,terser:!0,copy:!1}};!0===r.webos&&(f.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===r.electron&&(f.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===r.nextjs&&(f.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===r.ios&&(f.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===r.macos&&(f.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===r.app.enabled&&(r.app.dir=`./dist/app/${r.app.folder}`,r.app.output={file:`./dist/app/${r.app.folder}/index.js`,dir:`./dist/app/${r.app.folder}/`,...r.app.output||{}},r.app.input={file:"./src/app/index.js",dir:"./src/app/",...r.app.input||{}},f.app={format:r.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:r.app.input.file,output_dir:r.app.dir,terser:!0,output_exports:!1===r.app.export?"none":"auto",browsersync:!0}),!0===r.cli.enabled&&(r.cli.dir=`./dist/cli/${r.cli.folder}`,r.cli.output={file:`./dist/cli/${r.cli.folder}/index.js`,dir:`./dist/cli/${r.cli.folder}/`,...r.cli.output||{}},r.cli.input={file:"./src/cli/index.js",dir:"./src/cli/",...r.cli.input||{}},f.cli={format:r.cli.format,context:"global",babel:!0===r.src_uses_jsx||!0===r.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:r.cli.input.file,output_dir:r.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===r.cli.export?"none":"auto"});const m={server:".",startPath:`${t.normalize(r.app.dir||".")}`,files:[t.normalize("./dist/**/*")],cors:!0,open:!1};r.babel_options=p({targets:{browsers:"last 9 versions, not dead",node:"18"}},r.babel_options||r.babel?.options),r.browsersync_options=p(m,r.browsersync_options||r.browsersync?.options||{}),r.replace_options=p({},r.replace_options||r.replace?.options||{}),Reflect.has(r.browsersync_options,"proxy")&&delete r.browsersync_options.server,r.rollup=r.rollup||{},r.rollup_output=p(f,r.rollup_output||r.rollup?.output||{}),r.preact_enabled=!0===r.preact||r.preact&&!1!==r.preact?.enabled;let g=Object.keys(f);for(const e of g){const t=f[e];t&&(!1!==r.rollup[e]?(t.babel_options=t.babel_options||r.babel_options,t.browsersync_options=p(r.browsersync_options,t.browsersync_options),t.replace_options=p(r.replace_options,t.replace_options),r.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"),(r.form_enabled||r.babel)&&(t.babel=!0)):delete r.rollup_output[e])}g=Object.keys(r.rollup_output),r.babel_enabled=g.some((e=>!0===r.rollup_output[e].babel)),r.browser_enabled=g.some((e=>!0===r.rollup_output[e].babel)),r.browsersync_enabled=!1!==r.browsersync&&g.some((e=>!0===r.rollup_output[e].browsersync)),r.browsersync_enabled=r.browsersync_enabled&&r.app.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,function(e){const{atom:t,packageDevDependencies:a}=e,s=t.doc.features,o=s.css&&!1!==s.css.enabled;let n=[];o&&(n.push(["rollup-plugin-postcss","^4"]),n.push(["sass","^1.66"]),(s.css?.options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":n.push(["postcss-import","^15"]);break;case"postcss-url":n.push(["postcss-url","^10"]);break;case"postcss-preset-env":n.push(["postcss-preset-env","^9"]);break;case"autoprefixer":n.push(["autoprefixer","^10"]);break;case"cssnano":n.push(["cssnano","^6"])}})));y({feature:{name:"css",packages:n},features:s,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e,s=t.doc.features;if("bun"===s.runtime.type)return;const o={};!0===s.app?.enabled&&(o.targets=o.targets||[],o.targets.push({src:"./src/app/index.html",dest:s.app.dir}),Reflect.has(s.app,"copy")||Reflect.has(s,"copy")||(s.copy=!0)),y({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:o},features:s,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e,s=t.doc.features;"bun"!==s.runtime.type&&y({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:s,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]]},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:t.doc.features,packageDevDependencies:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({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:a})}(e),function(e){const{atom:t,packageDevDependencies:a}=e;y({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:t.doc.features,packageDevDependencies:a})}(e)}async function v({projectDir:a,name:s,setProgress:o,count:n=1}){let r;const i=d(["npm-pick-versions",s,n]),p=t.join(a,".cache"),c=t.join(p,i+".json");return e.existsSync(c)?(o&&o(`Picking npm version of ${s} from cache ...`),r=JSON.parse(e.readFileSync(c,"utf8"))):(o&&o(`Picking npm version of ${s} ...`),r=await u({name:s,count:n}),e.mkdirSync(p,{recursive:!0}),e.writeFileSync(c,JSON.stringify(r),"utf8")),r}class _ extends n{async initRuntime(){await k(this.apiContext);"bun"===this.apiContext.context.project.runtime.type?await async function({atom:e,packageDependencies:t,packageDevDependencies:a,setProgress:s}){s("Initializing dependencies for Bun");const o=e.doc.dependencies||[];if(o.filter((e=>!e.dev)).forEach((e=>t.push(e))),o.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";s("Fetching React versions"),a=`^${(await c({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"}),t.push({package:"yargs-parser",version:"^22.0"}),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"}),t.push({package:"express",version:"^4.18"}))),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 async function({atom:e,packageDependencies:t,packageDevDependencies:a,setProgress:s}){s("Initializing dependencies");const o=e.doc.dependencies||[];if(o.filter((e=>!e.dev)).forEach((e=>t.push(e))),o.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";s("Fetching React versions"),a=`^${(await c({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"}),t.push({package:"yargs-parser",version:"^22.0"}),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"}),t.push({package:"express",version:"^4.18"}))),e.doc.features.render&&!1!==e.doc.features.render.enabled&&a.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"}),a.push({package:"@babel/core",version:"^7"}),a.push({package:"@rollup/plugin-commonjs",version:"^28"}),a.push({package:"@rollup/plugin-node-resolve",version:"^16"}),a.push({package:"@rollup/plugin-replace",version:"^6"}),a.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&a.push({package:"rollup-plugin-dts",version:"^6"}),a.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),a.push({package:"@rollup/plugin-alias",version:"^5"}),a.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(a.push({package:"@rollup/plugin-babel",version:"^6"}),a.push({package:"@babel/preset-env",version:"^7"}),a.push({package:"@babel/preset-react",version:"^7"}),e.doc.features.babel?.options?.plugins?.forEach((e=>{switch(e[0]){case"@babel/plugin-proposal-decorators":a.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":a.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":a.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":a.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":a.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"})}}))),a.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),e.doc.features.browsersync_enabled&&a.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}(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 s=a[e],o=await this.findAtomLibrary({url:s.name});s.atom=o;const n=o.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));n?.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=o({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"),o=await s({file:a,recursive:!0}),n=e.doc.dependencies,r=o.all;for await(const e of r){if("npm"!==e.type)continue;if(n.find((t=>t.package===e.package)))continue;const t=await v({name:e.package,projectDir:this.context.projectDir,setProgress:this.apiContext.setProgress});n.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 s=a.filter((e=>"atom"===e.type));for(let a=0;a<s.length;a++){const o=s[a].atom,n=this.context.projectDir;if("local:"===o.protocol){const a=t.resolve(this.context.projectSrcDir,`${o.fileName||o.name}.js`),s=t.relative(t.join(this.context.projectDir,"src","default"),a);if(!e.existsSync(a)){e.mkdirSync(t.dirname(a),{recursive:!0});let s="export default async (input)=>{\n";s+="}",e.writeFileSync(a,s,"utf8")}o.relativePath=s.split(t.sep).join("/"),this.atom.typesDir=`./types/${t.basename(n)}/src`}else{const a=t.join(n,"src","libs",`${o.id}.js`),s=o.doc.contents?.find((e=>"esm"===e.format))||o.doc;e.writeFileSync(a,s.content,"utf8")}}}async createEngine(){await this.setProgress({message:"Creating engine file."});const s={libs:this.libs.filter((e=>"atom"===e.type)),libraryAtom:this.atom,atom:this.atom},o=this.context.templateDir,n=a.compile(e.readFileSync(t.resolve(o,t.join("src","default","engine.js.njk")),"utf8"),this.apiContext.njEnv).render(s),r=this.context.projectDir,i=t.resolve(r,t.join("src","default","index.js"));e.writeFileSync(i,n,"utf8")}async build(){try{if(this.fileMode){const o=this.apiContext.context.project;await this.createAtomLibFiles({libs:this.libs}),await this.createEngine(),await this.createProjectYaml(),await r(this.apiContext),await async function({atom:s,setProgress:o,context:n,packageDependencies:r}){await o({message:"Creating tsconfig.json."});const i={atom:s,packageDependencies:r},p=n.templateDir,c=a.compile(e.readFileSync(t.resolve(p,"tsconfig.json.njk"),"utf8"),a.configure(p)).render(i),l=n.projectDir,u=t.resolve(l,"tsconfig.json");e.writeFileSync(u,c,"utf8")}(this.apiContext),await i(this.apiContext),await async function({atom:s,setProgress:o,context:n,njEnv:r}){if(!0!==s.doc.features.cli.enabled)return;await o({message:"Creating input args."});let i={};if(i=s.doc.input?s.doc.input:{type:"object",properties:{},required:[]},s.doc.features.cli.fargs&&!1!==s.doc.features.cli.fargs?.enabled){const e=s.doc.features.cli.fargs;Reflect.has(e,"default")&&e.default}const p={imports:[],atom:s},c=n.templateDir,l=a.compile(e.readFileSync(t.resolve(c,"src/default/input.args.js.njk"),"utf8"),r).render(p),u=n.projectDir,d=t.resolve(u,"src/default/input.args.js");e.writeFileSync(d,l,"utf8");const b=new f({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});g(b);const h=b.compile(i),y=m(b,h)+"\nexport { schema31 as schema };";e.writeFileSync(t.resolve(u,"src/default/validate_input.js"),y,"utf8")}(this.apiContext),await async function({atom:a,setProgress:s,context:o,packageDependencies:n}){if(!0!==a.doc.features.cli.enabled)return;await s({message:"Creating cli."});const r={atom:a,packageDependencies:n},i=o.templateDir,p=t.resolve(o.projectDir,"src/cli");e.existsSync(p)||e.mkdirSync(p,{recursive:!0}),await l({pattern:["index.js.njk"],dir:t.resolve(i,"src/cli"),outDir:p,context:r})}(this.apiContext),await async function({atom:a,setProgress:s,context:o,packageDependencies:n}){if(!0!==a.doc.features.app.enabled)return;await s({message:"Creating app folder"});const r={atom:a,packageDependencies:n,ts:Date.now()},i=o.templateDir,p=t.resolve(o.projectDir,"src/app");e.existsSync(p)||e.mkdirSync(p,{recursive:!0});let c=["index.js.njk"];!1!==a.doc.features.app.html&&c.push("index.html.njk"),await l({pattern:c,dir:t.resolve(i,"src/app"),outDir:p,context:r})}(this.apiContext),"bun"===o.runtime.type?await async function({atom:s,setProgress:o,context:n,packageDependencies:r}){await o({message:"Creating build.js file."});const i={atom:s,packageDependencies:r},p=n.templateDir,c=a.compile(e.readFileSync(t.resolve(p,"build.js.njk"),"utf8"),a.configure(p)).render(i),l=n.projectDir,u=t.resolve(l,"build.js");e.writeFileSync(u,c,"utf8"),e.chmodSync(u,"755")}(this.apiContext):await async function({atom:o,setProgress:n,context:r,packageDependencies:i}){await n({message:"Creating rollup file."});const p={atom:o,packageDependencies:i},c=t.resolve(r.projectDir,"src","default/index.js");if(!e.existsSync(c))throw new Error(`Entry file not found: ${c}`);const l=(await s({file:c,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),u=o.doc.features.rollup_output,d=Object.keys(u);for(let e=0;e<d.length;e++){const t=u[d[e]];if(!0===t.browser&&l.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(l.map((e=>({key:e,value:e})))),t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{};for(let e=0;e<l.length;e++){const a=l[e];t.alias.entries[a]=`node:${a}`,t.alias.entries[`node:${a}`]=a}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(l)}}const f=r.templateDir;let m=a.compile(e.readFileSync(t.resolve(f,"rollup.config.mjs.njk"),"utf8"),a.configure(f)).render(p);const g=r.projectDir;let b=t.resolve(g,"rollup.config.mjs");e.writeFileSync(b,m,"utf8")}(this.apiContext),await async function({atom:o,context:n,packageDependencies:r,packageDevDependencies:i,setProgress:p}){await p({message:"Creating package.json."}),r.filter((e=>!0===e.dev)).forEach((e=>{i.find((t=>t.package===e.package))||i.push(e);const t=r.findIndex((t=>t.package===e.package));r.splice(t,1)}));const c=r.find((e=>"react"===e.package)),l=r.find((e=>"react-dom"===e.package));c&&!l?r.push({package:"react-dom",version:c.version}):c&&l&&(l.version=c.version),c&&o.doc.features.react_version>=17&&(r.find((e=>"@emotion/react"===e.package))||r.push({package:"@emotion/react",version:"^11"}),r.find((e=>"@emotion/styled"===e.package))||r.push({package:"@emotion/styled",version:"^11"}));const u=[];!0===o.doc.features.app.enabled&&u.push({file:t.resolve(n.projectDir,"src/app/index.js"),dev:!1!==o.doc.features.app.dev}),!0===o.doc.features.cli.enabled&&u.push({file:t.resolve(n.projectDir,"src/cli/index.js"),dev:!1!==o.doc.features.cli.dev});for await(const t of u){const a=t.file;if(!e.existsSync(a))throw new Error(`App file not found: ${a}`);const o=(await s({file:a,recursive:!0})).all;for await(const e of o){if("npm"!==e.type)continue;if(r.find((t=>t.package===e.package)))continue;if(i.find((t=>t.package===e.package)))continue;const a=await v({name:e.package,projectDir:n.projectDir,setProgress:p});(!0===t.dev?i:r).push({package:e.package,subpath:e.subpath,version:a.minorRange,type:"npm"})}}const d={atom:o,packageDependencies:r,packageDevDependencies:i},f=n.templateDir,m=a.compile(e.readFileSync(t.resolve(f,"package.json.njk"),"utf8"),a.configure(f)).render(d),g=n.projectDir,b=t.resolve(g,"package.json");e.writeFileSync(b,m,"utf8");const h=t.resolve(n.project.projectDir,"fnet");if(e.existsSync(h)){const a=t.resolve(n.projectDir,"fnet");e.existsSync(a)||e.mkdirSync(a);const s=e.readdirSync(h);for(const o of s){const s=t.resolve(h,o);if(!e.lstatSync(s).isFile())continue;const n=t.resolve(a,o);e.copyFileSync(s,n)}}}(this.apiContext),await async function({setProgress:e,context:a}){const s=a.projectDir;await e({message:"Prettifiying source files."});let o=t.join("src","**","*");if(h("bun")){const e=await b(`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:s});if(0!==e.code)throw new Error(e.stderr)}else{const e=await b(`prettier --write ${o} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:s});if(0!==e.code)throw new Error(e.stderr)}}(this.apiContext),await async function({atom:e,setProgress:t,context:a}){if(!e.doc.features.dts_enabled)return;const s=a.projectDir;if(await t({message:"Creating .d.ts"}),0!==(await b("tsc",{cwd:s})).code)throw new Error("Couldnt create .d.ts files.")}(this.apiContext),this.buildMode&&(await async function({setProgress:e,atom:t,context:a}){const s=a.projectDir;if(await e({message:"Installing npm packages."}),h("bun")){if(0!==(await b(`bun install ${t.doc.features.npm_install_flags}`,{cwd:s})).code)throw new Error("Couldnt install npm packages.")}else if(0!==(await b(`npm install ${t.doc.features.npm_install_flags}`,{cwd:s})).code)throw new Error("Couldnt install npm packages.")}(this.apiContext),await async function({setProgress:e,context:t}){const a=t.projectDir;if(await e({message:"Building main project."}),h("bun")){if(0!==(await b(t.dev?"bun run build:dev":"bun run build",{cwd:a})).code)throw new Error("Couldnt build project.")}else if(0!==(await b(t.dev?"npm run build:dev":"npm run build",{cwd:a})).code)throw new Error("Couldnt build project.")}(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{_ as default};
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import e from"yargs";import o from"chalk";import{promisify as t}from"node:util";import n from"tree-kill";import r,{delimiter as i,join as s}from"node:path";import{fileURLToPath as a}from"node:url";import{spawn as c}from"node:child_process";import l,{existsSync as d}from"node:fs";import p from"@fnet/config";import m from"node:os";import u from"@flownet/lib-render-templates-dir";import f from"@fnet/shelljs";import y from"@fnet/yaml";import g from"yaml";import w from"@fnet/prompt";const j=t(n);let b=!1;async function h(e,o){if(b)return;if(b=!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 t="SIGINT"===o?130:"SIGTERM"===o?143:1;process.exit(t)}function v(e){["SIGINT","SIGTERM","SIGQUIT"].forEach((o=>{process.once(o,(async()=>{await h(e,o)}))})),process.on("uncaughtException",(async o=>{await h(e)})),process.on("unhandledRejection",(async o=>{await h(e)})),e.on("close",(e=>{b||process.exit(e)}))}function x(e,{name:o,bin:t,preArgs:n=[]}){return"function"==typeof t&&(t=t()),e.command(`${o||t} [commands..]`,`${t} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const o=await S(e),{projectDir:r}=o,i=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,s=process.argv.slice(3).map(i);v(c(t,[...n,...s],{cwd:r,stdio:"inherit",shell:!0,detached:!0}))}catch(e){console.error(e.message),process.exit(1)}}))}function $(e,{name:o,bin:t,preArgs:n=[]}){return e.command(`${o||t} [commands..]`,`${t} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const i=await S(e),{projectDir:s}=i,a=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,l=process.argv.slice(3).map(a);t=r.join(s,".conda","bin",t||o);v(c(t,[...n,...l],{cwd:s,stdio:"inherit",shell:!0,detached:!0,env:{PYTHONPATH:s}}))}catch(e){console.error(e.message),process.exit(1)}}))}async function S(e){try{const o=process.argv[1].split("/").pop().split(".")[0];if("fnode"===o){const{createContext:o}=await Promise.resolve().then((function(){return F}));return o(e)}if("fnet"===o){const{createContext:o}=await import("./index.UNoFg95r.js");return o(e)}if("frun"===o){const{createContext:o}=await import("./index.CuMyez3E.js");return o(e)}if("fbin"===o){const{createContext:o}=await import("./index.DWpw12No.js");return o(e)}}catch(e){console.warn(`Warning: Could not import context from CLI tool: ${e.message}`)}return{projectDir:process.cwd(),tags:e.ftag}}var P=e=>{const o=process.env.PATH||"",t="win32"===process.platform?(process.env.PATHEXT||".EXE;.CMD;.BAT;.COM").split(";"):[""],n=o.split(i);for(const o of n)for(const n of t){const t=s(o,"win32"===process.platform?e+n:e);if(d(t))return t}return null};const N=r.dirname(a(import.meta.url)),D=process.cwd();function E(e){const o=r.resolve(D,e);if(l.existsSync(o))return o;const t=r.resolve(N,"../..",e);if(l.existsSync(t))return t;throw new Error(`Template path not found: ${e}`)}const I={command:"create",describe:"Create a new fnode project",builder:e=>e.option("name",{type:"string",describe:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node","python","bun"],describe:"Runtime environment"}),handler:async e=>{try{const o=process.cwd(),t=E("./template/fnode/project"),n=r.resolve(o,e.name);l.existsSync(n)||l.mkdirSync(n),await u({dir:t,outDir:n,context:{name:e.name,runtime:e.runtime,platform:m.platform()},copyUnmatchedAlso:!0});let i=await f("fnode build",{cwd:n});if(0!==i.code)throw new Error("Failed to build project.");if(P("git")&&(i=await f("git init --initial-branch=main",{cwd:n}),0!==i.code))throw new Error("Failed to initialize git.");if(P("code")&&e.vscode&&(i=await f(`cd ${n} && code .`),0!==i.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 C(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:E("./template/fnode/node"),projectDir:r.resolve(process.cwd(),`./.output/${e.id}`),tags:e.ftag,dev:e.dev};try{const o=await async function({tags:e}){let o=function(e){const o=r.resolve(e,"node.yaml"),t=r.resolve(e,"fnode.yaml");if(l.existsSync(t))return t;if(l.existsSync(o))try{const n=l.readFileSync(o,"utf8");return l.writeFileSync(t,n,"utf8"),l.unlinkSync(o),console.log(`Migrated node.yaml to fnode.yaml in ${e}`),t}catch(e){return console.error(`Error migrating node.yaml to fnode.yaml: ${e.message}`),o}return t}(process.cwd());if(!l.existsSync(o))throw new Error("fnode.yaml file not found in current directory.");const{raw:t,parsed:n}=await y({file:o,tags:e}),i=r.dirname(o);n.features=n.features||{};const s=n.features;s.runtime=s.runtime||{},s.runtime.type=s.runtime.type||"node","python"===s.runtime.type?s.runtime.template=s.runtime.template||"python":"bun"===s.runtime.type?s.runtime.template=s.runtime.template||"bun":s.runtime.template=s.runtime.template||"node";const a={libraryAtom:{doc:{...n},fileName:"index"},projectDir:i,projectFilePath:o,projectFileContent:t,projectFileParsed:n,runtime:s.runtime};let c=r.resolve(i,"fnet/targets.yaml");if(!l.existsSync(c)&&(c=r.resolve(i,"node.devops.yaml"),l.existsSync(c))){const e=r.resolve(i,"fnet");l.existsSync(e)||l.mkdirSync(e),l.copyFileSync(c,r.resolve(i,"fnet/targets.yaml")),l.unlinkSync(c)}if(l.existsSync(c)){const{raw:o,parsed:t}=await y({file:c,tags:e}),n=g.parseDocument(o);a.devops={filePath:c,fileContent:o,yamlDocument:n,doc:{...t},type:"library.deploy",save:async()=>{l.writeFileSync(a.devops.filePath,n.toString())}}}const d=r.resolve(i,"readme.md");if(l.existsSync(d)){const e=l.readFileSync(d,"utf8");a.readme={filePath:d,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return a}({tags:e.ftag});return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:E(`./template/fnode/${o.runtime.template}`),projectDir:r.resolve(o.projectDir,"./.workspace"),projectSrcDir:r.resolve(o.projectDir,"./src"),project:o,tags:e.ftag,dev:e.dev}}catch(o){return console.warn(`Warning: Could not load project: ${o.message}`),{projectDir:process.cwd(),tags:e.ftag}}}var F=Object.freeze({__proto__:null,createContext:C});const T={command:"project",describe:"Manage fnode project",builder:e=>e.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"}),handler:async e=>{try{const o=E("./template/fnode/project"),t=process.cwd(),n=await C(e);if(e.update){if(await u({dir:o,outDir:t,context:{name:n.project.projectFileParsed.name,runtime:n.project.runtime.type,platform:m.platform()},copyUnmatchedAlso:!0}),0!==(await f("fnode build",{cwd:t})).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 A{static async createBuilder(e){if(!e.project){console.warn("No project provided, defaulting to node runtime");return new(0,(await import("./index.Bi6l2DjU.js")).default)(e)}const o=e.project?.runtime?.type||"node";try{return new(await this.loadBuilderClass(o))(e)}catch(t){console.warn(`Warning: Could not load builder for runtime '${o}'. Falling back to node builder.`),console.warn(`Error: ${t.message}`);return new(0,(await import("./index.Bi6l2DjU.js")).default)(e)}}static async loadBuilderClass(e){switch(e.toLowerCase()){case"node":return(await import("./index.Bi6l2DjU.js")).default;case"python":return(await import("./index.e2SSlEgE.js")).default;case"bun":return(await import("./index.BrgASaOV.js")).default;default:throw new Error(`Unsupported runtime type: ${e}`)}}}const k={command:"build",describe:"Build fnode 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"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{const o=await C(e),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},B={command:"build:dev",describe:"Build fnode 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"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{e.dev=!0;const o=await C(e),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},O={command:"deploy",describe:"Build and deploy fnode 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 o=await C({...e,mode:"all"}),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},M={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 o=await C({...e,mode:"file"}),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},R={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 e=>{try{const o=await C(e),{project:t}=o,{projectDir:n,projectFileParsed:i}=t,s=i.input;if(!s)throw new Error("Config schema not found in project file.");if(!Reflect.has(e,"name")){const{inputName:o}=await w({type:"input",name:"inputName",message:"Input name:",initial:"dev"});e.name=o}const a=r.resolve(n,".fnet");l.existsSync(a)||l.mkdirSync(a);const c=r.resolve(a,`${e.name}.fnet`),d=l.existsSync(c),p=(await import("@fnet/object-from-schema")).default,m=await p({schema:s,format:"yaml",ref:d?c:void 0});l.writeFileSync(c,m)}catch(e){console.error(e.message),process.exit(1)}}};var W={promptForSelection:async function(e){const{items:t,message:n,nameField:r="name",valueField:i="name",initialValue:s=null,allowAbort:a=!0}=e;if(!t||0===t.length)return console.log(o.yellow("No items available for selection.")),null;if(1===t.length&&!a){const e=t[0],n="string"==typeof e?e:e[i];return console.log(o.blue(`Only one option available: ${"string"==typeof e?e:e[r]}`)),n}let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[i],value:e[i],message:e[r]||e[i]}));a&&c.push({name:"cancel",value:null,message:o.yellow("Cancel")});let l=null;if(s){const e=c.findIndex((e=>e.name===s));-1!==e&&(l=e)}const d="selectedItem",{[d]:p}=await w({type:"select",name:d,message:n,choices:c,initial:l});return"cancel"===p?null:p},promptForMultipleSelection:async function(e){const{items:t,message:n,nameField:r="name",valueField:i="name",initialValues:s=[],allowAbort:a=!0}=e;if(!t||0===t.length)return console.log(o.yellow("No items available for selection.")),null;let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[i],value:e[i],message:e[r]||e[i]})),l=[];s&&s.length>0&&(l=c.map(((e,o)=>s.includes(e.name)?o:-1)).filter((e=>-1!==e)));const d="selectedItems",p=await w({type:"multiselect",name:d,message:n,choices:c,initial:l,hint:"(Use space to select, enter to confirm)",validate:e=>!(0===e.length&&!a)||"Please select at least one item"});return a&&0===p[d].length?null:p[d]}};const U=r.join(m.homedir(),".fnet","express");async function G(e){e.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, python, bun)",type:"string",choices:["node","python","bun"],default:"node"})),(async e=>{await async function(e){try{l.existsSync(U)||l.mkdirSync(U,{recursive:!0});const t=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=r.join(U,t);l.existsSync(n)||l.mkdirSync(n,{recursive:!0});let i,s=e.projectName,a=e.runtime;if(e.yes){if(!s){const e=l.readdirSync(n).filter((e=>e.startsWith("fnode-"))).map((e=>parseInt(e.replace("fnode-",""),10))).filter((e=>!isNaN(e))),o=e.length>0?Math.max(...e)+1:1;s=`fnode-${o}`}a||(a="node")}else{if(!s){const e=l.readdirSync(n).filter((e=>e.startsWith("fnode-"))).map((e=>parseInt(e.replace("fnode-",""),10))).filter((e=>!isNaN(e))),o=`fnode-${e.length>0?Math.max(...e)+1:1}`,t=await w([{type:"input",name:"projectName",message:"Enter project name:",default:o}]);s=t.projectName}const e=a||"node";a=(await w({type:"select",name:"runtime",message:"Select runtime:",choices:["node","python","bun"],initial:e})).runtime}if(i=r.join(n,s),l.existsSync(i)){let e=1;for(;l.existsSync(r.join(n,`${s}-${e}`));)e++;s=`${s}-${e}`,i=r.join(n,s)}if(!e.yes){if(!(await w([{type:"confirm",name:"proceed",message:`Create express project "${s}" in ${i}?`,default:!0}])).proceed)return void console.log(o.yellow("Project creation cancelled."))}console.log(o.blue(`Creating express project "${s}" in ${i}...`));const d=r.dirname(i),p=["create","--name",r.basename(i)];p.push("--runtime",a),e.yes&&p.push("--yes"),l.existsSync(d)||l.mkdirSync(d,{recursive:!0});const m=c("fnode",p,{stdio:"inherit",shell:!0,cwd:d});return new Promise(((t,n)=>{m.on("close",(r=>{0===r?(console.log(o.green(`\nExpress project "${s}" created successfully!`)),console.log(o.blue(`\nProject location: ${i}`)),e.yes?t():async function(e){try{(await w({type:"confirm",name:"openIDE",message:"Would you like to open the project in an IDE?",initial:!0})).openIDE&&await V(e)}catch(e){console.error(o.red(`Error opening IDE: ${e.message}`))}}(i)):(console.error(o.red(`\nFailed to create express project "${s}".`)),n(new Error(`Process exited with code ${r}`)))}))}))}catch(e){console.error(o.red(`Error creating express project: ${e.message}`)),process.exit(1)}}(e)})).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("all",{describe:"Show all projects regardless of type",type:"boolean",default:!1,alias:"a"}).option("name",{describe:"Filter by project name",type:"string"})),(async e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));const t=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));if(e.today){const e=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=t.indexOf(e);if(-1===n)return void console.log(o.yellow("No express projects found for today."));t.splice(0,n),t.splice(1)}const n=[];e.type||e.all||(e.type="fnode");for(const o of t){const t=r.join(U,o),i=l.readdirSync(t);for(const s of i){const i=r.join(t,s),a=l.statSync(i);let c="unknown";if(s.startsWith("fnode-")||l.existsSync(r.join(i,"fnode.yaml"))?c="fnode":(s.startsWith("fnet-")||l.existsSync(r.join(i,"fnet.yaml")))&&(c="fnet"),e.type&&c!==e.type)continue;if(e.name&&!s.includes(e.name))continue;const d=`${o.slice(0,4)}-${o.slice(4,6)}-${o.slice(6,8)}`;n.push({name:s,type:c,date:d,path:i,created:a.birthtime})}}if(n.sort(((e,o)=>o.created-e.created)),0===n.length)return void console.log(o.yellow("No express projects found matching the criteria."));console.log(o.blue("\nExpress Projects:"));const i=(await import("./index.-SGbq2cI.js")).default,s=["NAME","TYPE","DATE","PATH"],a=i.createTable(s,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});for(const e of n){let t=e.path;t.startsWith(m.homedir())&&(t="~"+t.substring(m.homedir().length)),a.push([o.white(e.name),"fnet"===e.type?o.cyan(e.type):"fnode"===e.type?o.green(e.type):e.type,e.date,t])}console.log(a.toString()),console.log(o.green("Projects: ")+o.yellow(n.filter((e=>"fnode"===e.type)).length+" fnode, ")+o.cyan(n.filter((e=>"fnet"===e.type)).length+" fnet")),console.log(o.blue(`\nTotal: ${n.length} projects`))}catch(e){console.error(o.red(`Error listing express projects: ${e.message}`)),process.exit(1)}}(e)})).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 e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));let t;if(e.latest){if(t=await H(),!t)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(t=await L(e.projectName),!t)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));t=r.join(U,e)}await V(t)}catch(e){console.error(o.red(`Error opening express project: ${e.message}`)),process.exit(1)}}(e)})).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 e=>{await async function(e){try{const t=process.cwd();let n;if(t.includes(U))n=t,console.log(o.blue(`Using current express project: ${r.basename(n)}`));else if(e.latest){if(n=await H(),!n)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(n=await L(e.projectName),!n)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));n=r.join(U,e)}let i=e.destination;if(!i){i=(await w({type:"input",name:"destination",message:"Enter destination directory:",initial:r.join(process.cwd(),r.basename(n))})).destination}if(i.startsWith("~")&&(i=r.join(m.homedir(),i.slice(1))),i=r.resolve(i),i.startsWith(n+r.sep)||i===n)return void console.log(o.red("Destination cannot be inside the source directory."));if(l.existsSync(i)){if(!l.statSync(i).isDirectory())return void console.log(o.red(`Destination "${i}" is not a directory.`));if(l.readdirSync(i).length>0){if(!(await w({type:"confirm",name:"overwrite",message:`Destination "${i}" is not empty. Continue anyway?`,initial:!1})).overwrite)return void console.log(o.yellow("Project move cancelled."))}}else l.mkdirSync(i,{recursive:!0});console.log(o.blue(`Moving project from ${n} to ${i}...`)),z(n,i),console.log(o.green(`\nProject moved successfully to ${i}`));(await w({type:"confirm",name:"deleteOriginal",message:"Delete the original express project?",initial:!1})).deleteOriginal&&(l.rmSync(n,{recursive:!0,force:!0}),console.log(o.green("Original project deleted."))),await V(i)}catch(e){console.error(o.red(`Error moving express project: ${e.message}`)),process.exit(1)}}(e)})).command("remove [project-name]","Remove an express project",(e=>e.positional("project-name",{describe:"Name of the project to remove",type:"string"}).option("latest",{describe:"Remove the most recent project",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Skip confirmation prompt",type:"boolean",default:!1})),(async e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));let t;if(e.latest){if(t=await H(),!t)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(t=await L(e.projectName),!t)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));t=r.join(U,e)}const n=r.basename(t);if(!e.yes){if(!(await w({type:"confirm",name:"confirm",message:`Are you sure you want to remove project "${n}"?`,initial:!1})).confirm)return void console.log(o.yellow("Project removal cancelled."))}console.log(o.blue(`Removing project "${n}"...`)),l.rmSync(t,{recursive:!0,force:!0}),console.log(o.green(`Project "${n}" removed successfully.`))}catch(e){console.error(o.red(`Error removing express project: ${e.message}`)),process.exit(1)}}(e)})).command("enter [project-name]","Enter the directory of an express project in the active terminal",(e=>e.positional("project-name",{describe:"Name of the project to enter",type:"string"}).option("latest",{describe:"Enter the most recent project directory",type:"boolean",default:!1})),(async e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));let t;if(e.latest){if(t=await H(),!t)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(t=await L(e.projectName),!t)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));t=r.join(U,e)}console.log(o.blue(`Entering project directory: ${t}`)),console.log(o.yellow("\nOpening a new shell in the project directory..."));const n=process.env.SHELL||"/bin/bash",i=c(n,[],{stdio:"inherit",cwd:t,shell:!0});return new Promise((e=>{i.on("close",(()=>{console.log(o.green("\nReturned from project directory.")),e()}))}))}catch(e){console.error(o.red(`Error entering express project directory: ${e.message}`)),process.exit(1)}}(e)})).demandCommand(1,"You need to specify a command").help()}async function H(){const e=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));if(0===e.length)return null;const o=e[0],t=r.join(U,o),n=l.readdirSync(t);if(0===n.length)return null;let i=null,s=0;for(const e of n){const o=r.join(t,e),n=l.statSync(o);n.birthtimeMs>s&&(s=n.birthtimeMs,i=o)}return i}async function L(e){const t=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));for(const n of t){const t=r.join(U,n),i=l.readdirSync(t);if(i.includes(e))return r.join(t,e);const s=i.filter((o=>o.includes(e)));if(s.length>0){if(1===s.length)return r.join(t,s[0]);{const i=s.map((e=>({name:r.join(t,e),value:r.join(t,e),message:`${e} (${n})`}))),a=await W.promptForSelection({items:i,message:`Multiple projects match "${e}". Please select one:`,nameField:"message",valueField:"value",allowAbort:!0});return null===a?(console.log(o.yellow("Operation cancelled.")),null):a}}}return null}async function _(){const e=[],t=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));for(const o of t){const t=r.join(U,o),n=l.readdirSync(t);for(const i of n){const n=r.join(t,i),s=l.statSync(n),a=`${o}/${i}`;e.push({name:a,value:a,message:`${i} (${o})`,created:s.birthtime})}}if(e.sort(((e,o)=>o.created-e.created)),0===e.length)return null;const n=await W.promptForSelection({items:e,message:"Select a project:",nameField:"message",valueField:"value",allowAbort:!0});return null===n?(console.log(o.yellow("Operation cancelled.")),null):n}async function V(e){const t=await Y("code --version"),n=await Y("code-insiders --version");let r=null;if(t&&n){const e=await w({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"}]});r=e.ide}else if(t)r="code";else{if(!n)return console.log(o.yellow("No supported IDE found. Please open the project manually.")),void console.log(o.blue(`Project path: ${e}`));r="code-insiders"}console.log(o.blue(`Opening project in ${r}...`)),console.log(o.blue(`Project path: ${e}`));const i=c(r,[e],{stdio:"inherit",shell:!0});return new Promise(((e,t)=>{i.on("close",(n=>{0===n?(console.log(o.green(`Project opened in ${r}.`)),e()):(console.error(o.red(`Failed to open project in ${r}.`)),t(new Error(`Process exited with code ${n}`)))}))}))}async function Y(e){return new Promise((o=>{c(e,{shell:!0,stdio:"ignore"}).on("close",(e=>{o(0===e)}))}))}function z(e,o){l.existsSync(o)||l.mkdirSync(o,{recursive:!0});const t=l.readdirSync(e,{withFileTypes:!0});for(const n of t){const t=r.join(e,n.name),i=r.join(o,n.name);if(n.isDirectory()){if(".git"===n.name||".workspace"===n.name)continue;z(t,i)}else l.copyFileSync(t,i)}}const X=r.dirname(a(import.meta.url));const J=r.dirname(a(import.meta.url)),K=process.cwd();process.on("uncaughtException",(e=>{b||(b=!0,setTimeout((()=>process.exit(1)),500))})),process.on("unhandledRejection",(e=>{b||(b=!0,setTimeout((()=>process.exit(1)),500))})),function(){p({name:["redis"],dir:K,optional:!0});const e=function({baseDir:e}){let o=e=e||X;for(;o!==r.parse(o).root;){const e=r.join(o,"node_modules");if(l.existsSync(e))return e;o=r.dirname(o)}return null}({baseDir:J}),o="win32"===process.platform?";":":";e&&(process.env.PATH=`${r.join(e,"/.bin")}${o}${process.env.PATH}`)}(),async function(){try{let t=e(process.argv.slice(2)).usage("Usage: $0 <command> [options]").command(I).command(T).command(k).command(B).command(O).command(M).command(R).command("express","Create and manage express projects",G);t=x(t,{bin:"npm"}),t=x(t,{bin:"node"}),t=x(t,{bin:"bun"}),t=x(t,{name:"serve",bin:"bun",preArgs:["run","serve","--"]}),t=x(t,{name:"watch",bin:"bun",preArgs:["run","watch","--"]}),t=x(t,{name:"app",bin:"bun",preArgs:["run","app","--"]}),t=x(t,{name:"cli",bin:"bun",preArgs:["run","cli","--"]}),t=x(t,{name:"cli:dev",bin:"bun",preArgs:["run","cli:dev","--"]}),t=x(t,{name:"cli:compile",bin:"bun",preArgs:["run","cli:compile","--"]}),t=x(t,{name:"cli:compile:dev",bin:"bun",preArgs:["run","cli:compile:dev","--"]}),t=x(t,{name:"cli:install",bin:"bun",preArgs:["run","cli:install","--"]}),t=x(t,{name:"compile",bin:"bun",preArgs:["run","compile","--"]}),t=function(e,{name:t}){return e.command(`${t} [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 e=>{try{const t=await S(e),{projectDir:n}=t;console.log(o.blue("Compiling project..."));const i=r.join(n,".bin");l.existsSync(i)||l.mkdirSync(i,{recursive:!0});const s=r.basename(r.dirname(n)),a=t.project?.projectFileParsed?.features?.cli?.bin,c=e.name||a||s;console.log(o.blue(`Using binary name: ${c}`));const d=r.join(i,c),{spawn:p}=await import("child_process"),m=p("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${d}`],{cwd:n,stdio:"inherit",shell:!0});await new Promise(((e,o)=>{m.on("close",(t=>{0===t?e():o(new Error(`Compilation failed with code ${t}`))})),m.on("error",(e=>{o(e)}))})),"win32"!==process.platform&&l.chmodSync(d,493),console.log(o.green(`Binary compiled successfully: ${d}`)),console.log(o.blue("Installing binary..."));const u=["install",d];e.name&&u.push("--name",e.name),e.force&&u.push("--force"),e.yes&&u.push("--yes");const f=p("fbin",u,{stdio:"inherit",shell:!0});await new Promise(((e,o)=>{f.on("close",(t=>{0===t?e():o(new Error(`Installation failed with code ${t}`))})),f.on("error",(e=>{o(e)}))}))}catch(e){console.error(o.red(`Failed to install binary: ${e.message}`)),process.exit(1)}}))}(t,{name:"install"}),t=x(t,{bin:"npx"}),t=x(t,{bin:"cdk"}),t=x(t,{bin:"aws"}),t=function(e,{name:o,preArgs:t=[]}){return e.command(`${o} <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 o=await S(e),{projectDir:n}=o,r=e.config,i=await p({name:r,dir:n,transferEnv:!1,optional:!0,tags:o.tags}),s=i?.data?.env||void 0,a=e.command,d=process.argv.slice(5);v(c(a,[...t,...d],{cwd:l.existsSync(n)?n:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...s}}))}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"with"}),t=function(e,{name:o,projectType:t="auto"}){return e.command(`${o} 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:o}=await import("./index.DrwlOzAe.js");await o({projectType:t,group:e.group,tags:e.ftag,args:e,argv:process.argv})}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"run",projectType:"fnode"}),t=$(t,{name:"python"}),t=$(t,{name:"python3"}),t=$(t,{name:"pip"}),t=$(t,{name:"pip3"}),t.demandCommand(1,"You need at least one command before moving on").help().version().argv}catch(e){console.error(o.red(`Fatal error: ${e.message}`)),process.exit(1)}}().catch((e=>{console.error(o.red(`Fatal error: ${e.message}`)),process.exit(1)}));export{E as r,P as w};
2
+ import e from"yargs";import o from"chalk";import{promisify as t}from"node:util";import n from"tree-kill";import r,{delimiter as i,join as s}from"node:path";import{fileURLToPath as a}from"node:url";import{spawn as c}from"node:child_process";import l,{existsSync as d}from"node:fs";import p from"@fnet/config";import m from"node:os";import u from"@flownet/lib-render-templates-dir";import f from"@fnet/shelljs";import y from"@fnet/yaml";import g from"yaml";import w from"@fnet/prompt";const h=t(n);let j=!1;async function b(e,o){if(j)return;if(j=!0,!e.killed&&e.pid)try{await h(e.pid,"SIGTERM").catch((()=>{})),await new Promise((e=>setTimeout(e,500))),e.killed||await h(e.pid,"SIGKILL").catch((()=>{}))}catch(e){}await new Promise((e=>setTimeout(e,100)));const t="SIGINT"===o?130:"SIGTERM"===o?143:1;process.exit(t)}function v(e){["SIGINT","SIGTERM","SIGQUIT"].forEach((o=>{process.once(o,(async()=>{await b(e,o)}))})),process.on("uncaughtException",(async o=>{await b(e)})),process.on("unhandledRejection",(async o=>{await b(e)})),e.on("close",(e=>{j||process.exit(e)}))}function x(e,{name:o,bin:t,preArgs:n=[]}){return"function"==typeof t&&(t=t()),e.command(`${o||t} [commands..]`,`${t} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const o=await S(e),{projectDir:r}=o,i=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,s=process.argv.slice(3).map(i);v(c(t,[...n,...s],{cwd:r,stdio:"inherit",shell:!0,detached:!0}))}catch(e){console.error(e.message),process.exit(1)}}))}function $(e,{name:o,bin:t,preArgs:n=[]}){return e.command(`${o||t} [commands..]`,`${t} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const i=await S(e),{projectDir:s}=i,a=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,l=process.argv.slice(3).map(a);t=r.join(s,".conda","bin",t||o);v(c(t,[...n,...l],{cwd:s,stdio:"inherit",shell:!0,detached:!0,env:{PYTHONPATH:s}}))}catch(e){console.error(e.message),process.exit(1)}}))}async function S(e){try{const o=process.argv[1].split("/").pop().split(".")[0];if("fnode"===o){const{createContext:o}=await Promise.resolve().then((function(){return C}));return o(e)}if("fnet"===o){const{createContext:o}=await import("./index.UNoFg95r.js");return o(e)}if("frun"===o){const{createContext:o}=await import("./index.CuMyez3E.js");return o(e)}if("fbin"===o){const{createContext:o}=await import("./index.DWpw12No.js");return o(e)}}catch(e){console.warn(`Warning: Could not import context from CLI tool: ${e.message}`)}return{projectDir:process.cwd(),tags:e.ftag}}var P=e=>{const o=process.env.PATH||"",t="win32"===process.platform?(process.env.PATHEXT||".EXE;.CMD;.BAT;.COM").split(";"):[""],n=o.split(i);for(const o of n)for(const n of t){const t=s(o,"win32"===process.platform?e+n:e);if(d(t))return t}return null};const N=r.dirname(a(import.meta.url)),D=process.cwd();function E(e){const o=r.resolve(D,e);if(l.existsSync(o))return o;const t=r.resolve(N,"../..",e);if(l.existsSync(t))return t;throw new Error(`Template path not found: ${e}`)}const I={command:"create",describe:"Create a new fnode project",builder:e=>e.option("name",{type:"string",describe:"Project name",demandOption:!0}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node","python","bun"],describe:"Runtime environment"}),handler:async e=>{try{const o=process.cwd(),t=E("./template/fnode/project"),n=r.resolve(o,e.name);l.existsSync(n)||l.mkdirSync(n),await u({dir:t,outDir:n,context:{name:e.name,runtime:e.runtime,platform:m.platform()},copyUnmatchedAlso:!0});let i=await f("fnode build",{cwd:n});if(0!==i.code)throw new Error("Failed to build project.");if(P("git")&&(i=await f("git init --initial-branch=main",{cwd:n}),0!==i.code))throw new Error("Failed to initialize git.");if(P("code")&&e.vscode&&(i=await f(`cd ${n} && code .`),0!==i.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 F(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:E("./template/fnode/node"),projectDir:r.resolve(process.cwd(),`./.output/${e.id}`),tags:e.ftag,dev:e.dev};try{const o=await async function({tags:e}){let o=function(e){const o=r.resolve(e,"node.yaml"),t=r.resolve(e,"fnode.yaml");if(l.existsSync(t))return t;if(l.existsSync(o))try{const n=l.readFileSync(o,"utf8");return l.writeFileSync(t,n,"utf8"),l.unlinkSync(o),console.log(`Migrated node.yaml to fnode.yaml in ${e}`),t}catch(e){return console.error(`Error migrating node.yaml to fnode.yaml: ${e.message}`),o}return t}(process.cwd());if(!l.existsSync(o))throw new Error("fnode.yaml file not found in current directory.");const{raw:t,parsed:n}=await y({file:o,tags:e}),i=r.dirname(o);n.features=n.features||{};const s=n.features;s.runtime=s.runtime||{},s.runtime.type=s.runtime.type||"node","python"===s.runtime.type?s.runtime.template=s.runtime.template||"python":(s.runtime.type,s.runtime.template=s.runtime.template||"node");const a={libraryAtom:{doc:{...n},fileName:"index"},projectDir:i,projectFilePath:o,projectFileContent:t,projectFileParsed:n,runtime:s.runtime};let c=r.resolve(i,"fnet/targets.yaml");if(!l.existsSync(c)&&(c=r.resolve(i,"node.devops.yaml"),l.existsSync(c))){const e=r.resolve(i,"fnet");l.existsSync(e)||l.mkdirSync(e),l.copyFileSync(c,r.resolve(i,"fnet/targets.yaml")),l.unlinkSync(c)}if(l.existsSync(c)){const{raw:o,parsed:t}=await y({file:c,tags:e}),n=g.parseDocument(o);a.devops={filePath:c,fileContent:o,yamlDocument:n,doc:{...t},type:"library.deploy",save:async()=>{l.writeFileSync(a.devops.filePath,n.toString())}}}const d=r.resolve(i,"readme.md");if(l.existsSync(d)){const e=l.readFileSync(d,"utf8");a.readme={filePath:d,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return a}({tags:e.ftag}),t="bun"===o.runtime.type?"node":o.runtime.type;return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:E(`./template/fnode/${t}`),projectDir:r.resolve(o.projectDir,"./.workspace"),projectSrcDir:r.resolve(o.projectDir,"./src"),project:o,tags:e.ftag,dev:e.dev}}catch(o){return console.warn(`Warning: Could not load project: ${o.message}`),{projectDir:process.cwd(),tags:e.ftag}}}var C=Object.freeze({__proto__:null,createContext:F});const T={command:"project",describe:"Manage fnode project",builder:e=>e.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"}),handler:async e=>{try{const o=E("./template/fnode/project"),t=process.cwd(),n=await F(e);if(e.update){if(await u({dir:o,outDir:t,context:{name:n.project.projectFileParsed.name,runtime:n.project.runtime.type,platform:m.platform()},copyUnmatchedAlso:!0}),0!==(await f("fnode build",{cwd:t})).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 A{static async createBuilder(e){if(!e.project){console.warn("No project provided, defaulting to node runtime");return new(0,(await import("./index.D9RmDejw.js")).default)(e)}const o=e.project?.runtime?.type||"node";try{return new(await this.loadBuilderClass(o))(e)}catch(e){throw new Error(`Failed to create builder for runtime '${o}': ${e.message}`)}}static async loadBuilderClass(e){switch(e.toLowerCase()){case"node":case"bun":return(await import("./index.D9RmDejw.js")).default;case"python":return(await import("./index.e2SSlEgE.js")).default;default:throw new Error(`Unsupported runtime type: ${e}`)}}}const B={command:"build",describe:"Build fnode 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"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{const o=await F(e),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},k={command:"build:dev",describe:"Build fnode 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"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{e.dev=!0;const o=await F(e),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},O={command:"deploy",describe:"Build and deploy fnode 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 o=await F({...e,mode:"all"}),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},M={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 o=await F({...e,mode:"file"}),t=await A.createBuilder(o);await t.init(),await t.build(),console.log("Building library succeeded!"),process.exit(0)}catch(e){console.error("Building library failed!",e.message),process.exit(1)}}},R={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 e=>{try{const o=await F(e),{project:t}=o,{projectDir:n,projectFileParsed:i}=t,s=i.input;if(!s)throw new Error("Config schema not found in project file.");if(!Reflect.has(e,"name")){const{inputName:o}=await w({type:"input",name:"inputName",message:"Input name:",initial:"dev"});e.name=o}const a=r.resolve(n,".fnet");l.existsSync(a)||l.mkdirSync(a);const c=r.resolve(a,`${e.name}.fnet`),d=l.existsSync(c),p=(await import("@fnet/object-from-schema")).default,m=await p({schema:s,format:"yaml",ref:d?c:void 0});l.writeFileSync(c,m)}catch(e){console.error(e.message),process.exit(1)}}};var W={promptForSelection:async function(e){const{items:t,message:n,nameField:r="name",valueField:i="name",initialValue:s=null,allowAbort:a=!0}=e;if(!t||0===t.length)return console.log(o.yellow("No items available for selection.")),null;if(1===t.length&&!a){const e=t[0],n="string"==typeof e?e:e[i];return console.log(o.blue(`Only one option available: ${"string"==typeof e?e:e[r]}`)),n}let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[i],value:e[i],message:e[r]||e[i]}));a&&c.push({name:"cancel",value:null,message:o.yellow("Cancel")});let l=null;if(s){const e=c.findIndex((e=>e.name===s));-1!==e&&(l=e)}const d="selectedItem",{[d]:p}=await w({type:"select",name:d,message:n,choices:c,initial:l});return"cancel"===p?null:p},promptForMultipleSelection:async function(e){const{items:t,message:n,nameField:r="name",valueField:i="name",initialValues:s=[],allowAbort:a=!0}=e;if(!t||0===t.length)return console.log(o.yellow("No items available for selection.")),null;let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[i],value:e[i],message:e[r]||e[i]})),l=[];s&&s.length>0&&(l=c.map(((e,o)=>s.includes(e.name)?o:-1)).filter((e=>-1!==e)));const d="selectedItems",p=await w({type:"multiselect",name:d,message:n,choices:c,initial:l,hint:"(Use space to select, enter to confirm)",validate:e=>!(0===e.length&&!a)||"Please select at least one item"});return a&&0===p[d].length?null:p[d]}};const U=r.join(m.homedir(),".fnet","express");async function G(e){e.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, python, bun)",type:"string",choices:["node","python","bun"],default:"node"})),(async e=>{await async function(e){try{l.existsSync(U)||l.mkdirSync(U,{recursive:!0});const t=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=r.join(U,t);l.existsSync(n)||l.mkdirSync(n,{recursive:!0});let i,s=e.projectName,a=e.runtime;if(e.yes){if(!s){const e=l.readdirSync(n).filter((e=>e.startsWith("fnode-"))).map((e=>parseInt(e.replace("fnode-",""),10))).filter((e=>!isNaN(e))),o=e.length>0?Math.max(...e)+1:1;s=`fnode-${o}`}a||(a="node")}else{if(!s){const e=l.readdirSync(n).filter((e=>e.startsWith("fnode-"))).map((e=>parseInt(e.replace("fnode-",""),10))).filter((e=>!isNaN(e))),o=`fnode-${e.length>0?Math.max(...e)+1:1}`,t=await w([{type:"input",name:"projectName",message:"Enter project name:",default:o}]);s=t.projectName}const e=a||"node";a=(await w({type:"select",name:"runtime",message:"Select runtime:",choices:["node","python","bun"],initial:e})).runtime}if(i=r.join(n,s),l.existsSync(i)){let e=1;for(;l.existsSync(r.join(n,`${s}-${e}`));)e++;s=`${s}-${e}`,i=r.join(n,s)}if(!e.yes){if(!(await w([{type:"confirm",name:"proceed",message:`Create express project "${s}" in ${i}?`,default:!0}])).proceed)return void console.log(o.yellow("Project creation cancelled."))}console.log(o.blue(`Creating express project "${s}" in ${i}...`));const d=r.dirname(i),p=["create","--name",r.basename(i)];p.push("--runtime",a),e.yes&&p.push("--yes"),l.existsSync(d)||l.mkdirSync(d,{recursive:!0});const m=c("fnode",p,{stdio:"inherit",shell:!0,cwd:d});return new Promise(((t,n)=>{m.on("close",(r=>{0===r?(console.log(o.green(`\nExpress project "${s}" created successfully!`)),console.log(o.blue(`\nProject location: ${i}`)),e.yes?t():async function(e){try{(await w({type:"confirm",name:"openIDE",message:"Would you like to open the project in an IDE?",initial:!0})).openIDE&&await V(e)}catch(e){console.error(o.red(`Error opening IDE: ${e.message}`))}}(i)):(console.error(o.red(`\nFailed to create express project "${s}".`)),n(new Error(`Process exited with code ${r}`)))}))}))}catch(e){console.error(o.red(`Error creating express project: ${e.message}`)),process.exit(1)}}(e)})).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("all",{describe:"Show all projects regardless of type",type:"boolean",default:!1,alias:"a"}).option("name",{describe:"Filter by project name",type:"string"})),(async e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));const t=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));if(e.today){const e=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=t.indexOf(e);if(-1===n)return void console.log(o.yellow("No express projects found for today."));t.splice(0,n),t.splice(1)}const n=[];e.type||e.all||(e.type="fnode");for(const o of t){const t=r.join(U,o),i=l.readdirSync(t);for(const s of i){const i=r.join(t,s),a=l.statSync(i);let c="unknown";if(s.startsWith("fnode-")||l.existsSync(r.join(i,"fnode.yaml"))?c="fnode":(s.startsWith("fnet-")||l.existsSync(r.join(i,"fnet.yaml")))&&(c="fnet"),e.type&&c!==e.type)continue;if(e.name&&!s.includes(e.name))continue;const d=`${o.slice(0,4)}-${o.slice(4,6)}-${o.slice(6,8)}`;n.push({name:s,type:c,date:d,path:i,created:a.birthtime})}}if(n.sort(((e,o)=>o.created-e.created)),0===n.length)return void console.log(o.yellow("No express projects found matching the criteria."));console.log(o.blue("\nExpress Projects:"));const i=(await import("./index.-SGbq2cI.js")).default,s=["NAME","TYPE","DATE","PATH"],a=i.createTable(s,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});for(const e of n){let t=e.path;t.startsWith(m.homedir())&&(t="~"+t.substring(m.homedir().length)),a.push([o.white(e.name),"fnet"===e.type?o.cyan(e.type):"fnode"===e.type?o.green(e.type):e.type,e.date,t])}console.log(a.toString()),console.log(o.green("Projects: ")+o.yellow(n.filter((e=>"fnode"===e.type)).length+" fnode, ")+o.cyan(n.filter((e=>"fnet"===e.type)).length+" fnet")),console.log(o.blue(`\nTotal: ${n.length} projects`))}catch(e){console.error(o.red(`Error listing express projects: ${e.message}`)),process.exit(1)}}(e)})).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 e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));let t;if(e.latest){if(t=await H(),!t)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(t=await L(e.projectName),!t)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));t=r.join(U,e)}await V(t)}catch(e){console.error(o.red(`Error opening express project: ${e.message}`)),process.exit(1)}}(e)})).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 e=>{await async function(e){try{const t=process.cwd();let n;if(t.includes(U))n=t,console.log(o.blue(`Using current express project: ${r.basename(n)}`));else if(e.latest){if(n=await H(),!n)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(n=await L(e.projectName),!n)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));n=r.join(U,e)}let i=e.destination;if(!i){i=(await w({type:"input",name:"destination",message:"Enter destination directory:",initial:r.join(process.cwd(),r.basename(n))})).destination}if(i.startsWith("~")&&(i=r.join(m.homedir(),i.slice(1))),i=r.resolve(i),i.startsWith(n+r.sep)||i===n)return void console.log(o.red("Destination cannot be inside the source directory."));if(l.existsSync(i)){if(!l.statSync(i).isDirectory())return void console.log(o.red(`Destination "${i}" is not a directory.`));if(l.readdirSync(i).length>0){if(!(await w({type:"confirm",name:"overwrite",message:`Destination "${i}" is not empty. Continue anyway?`,initial:!1})).overwrite)return void console.log(o.yellow("Project move cancelled."))}}else l.mkdirSync(i,{recursive:!0});console.log(o.blue(`Moving project from ${n} to ${i}...`)),z(n,i),console.log(o.green(`\nProject moved successfully to ${i}`));(await w({type:"confirm",name:"deleteOriginal",message:"Delete the original express project?",initial:!1})).deleteOriginal&&(l.rmSync(n,{recursive:!0,force:!0}),console.log(o.green("Original project deleted."))),await V(i)}catch(e){console.error(o.red(`Error moving express project: ${e.message}`)),process.exit(1)}}(e)})).command("remove [project-name]","Remove an express project",(e=>e.positional("project-name",{describe:"Name of the project to remove",type:"string"}).option("latest",{describe:"Remove the most recent project",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Skip confirmation prompt",type:"boolean",default:!1})),(async e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));let t;if(e.latest){if(t=await H(),!t)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(t=await L(e.projectName),!t)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));t=r.join(U,e)}const n=r.basename(t);if(!e.yes){if(!(await w({type:"confirm",name:"confirm",message:`Are you sure you want to remove project "${n}"?`,initial:!1})).confirm)return void console.log(o.yellow("Project removal cancelled."))}console.log(o.blue(`Removing project "${n}"...`)),l.rmSync(t,{recursive:!0,force:!0}),console.log(o.green(`Project "${n}" removed successfully.`))}catch(e){console.error(o.red(`Error removing express project: ${e.message}`)),process.exit(1)}}(e)})).command("enter [project-name]","Enter the directory of an express project in the active terminal",(e=>e.positional("project-name",{describe:"Name of the project to enter",type:"string"}).option("latest",{describe:"Enter the most recent project directory",type:"boolean",default:!1})),(async e=>{await async function(e){try{if(!l.existsSync(U))return void console.log(o.yellow("No express projects found."));let t;if(e.latest){if(t=await H(),!t)return void console.log(o.yellow("No express projects found."))}else if(e.projectName){if(t=await L(e.projectName),!t)return void console.log(o.yellow(`Project "${e.projectName}" not found.`))}else{const e=await _();if(!e)return void console.log(o.yellow("No project selected."));t=r.join(U,e)}console.log(o.blue(`Entering project directory: ${t}`)),console.log(o.yellow("\nOpening a new shell in the project directory..."));const n=process.env.SHELL||"/bin/bash",i=c(n,[],{stdio:"inherit",cwd:t,shell:!0});return new Promise((e=>{i.on("close",(()=>{console.log(o.green("\nReturned from project directory.")),e()}))}))}catch(e){console.error(o.red(`Error entering express project directory: ${e.message}`)),process.exit(1)}}(e)})).demandCommand(1,"You need to specify a command").help()}async function H(){const e=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));if(0===e.length)return null;const o=e[0],t=r.join(U,o),n=l.readdirSync(t);if(0===n.length)return null;let i=null,s=0;for(const e of n){const o=r.join(t,e),n=l.statSync(o);n.birthtimeMs>s&&(s=n.birthtimeMs,i=o)}return i}async function L(e){const t=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));for(const n of t){const t=r.join(U,n),i=l.readdirSync(t);if(i.includes(e))return r.join(t,e);const s=i.filter((o=>o.includes(e)));if(s.length>0){if(1===s.length)return r.join(t,s[0]);{const i=s.map((e=>({name:r.join(t,e),value:r.join(t,e),message:`${e} (${n})`}))),a=await W.promptForSelection({items:i,message:`Multiple projects match "${e}". Please select one:`,nameField:"message",valueField:"value",allowAbort:!0});return null===a?(console.log(o.yellow("Operation cancelled.")),null):a}}}return null}async function _(){const e=[],t=l.readdirSync(U).filter((e=>/^\d{8}$/.test(e))).sort(((e,o)=>o.localeCompare(e)));for(const o of t){const t=r.join(U,o),n=l.readdirSync(t);for(const i of n){const n=r.join(t,i),s=l.statSync(n),a=`${o}/${i}`;e.push({name:a,value:a,message:`${i} (${o})`,created:s.birthtime})}}if(e.sort(((e,o)=>o.created-e.created)),0===e.length)return null;const n=await W.promptForSelection({items:e,message:"Select a project:",nameField:"message",valueField:"value",allowAbort:!0});return null===n?(console.log(o.yellow("Operation cancelled.")),null):n}async function V(e){const t=await Y("code --version"),n=await Y("code-insiders --version");let r=null;if(t&&n){const e=await w({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"}]});r=e.ide}else if(t)r="code";else{if(!n)return console.log(o.yellow("No supported IDE found. Please open the project manually.")),void console.log(o.blue(`Project path: ${e}`));r="code-insiders"}console.log(o.blue(`Opening project in ${r}...`)),console.log(o.blue(`Project path: ${e}`));const i=c(r,[e],{stdio:"inherit",shell:!0});return new Promise(((e,t)=>{i.on("close",(n=>{0===n?(console.log(o.green(`Project opened in ${r}.`)),e()):(console.error(o.red(`Failed to open project in ${r}.`)),t(new Error(`Process exited with code ${n}`)))}))}))}async function Y(e){return new Promise((o=>{c(e,{shell:!0,stdio:"ignore"}).on("close",(e=>{o(0===e)}))}))}function z(e,o){l.existsSync(o)||l.mkdirSync(o,{recursive:!0});const t=l.readdirSync(e,{withFileTypes:!0});for(const n of t){const t=r.join(e,n.name),i=r.join(o,n.name);if(n.isDirectory()){if(".git"===n.name||".workspace"===n.name)continue;z(t,i)}else l.copyFileSync(t,i)}}const X=r.dirname(a(import.meta.url));const J=r.dirname(a(import.meta.url)),K=process.cwd();process.on("uncaughtException",(e=>{j||(j=!0,setTimeout((()=>process.exit(1)),500))})),process.on("unhandledRejection",(e=>{j||(j=!0,setTimeout((()=>process.exit(1)),500))})),function(){p({name:["redis"],dir:K,optional:!0});const e=function({baseDir:e}){let o=e=e||X;for(;o!==r.parse(o).root;){const e=r.join(o,"node_modules");if(l.existsSync(e))return e;o=r.dirname(o)}return null}({baseDir:J}),o="win32"===process.platform?";":":";e&&(process.env.PATH=`${r.join(e,"/.bin")}${o}${process.env.PATH}`)}(),async function(){try{let t=e(process.argv.slice(2)).usage("Usage: $0 <command> [options]").command(I).command(T).command(B).command(k).command(O).command(M).command(R).command("express","Create and manage express projects",G);t=x(t,{bin:"npm"}),t=x(t,{bin:"node"}),t=x(t,{bin:"bun"}),t=x(t,{name:"serve",bin:"bun",preArgs:["run","serve","--"]}),t=x(t,{name:"watch",bin:"bun",preArgs:["run","watch","--"]}),t=x(t,{name:"app",bin:"bun",preArgs:["run","app","--"]}),t=x(t,{name:"cli",bin:"bun",preArgs:["run","cli","--"]}),t=x(t,{name:"cli:dev",bin:"bun",preArgs:["run","cli:dev","--"]}),t=x(t,{name:"cli:compile",bin:"bun",preArgs:["run","cli:compile","--"]}),t=x(t,{name:"cli:compile:dev",bin:"bun",preArgs:["run","cli:compile:dev","--"]}),t=x(t,{name:"cli:install",bin:"bun",preArgs:["run","cli:install","--"]}),t=x(t,{name:"compile",bin:"bun",preArgs:["run","compile","--"]}),t=function(e,{name:t}){return e.command(`${t} [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 e=>{try{const t=await S(e),{projectDir:n}=t;console.log(o.blue("Compiling project..."));const i=r.join(n,".bin");l.existsSync(i)||l.mkdirSync(i,{recursive:!0});const s=r.basename(r.dirname(n)),a=t.project?.projectFileParsed?.features?.cli?.bin,c=e.name||a||s;console.log(o.blue(`Using binary name: ${c}`));const d=r.join(i,c),{spawn:p}=await import("child_process"),m=p("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${d}`],{cwd:n,stdio:"inherit",shell:!0});await new Promise(((e,o)=>{m.on("close",(t=>{0===t?e():o(new Error(`Compilation failed with code ${t}`))})),m.on("error",(e=>{o(e)}))})),"win32"!==process.platform&&l.chmodSync(d,493),console.log(o.green(`Binary compiled successfully: ${d}`)),console.log(o.blue("Installing binary..."));const u=["install",d];e.name&&u.push("--name",e.name),e.force&&u.push("--force"),e.yes&&u.push("--yes");const f=p("fbin",u,{stdio:"inherit",shell:!0});await new Promise(((e,o)=>{f.on("close",(t=>{0===t?e():o(new Error(`Installation failed with code ${t}`))})),f.on("error",(e=>{o(e)}))}))}catch(e){console.error(o.red(`Failed to install binary: ${e.message}`)),process.exit(1)}}))}(t,{name:"install"}),t=x(t,{bin:"npx"}),t=x(t,{bin:"cdk"}),t=x(t,{bin:"aws"}),t=function(e,{name:o,preArgs:t=[]}){return e.command(`${o} <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 o=await S(e),{projectDir:n}=o,r=e.config,i=await p({name:r,dir:n,transferEnv:!1,optional:!0,tags:o.tags}),s=i?.data?.env||void 0,a=e.command,d=process.argv.slice(5);v(c(a,[...t,...d],{cwd:l.existsSync(n)?n:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...s}}))}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"with"}),t=function(e,{name:o,projectType:t="auto"}){return e.command(`${o} 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:o}=await import("./index.DrwlOzAe.js");await o({projectType:t,group:e.group,tags:e.ftag,args:e,argv:process.argv})}catch(e){console.error(e.message),process.exit(1)}}))}(t,{name:"run",projectType:"fnode"}),t=$(t,{name:"python"}),t=$(t,{name:"python3"}),t=$(t,{name:"pip"}),t=$(t,{name:"pip3"}),t.demandCommand(1,"You need at least one command before moving on").help().version().argv}catch(e){console.error(o.red(`Fatal error: ${e.message}`)),process.exit(1)}}().catch((e=>{console.error(o.red(`Fatal error: ${e.message}`)),process.exit(1)}));export{E as r,P as w};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fnet/cli",
3
- "version": "0.129.2",
3
+ "version": "0.130.2",
4
4
  "files": [
5
5
  "dist",
6
6
  "template"
@@ -42,26 +42,14 @@ async function buildOutput(name, config) {
42
42
  }
43
43
  {% endif %}
44
44
 
45
- // Build with Bun.build
46
- const result = await Bun.build({
45
+ const buildConfig = {
47
46
  entrypoints: config.entrypoints || [`./src/${name}/index.js`],
48
47
  outdir: outdir,
49
48
  format: config.format || 'esm',
50
- target: config.target || 'browser',
49
+ target: config.target || "browser",
51
50
  minify: config.minify !== undefined ? config.minify : false,
52
51
  sourcemap: config.sourcemap || 'external',
53
-
54
- // Mark npm dependencies as external to prevent bundling issues
55
- external: (() => {
56
- try {
57
- const pkg = JSON.parse(fs.readFileSync('./package.json', 'utf8'));
58
- return [...Object.keys(pkg.dependencies || {})];
59
- } catch (err) {
60
- console.warn('Could not read package.json:', err.message);
61
- return [];
62
- }
63
- })(),
64
-
52
+ splitting: true,
65
53
  // Add environment variables to help with module resolution
66
54
  define: {
67
55
  'process.env.NODE_PATH': JSON.stringify('./node_modules')
@@ -70,7 +58,15 @@ async function buildOutput(name, config) {
70
58
  plugins: [
71
59
  ...(config.plugins || [])
72
60
  ]
73
- });
61
+ };
62
+
63
+ if(config.external) buildConfig.external = config.external;
64
+ if(config.packages) buildConfig.packages = config.packages;
65
+ if(config.banner) buildConfig.banner = config.banner;
66
+ if(config.footer) buildConfig.footer = config.footer;
67
+
68
+ // Build with Bun.build
69
+ const result = await Bun.build(buildConfig);
74
70
 
75
71
  if (!result.success) {
76
72
  console.error(`${name} build failed:`, result.logs);
@@ -83,52 +79,51 @@ async function buildOutput(name, config) {
83
79
  async function main() {
84
80
  try {
85
81
  {% if atom.doc.features.project.format === 'esm' or atom.doc.features.project.format === undefined %}
86
- // Build default ESM
87
- await buildOutput('default', {
88
- format: "esm",
89
- target: "browser",
90
- minify: false,
91
- sourcemap: "external",
92
- entrypoints: ["./src/default/index.js"],
93
- outdir: "./dist/default/esm"
82
+ // Build default ESM
83
+ await buildOutput('default', {
84
+ format: "esm",
85
+ target: "browser",
86
+ minify: false,
87
+ sourcemap: "external",
88
+ entrypoints: ["./src/default/index.js"],
89
+ outdir: "./dist/default/esm",
90
+ packages: "external"
94
91
  });
95
92
  {% endif %}
96
93
 
97
94
  {% if atom.doc.features.project.format !== 'esm' %}
98
- // Build default CJS
99
- await buildOutput('defaultCjs', {
100
- format: "cjs",
101
- target: "node",
102
- minify: false,
103
- sourcemap: "external",
104
- entrypoints: ["./src/default/index.js"],
105
- outdir: "./dist/default/cjs"
106
- });
95
+ // Build default CJS
96
+ await buildOutput('defaultCjs', {
97
+ format: "cjs",
98
+ target: "browser",
99
+ minify: false,
100
+ sourcemap: "external",
101
+ entrypoints: ["./src/default/index.js"],
102
+ outdir: "./dist/default/cjs",
103
+ packages: "external"
104
+ });
107
105
  {% endif %}
108
106
 
109
107
  {% if atom.doc.features.cli.enabled !== false %}
110
- // Build CLI if exists
111
- try {
108
+ // Build CLI if exists
112
109
  if (fs.existsSync('./src/cli/index.js')) {
113
110
  await buildOutput('cli', {
114
111
  format: "esm",
115
- target: "node",
112
+ target: "browser",
116
113
  minify: false,
117
114
  sourcemap: "external",
118
115
  entrypoints: ["./src/cli/index.js"],
119
- outdir: "{{ atom.doc.features.cli.dir | default('./dist/cli/esm') }}"
116
+ outdir: "{{ atom.doc.features.cli.dir | default('./dist/cli/esm') }}",
117
+ packages: "external",
118
+ banner: "#!/usr/bin/env bun"
120
119
  });
121
120
  } else {
122
121
  console.log('CLI not found, skipping CLI build');
123
122
  }
124
- } catch (err) {
125
- console.log('Error building CLI:', err.message);
126
- }
127
123
  {% endif %}
128
124
 
129
125
  {% if atom.doc.features.app.enabled !== false %}
130
- // Build App if exists
131
- try {
126
+ // Build App if exists
132
127
  if (fs.existsSync('./src/app/index.js')) {
133
128
  await buildOutput('app', {
134
129
  format: "esm",
@@ -136,14 +131,12 @@ async function main() {
136
131
  minify: false,
137
132
  sourcemap: "external",
138
133
  entrypoints: ["./src/app/index.js"],
139
- outdir: "{{ atom.doc.features.app.dir | default('./dist/app/esm') }}"
134
+ outdir: "{{ atom.doc.features.app.dir | default('./dist/app/esm') }}",
135
+ packages: "bundle"
140
136
  });
141
137
  } else {
142
138
  console.log('App not found, skipping App build');
143
139
  }
144
- } catch (err) {
145
- console.log('Error building App:', err.message);
146
- }
147
140
  {% endif %}
148
141
 
149
142
  console.log('Build completed successfully!');
@@ -57,10 +57,17 @@
57
57
  {% endif %}
58
58
  "license": "{{atom.doc.license or 'MIT'}}",
59
59
  "scripts": {
60
- "build": "rollup --config",
61
- "build:dev": "rollup --config --sourcemap --environment DEVELOPMENT",
62
- "watch": "rollup --config --watch --sourcemap --environment DEVELOPMENT --environment FLOWNET_WATCH",
63
- "serve": "bunx serve ./"
60
+ {% if atom.doc.features.runtime.type === 'bun' %}
61
+ "build": "bun ./build.js",
62
+ "build:dev": "bun ./build.js --dev",
63
+ "watch": "bun --watch --watch-mode=poll --watch-ignore-dirs=node_modules,dist --watch-paths=./src ./build.js --dev",
64
+ "serve": "bunx serve ./"
65
+ {% else %}
66
+ "build": "rollup --config",
67
+ "build:dev": "rollup --config --sourcemap --environment DEVELOPMENT",
68
+ "watch": "rollup --config --watch --sourcemap --environment DEVELOPMENT --environment FLOWNET_WATCH",
69
+ "serve": "bunx serve ./"
70
+ {% endif %}
64
71
 
65
72
  {% if atom.doc.features.cli.enabled %}
66
73
  {% if atom.doc.features.project.format ==='cjs' %}
@@ -89,7 +96,6 @@
89
96
 
90
97
  {% if atom.doc.features.app.enabled %}
91
98
  ,"app": "bunx serve {{atom.doc.features.app.dir}}/"
92
- {# ,"app:dev": "bunx serve {{atom.doc.features.app.input.dir}}" #}
93
99
  {% endif %}
94
100
  },
95
101
  "devDependencies": {
@@ -0,0 +1,149 @@
1
+ #!/usr/bin/env bun
2
+ /**
3
+ * Build script for Bun projects
4
+ * This script uses Bun's built-in bundler instead of Rollup
5
+ */
6
+
7
+ import { mkdir, writeFile } from 'node:fs/promises';
8
+ import { join, dirname } from 'node:path';
9
+ import { fileURLToPath } from 'node:url';
10
+ import fs from 'node:fs';
11
+
12
+ const __dirname = dirname(fileURLToPath(import.meta.url));
13
+
14
+ async function ensureDir(dir) {
15
+ try {
16
+ await mkdir(dir, { recursive: true });
17
+ } catch (err) {
18
+ if (err.code !== 'EEXIST') throw err;
19
+ }
20
+ }
21
+
22
+ async function buildOutput(name, config) {
23
+ console.log(`Building ${name}...`);
24
+
25
+ const outdir = config.outdir || join(__dirname, `dist/${name}`);
26
+ await ensureDir(outdir);
27
+
28
+ {% if atom.doc.features.app.enabled !== false %}
29
+ // Copy HTML file if it exists and this is an app build
30
+ if (name === 'app') {
31
+ try {
32
+ const htmlPath = './src/app/index.html';
33
+ if (fs.existsSync(htmlPath)) {
34
+ const htmlContent = await Bun.file(htmlPath).text();
35
+ await writeFile(join(outdir, 'index.html'), htmlContent);
36
+ }
37
+ } catch (err) {
38
+ if (err.code !== 'ENOENT') {
39
+ console.warn('Warning: Could not copy HTML file:', err.message);
40
+ }
41
+ }
42
+ }
43
+ {% endif %}
44
+
45
+ const buildConfig = {
46
+ entrypoints: config.entrypoints || [`./src/${name}/index.js`],
47
+ outdir: outdir,
48
+ format: config.format || 'esm',
49
+ target: config.target || "browser",
50
+ minify: config.minify !== undefined ? config.minify : false,
51
+ sourcemap: config.sourcemap || 'external',
52
+ splitting: true,
53
+ // Add environment variables to help with module resolution
54
+ define: {
55
+ 'process.env.NODE_PATH': JSON.stringify('./node_modules')
56
+ },
57
+
58
+ plugins: [
59
+ ...(config.plugins || [])
60
+ ]
61
+ };
62
+
63
+ if(config.external) buildConfig.external = config.external;
64
+ if(config.packages) buildConfig.packages = config.packages;
65
+ if(config.banner) buildConfig.banner = config.banner;
66
+ if(config.footer) buildConfig.footer = config.footer;
67
+
68
+ // Build with Bun.build
69
+ const result = await Bun.build(buildConfig);
70
+
71
+ if (!result.success) {
72
+ console.error(`${name} build failed:`, result.logs);
73
+ process.exit(1);
74
+ }
75
+
76
+ return result;
77
+ }
78
+
79
+ async function main() {
80
+ try {
81
+ {% if atom.doc.features.project.format === 'esm' or atom.doc.features.project.format === undefined %}
82
+ // Build default ESM
83
+ await buildOutput('default', {
84
+ format: "esm",
85
+ target: "browser",
86
+ minify: false,
87
+ sourcemap: "external",
88
+ entrypoints: ["./src/default/index.js"],
89
+ outdir: "./dist/default/esm",
90
+ packages: "external"
91
+ });
92
+ {% endif %}
93
+
94
+ {% if atom.doc.features.project.format !== 'esm' %}
95
+ // Build default CJS
96
+ await buildOutput('defaultCjs', {
97
+ format: "cjs",
98
+ target: "browser",
99
+ minify: false,
100
+ sourcemap: "external",
101
+ entrypoints: ["./src/default/index.js"],
102
+ outdir: "./dist/default/cjs",
103
+ packages: "external"
104
+ });
105
+ {% endif %}
106
+
107
+ {% if atom.doc.features.cli.enabled !== false %}
108
+ // Build CLI if exists
109
+ if (fs.existsSync('./src/cli/index.js')) {
110
+ await buildOutput('cli', {
111
+ format: "esm",
112
+ target: "browser",
113
+ minify: false,
114
+ sourcemap: "external",
115
+ entrypoints: ["./src/cli/index.js"],
116
+ outdir: "{{ atom.doc.features.cli.dir | default('./dist/cli/esm') }}",
117
+ packages: "external",
118
+ banner: "#!/usr/bin/env bun"
119
+ });
120
+ } else {
121
+ console.log('CLI not found, skipping CLI build');
122
+ }
123
+ {% endif %}
124
+
125
+ {% if atom.doc.features.app.enabled !== false %}
126
+ // Build App if exists
127
+ if (fs.existsSync('./src/app/index.js')) {
128
+ await buildOutput('app', {
129
+ format: "esm",
130
+ target: "browser",
131
+ minify: false,
132
+ sourcemap: "external",
133
+ entrypoints: ["./src/app/index.js"],
134
+ outdir: "{{ atom.doc.features.app.dir | default('./dist/app/esm') }}",
135
+ packages: "bundle"
136
+ });
137
+ } else {
138
+ console.log('App not found, skipping App build');
139
+ }
140
+ {% endif %}
141
+
142
+ console.log('Build completed successfully!');
143
+ } catch (err) {
144
+ console.error('Build failed:', err);
145
+ process.exit(1);
146
+ }
147
+ }
148
+
149
+ main();
@@ -56,10 +56,18 @@
56
56
  {% endif %}
57
57
  "license": "{{atom.doc.license or 'MIT'}}",
58
58
  "scripts": {
59
- "build": "rollup --config",
60
- "build:dev": "rollup --config --sourcemap --environment DEVELOPMENT",
61
- "watch": "rollup --config --watch --sourcemap --environment DEVELOPMENT --environment FLOWNET_WATCH",
62
- "serve": "bunx serve ./"
59
+
60
+ {% if atom.doc.features.runtime.type === 'bun' %}
61
+ "build": "bun ./build.js",
62
+ "build:dev": "bun ./build.js --dev",
63
+ "watch": "bun --watch --watch-mode=poll --watch-ignore-dirs=node_modules,dist --watch-paths=./src ./build.js --dev",
64
+ "serve": "bunx serve ./"
65
+ {% else %}
66
+ "build": "rollup --config",
67
+ "build:dev": "rollup --config --sourcemap --environment DEVELOPMENT",
68
+ "watch": "rollup --config --watch --sourcemap --environment DEVELOPMENT --environment FLOWNET_WATCH",
69
+ "serve": "bunx serve ./"
70
+ {% endif %}
63
71
 
64
72
  {% if atom.doc.features.cli.enabled %}
65
73
  {% if atom.doc.features.project.format ==='cjs' %}
@@ -7,8 +7,8 @@ npm-default:
7
7
  # bin: some-bin-name
8
8
  name: "{{npm.name or "@fnet/"+name}}"
9
9
  {% elif runtime==='bun' %}
10
- bun-default:
11
- type: bun
10
+ npm-default:
11
+ type: npm
12
12
  enabled: false
13
13
  version: "{{npm.version or "0.1.0"}}"
14
14
  params:
@@ -11,4 +11,4 @@ properties:
11
11
  required:
12
12
  - NPM_TOKEN
13
13
  required:
14
- - env
14
+ - env