@fnet/cli 0.131.2 → 0.132.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import e from"chalk";import o from"yargs";import{hideBin as t}from"yargs/helpers";import n from"node:path";import s from"node:fs";import l from"node:os";import r from"@fnet/prompt";import{fileURLToPath as i}from"node:url";import a from"cli-table3";import{promisify as c}from"node:util";import m from"tree-kill";function d(){return n.join(l.homedir(),".fnet","bin")}function h(){return n.join(l.homedir(),".fnet","metadata")}function u(){return n.join(h(),"binaries.json")}function f(){try{if("win32"===process.platform)return process.env.PSModulePath&&process.env.PSModulePath.includes("PowerShell")?"powershell-core":process.env.PSModulePath?"powershell":"cmd";const e=process.env.SHELL||"";return e.includes("bash")?"bash":e.includes("zsh")?"zsh":e.includes("fish")?"fish":e.includes("ksh")?"ksh":e.includes("csh")||e.includes("tcsh")?"csh":s.existsSync(n.join(l.homedir(),".bashrc"))?"bash":s.existsSync(n.join(l.homedir(),".zshrc"))?"zsh":s.existsSync(n.join(l.homedir(),".config","fish","config.fish"))?"fish":"unknown"}catch(e){return"unknown"}}function p(e){const o=l.homedir(),t=[];switch(e){case"bash":t.push({name:".bashrc",path:n.join(o,".bashrc")}),t.push({name:".bash_profile",path:n.join(o,".bash_profile")}),t.push({name:".profile",path:n.join(o,".profile")});break;case"zsh":t.push({name:".zshrc",path:n.join(o,".zshrc")}),t.push({name:".zprofile",path:n.join(o,".zprofile")});break;case"fish":t.push({name:"config.fish",path:n.join(o,".config","fish","config.fish")});break;case"ksh":t.push({name:".kshrc",path:n.join(o,".kshrc")}),t.push({name:".profile",path:n.join(o,".profile")});break;case"csh":t.push({name:".cshrc",path:n.join(o,".cshrc")}),t.push({name:".tcshrc",path:n.join(o,".tcshrc")});break;case"powershell":t.push({name:"Microsoft.PowerShell_profile.ps1",path:n.join(o,"Documents","WindowsPowerShell","Microsoft.PowerShell_profile.ps1")}),t.push({name:"profile.ps1",path:n.join(o,"Documents","WindowsPowerShell","profile.ps1")});break;case"powershell-core":t.push({name:"Microsoft.PowerShell_profile.ps1",path:n.join(o,"Documents","PowerShell","Microsoft.PowerShell_profile.ps1")}),t.push({name:"profile.ps1",path:n.join(o,"Documents","PowerShell","profile.ps1")});break;case"cmd":t.push({name:"fnet-path.bat",path:n.join(o,"fnet-path.bat")})}return t}function y(e,o){switch(e){case"bash":case"zsh":case"ksh":default:return`export PATH="${o}:$PATH"`;case"fish":return`set -gx PATH ${o} $PATH`;case"csh":return`setenv PATH ${o}:$PATH`;case"powershell":case"powershell-core":return`$env:PATH = "${o};" + $env:PATH`;case"cmd":return`@echo off\nSETX PATH "%PATH%;${o}"\necho Path updated successfully`}}var g={getBinDirectory:d,getMetadataDirectory:h,getMetadataFilePath:u,checkIfInPath:function(e){return(process.env.PATH||"").split(n.delimiter).includes(e)},detectUserShell:f,getShellConfigPath:function(){const e=p(f());for(const o of e)if(s.existsSync(o.path))return o.path;return e.length>0?e[0].path:null},getAllShellConfigPaths:p,createBinDirectoryStructure:async function(){const e=d(),o=h(),t=u();s.existsSync(e)||s.mkdirSync(e,{recursive:!0}),s.existsSync(o)||s.mkdirSync(o,{recursive:!0}),s.existsSync(t)||s.writeFileSync(t,JSON.stringify({binaries:{},lastUpdated:(new Date).toISOString()},null,2))},getExportPathCommand:y,addBinToPath:async function(o,t,l){try{const r=y(o,l);if("cmd"===o)return s.writeFileSync(t,r),console.log(e.yellow(`Created batch file at ${t}`)),console.log(e.yellow("Run this file to add the bin directory to your PATH")),!0;if("powershell"!==o&&"powershell-core"!==o||s.existsSync(n.dirname(t))||s.mkdirSync(n.dirname(t),{recursive:!0}),!s.existsSync(t)){const n="fish"===o?"# Fish shell configuration\n\n":"powershell"===o||"powershell-core"===o?"# PowerShell profile\n\n":"# Shell configuration\n\n";s.writeFileSync(t,n),console.log(e.green(`Created config file at ${t}`))}const i=s.readFileSync(t,"utf8");if(i.includes(l))return!0;const a=`${i.trim()}\n\n# Added by @fnet/cli\n${r}\n`;return s.writeFileSync(t,a),"powershell"!==o&&"powershell-core"!==o||(console.log(e.yellow("You may need to set the PowerShell execution policy to run scripts:")),console.log(e.green("Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned"))),!0}catch(o){return console.error(e.red(`Failed to add bin directory to PATH: ${o.message}`)),!1}}};async function w(e){const o=function(){const e=l.homedir(),o=n.join(e,".fnet","bin");return s.existsSync(o)||s.mkdirSync(o,{recursive:!0}),o}(),t=function(){const e=l.homedir(),o=n.join(e,".fnet");return s.existsSync(o)||s.mkdirSync(o,{recursive:!0}),n.join(o,"bin-registry.json")}();let r={};if(s.existsSync(t))try{const e=s.readFileSync(t,"utf8");r=JSON.parse(e)}catch(e){console.warn(`Warning: Could not parse bin registry: ${e.message}`)}return{binDir:o,registryPath:t,registry:r,args:e}}n.dirname(i(import.meta.url));var b={command:"setup",describe:"Initialize the bin system",builder:{},handler:async o=>{try{await w(o);console.log(e.blue("Setting up the bin system...")),await g.createBinDirectoryStructure();const t=g.getBinDirectory();console.log(e.green(`Bin directory: ${t}`));if(g.checkIfInPath(t))console.log(e.green("Bin directory is already in PATH."));else{console.log(e.yellow("Bin directory is not in PATH."));const{confirmAddToPath:o}=await r({type:"confirm",name:"confirmAddToPath",message:`Would you like to add ${t} to your PATH?`,initial:!0});if(o){let o=g.detectUserShell();if("unknown"===o){const{selectedShell:e}=await r({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});o=e}else{const{confirmShell:e}=await r({type:"confirm",name:"confirmShell",message:`Detected shell: ${o}. Is this correct?`,initial:!0});if(!e){const{selectedShell:e}=await r({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});o=e}}const i=g.getAllShellConfigPaths(o);let a;if(i.length>1){const e=i.filter((e=>s.existsSync(e.path)));if(e.length>0){const{selectedConfigPath:o}=await r({type:"select",name:"selectedConfigPath",message:"Select the configuration file to modify:",choices:e.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});a=o}else{const{selectedConfigPath:e}=await r({type:"select",name:"selectedConfigPath",message:"Select the configuration file to create:",choices:i.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});a=e}}else if(1===i.length)a=i[0].path;else{const{enteredConfigPath:e}=await r({type:"input",name:"enteredConfigPath",message:"Enter the path to your shell configuration file:",initial:n.join(l.homedir(),".bashrc")});a=e}await g.addBinToPath(o,a,t)?(console.log(e.green(`Added bin directory to PATH in ${a}`)),console.log(e.yellow("Please restart your terminal or run the following command:")),console.log(e.green(`source ${a}`))):(console.log(e.red(`Failed to add bin directory to PATH in ${a}`)),console.log(e.yellow("You can add it manually by adding the following line to your shell configuration:")),console.log(e.green(g.getExportPathCommand(o,t))))}else console.log(e.yellow("You can add it manually by adding the following line to your shell configuration:")),console.log(e.green(`export PATH="${t}:$PATH"`)),console.log(e.yellow("Or run:")),console.log(e.green("fbin path"))}console.log(e.green("Bin system setup completed successfully."))}catch(o){console.error(e.red(`Failed to set up bin system: ${o.message}`)),process.exit(1)}}};var S={command:"path",describe:"Add bin directory to PATH",builder:{yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await w(o);const t=g.getBinDirectory();console.log(e.blue(`Adding ${t} to PATH...`)),g.createBinDirectoryStructure()||(console.log(e.yellow("Creating bin directory structure...")),await g.createBinDirectoryStructure());if(g.checkIfInPath(t))return void console.log(e.green("Bin directory is already in PATH."));let i=g.detectUserShell();if("unknown"===i)if(o.yes)i="win32"===process.platform?"powershell":"bash",console.log(e.yellow(`Auto-selecting ${i} shell due to --yes flag`));else{const{selectedShell:e}=await r({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});i=e}else if(o.yes)console.log(e.yellow(`Auto-confirming detected shell: ${i} due to --yes flag`));else{const{confirmShell:e}=await r({type:"confirm",name:"confirmShell",message:`Detected shell: ${i}. Is this correct?`,initial:!0});if(!e){const{selectedShell:e}=await r({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});i=e}}const a=g.getAllShellConfigPaths(i);let c;if(a.length>1){const t=a.filter((e=>s.existsSync(e.path)));if(t.length>0)if(o.yes)c=t[0].path,console.log(e.yellow(`Auto-selecting config file: ${c} due to --yes flag`));else{const{selectedConfigPath:e}=await r({type:"select",name:"selectedConfigPath",message:"Select the configuration file to modify:",choices:t.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});c=e}else if(o.yes)c=a[0].path,console.log(e.yellow(`Auto-selecting config file to create: ${c} due to --yes flag`));else{const{selectedConfigPath:e}=await r({type:"select",name:"selectedConfigPath",message:"Select the configuration file to create:",choices:a.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});c=e}}else if(1===a.length)c=a[0].path;else if(o.yes)c=n.join(l.homedir(),"win32"===process.platform?"_profile":".bashrc"),console.log(e.yellow(`Auto-selecting default config file: ${c} due to --yes flag`));else{const{enteredConfigPath:e}=await r({type:"input",name:"enteredConfigPath",message:"Enter the path to your shell configuration file:",initial:n.join(l.homedir(),".bashrc")});c=e}await g.addBinToPath(i,c,t)?(console.log(e.green(`Added bin directory to PATH in ${c}`)),console.log(e.yellow("Please restart your terminal or run the following command:")),console.log(e.green(`source ${c}`))):(console.log(e.red(`Failed to add bin directory to PATH in ${c}`)),console.log(e.yellow("You can add it manually by adding the following line to your shell configuration:")),console.log(e.green(g.getExportPathCommand(i,t))))}catch(o){console.error(e.red(`Failed to add bin directory to PATH: ${o.message}`)),process.exit(1)}}};var P={command:"compile [source] [options]",describe:"Compile a CLI project to a binary",builder:{source:{describe:"Source file to compile",type:"string",default:"./dist/cli/esm/index.js"},output:{describe:"Output file name",type:"string",alias:"o"},name:{describe:"Binary name",type:"string",alias:"n"},force:{describe:"Force overwrite if binary already exists",type:"boolean",default:!1,alias:"f"},target:{describe:"Target platform (auto, linux, macos, windows)",type:"string",choices:["auto","linux","macos","windows"],default:"auto"},minify:{describe:"Minify the output binary",type:"boolean",default:!0},external:{describe:"External packages to exclude from the bundle (comma-separated)",type:"string"}},handler:async o=>{try{await w(o);const t=process.cwd(),l=n.basename(t),i=o.name||l;let a;if(o.output)a=o.output;else{const e=n.join(t,".bin");s.existsSync(e)||s.mkdirSync(e,{recursive:!0}),a=n.join(e,i)}const c=n.resolve(process.cwd(),o.source);if(s.existsSync(c)||(console.error(e.red(`Source file not found: ${c}`)),console.error(e.yellow("Make sure to build your project first.")),process.exit(1)),s.existsSync(a)&&!o.force){const{confirmOverwrite:o}=await r({type:"confirm",name:"confirmOverwrite",message:`Binary already exists at ${a}. Overwrite?`,initial:!1});if(!o)return void console.log(e.yellow("Compilation cancelled."))}const m=process.platform;console.log(e.blue(`Detected platform: ${m}`)),"win32"!==m||a.endsWith(".exe")||(a=`${a}.exe`,console.log(e.blue(`Adjusted output path for Windows: ${a}`))),console.log(e.blue(`Compiling ${c} to ${a}...`));const{spawn:d}=await import("child_process");try{const e=d("bun",["--version"],{stdio:"pipe"});await new Promise(((o,t)=>{e.on("close",(e=>{0===e?o():t(new Error("Bun is not available. Please install Bun first."))})),e.on("error",(e=>{t(new Error(`Bun is not available: ${e.message}`))}))}))}catch(o){console.error(e.red(`Bun is not available: ${o.message}`)),console.error(e.yellow("Please install Bun first: https://bun.sh/")),process.exit(1)}const h=["build",c,"--compile",`--outfile=${a}`];if(o.target&&"auto"!==o.target&&h.push(`--target=${o.target}`),!1===o.minify&&h.push("--no-minify"),o.external){o.external.split(",").map((e=>e.trim())).forEach((e=>{h.push(`--external:${e}`)}))}console.log(e.blue(`Running: bun ${h.join(" ")}`));const u=d("bun",h,{stdio:"inherit"});await new Promise(((e,o)=>{u.on("close",(t=>{0===t?e():o(new Error(`Compilation failed with code ${t}`))})),u.on("error",(e=>{o(e)}))})),"win32"!==m&&s.chmodSync(a,493),console.log(e.green(`Binary compiled successfully: ${a}`)),"win32"===m?console.log(e.yellow("Note: On Windows, you may need to run the binary from a command prompt or PowerShell.")):"darwin"===m&&console.log(e.yellow("Note: On macOS, you may need to allow the binary to run in System Preferences > Security & Privacy."))}catch(o){console.error(e.red(`Failed to compile binary: ${o.message}`)),process.exit(1)}}};var $={command:"install [source] [options]",describe:"Install a binary to the bin directory",builder:{source:{describe:"Source binary to install",type:"string",demandOption:!0},name:{describe:"Name to use for the installed binary",type:"string",alias:"n"},force:{describe:"Force overwrite if binary already exists",type:"boolean",default:!1,alias:"f"},yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await w(o);const t=n.resolve(process.cwd(),o.source);s.existsSync(t)||(console.error(e.red(`Source file not found: ${t}`)),process.exit(1)),await g.createBinDirectoryStructure();const l=g.getBinDirectory();let i;i=o.name?o.name:n.basename(t),"win32"!==process.platform||i.endsWith(".exe")||(i=`${i}.exe`);const a=n.join(l,i);if(s.existsSync(a)&&!o.force&&!o.yes){const{confirmOverwrite:o}=await r({type:"confirm",name:"confirmOverwrite",message:`Binary already exists at ${a}. Overwrite?`,initial:!1});if(!o)return void console.log(e.yellow("Installation cancelled."))}console.log(e.blue(`Installing ${t} to ${a}...`)),s.copyFileSync(t,a),"win32"!==process.platform&&s.chmodSync(a,493);const c=g.getMetadataFilePath();let m={binaries:{},lastUpdated:(new Date).toISOString()};if(s.existsSync(c))try{m=JSON.parse(s.readFileSync(c,"utf8"))}catch(o){console.warn(e.yellow(`Failed to parse metadata file: ${o.message}`)),console.warn(e.yellow("Creating new metadata file."))}let d="0.0.0";try{const{execSync:o}=require("child_process"),t=o(`"${a}" --version`,{timeout:5e3,stdio:["ignore","pipe","ignore"]}).toString().trim(),n=t.match(/v?(\d+\.\d+\.\d+)/);n?(d=n[1],console.log(e.blue(`Detected binary version: ${d}`))):(console.log(e.yellow(`Could not parse version from output: ${t}`)),console.log(e.yellow(`Using default version: ${d}`)))}catch(o){console.log(e.yellow(`Could not detect binary version, using default: ${d}`))}m.binaries[i]={path:a,source:t,created:(new Date).toISOString(),platform:process.platform,version:d,project:n.basename(process.cwd())},m.lastUpdated=(new Date).toISOString(),s.writeFileSync(c,JSON.stringify(m,null,2)),console.log(e.green(`Binary installed successfully: ${a}`));g.checkIfInPath(l)?console.log(e.green(`You can now run '${i}' from anywhere.`)):console.log(e.yellow("Bin directory is not in PATH. Run 'fbin path' to add it."))}catch(o){console.error(e.red(`Failed to install binary: ${o.message}`)),process.exit(1)}}};var x={promptForSelection:async function(o){const{items:t,message:n,nameField:s="name",valueField:l="name",initialValue:i=null,allowAbort:a=!0}=o;if(!t||0===t.length)return console.log(e.yellow("No items available for selection.")),null;if(1===t.length&&!a){const o=t[0],n="string"==typeof o?o:o[l];return console.log(e.blue(`Only one option available: ${"string"==typeof o?o:o[s]}`)),n}let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[l],value:e[l],message:e[s]||e[l]}));a&&c.push({name:"cancel",value:null,message:e.yellow("Cancel")});let m=null;if(i){const e=c.findIndex((e=>e.name===i));-1!==e&&(m=e)}const d="selectedItem",{[d]:h}=await r({type:"select",name:d,message:n,choices:c,initial:m});return"cancel"===h?null:h},promptForMultipleSelection:async function(o){const{items:t,message:n,nameField:s="name",valueField:l="name",initialValues:i=[],allowAbort:a=!0}=o;if(!t||0===t.length)return console.log(e.yellow("No items available for selection.")),null;let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[l],value:e[l],message:e[s]||e[l]})),m=[];i&&i.length>0&&(m=c.map(((e,o)=>i.includes(e.name)?o:-1)).filter((e=>-1!==e)));const d="selectedItems",h=await r({type:"multiselect",name:d,message:n,choices:c,initial:m,hint:"(Use space to select, enter to confirm)",validate:e=>!(0===e.length&&!a)||"Please select at least one item"});return a&&0===h[d].length?null:h[d]}};var v={command:"uninstall [name] [options]",describe:"Uninstall a binary from the bin directory",builder:{name:{describe:"Name of the binary to uninstall",type:"string",demandOption:!1},force:{describe:"Skip confirmation prompt",type:"boolean",default:!1,alias:"f"},yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await w(o);const t=g.getBinDirectory(),n=g.getMetadataFilePath();let l;s.existsSync(t)||(console.error(e.red(`Bin directory not found: ${t}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1)),s.existsSync(n)||(console.error(e.red(`Metadata file not found: ${n}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1));try{l=JSON.parse(s.readFileSync(n,"utf8"))}catch(o){console.error(e.red(`Failed to parse metadata file: ${o.message}`)),process.exit(1)}if(!o.name&&!o.yes){const t=Object.keys(l.binaries);if(0===t.length)return void console.log(e.yellow("No binaries installed."));const n=await x.promptForSelection({items:t,message:"Select a binary to uninstall:",allowAbort:!0});if(null===n)return void console.log(e.yellow("Uninstallation cancelled."));o.name=n}const i=o.name;i||(console.error(e.red("Binary name is required.")),console.error(e.yellow("Use --name to specify a binary or run without --yes to select interactively.")),process.exit(1)),l.binaries[i]||(console.error(e.red(`Binary not found in metadata: ${i}`)),console.log(e.yellow("Use fbin list to see installed binaries.")),process.exit(1));const a=l.binaries[i].path;if(s.existsSync(a)||(console.warn(e.yellow(`Binary file not found: ${a}`)),console.warn(e.yellow("Metadata will be updated anyway."))),!o.force&&!o.yes){const{confirmUninstall:o}=await r({type:"confirm",name:"confirmUninstall",message:`Are you sure you want to uninstall ${i}?`,initial:!1});if(!o)return void console.log(e.yellow("Uninstallation cancelled."))}if(s.existsSync(a))try{s.unlinkSync(a),console.log(e.green(`Binary file removed: ${a}`))}catch(o){console.error(e.red(`Failed to remove binary file: ${o.message}`))}delete l.binaries[i],l.lastUpdated=(new Date).toISOString(),s.writeFileSync(n,JSON.stringify(l,null,2)),console.log(e.green(`Binary uninstalled successfully: ${i}`))}catch(o){console.error(e.red(`Failed to uninstall binary: ${o.message}`)),process.exit(1)}}};function A(o,t={}){const n={chars:{top:"─","top-mid":"─","top-left":" ","top-right":" ",bottom:"─","bottom-mid":"─","bottom-left":" ","bottom-right":" ",left:" ","left-mid":" ",mid:"─","mid-mid":"─",right:" ","right-mid":" ",middle:" "},style:{head:[],border:[],compact:!0},wordWrap:!0,...t,head:o.map((o=>e.bold(o)))};return new a(n)}var C={createTable:A,createTableWithData:function(e,o,t={}){const n=A(e,t);return Array.isArray(o)&&o.forEach((e=>{n.push(e)})),n.toString()},getStatusColor:function(o){switch(o){case"running":return e.green;case"stopped":return e.yellow;case"failed":return e.red;case"registered":return e.blue;default:return e.gray}}};var F={command:"list [options]",describe:"List installed binaries",builder:{json:{describe:"Output in JSON format",type:"boolean",default:!1,alias:"j"},filter:{describe:"Filter binaries by name",type:"string",alias:"f"}},handler:async o=>{try{await w(o);const t=g.getBinDirectory(),n=g.getMetadataFilePath();let l;s.existsSync(t)||(console.error(e.red(`Bin directory not found: ${t}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1)),s.existsSync(n)||(console.error(e.red(`Metadata file not found: ${n}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1));try{l=JSON.parse(s.readFileSync(n,"utf8"))}catch(o){console.error(e.red(`Failed to parse metadata file: ${o.message}`)),process.exit(1)}let r=l.binaries;if(o.filter){const e=o.filter.toLowerCase();r=Object.entries(r).filter((([o])=>o.toLowerCase().includes(e))).reduce(((e,[o,t])=>(e[o]=t,e)),{})}if(o.json)return void console.log(JSON.stringify(r,null,2));const i=Object.keys(r).length;if(0===i)return void console.log(e.yellow("No binaries installed."));console.log(e.blue(`Found ${i} installed binaries:`)),console.log();const a=["NAME","VERSION","PLATFORM","CREATED"],c=C.createTable(a,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});Object.entries(r).forEach((([o,t])=>{const n=new Date(t.created).toLocaleString();c.push([e.white(o),t.version||"N/A",t.platform||"N/A",n])})),console.log(c.toString()),console.log(),console.log(e.blue(`Bin directory: ${t}`));g.checkIfInPath(t)||console.log(e.yellow("Bin directory is not in PATH. Run 'fbin path' to add it."))}catch(o){console.error(e.red(`Failed to list binaries: ${o.message}`)),process.exit(1)}}};c(m);let j=!1;process.on("uncaughtException",(e=>{j||(j=!0,setTimeout((()=>process.exit(1)),500))})),process.on("unhandledRejection",(e=>{j||(j=!0,setTimeout((()=>process.exit(1)),500))})),async function(){try{o(t(process.argv)).usage("Usage: $0 <command> [options]").command(b).command(S).command(P).command($).command(v).command(F).demandCommand(1,"You need to specify a command").help().version().argv}catch(o){console.error(e.red(`Fatal error: ${o.message}`)),process.exit(1)}}().catch((o=>{console.error(e.red(`Fatal error: ${o.message}`)),process.exit(1)}));
2
+ import e from"chalk";import o from"yargs";import{hideBin as t}from"yargs/helpers";import s from"node:path";import n from"node:fs";import l from"node:os";import i from"@fnet/prompt";import{fileURLToPath as a}from"node:url";import r from"cli-table3";import{promisify as c}from"node:util";import d from"tree-kill";function m(){return s.join(l.homedir(),".fnet","bin")}function u(){return s.join(l.homedir(),".fnet","metadata")}function g(){return s.join(u(),"binaries.json")}function p(){try{if("win32"===process.platform)return process.env.PSModulePath&&process.env.PSModulePath.includes("PowerShell")?"powershell-core":process.env.PSModulePath?"powershell":"cmd";const e=process.env.SHELL||"";return e.includes("bash")?"bash":e.includes("zsh")?"zsh":e.includes("fish")?"fish":e.includes("ksh")?"ksh":e.includes("csh")||e.includes("tcsh")?"csh":n.existsSync(s.join(l.homedir(),".bashrc"))?"bash":n.existsSync(s.join(l.homedir(),".zshrc"))?"zsh":n.existsSync(s.join(l.homedir(),".config","fish","config.fish"))?"fish":"unknown"}catch(e){return"unknown"}}function f(e){const o=l.homedir(),t=[];switch(e){case"bash":t.push({name:".bashrc",path:s.join(o,".bashrc")}),t.push({name:".bash_profile",path:s.join(o,".bash_profile")}),t.push({name:".profile",path:s.join(o,".profile")});break;case"zsh":t.push({name:".zshrc",path:s.join(o,".zshrc")}),t.push({name:".zprofile",path:s.join(o,".zprofile")});break;case"fish":t.push({name:"config.fish",path:s.join(o,".config","fish","config.fish")});break;case"ksh":t.push({name:".kshrc",path:s.join(o,".kshrc")}),t.push({name:".profile",path:s.join(o,".profile")});break;case"csh":t.push({name:".cshrc",path:s.join(o,".cshrc")}),t.push({name:".tcshrc",path:s.join(o,".tcshrc")});break;case"powershell":t.push({name:"Microsoft.PowerShell_profile.ps1",path:s.join(o,"Documents","WindowsPowerShell","Microsoft.PowerShell_profile.ps1")}),t.push({name:"profile.ps1",path:s.join(o,"Documents","WindowsPowerShell","profile.ps1")});break;case"powershell-core":t.push({name:"Microsoft.PowerShell_profile.ps1",path:s.join(o,"Documents","PowerShell","Microsoft.PowerShell_profile.ps1")}),t.push({name:"profile.ps1",path:s.join(o,"Documents","PowerShell","profile.ps1")});break;case"cmd":t.push({name:"fnet-path.bat",path:s.join(o,"fnet-path.bat")})}return t}function h(e,o){switch(e){case"bash":case"zsh":case"ksh":default:return`export PATH="${o}:$PATH"`;case"fish":return`set -gx PATH ${o} $PATH`;case"csh":return`setenv PATH ${o}:$PATH`;case"powershell":case"powershell-core":return`$env:PATH = "${o};" + $env:PATH`;case"cmd":return`@echo off\nSETX PATH "%PATH%;${o}"\necho Path updated successfully`}}function y(){return s.join(l.homedir(),".fnet","backups")}function b(){const e=(new Date).toISOString().replace(/:/g,"-").replace(/\..+/,""),o=s.join(y(),e);return n.existsSync(o)||n.mkdirSync(o,{recursive:!0}),o}function w(o,t,l=null){try{if(!n.existsSync(o))return!1;const e=l||s.basename(o),i=s.join(t,e),a=s.dirname(i);return n.existsSync(a)||n.mkdirSync(a,{recursive:!0}),n.copyFileSync(o,i),!0}catch(t){return console.error(e.red(`Failed to backup file ${o}: ${t.message}`)),!1}}function S(e,o={}){const t={timestamp:(new Date).toISOString(),type:o.type||"manual",message:o.message||"",command:o.command||"",files:o.files||[],...o},l=s.join(e,"metadata.json");n.writeFileSync(l,JSON.stringify(t,null,2))}function $(o){const t=s.join(y(),"latest");try{n.existsSync(t)&&n.unlinkSync(t),"win32"===process.platform?n.writeFileSync(t+".txt",o):n.symlinkSync(o,t)}catch(o){console.warn(e.yellow(`Could not create latest symlink: ${o.message}`))}}var k={getBinDirectory:m,getMetadataDirectory:u,getMetadataFilePath:g,checkIfInPath:function(e){return(process.env.PATH||"").split(s.delimiter).includes(e)},detectUserShell:p,getShellConfigPath:function(){const e=f(p());for(const o of e)if(n.existsSync(o.path))return o.path;return e.length>0?e[0].path:null},getAllShellConfigPaths:f,createBinDirectoryStructure:async function(){const e=m(),o=u(),t=g();n.existsSync(e)||n.mkdirSync(e,{recursive:!0}),n.existsSync(o)||n.mkdirSync(o,{recursive:!0}),n.existsSync(t)||n.writeFileSync(t,JSON.stringify({binaries:{},lastUpdated:(new Date).toISOString()},null,2))},getExportPathCommand:h,addBinToPath:async function(o,t,l,i={}){try{const{autoBackup:a=!0}=i,r=h(o,l);if("cmd"===o)return n.writeFileSync(t,r),console.log(e.yellow(`Created batch file at ${t}`)),console.log(e.yellow("Run this file to add the bin directory to your PATH")),!0;if("powershell"!==o&&"powershell-core"!==o||n.existsSync(s.dirname(t))||n.mkdirSync(s.dirname(t),{recursive:!0}),!n.existsSync(t)){const s="fish"===o?"# Fish shell configuration\n\n":"powershell"===o||"powershell-core"===o?"# PowerShell profile\n\n":"# Shell configuration\n\n";n.writeFileSync(t,s),console.log(e.green(`Created config file at ${t}`))}const c=n.readFileSync(t,"utf8");if(c.includes(l))return!0;if(a&&n.existsSync(t)){const o=b(),n=s.basename(t);w(t,s.join(o,"configs"),n)&&(S(o,{type:"auto",command:"addBinToPath",message:`Automatic backup before modifying ${n}`,files:[t]}),$(o),console.log(e.green(`✓ Backed up ${n} to ${o}`)))}const d=`${c.trim()}\n\n# Added by @fnet/cli\n${r}\n`;return n.writeFileSync(t,d),"powershell"!==o&&"powershell-core"!==o||(console.log(e.yellow("You may need to set the PowerShell execution policy to run scripts:")),console.log(e.green("Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned"))),!0}catch(o){return console.error(e.red(`Failed to add bin directory to PATH: ${o.message}`)),!1}},getBackupDirectory:y,createBackupDirectory:b,backupFile:w,createBackupMetadata:S,listBackups:function(){const e=y();if(!n.existsSync(e))return[];const o=[],t=n.readdirSync(e);for(const l of t){const t=s.join(e,l),i=n.statSync(t);if(i.isDirectory()&&"latest"!==l){const e=s.join(t,"metadata.json");let a={};if(n.existsSync(e))try{a=JSON.parse(n.readFileSync(e,"utf8"))}catch(e){}o.push({timestamp:l,path:t,created:i.mtime,...a})}}return o.sort(((e,o)=>new Date(o.created)-new Date(e.created))),o},updateLatestSymlink:$};async function P(e){const o=function(){const e=l.homedir(),o=s.join(e,".fnet","bin");return n.existsSync(o)||n.mkdirSync(o,{recursive:!0}),o}(),t=function(){const e=l.homedir(),o=s.join(e,".fnet");return n.existsSync(o)||n.mkdirSync(o,{recursive:!0}),s.join(o,"bin-registry.json")}();let i={};if(n.existsSync(t))try{const e=n.readFileSync(t,"utf8");i=JSON.parse(e)}catch(e){console.warn(`Warning: Could not parse bin registry: ${e.message}`)}return{binDir:o,registryPath:t,registry:i,args:e}}s.dirname(a(import.meta.url));var v={command:"setup",describe:"Initialize the bin system",builder:{yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await P(o);console.log(e.blue("Setting up the bin system...")),await k.createBinDirectoryStructure();const t=k.getBinDirectory();console.log(e.green(`Bin directory: ${t}`));if(k.checkIfInPath(t))console.log(e.green("Bin directory is already in PATH."));else{console.log(e.yellow("Bin directory is not in PATH."));let a=o.yes;if(o.yes)console.log(e.yellow("Auto-confirming to add bin directory to PATH due to --yes flag"));else{a=(await i({type:"confirm",name:"confirmAddToPath",message:`Would you like to add ${t} to your PATH?`,initial:!0})).confirmAddToPath}if(a){let a=k.detectUserShell();if("unknown"===a)if(o.yes)a="win32"===process.platform?"powershell":"bash",console.log(e.yellow(`Auto-selecting ${a} shell due to --yes flag`));else{const{selectedShell:e}=await i({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});a=e}else if(o.yes)console.log(e.yellow(`Auto-confirming detected shell: ${a} due to --yes flag`));else{const{confirmShell:e}=await i({type:"confirm",name:"confirmShell",message:`Detected shell: ${a}. Is this correct?`,initial:!0});if(!e){const{selectedShell:e}=await i({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});a=e}}const r=k.getAllShellConfigPaths(a);let c;if(r.length>1){const t=r.filter((e=>n.existsSync(e.path)));if(t.length>0)if(o.yes)c=t[0].path,console.log(e.yellow(`Auto-selecting config file: ${c} due to --yes flag`));else{const{selectedConfigPath:e}=await i({type:"select",name:"selectedConfigPath",message:"Select the configuration file to modify:",choices:t.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});c=e}else if(o.yes)c=r[0].path,console.log(e.yellow(`Auto-selecting config file to create: ${c} due to --yes flag`));else{const{selectedConfigPath:e}=await i({type:"select",name:"selectedConfigPath",message:"Select the configuration file to create:",choices:r.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});c=e}}else if(1===r.length)c=r[0].path;else if(o.yes)c=s.join(l.homedir(),"win32"===process.platform?"_profile":".bashrc"),console.log(e.yellow(`Auto-selecting default config file: ${c} due to --yes flag`));else{const{enteredConfigPath:e}=await i({type:"input",name:"enteredConfigPath",message:"Enter the path to your shell configuration file:",initial:s.join(l.homedir(),".bashrc")});c=e}await k.addBinToPath(a,c,t)?(console.log(e.green(`Added bin directory to PATH in ${c}`)),console.log(e.yellow("Please restart your terminal or run the following command:")),console.log(e.green(`source ${c}`))):(console.log(e.red(`Failed to add bin directory to PATH in ${c}`)),console.log(e.yellow("You can add it manually by adding the following line to your shell configuration:")),console.log(e.green(k.getExportPathCommand(a,t))))}else console.log(e.yellow("You can add it manually by adding the following line to your shell configuration:")),console.log(e.green(`export PATH="${t}:$PATH"`)),console.log(e.yellow("Or run:")),console.log(e.green("fbin path"))}console.log(e.green("Bin system setup completed successfully."))}catch(o){console.error(e.red(`Failed to set up bin system: ${o.message}`)),process.exit(1)}}};var x={command:"path",describe:"Add bin directory to PATH",builder:{yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await P(o);const t=k.getBinDirectory();console.log(e.blue(`Adding ${t} to PATH...`)),k.createBinDirectoryStructure()||(console.log(e.yellow("Creating bin directory structure...")),await k.createBinDirectoryStructure());if(k.checkIfInPath(t))return void console.log(e.green("Bin directory is already in PATH."));let a=k.detectUserShell();if("unknown"===a)if(o.yes)a="win32"===process.platform?"powershell":"bash",console.log(e.yellow(`Auto-selecting ${a} shell due to --yes flag`));else{const{selectedShell:e}=await i({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});a=e}else if(o.yes)console.log(e.yellow(`Auto-confirming detected shell: ${a} due to --yes flag`));else{const{confirmShell:e}=await i({type:"confirm",name:"confirmShell",message:`Detected shell: ${a}. Is this correct?`,initial:!0});if(!e){const{selectedShell:e}=await i({type:"select",name:"selectedShell",message:"Select your shell:",choices:[{name:"bash",message:"Bash"},{name:"zsh",message:"Zsh"},{name:"fish",message:"Fish"},{name:"powershell",message:"PowerShell"},{name:"powershell-core",message:"PowerShell Core"},{name:"cmd",message:"Windows Command Prompt"},{name:"ksh",message:"Korn Shell (ksh)"},{name:"csh",message:"C Shell (csh/tcsh)"}]});a=e}}const r=k.getAllShellConfigPaths(a);let c;if(r.length>1){const t=r.filter((e=>n.existsSync(e.path)));if(t.length>0)if(o.yes)c=t[0].path,console.log(e.yellow(`Auto-selecting config file: ${c} due to --yes flag`));else{const{selectedConfigPath:e}=await i({type:"select",name:"selectedConfigPath",message:"Select the configuration file to modify:",choices:t.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});c=e}else if(o.yes)c=r[0].path,console.log(e.yellow(`Auto-selecting config file to create: ${c} due to --yes flag`));else{const{selectedConfigPath:e}=await i({type:"select",name:"selectedConfigPath",message:"Select the configuration file to create:",choices:r.map((e=>({name:e.path,message:`${e.name} (${e.path})`})))});c=e}}else if(1===r.length)c=r[0].path;else if(o.yes)c=s.join(l.homedir(),"win32"===process.platform?"_profile":".bashrc"),console.log(e.yellow(`Auto-selecting default config file: ${c} due to --yes flag`));else{const{enteredConfigPath:e}=await i({type:"input",name:"enteredConfigPath",message:"Enter the path to your shell configuration file:",initial:s.join(l.homedir(),".bashrc")});c=e}await k.addBinToPath(a,c,t)?(console.log(e.green(`Added bin directory to PATH in ${c}`)),console.log(e.yellow("Please restart your terminal or run the following command:")),console.log(e.green(`source ${c}`))):(console.log(e.red(`Failed to add bin directory to PATH in ${c}`)),console.log(e.yellow("You can add it manually by adding the following line to your shell configuration:")),console.log(e.green(k.getExportPathCommand(a,t))))}catch(o){console.error(e.red(`Failed to add bin directory to PATH: ${o.message}`)),process.exit(1)}}};var A={command:"compile [source] [options]",describe:"Compile a CLI project to a binary",builder:{source:{describe:"Source file to compile",type:"string",default:"./dist/cli/esm/index.js"},output:{describe:"Output file name",type:"string",alias:"o"},name:{describe:"Binary name",type:"string",alias:"n"},force:{describe:"Force overwrite if binary already exists",type:"boolean",default:!1,alias:"f"},yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"},target:{describe:"Target platform (auto, linux, macos, windows)",type:"string",choices:["auto","linux","macos","windows"],default:"auto"},minify:{describe:"Minify the output binary",type:"boolean",default:!0},external:{describe:"External packages to exclude from the bundle (comma-separated)",type:"string"}},handler:async o=>{try{await P(o);const t=process.cwd(),l=s.basename(t),a=o.name||l;let r;if(o.output)r=o.output;else{const e=s.join(t,".bin");n.existsSync(e)||n.mkdirSync(e,{recursive:!0}),r=s.join(e,a)}const c=s.resolve(process.cwd(),o.source);if(n.existsSync(c)||(console.error(e.red(`Source file not found: ${c}`)),console.error(e.yellow("Make sure to build your project first.")),process.exit(1)),n.existsSync(r)&&!o.force&&!o.yes){const{confirmOverwrite:o}=await i({type:"confirm",name:"confirmOverwrite",message:`Binary already exists at ${r}. Overwrite?`,initial:!1});if(!o)return void console.log(e.yellow("Compilation cancelled."))}const d=process.platform;console.log(e.blue(`Detected platform: ${d}`)),"win32"!==d||r.endsWith(".exe")||(r=`${r}.exe`,console.log(e.blue(`Adjusted output path for Windows: ${r}`))),console.log(e.blue(`Compiling ${c} to ${r}...`));const{spawn:m}=await import("child_process");try{const e=m("bun",["--version"],{stdio:"pipe"});await new Promise(((o,t)=>{e.on("close",(e=>{0===e?o():t(new Error("Bun is not available. Please install Bun first."))})),e.on("error",(e=>{t(new Error(`Bun is not available: ${e.message}`))}))}))}catch(o){console.error(e.red(`Bun is not available: ${o.message}`)),console.error(e.yellow("Please install Bun first: https://bun.sh/")),process.exit(1)}const u=["build",c,"--compile",`--outfile=${r}`];if(o.target&&"auto"!==o.target&&u.push(`--target=${o.target}`),!1===o.minify&&u.push("--no-minify"),o.external){o.external.split(",").map((e=>e.trim())).forEach((e=>{u.push(`--external:${e}`)}))}console.log(e.blue(`Running: bun ${u.join(" ")}`));const g=m("bun",u,{stdio:"inherit"});await new Promise(((e,o)=>{g.on("close",(t=>{0===t?e():o(new Error(`Compilation failed with code ${t}`))})),g.on("error",(e=>{o(e)}))})),"win32"!==d&&n.chmodSync(r,493),console.log(e.green(`Binary compiled successfully: ${r}`)),"win32"===d?console.log(e.yellow("Note: On Windows, you may need to run the binary from a command prompt or PowerShell.")):"darwin"===d&&console.log(e.yellow("Note: On macOS, you may need to allow the binary to run in System Preferences > Security & Privacy."))}catch(o){console.error(e.red(`Failed to compile binary: ${o.message}`)),process.exit(1)}}};var B={command:"install [source] [options]",describe:"Install a binary to the bin directory",builder:{source:{describe:"Source binary to install",type:"string",demandOption:!0},name:{describe:"Name to use for the installed binary",type:"string",alias:"n"},force:{describe:"Force overwrite if binary already exists",type:"boolean",default:!1,alias:"f"},yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await P(o);const t=s.resolve(process.cwd(),o.source);n.existsSync(t)||(console.error(e.red(`Source file not found: ${t}`)),process.exit(1)),await k.createBinDirectoryStructure();const l=k.getBinDirectory();let a;a=o.name?o.name:s.basename(t),"win32"!==process.platform||a.endsWith(".exe")||(a=`${a}.exe`);const r=s.join(l,a);if(n.existsSync(r)&&!o.force&&!o.yes){const{confirmOverwrite:o}=await i({type:"confirm",name:"confirmOverwrite",message:`Binary already exists at ${r}. Overwrite?`,initial:!1});if(!o)return void console.log(e.yellow("Installation cancelled."))}console.log(e.blue(`Installing ${t} to ${r}...`)),n.copyFileSync(t,r),"win32"!==process.platform&&n.chmodSync(r,493);const c=k.getMetadataFilePath();let d={binaries:{},lastUpdated:(new Date).toISOString()};if(n.existsSync(c))try{d=JSON.parse(n.readFileSync(c,"utf8"))}catch(o){console.warn(e.yellow(`Failed to parse metadata file: ${o.message}`)),console.warn(e.yellow("Creating new metadata file."))}let m="0.0.0";try{const{execSync:o}=require("child_process"),t=o(`"${r}" --version`,{timeout:5e3,stdio:["ignore","pipe","ignore"]}).toString().trim(),s=t.match(/v?(\d+\.\d+\.\d+)/);s?(m=s[1],console.log(e.blue(`Detected binary version: ${m}`))):(console.log(e.yellow(`Could not parse version from output: ${t}`)),console.log(e.yellow(`Using default version: ${m}`)))}catch(o){console.log(e.yellow(`Could not detect binary version, using default: ${m}`))}d.binaries[a]={path:r,source:t,created:(new Date).toISOString(),platform:process.platform,version:m,project:s.basename(process.cwd())},d.lastUpdated=(new Date).toISOString(),n.writeFileSync(c,JSON.stringify(d,null,2)),console.log(e.green(`Binary installed successfully: ${r}`));k.checkIfInPath(l)?console.log(e.green(`You can now run '${a}' from anywhere.`)):console.log(e.yellow("Bin directory is not in PATH. Run 'fbin path' to add it."))}catch(o){console.error(e.red(`Failed to install binary: ${o.message}`)),process.exit(1)}}};var F={promptForSelection:async function(o){const{items:t,message:s,nameField:n="name",valueField:l="name",initialValue:a=null,allowAbort:r=!0}=o;if(!t||0===t.length)return console.log(e.yellow("No items available for selection.")),null;if(1===t.length&&!r){const o=t[0],s="string"==typeof o?o:o[l];return console.log(e.blue(`Only one option available: ${"string"==typeof o?o:o[n]}`)),s}let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[l],value:e[l],message:e[n]||e[l]}));r&&c.push({name:"cancel",value:null,message:e.yellow("Cancel")});let d=null;if(a){const e=c.findIndex((e=>e.name===a));-1!==e&&(d=e)}const m="selectedItem",{[m]:u}=await i({type:"select",name:m,message:s,choices:c,initial:d});return"cancel"===u?null:u},promptForMultipleSelection:async function(o){const{items:t,message:s,nameField:n="name",valueField:l="name",initialValues:a=[],allowAbort:r=!0}=o;if(!t||0===t.length)return console.log(e.yellow("No items available for selection.")),null;let c=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[l],value:e[l],message:e[n]||e[l]})),d=[];a&&a.length>0&&(d=c.map(((e,o)=>a.includes(e.name)?o:-1)).filter((e=>-1!==e)));const m="selectedItems",u=await i({type:"multiselect",name:m,message:s,choices:c,initial:d,hint:"(Use space to select, enter to confirm)",validate:e=>!(0===e.length&&!r)||"Please select at least one item"});return r&&0===u[m].length?null:u[m]}};var j={command:"uninstall [name] [options]",describe:"Uninstall a binary from the bin directory",builder:{name:{describe:"Name of the binary to uninstall",type:"string",demandOption:!1},force:{describe:"Skip confirmation prompt",type:"boolean",default:!1,alias:"f"},yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await P(o);const t=k.getBinDirectory(),s=k.getMetadataFilePath();let l;n.existsSync(t)||(console.error(e.red(`Bin directory not found: ${t}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1)),n.existsSync(s)||(console.error(e.red(`Metadata file not found: ${s}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1));try{l=JSON.parse(n.readFileSync(s,"utf8"))}catch(o){console.error(e.red(`Failed to parse metadata file: ${o.message}`)),process.exit(1)}if(!o.name&&!o.yes){const t=Object.keys(l.binaries);if(0===t.length)return void console.log(e.yellow("No binaries installed."));const s=await F.promptForSelection({items:t,message:"Select a binary to uninstall:",allowAbort:!0});if(null===s)return void console.log(e.yellow("Uninstallation cancelled."));o.name=s}const a=o.name;a||(console.error(e.red("Binary name is required.")),console.error(e.yellow("Use --name to specify a binary or run without --yes to select interactively.")),process.exit(1)),l.binaries[a]||(console.error(e.red(`Binary not found in metadata: ${a}`)),console.log(e.yellow("Use fbin list to see installed binaries.")),process.exit(1));const r=l.binaries[a].path;if(n.existsSync(r)||(console.warn(e.yellow(`Binary file not found: ${r}`)),console.warn(e.yellow("Metadata will be updated anyway."))),!o.force&&!o.yes){const{confirmUninstall:o}=await i({type:"confirm",name:"confirmUninstall",message:`Are you sure you want to uninstall ${a}?`,initial:!1});if(!o)return void console.log(e.yellow("Uninstallation cancelled."))}if(n.existsSync(r))try{n.unlinkSync(r),console.log(e.green(`Binary file removed: ${r}`))}catch(o){console.error(e.red(`Failed to remove binary file: ${o.message}`))}delete l.binaries[a],l.lastUpdated=(new Date).toISOString(),n.writeFileSync(s,JSON.stringify(l,null,2)),console.log(e.green(`Binary uninstalled successfully: ${a}`))}catch(o){console.error(e.red(`Failed to uninstall binary: ${o.message}`)),process.exit(1)}}};function C(o,t={}){const s={chars:{top:"─","top-mid":"─","top-left":" ","top-right":" ",bottom:"─","bottom-mid":"─","bottom-left":" ","bottom-right":" ",left:" ","left-mid":" ",mid:"─","mid-mid":"─",right:" ","right-mid":" ",middle:" "},style:{head:[],border:[],compact:!0},wordWrap:!0,...t,head:o.map((o=>e.bold(o)))};return new r(s)}var T={createTable:C,createTableWithData:function(e,o,t={}){const s=C(e,t);return Array.isArray(o)&&o.forEach((e=>{s.push(e)})),s.toString()},getStatusColor:function(o){switch(o){case"running":return e.green;case"stopped":return e.yellow;case"failed":return e.red;case"registered":return e.blue;default:return e.gray}}};var D={command:"list [options]",describe:"List installed binaries",builder:{json:{describe:"Output in JSON format",type:"boolean",default:!1,alias:"j"},filter:{describe:"Filter binaries by name",type:"string",alias:"f"}},handler:async o=>{try{await P(o);const t=k.getBinDirectory(),s=k.getMetadataFilePath();let l;n.existsSync(t)||(console.error(e.red(`Bin directory not found: ${t}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1)),n.existsSync(s)||(console.error(e.red(`Metadata file not found: ${s}`)),console.error(e.yellow("Run fbin setup first.")),process.exit(1));try{l=JSON.parse(n.readFileSync(s,"utf8"))}catch(o){console.error(e.red(`Failed to parse metadata file: ${o.message}`)),process.exit(1)}let i=l.binaries;if(o.filter){const e=o.filter.toLowerCase();i=Object.entries(i).filter((([o])=>o.toLowerCase().includes(e))).reduce(((e,[o,t])=>(e[o]=t,e)),{})}if(o.json)return void console.log(JSON.stringify(i,null,2));const a=Object.keys(i).length;if(0===a)return void console.log(e.yellow("No binaries installed."));console.log(e.blue(`Found ${a} installed binaries:`)),console.log();const r=["NAME","VERSION","PLATFORM","CREATED"],c=T.createTable(r,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});Object.entries(i).forEach((([o,t])=>{const s=new Date(t.created).toLocaleString();c.push([e.white(o),t.version||"N/A",t.platform||"N/A",s])})),console.log(c.toString()),console.log(),console.log(e.blue(`Bin directory: ${t}`));k.checkIfInPath(t)||console.log(e.yellow("Bin directory is not in PATH. Run 'fbin path' to add it."))}catch(o){console.error(e.red(`Failed to list binaries: ${o.message}`)),process.exit(1)}}};var O={command:"backup [options]",describe:"Backup shell configs and binaries",builder:{config:{describe:"Backup shell configuration files",type:"boolean",default:!1,alias:"c"},binaries:{describe:"Backup installed binaries",type:"boolean",default:!1,alias:"b"},all:{describe:"Backup everything (configs + binaries)",type:"boolean",default:!1,alias:"a"},message:{describe:"Backup description message",type:"string",alias:"m"}},handler:async o=>{try{await P(o);const t=o.all||!o.config&&!o.binaries,l=o.config||t,i=o.binaries||t;console.log(e.blue("Creating backup..."));const a=k.createBackupDirectory(),r=[];if(l){console.log(e.blue("Backing up shell configurations..."));const o=s.join(a,"configs");n.mkdirSync(o,{recursive:!0});const t=k.detectUserShell(),l=k.getAllShellConfigPaths(t);let i=0;for(const t of l)if(n.existsSync(t.path)){k.backupFile(t.path,o,t.name)&&(r.push(t.path),i++,console.log(e.green(` ✓ ${t.name}`)))}0===i?console.log(e.yellow(" No configuration files found to backup")):console.log(e.green(` Backed up ${i} configuration file(s)`))}if(i){console.log(e.blue("Backing up binaries..."));const o=s.join(a,"binaries");n.mkdirSync(o,{recursive:!0});const t=k.getBinDirectory(),l=k.getMetadataFilePath();if(n.existsSync(l)&&(k.backupFile(l,o,"metadata.json"),r.push(l)),n.existsSync(t)){const l=n.readdirSync(t);let i=0;for(const a of l){const l=s.join(t,a);if(n.statSync(l).isFile()){k.backupFile(l,o,a)&&(r.push(l),i++,console.log(e.green(` ✓ ${a}`)))}}0===i?console.log(e.yellow(" No binaries found to backup")):console.log(e.green(` Backed up ${i} binary(ies)`))}else console.log(e.yellow(" Bin directory not found"))}k.createBackupMetadata(a,{type:"manual",command:"fbin backup",message:o.message||"Manual backup",files:r,config:l,binaries:i}),k.updateLatestSymlink(a),console.log(),console.log(e.green("✓ Backup created successfully!")),console.log(e.blue(` Location: ${a}`)),console.log(e.blue(` Files backed up: ${r.length}`)),o.message&&console.log(e.blue(` Message: ${o.message}`))}catch(o){console.error(e.red(`Failed to create backup: ${o.message}`)),process.exit(1)}}};var M={command:"restore [options]",describe:"Restore from backup",builder:{config:{describe:"Restore shell configuration files",type:"boolean",default:!1,alias:"c"},binaries:{describe:"Restore installed binaries",type:"boolean",default:!1,alias:"b"},all:{describe:"Restore everything (configs + binaries)",type:"boolean",default:!1,alias:"a"},list:{describe:"List available backups",type:"boolean",default:!1,alias:"l"},timestamp:{describe:"Backup timestamp to restore (defaults to latest)",type:"string",alias:"t"},yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"}},handler:async o=>{try{await P(o);if(o.list){const o=k.listBackups();if(0===o.length)return void console.log(e.yellow("No backups found."));console.log(e.blue(`Found ${o.length} backup(s):\n`));const t=["TIMESTAMP","TYPE","MESSAGE","FILES"],s=T.createTable(t,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});for(const t of o){const o=t.timestamp||"unknown",n=t.type||"manual",l=t.message||"",i=t.files?t.files.length:0;s.push([e.white(o),n,l.substring(0,40)+(l.length>40?"...":""),i.toString()])}return console.log(s.toString()),console.log(),void console.log(e.blue(`Backup directory: ${k.getBackupDirectory()}`))}const t=k.listBackups();if(0===t.length)return console.log(e.yellow("No backups found.")),void console.log(e.blue("Create a backup first with: fbin backup"));let l;if(o.timestamp)l=t.find((e=>e.timestamp===o.timestamp)),l||(console.error(e.red(`Backup not found: ${o.timestamp}`)),console.log(e.yellow("Use --list to see available backups")),process.exit(1));else if(o.yes)l=t[0],console.log(e.yellow(`Auto-selecting latest backup: ${l.timestamp}`));else{const o=t.map((e=>({name:e.timestamp,message:`${e.timestamp} - ${e.message||"No message"} (${e.files?.length||0} files)`}))),s=await F.promptForSelection({items:o.map((e=>e.name)),message:"Select a backup to restore:",allowAbort:!0});if(null===s)return void console.log(e.yellow("Restore cancelled."));l=t.find((e=>e.timestamp===s))}console.log(e.blue(`Restoring from backup: ${l.timestamp}`));const a=o.all||!o.config&&!o.binaries,r=o.config||a,c=o.binaries||a;if(!o.yes){const{confirmRestore:o}=await i({type:"confirm",name:"confirmRestore",message:"This will overwrite current files. Continue?",initial:!1});if(!o)return void console.log(e.yellow("Restore cancelled."))}let d=0;if(r){const o=s.join(l.path,"configs");if(n.existsSync(o)){console.log(e.blue("Restoring shell configurations..."));const t=n.readdirSync(o);for(const l of t){const t=s.join(o,l),i=k.detectUserShell(),a=k.getAllShellConfigPaths(i).find((e=>e.name===l));if(a){const o=a.path,i=s.dirname(o);n.existsSync(i)||n.mkdirSync(i,{recursive:!0}),n.copyFileSync(t,o),console.log(e.green(` ✓ ${l}`)),d++}}}}if(c){const o=s.join(l.path,"binaries");if(n.existsSync(o)){console.log(e.blue("Restoring binaries..."));const t=k.getBinDirectory();n.existsSync(t)||n.mkdirSync(t,{recursive:!0});const l=n.readdirSync(o);for(const i of l){const l=s.join(o,i),a=s.join(t,i);if("metadata.json"!==i)n.copyFileSync(l,a),"win32"!==process.platform&&n.chmodSync(a,493),console.log(e.green(` ✓ ${i}`)),d++;else{const o=k.getMetadataFilePath(),t=s.dirname(o);n.existsSync(t)||n.mkdirSync(t,{recursive:!0}),n.copyFileSync(l,o),console.log(e.green(" ✓ metadata.json")),d++}}}}console.log(),console.log(e.green("✓ Restore completed successfully!")),console.log(e.blue(` Files restored: ${d}`))}catch(o){console.error(e.red(`Failed to restore backup: ${o.message}`)),process.exit(1)}}};var N={command:"cleanup [options]",describe:"Clean up old backups",builder:{keep:{describe:"Number of recent backups to keep",type:"number",default:10,alias:"k"},older:{describe:"Remove backups older than N days",type:"number",alias:"o"},all:{describe:"Remove all backups",type:"boolean",default:!1,alias:"a"},yes:{describe:"Automatically answer yes to all prompts",type:"boolean",default:!1,alias:"y"},"dry-run":{describe:"Show what would be deleted without actually deleting",type:"boolean",default:!1,alias:"d"}},handler:async o=>{try{await P(o);const t=k.listBackups();if(0===t.length)return void console.log(e.yellow("No backups found."));console.log(e.blue(`Found ${t.length} backup(s)`));let l=[];if(o.all)l=t;else if(o.older){const s=new Date;s.setDate(s.getDate()-o.older),l=t.filter((e=>new Date(e.created)<s)),console.log(e.blue(`Removing backups older than ${o.older} days (before ${s.toLocaleDateString()})`))}else{if(!(t.length>o.keep))return void console.log(e.green(`Only ${t.length} backup(s) found, keeping all (limit: ${o.keep})`));l=t.slice(o.keep),console.log(e.blue(`Keeping ${o.keep} most recent backup(s), removing ${l.length} old backup(s)`))}if(0===l.length)return void console.log(e.green("No backups to delete."));console.log(),console.log(e.yellow(`Backups to be deleted (${l.length}):`)),console.log();const a=["TIMESTAMP","TYPE","MESSAGE","FILES","SIZE"],r=T.createTable(a,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});let c=0;for(const o of l){const t=o.timestamp||"unknown",l=o.type||"manual",i=o.message||"",a=o.files?o.files.length:0;let d=0;try{const e=o=>{let t=0;const l=n.readdirSync(o);for(const i of l){const l=s.join(o,i),a=n.statSync(l);a.isDirectory()?t+=e(l):t+=a.size}return t};d=e(o.path),c+=d}catch(e){}const m=d>0?`${(d/1024/1024).toFixed(2)} MB`:"N/A";r.push([e.white(t),l,i.substring(0,30)+(i.length>30?"...":""),a.toString(),m])}if(console.log(r.toString()),console.log(),console.log(e.blue(`Total size to free: ${(c/1024/1024).toFixed(2)} MB`)),o["dry-run"])return console.log(),console.log(e.yellow("DRY RUN: No backups were deleted.")),void console.log(e.blue("Run without --dry-run to actually delete these backups."));if(!o.yes){console.log();const{confirmDelete:o}=await i({type:"confirm",name:"confirmDelete",message:`Delete ${l.length} backup(s)?`,initial:!1});if(!o)return void console.log(e.yellow("Cleanup cancelled."))}console.log(),console.log(e.blue("Deleting backups..."));let d=0,m=0;for(const o of l)try{n.rmSync(o.path,{recursive:!0,force:!0}),console.log(e.green(` ✓ ${o.timestamp}`)),d++}catch(t){console.log(e.red(` ✗ ${o.timestamp}: ${t.message}`)),m++}console.log(),console.log(e.green("✓ Cleanup completed!")),console.log(e.blue(` Deleted: ${d}`)),m>0&&console.log(e.yellow(` Failed: ${m}`)),console.log(e.blue(` Space freed: ${(c/1024/1024).toFixed(2)} MB`));const u=k.listBackups();console.log(e.blue(` Remaining backups: ${u.length}`))}catch(o){console.error(e.red(`Failed to cleanup backups: ${o.message}`)),process.exit(1)}}};c(d);let I=!1;process.on("uncaughtException",(e=>{I||(I=!0,setTimeout((()=>process.exit(1)),500))})),process.on("unhandledRejection",(e=>{I||(I=!0,setTimeout((()=>process.exit(1)),500))})),async function(){try{o(t(process.argv)).usage("Usage: $0 <command> [options]").command(v).command(x).command(A).command(B).command(j).command(D).command(O).command(M).command(N).demandCommand(1,"You need to specify a command").help().version().argv}catch(o){console.error(e.red(`Fatal error: ${o.message}`)),process.exit(1)}}().catch((o=>{console.error(e.red(`Fatal error: ${o.message}`)),process.exit(1)}));
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import e from"yargs";import t from"chalk";import{promisify as o}from"node:util";import n from"tree-kill";import i,{delimiter as s,join as r}from"node:path";import{fileURLToPath as a}from"node:url";import{spawn as c}from"node:child_process";import l,{existsSync as p}from"node:fs";import d from"@fnet/config";import f from"node:os";import m from"@flownet/lib-render-templates-dir";import u from"@fnet/shelljs";import y from"@fnet/yaml";import h from"yaml";import g from"nunjucks";import w from"lodash.clonedeep";import b from"isobject";import x from"redis";import v from"@flownet/lib-is-redis-online";import{randomUUID as j}from"node:crypto";import{Api as k,Atom as D}from"@flownet/lib-atom-api-js";import _ from"lodash.merge";import S from"@flownet/lib-parse-imports-js";import E from"@fnet/npm-list-versions";import $ from"@fnet/npm-pick-versions";import P from"object-hash";import N from"ajv/dist/2020.js";import T from"ajv/dist/standalone/index.js";import C from"ajv-formats";import F from"@flownet/lib-parse-node-url";import I from"bpmn-moddle";import O from"dagre";import A from"@fnet/expression";import B from"@fnet/list-files";import R from"@fnet/key-value-transformer";import K from"@flownet/lib-parse-npm-path";import M from"@fnet/prompt";const L=o(n);let J=!1;async function W(e,t){if(J)return;if(J=!0,!e.killed&&e.pid)try{await L(e.pid,"SIGTERM").catch((()=>{})),await new Promise((e=>setTimeout(e,500))),e.killed||await L(e.pid,"SIGKILL").catch((()=>{}))}catch(e){}await new Promise((e=>setTimeout(e,100)));const o="SIGINT"===t?130:"SIGTERM"===t?143:1;process.exit(o)}function z(e){["SIGINT","SIGTERM","SIGQUIT"].forEach((t=>{process.once(t,(async()=>{await W(e,t)}))})),process.on("uncaughtException",(async t=>{await W(e)})),process.on("unhandledRejection",(async t=>{await W(e)})),e.on("close",(e=>{J||process.exit(e)}))}function G(e,{name:t,bin:o,preArgs:n=[]}){return"function"==typeof o&&(o=o()),e.command(`${t||o} [commands..]`,`${o} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await V(e),{projectDir:s}=t,r=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,a=process.argv.slice(3).map(r),l={...process.env},p=i.join(s,"node_modules");l.NODE_PATH=p;const d=l.NODE_OPTIONS||"";l.NODE_OPTIONS=`${d} --preserve-symlinks`.trim();z(c(o,[...n,...a],{cwd:s,stdio:"inherit",shell:!0,detached:!0,env:l}))}catch(e){console.error(e.message),process.exit(1)}}))}async function V(e){try{const t=process.argv[1].split("/").pop().split(".")[0];if("fnode"===t){const{createContext:t}=await import("./index.DOYkqsYT.js");return t(e)}if("fnet"===t){const{createContext:t}=await Promise.resolve().then((function(){return Z}));return t(e)}if("frun"===t){const{createContext:t}=await import("./index.CuMyez3E.js");return t(e)}if("fbin"===t){const{createContext:t}=await import("./index.DWpw12No.js");return t(e)}}catch(e){console.warn(`Warning: Could not import context from CLI tool: ${e.message}`)}return{projectDir:process.cwd(),tags:e.ftag}}var q=e=>{const t=process.env.PATH||"",o="win32"===process.platform?(process.env.PATHEXT||".EXE;.CMD;.BAT;.COM").split(";"):[""],n=t.split(s);for(const t of n)for(const n of o){const o=r(t,"win32"===process.platform?e+n:e);if(p(o))return o}return null};const U=i.dirname(a(import.meta.url)),X=process.cwd();function H(e){const t=i.resolve(X,e);if(l.existsSync(t))return t;const o=i.resolve(U,"../..",e);if(l.existsSync(o))return o;throw new Error(`Template path not found: ${e}`)}const Y={command:"create",describe:"Initialize a new fnet project",builder:e=>e.option("name",{type:"string",describe:"Project name"}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node"],describe:"Runtime environment"}),handler:async e=>{try{const t=process.cwd(),o=H("./template/fnet/project"),n=i.resolve(t,e.name);l.existsSync(n)||l.mkdirSync(n),await m({dir:o,outDir:n,context:e,copyUnmatchedAlso:!0,platform:f.platform()});let s=await u("fnet build",{cwd:n});if(0!==s.code)throw new Error("Failed to build project.");if(q("git")&&(s=await u("git init --initial-branch=main",{cwd:n}),0!==s.code))throw new Error("Failed to initialize git.");if(q("code")&&e.vscode&&(s=await u(`cd ${n} && code .`),0!==s.code))throw new Error("Failed to open vscode.");console.log("Creating project succeeded!"),process.exit(0)}catch(e){console.error("Initialization failed!",e.message),process.exit(1)}}};async function Q(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:H("./template/fnet/node"),coreDir:H("./template/fnet/core"),projectDir:i.resolve(process.cwd(),`./.output/${e.id}`),tags:e.ftag,dev:e.dev};try{const t=await async function({tags:e}){let t=(o=process.cwd(),i.resolve(o,"fnet.yaml"));var o;if(!l.existsSync(t))throw new Error("fnet.yaml file not found in current directory.");const{raw:n,parsed:s}=await y({file:t,tags:e}),r=i.dirname(t);s.features=s.features||{};const a=s.features;let c;if(a.runtime=a.runtime||{},a.runtime.type=a.runtime.type||"node","object"==typeof s.flows)c=s.flows;else{let t="flow.main.yaml";l.existsSync(i.join(r,"fnet","flows.yaml"))&&(t=i.join("fnet","flows.yaml"));const o=s.main||t;let n=i.resolve(r,o);if(l.existsSync(n)){const{parsed:t}=await y({file:n,tags:e});c=t}else c={main:{steps:[]}}}const p={workflowAtom:{doc:{...s,content:c}},projectDir:r,projectFilePath:t,projectFileContent:n,projectFileParsed:s,runtime:a.runtime};let d=i.resolve(r,"fnet/targets.yaml");if(l.existsSync(d)){const{raw:t,parsed:o}=await y({file:d,tags:e}),n=h.parseDocument(t);p.devops={filePath:d,fileContent:t,yamlDocument:n,doc:{...o},type:"workflow.deploy",save:async()=>{l.writeFileSync(p.devops.filePath,n.toString())}}}const f=i.resolve(r,"readme.md");if(l.existsSync(f)){const e=l.readFileSync(f,"utf8");p.readme={filePath:f,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return p}({tags:e.ftag});return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:H("./template/fnet/node"),coreDir:H("./template/fnet/core"),projectDir:i.resolve(t.projectDir,"./.workspace"),projectSrcDir:i.resolve(t.projectDir,"./src"),project:t,tags:e.ftag,dev:e.dev}}catch(t){return console.warn(`Warning: Could not load project: ${t.message}`),{projectDir:process.cwd(),tags:e.ftag}}}var Z=Object.freeze({__proto__:null,createContext:Q});const ee={command:"project",describe:"Manage fnet project",builder:e=>e.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"}),handler:async e=>{try{const t=H("./template/fnet/project"),o=process.cwd(),n=await Q(e);if(e.update){if(await m({dir:t,outDir:o,context:{name:n.project.projectFileParsed.name,runtime:"node"},copyUnmatchedAlso:!0,platform:f.platform()}),0!==(await u("fnet build",{cwd:o})).code)throw new Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(e){console.error("Project failed.",e.message),process.exit(1)}}};class te{init({config:e,accessToken:t}){return new Promise(((o,n)=>{if(k.set_api_url(e.data.url),t)return k.set_req_token(t),void o(t);fetch(`${e.data.issuer}/protocol/openid-connect/token`,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams(e.data.grant.params)}).then((async e=>{if(!e.ok)throw new Error(await e.text());return e.json()})).then((e=>{k.set_req_token(e.access_token),o(e.access_token)})).catch((e=>{k.set_req_token(),n(e)}))}))}}function oe({feature:e,features:t,packageDevDependencies:o}){const{name:n,packages:i,options:s,extraCheck:r,explicit:a}=e,c=`${n}_enabled`,l=t.rollup_output||{},p=Object.keys(l);let d=s||{};const f=t[n]?.options;f&&(d=_(d,f));const m=!t[n]||!1===t[n]?.enabled;p.forEach((e=>{const o=t.rollup_output[e];if(o){if(Reflect.has(o,n)){if(m||!o[n]||!1===o[n]?.enabled)return void delete o[n];!0===o[n]&&(o[n]={enabled:!0,options:d})}else{if(m||a||!1===t[c])return;o[n]={enabled:!0}}o[n]=o[n]||{},o[n].options={...d,...o[n].options}}}));let u=p.some((e=>!0===t.rollup_output[e][n]?.enabled));r&&(u=r()&&u),t[c]=u,u&&i.forEach((e=>o.push({package:e[0],version:e[1]})))}function ne({dir:e,name:t="index"}){let o=i.resolve(e,`./${t}.tsx`);if(l.existsSync(o)||(o=i.resolve(e,`./${t}.ts`)),l.existsSync(o)||(o=i.resolve(e,`./${t}.jsx`)),l.existsSync(o)||(o=i.resolve(e,`./${t}.js`)),!l.existsSync(o))return{};const n=o,s=i.extname(o);return{file:n,ext:s,ts:".ts"===s||".tsx"===s,name:t}}async function ie(e){const{atom:t,context:o,setProgress:n}=e;n("Initializing features..."),t.doc.features=t.doc.features||{};const s=t.doc.features;s.project=s.project||{},s.project.format=s.project.format||s.project_format||"esm",s.project_format=s.project.format,s.dts_enabled=!0===s.dts||void 0!==s.dts&&!1!==s.dts;const r=i.resolve(o.project.projectDir),a=ne({dir:i.resolve(r,"./app")});if(a.file){n("Parsing app entry imports...");let e=await S({file:a.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.app_uses_jsx=t,s.app_has_entry=!0,e=await S({file:a.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.app_entry_uses_jsx=t,s.app_entry_is_ts=a.ts,s.app_entry_ext=a.ext}const c=ne({dir:i.resolve(r,"./cli")});if(c.file){n("Parsing cli entry imports...");let e=await S({file:c.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.cli_uses_jsx=t,s.cli_has_entry=!0,e=await S({file:c.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.cli_entry_uses_jsx=t,s.cli_entry_is_ts=c.ts,s.cli_entry_ext=c.ext}if("workflow.lib"===t.type){const e=ne({dir:i.resolve(r,"./src")});if(e.file){n("Parsing src entry imports...");let t=await S({file:e.file,recursive:!0}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.src_uses_jsx=o,s.src_has_entry=!0,t=await S({file:e.file}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.src_entry_uses_jsx=o,s.src_entry_is_ts=e.ts,s.src_entry_ext=e.ext}}const l=Reflect.has(s,"app_entry_uses_jsx")?!0===s.app_entry_uses_jsx:!0===s.src_entry_uses_jsx,p=Reflect.has(s,"cli_entry_uses_jsx")?!0===s.cli_entry_uses_jsx:!0===s.src_entry_uses_jsx;s.form_enabled=l||p||!0===s.form||!0===s.form?.enabled,s.multiple_enabled=s.multiple_enabled||!0===s.multiple||!0===s.multiple?.enabled,!1===s.app?s.app={enabled:!1}:!0===s.app?s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l}:s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l,...s.app||{}},s.app.enabled=!0===s.app.enabled&&(!0===t.doc.features.form_enabled||!0===s.app.extend||!0===s.app.enabled),s.app.format=s.app.format||"esm",s.app.folder=s.app.folder||s.app.format||"default",!1===s.cli?s.cli={enabled:!1}:!0===s.cli?s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p}:s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p,...s.cli||{}},s.cli.enabled=!0===s.cli.enabled&&(!1===t.doc.features.form_enabled||!0===s.cli.extend||!0===s.cli.enabled),s.cli.format=s.cli.format||"esm",s.cli.folder=s.cli.folder||s.cli.folder||"esm",s.cli.node_options=s.cli.node?.options||s.cli.node_options||"",s.cli.bin=s.cli.bin||t.doc.name,s.cli.installable=!0===s.cli.installable,s.cli.enabled&&(t.doc["npm::bin"]=s.cli.bin),s.json=s.cli.enabled||s.json;const d={cjs:{format:"cjs",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!1!==s.cjs,copy:!1},esm:{format:"esm",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!1,enabled:!1!==s.esm,copy:!0},iife:{format:"iife",context:s.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!0===s.iife,terser:!0,copy:!1}};!0===s.webos&&(d.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}}),!0===s.electron&&(d.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===s.nextjs&&(d.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===s.ios&&(d.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===s.macos&&(d.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===s.app.enabled&&(s.app.dir=`./dist/app/${s.app.folder}`,s.app.output={file:`./dist/app/${s.app.folder}/index.js`,dir:`./dist/app/${s.app.folder}/`,...s.app.output||{}},s.app.input={file:"./src/app/index.js",dir:"./src/app/",...s.app.input||{}},d.app={format:s.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:s.app.input.file,output_dir:s.app.dir,terser:!0,output_exports:!1===s.app.export?"none":"auto",browsersync:!0}),!0===s.cli.enabled&&(s.cli.dir=`./dist/cli/${s.cli.folder}`,s.cli.output={file:`./dist/cli/${s.cli.folder}/index.js`,dir:`./dist/cli/${s.cli.folder}/`,...s.cli.output||{}},s.cli.input={file:"./src/cli/index.js",dir:"./src/cli/",...s.cli.input||{}},d.cli={format:s.cli.format,context:"global",babel:!0===s.src_uses_jsx||!0===s.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:s.cli.input.file,output_dir:s.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===s.cli.export?"none":"auto"});const f={server:".",startPath:`${i.normalize(s.app.dir||".")}`,files:[i.normalize("./dist/**/*")],cors:!0,open:!1};s.babel_options=_({targets:{browsers:"last 9 versions, not dead",node:"18"}},s.babel_options||s.babel?.options),s.browsersync_options=_(f,s.browsersync_options||s.browsersync?.options||{}),s.replace_options=_({},s.replace_options||s.replace?.options||{}),Reflect.has(s.browsersync_options,"proxy")&&delete s.browsersync_options.server,s.rollup=s.rollup||{},s.rollup_output=_(d,s.rollup_output||s.rollup?.output||{}),s.preact_enabled=!0===s.preact||s.preact&&!1!==s.preact?.enabled;let m=Object.keys(d);for(const e of m){const t=d[e];t&&(!1!==s.rollup[e]?(t.babel_options=t.babel_options||s.babel_options,t.browsersync_options=_(s.browsersync_options,t.browsersync_options),t.replace_options=_(s.replace_options,t.replace_options),s.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),(s.form_enabled||s.babel)&&(t.babel=!0)):delete s.rollup_output[e])}m=Object.keys(s.rollup_output),s.babel_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browser_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browsersync_enabled=!1!==s.browsersync&&m.some((e=>!0===s.rollup_output[e].browsersync)),s.browsersync_enabled=s.browsersync_enabled&&s.app.enabled,s.dependency_auto_enabled=!1!==s.dependency_auto&&!1!==s.dependency_auto?.enabled,s.npm_install_flags=s.npm_install_flags||"",s.react_version=s.react_version||s.react?.version||18,function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features,i=n.css&&!1!==n.css.enabled;let s=[];i&&(s.push(["rollup-plugin-postcss","^4"]),s.push(["sass","^1.66"]),(n.css?.options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":s.push(["postcss-import","^15"]);break;case"postcss-url":s.push(["postcss-url","^10"]);break;case"postcss-preset-env":s.push(["postcss-preset-env","^9"]);break;case"autoprefixer":s.push(["autoprefixer","^10"]);break;case"cssnano":s.push(["cssnano","^6"])}})));oe({feature:{name:"css",packages:s},features:n,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features;if("bun"===n.runtime.type)return;const i={};!0===n.app?.enabled&&(i.targets=i.targets||[],i.targets.push({src:"./src/app/index.html",dest:n.app.dir}),Reflect.has(n.app,"copy")||Reflect.has(n,"copy")||(n.copy=!0)),oe({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:i},features:n,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features;"bun"!==n.runtime.type&&oe({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:n,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:t.doc.features,packageDevDependencies:o})}(e)}async function se({projectDir:e,name:t,setProgress:o,count:n=1}){let s;const r=P(["npm-pick-versions",t,n]),a=i.join(e,".cache"),c=i.join(a,r+".json");return l.existsSync(c)?(o&&o(`Picking npm version of ${t} from cache ...`),s=JSON.parse(l.readFileSync(c,"utf8"))):(o&&o(`Picking npm version of ${t} ...`),s=await $({name:t,count:n}),l.mkdirSync(a,{recursive:!0}),l.writeFileSync(c,JSON.stringify(s),"utf8")),s}var re=async e=>{const{atom:t,packageDependencies:o,context:n,deploymentProjectTarget:i,setProgress:s,deploymentProject:r,yamlTarget:a}=e;if(!0!==i.enabled)return;const c=i.type;try{if("lib"===c)await(await import("./index.DG8TqL-1.js")).default({...e});else if("red"===c)await(await import("./index.CmMM-Ek9.js")).default({...e});else if("npm"===c)await(await import("./index.C0YpfQ5j.js")).default({...e});else if("gcs"===c)await(await import("./index.Bft2w7m3.js")).default({...e});else if("gitlab"===c)await(await import("./index.DI3yyTtl.js")).default({...e});else if("fnet-package"===c)await(await import("./index.D3p7pncT.js")).default({...e});else if("fnet-form"===c)await(await import("./index.Q-CYRcna.js")).default({...e});else if("fnet-node"===c)await(await import("./index.C2S9JYhS.js")).default({...e});else if("fnet-flow"===c)await(await import("./index.BuYxdKtK.js")).default({...e});else if("nextjs"===c)await(await import("./index.CDct_kkF.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("webos"===c)await(await import("./index.CMC8mlye.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("electron"===c)await(await import("./index.xd8c7XMr.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("docker"===c)await(await import("./index.D2N9YZmA.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("ios"===c)await(await import("./index.B5XE4ChJ.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("macos"===c)await(await import("./index.W6RYgypK.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("rust"===c)await(await import("./index.CzAV0S36.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else{if("pypi"!==c)return void console.warn(`No deployer found for type: ${c}`);await(await import("./index.C7saWH6d.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0}}catch(e){throw console.error(`Error during deployment for type "${c}":`,e),e}},ae={name:"ATOM",uri:"http://atom.org/bpmn",prefix:"atom",types:[{name:"AtomExtension",extends:["bpmn:BaseElement"],properties:[{name:"atom",type:"atom:Atom",isMany:!1}]},{name:"Atom",properties:[{name:"type",type:"String",isAttr:!0}]}]};function ce(e,t){return e.filter(((e,o,n)=>n.map((e=>e[t])).indexOf(e[t])===o))}function le(e){const{nodes:t,nodeIndex:o,root:n}=e,i=e.targetNodes||n.childs;i.forEach((t=>{const o="workflow"===t.type||"subworkflow"===t.type,n=!o&&t.childs.filter((e=>!e.virtual)).length>0;if(n&&(t.bpmn.type="bpmn:SubProcess"),o||n){const o=t.childs.filter((e=>!0!==e.module))[0];t.childs.filter((e=>!0===e.module)).forEach((o=>{const n=pe({...e,parent:t,bpmnType:"bpmn:IntermediateCatchEvent",type:"inter",definitions:[{type:"bpmn:SignalEventDefinition"}]});n.bpmn.edges=[{from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const n=t.childs.find((e=>"try"===e.name&&"tryexcept"===t.type)),s=t.childs.filter((e=>"except"===e.name&&"tryexcept"===t.type));n&&s.length&&s.forEach((o=>{const i=pe({location:t.childs.indexOf(o),...e,parent:t,bpmnType:"bpmn:BoundaryEvent",type:"boundary",attrs:{attachedToRef:n},definitions:[{type:"bpmn:ErrorEventDefinition"}]});i.bpmn.edges=[{from:i.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const r=t.childs.find((e=>"raise"===e.type));if(r){const o=pe({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:"ERROR",definitions:[{type:"bpmn:ErrorEventDefinition"}]});r.bpmn.edges=[{from:r.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}if(o)if(t.bpmn.starts.length>1){const o=pe({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"}),n=pe({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch"});o.bpmn.edges=[{from:o.indexKey,to:n.indexKey,type:"bpmn:SequenceFlow"}],n.bpmn.edges=t.bpmn.starts.map((e=>({...e,from:n.indexKey})));const i=n.bpmn.edges.find((e=>!0===e.next));if(i){const o=pe({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:i.to});i.to=o.indexKey}}else{const n=pe({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"});n.bpmn.edges.push({from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"})}t.childs.filter((e=>!0!==e.virtual&&e.bpmn.outside.length&&"bpmn:EndEvent"!==e.bpmn.type)).forEach((o=>{o.bpmn.outside.forEach((n=>{const s=i.indexOf(t),r=pe({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:n.to,location:s+1});o.bpmn.edges.push({from:o.indexKey,to:r.indexKey,type:"bpmn:SequenceFlow"})}))}));t.childs.filter((e=>!0!==e.virtual&&e.bpmn.edges.length>1)).forEach((o=>{const n=i.indexOf(o),s=pe({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch",location:n+1});s.bpmn.edges=o.bpmn.edges.map((e=>({...e,from:s.indexKey}))),o.bpmn.edges=[{from:o.indexKey,to:s.indexKey,type:"bpmn:SequenceFlow"}],o.bpmn.outside=[]}))}le({...e,targetNodes:t.childs})}))}function pe(e){const{parent:t,nodes:o,nodeIndex:n,bpmnType:i,type:s,name:r,outside:a,location:c,definitions:l,attrs:p}=e,d=t.childs.filter((e=>e.type===`v${s}`)).length,f={indexKey:`${t.indexKey}/_${s}${d}`,pathKey:`${t.pathKey}._${s}${d}`,type:`v${s}`,name:r,bpmn:{edges:[],outside:[],type:i,width:36,height:36,fill:"#c8e6c9",stroke:"#205022",definitions:l,attrs:p},virtual:!0,childs:[]};return t.childs.splice(c||0,0,f),o.push(f),n[f.indexKey]=f,f}function de(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a,nodes:c}=e;!function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,nodes:a}=e,c=o.get("flowElements");o.$nodes=o.$nodes||[],t.childs.forEach((e=>{const t=i.create(e.bpmn.type,{id:`node.${e.pathKey}`,name:e.definition?.title||e.name});if(s[t.id]=t,t.$isNode=!0,t.$node=e,e.$flow=t,o.$nodes.push(t),c.push(t),e.bpmn.attrs){Object.keys(e.bpmn.attrs).forEach((o=>{"attachedToRef"===o&&t.set(o,e.bpmn.attrs[o].$flow)}))}if(e.bpmn.definitions){const o=e.bpmn.definitions.map((e=>{const t=i.create(e.type);return Object.keys(e.attrs||{}).forEach((o=>{t.set(o,e.attrs[o])})),t}));t.eventDefinitions=o}}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=o.get("flowElements");o.$edges=o.$edges||[],t.childs.forEach((e=>{e.bpmn.edges.forEach((t=>{const n=e,c=r[t.to],l=`edge.${n.pathKey}_${c.pathKey}`;if(s[l])return;const p=s[`node.${n.pathKey}`],d=s[`node.${c.pathKey}`],f=i.create(t.type,{id:l,sourceRef:p,targetRef:d});s[f.id]=f,f.$is_edge=!0,p.get("outgoing").push(f),d.get("incoming").push(f),o.$edges.push({from:p,to:d,flow:f}),a.push(f)}))}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=120,c=80,l=160,p=160,d=new O.graphlib.Graph;d.setDefaultEdgeLabel((()=>({}))),d.setGraph({rankdir:"TB",nodesep:a,ranksep:c,xranker:"longest-path"}),o.$nodes.forEach((e=>{d.setNode(e.id,{width:e.$node?.bpmn.width||a,height:e.$node?.bpmn.height||c,label:e.id})})),o.$edges.forEach((e=>{d.setEdge(e.from.id,e.to.id)})),O.layout(d),o.$nodes.forEach((e=>{const t=d.node(e.id);let o=t.width,s=t.height;const r=i.create("bpmndi:BPMNShape",{id:`shape.${e.id}`,bpmnElement:e,bounds:i.create("dc:Bounds",{x:l+t.x-t.width/2,y:p+t.y-t.height/2,width:o,height:s}),label:i.create("bpmndi:BPMNLabel")});e.$node.bpmn.fill&&r.set("bioc:fill",e.$node.bpmn.fill),e.$node.bpmn.stroke&&r.set("bioc:stroke",e.$node.bpmn.stroke);n.get("planeElement").push(r)})),o.$edges.forEach((e=>{const t=d.edge(e.from.id,e.to.id),o=i.create("bpmndi:BPMNEdge",{id:`edge.${e.from.id}_${e.to.id}`,bpmnElement:e.flow,label:i.create("bpmndi:BPMNLabel")});t.points.forEach((e=>{const t=i.create("dc:Point",{x:l+e.x,y:p+e.y});o.get("waypoint").push(t)}));n.get("planeElement").push(o)}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a}=e,c=t.childs.filter((e=>"bpmn:SubProcess"===e.bpmn.type));c.forEach((t=>{const o=s[`node.${t.pathKey}`],n=i.create("bpmndi:BPMNDiagram",{id:`diagram_${t.pathKey}`});s[n.id]=n,a.push(n);const r=i.create("bpmndi:BPMNPlane",{id:`plane_${t.pathKey}`});s[r.id]=r,n.plane=r,r.bpmnElement=o,de({...e,targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:r})}))}(e)}async function fe(e){const t=e.root,o=t.context.index,n=Object.keys(o).map((e=>o[e]));!function(e){const{nodes:t}=e;t.forEach((e=>{const t=[],o=[],n=i=>{i.context.next&&(t.push({from:i,to:i.context.next,type:"bpmn:SequenceFlow"}),i===e&&o.push({to:i.context.next,type:"bpmn:SequenceFlow",next:!0})),i.childs.forEach((t=>{i===e&&"switch"===e.type&&o.push({to:t,type:"bpmn:SequenceFlow"}),n(t)}))};n(e);const i=t.filter((t=>t.to.parent.indexKey===e.parent.indexKey)).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),s=t.filter((t=>t.to.parent.indexKey!==e.parent.indexKey&&!t.to.indexKey.startsWith(e.indexKey+"/"))).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),r=o.map((e=>({...e,to:e.to.indexKey})));e.bpmn=e.bpmn||{},e.bpmn.edges=ce(i,"to"),e.bpmn.outside=ce(s,"to"),e.bpmn.starts=ce(r,"to"),e.bpmn.type=function(e){return"call"===e.type?"bpmn:ServiceTask":"form"===e.type?"bpmn:UserTask":"return"===e.type?"bpmn:EndEvent":"bpmn:Task"}(e),e.bpmn.width=120,e.bpmn.height=80,"return"===e.type&&(e.bpmn.width=36,e.bpmn.height=36)}))}({nodes:n}),le({nodes:n,nodeIndex:o,root:t});const i=new I({atom:ae}),s={},r=i.create("bpmn:Definitions",{id:"definitions_0"});s[r.id]=r;for await(const e of t.childs){const t=r.get("rootElements"),a=r.get("diagrams"),c=i.create("bpmn:Process",{id:`process_${e.pathKey}`,name:e.name,documentation:[i.create("bpmn:Documentation",{text:`Workflow - ${e.name}`})]});s[c.id]=c,c.isExecutable=!0,t.push(c);const l=i.create("bpmndi:BPMNDiagram",{id:`diagram_${e.pathKey}`});s[l.id]=l,a.push(l);const p=i.create("bpmndi:BPMNPlane",{id:`plane_${e.pathKey}`});s[p.id]=p,l.plane=p,p.bpmnElement=c;de({targetNode:e,targetFlowElementsContainer:c,targetPlaneElement:p,moddle:i,elementIndex:s,nodeIndex:o,nodes:n,diagrams:a})}return{diagramXML:(await i.toXML(r,{format:!0})).xml}}async function me(e={}){return await fe(w(e))}async function ue({node:e,initNode:t,extra:o=!0}){if(Reflect.has(e.definition,"modules")&&!Array.isArray(e.definition.modules)){const t=e.definition.modules;e.definition.modules=[],Object.keys(t).forEach((o=>{const n={...t[o]};"boolean"==typeof n.export?n.export=!0===n.export&&o:"string"==typeof n.export?n.export=n.export:delete n.export,e.definition.modules.push({[o]:n})}))}if(o){const t=[],o=await R({data:e.definition,callback:(e,o,n)=>{const i=A({expression:e});if("m"===i?.processor){const e=n.slice(0,-1);e.push(i.statement);const s=e.join("_");return t.push({[s]:o}),[i.statement,`m::${s}`]}return[e,o]}});t.length>0&&(e.definition=o,e.definition.modules=e.definition.modules||[],e.definition.modules=e.definition.modules.concat(t))}e.hasModules=e.definition.modules?.length>0;for(let o=0;o<e.definition.modules?.length;o++){const n=e.definition.modules[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}}async function ye({node:e,transformExpression:t}){const o=e.context.transform;if(Reflect.has(o,"export")&&(o.export=await t(o.export)),Reflect.has(o,"return")&&(e.hasReturn=!0,o.return=await t(o.return)),Reflect.has(o,"output")&&(o.output=await t(o.output)),Reflect.has(o,"assign"))for(let e=0;e<o.assign?.length;e++){let n=o.assign[e],i=Object.keys(n)[0],s=n[i],r={key:await t(i),value:await t(s)};o.assign[e]=r}}async function he({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform;for(const t of e.childs)t.context.transform=t.context.transform||w(t.definition),t.definition.hasOwnProperty("condition")&&(t.context.transform.condition=await n(t.definition.condition));await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var ge={hits:async function({node:e}){return!!e.definition.hasOwnProperty("switch")},init:async function({node:e,initNode:t}){e.type="switch";const o=e.definition.switch||[];if(!o.every((e=>e.hasOwnProperty("condition")||e.hasOwnProperty("default"))))throw new Error("Switch must have condition or default");if(0===o.filter((e=>e.hasOwnProperty("condition"))).length)throw new Error("Switch must have at least one condition");const n=o.filter((e=>e.hasOwnProperty("default")));if(n.length>1)throw new Error("Switch must have only one default");if(1===n.length&&!o[o.length-1].hasOwnProperty("default"))throw new Error("Switch default must be the last child");e.hasDefaultCondition=1===n.length,await ue({node:e,initNode:t,extra:!1}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0;for(let o=0;o<e.definition.switch.length;o++){let n=e.definition.switch[o],i=`${o}`;n.hasOwnProperty("default")&&(i="default",n=n.default);const s={name:n.condition||i,childs:[],parent:e,definition:n,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=he},resolve:he};var we={hits:async function({node:e}){return 1===Object.keys(e.definition).map((e=>A({expression:e}))).filter((e=>"if"===e?.processor)).length||!(!e.definition.if||"object"!=typeof e.definition.if)},init:async function(e){const{node:t}=e,o=Object.keys(t.definition).map((e=>A({expression:e}))),n=[],i=o.find((e=>"if"===e?.processor));if(i){const e=t.definition[i.expression];n.push({name:`${t.name}_if`,definition:e,processor:i}),delete t.definition[i.expression]}else if(t.definition.if){const{condition:e,...o}=t.definition.if;n.push({name:`${t.name}_if`,definition:o,processor:{expression:`if::${e}`,statement:e}}),delete t.definition.if}const s=o.filter((e=>"elseif"===e?.processor));let r=0;for(const e of s){const o=t.definition[e.expression];n.push({name:`${t.name}_elseif_${r++}`,definition:o,processor:e}),delete t.definition[e.expression]}if(t.definition.elseif){const{condition:e,...o}=t.definition.elseif;n.push({name:`${t.name}_elseif_${r++}`,definition:o,processor:{expression:`elseif::${e}`,statement:e}}),delete t.definition.elseif}t.definition.switch=[];for(const e of n)t.definition.switch.push({condition:e.processor.statement,...e.definition});if(t.definition?.else){const e=t.definition.else;t.definition.switch.push({default:e}),delete t.definition.else}await ge.init(e)}};async function be({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){if(e.context.transform=e.context.transform||w(e.definition),e.context.transform,e.context.try=e.childs.find((e=>"try"===e.name)),e.context.except=e.childs.find((e=>"except"===e.name)),e.context.except){const t=e.context.except;t.context.transform=t.context.transform||w(t.definition),t.context.transform.hasOwnProperty("as")||(t.context.transform.as="error")}await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var xe={hits:async function({node:e}){return e.definition.hasOwnProperty("try")&&e.definition.hasOwnProperty("except")},init:async function({node:e,initNode:t}){if(e.type="tryexcept",await ue({node:e,initNode:t,extra:!1}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0,e.definition.try){const o="try",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}if(e.definition.except){const o="except",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}e.resolve=be},resolve:be};async function ve({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform,await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var je={hits:async function({node:e}){return e.definition.hasOwnProperty("assign")},init:async function({node:e,initNode:t}){e.type="assign",await ue({node:e,initNode:t}),e.resolve=ve},resolve:ve};async function ke({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);e.context.transform.for.in=await n(e.definition.for.in),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var De={hits:async function({node:e}){return e.definition.hasOwnProperty("for")},init:async function({node:e,initNode:t}){if(e.type="for",await ue({node:e,initNode:t,extra:!1}),e.blockAutoJumpToParent=!0,e.blockAutoJumpToSibling=!1,!e.definition.for.hasOwnProperty("steps")){const{value:t,in:o,...n}=e.definition.for,i={};void 0!==t&&(i.value=t),void 0!==o&&(i.in=o),e.definition.for=i,e.definition.for.steps=[{[`${e.name}_step`]:n}]}Array.isArray(e.definition.for.steps)||(e.definition.for.steps=[{[`${e.name}_step`]:e.definition.for.steps}]);for(let o=0;o<e.definition.for.steps.length;o++){const n=e.definition.for.steps[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=ke},resolve:ke};var _e={hits:async function({node:e}){return!1},init:async function({node:e,initNode:t}){},resolve:async function({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){}};async function Se({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;n.raise=await o(n.raise),await t({node:e})}var Ee={hits:async function({node:e}){return e.definition.hasOwnProperty("raise")},init:async function({node:e,initNode:t}){e.type="raise",e.resolve=Se},resolve:Se};async function $e({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;e.hasReturn=!0,n.return=await o(n.return),await t({node:e})}var Pe={hits:async function({node:e}){return e.definition.hasOwnProperty("return")},init:async function({node:e,initNode:t}){e.type="return",e.resolve=$e},resolve:$e};async function Ne({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;let s=i.from||i.import||i.call;if("function"===e.target?.atom?.doc?.type&&(Reflect.has(i,"from")?(s=i.from,i.from=await n(e.target.atom.name)):Reflect.has(i,"import")?(s=i.import,i.import=await n(e.target.atom.name)):Reflect.has(i,"call")&&(i.call=await n(e.target.atom.name),s=i.call)),i.args&&(i.args=await n(i.args)),i.new&&(i.new=await n(i.new)),i.context&&(i.context=await n(i.context)),i.result){"string"==typeof i.result&&(i.result=[{[i.result]:"e::result"}]);for(let e=0;e<i.result?.length;e++){let t=i.result[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.result[e]=r}}const r=e.workflow.parent;e.context.lib=r.context.libs.find((e=>e.name===s)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Te={hits:async function({node:e}){return e.definition.hasOwnProperty("call")},init:async function({node:e,initNode:t}){e.type="call",await ue({node:e,initNode:t}),e.resolve=Ne},resolve:Ne};async function Ce({node:e,transformExpression:t}){e.context.next=e.childs[0],e.context.transform=e.context.transform||w(e.definition),await ye({node:e,transformExpression:t})}var Fe={hits:async function({node:e}){return e.definition.hasOwnProperty("steps")},init:async function({node:e,initNode:t}){e.type||(e.type="steps");const o=e.definition.steps||[];for await(const n of o){const o=Object.keys(n)[0],i={name:o,childs:[],parent:e,definition:n[o],index:e.childs.length,context:{}};e.childs.push(i),await t({node:i})}e.resolve=Ce},resolve:Ce};async function Ie({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.props&&(i.props=await n(i.props));const s=e.workflow.parent;e.context.lib=s.context.libs.find((e=>e.name===i.form)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Oe={hits:async function({node:e}){return e.definition.hasOwnProperty("form")},init:async function({node:e,initNode:t}){e.type="form",await ue({node:e,initNode:t}),e.resolve=Ie},resolve:Ie};async function Ae({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){e.context.transform=e.context.transform||w(e.definition),await t({node:e}),o({node:e})}var Be={hits:async function({node:e}){return e.definition.hasOwnProperty("signal")},init:async function({node:e,initNode:t}){e.type="signal",e.resolve=Ae},resolve:Ae};async function Re({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){e.context.transform=e.context.transform||w(e.definition),await t({node:e}),o({node:e})}var Ke={hits:async function({node:e}){return e.definition.hasOwnProperty("wait")},init:async function({node:e,initNode:t}){e.type="wait",e.resolve=Re},resolve:Re};async function Me({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.next=await n(i.next),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Le={hits:async function({node:e}){return e.definition.hasOwnProperty("next")},init:async function({node:e,initNode:t}){e.type="next",e.resolve=Me},resolve:Me};async function Je({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform,await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var We={hits:async function({node:e}){return e.definition.hasOwnProperty("modules")},init:async function({node:e,initNode:t}){e.type="modules",await ue({node:e,initNode:t}),e.resolve=Je},resolve:Je};function ze({node:e}){const t=e.definition;if(!e.hasReturn)if("end"===t.next);else if("stop"===t.next);else if("none"===t.next);else if(t.next){let o=e.parent;for(;o.parent;){const n=o.childs.find((e=>e.name===t.next));if(n){e.context.next=n;break}o=o.parent}}else{if(!0===e.module)return;let t=e.parent,o=e.index+1;for(;t.parent&&(!t.blockAutoJumpToParent||!t.blockAutoJumpToSibling);)if(Reflect.has(t,"blockAutoJumpToParent")||Reflect.has(t,"blockAutoJumpToSibling")){if(t.blockAutoJumpToParent){const n=t.childs.find((e=>e.index===o));n&&(e.context.next=n);break}t.blockAutoJumpToParent||(o=t.index+1,t=t.parent)}else{const n=t.childs.find((e=>e.index===o));if(n){e.context.next=n;break}o=t.index+1,t=t.parent}}}class Ge{#e;#t;#o;#n;constructor({key:e,npm:t,master:o,extras:n}){this.#e=e,this.#t=t,this.#o=o,this.#n=n}hits({node:e}){return e.definition.hasOwnProperty(this.#e)}async init(e){const{node:t}=e,o=this.#e,n=t.definition,i=typeof n[o];if(n.call=`npm:${this.#t}`,n.args="object"!==i?{...n.args,[`${this.#o}`]:n[o]}:n[o],delete n[o],this.#n)for(const e in this.#n)n[e]=this.#n[e];console.log(`[npm-block] ${this.#e} --\x3e ${this.#t}`),await Te.init(e)}}function Ve(e){return new Ge(e)}async function qe({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;let s=i.from||i.import;if("function"===e.target?.atom?.doc?.type&&(Reflect.has(i,"from")?(s=i.from,i.from=await n(e.target.atom.name)):Reflect.has(i,"import")&&(s=i.import,i.import=await n(e.target.atom.name))),i.args&&(i.args=await n(i.args)),i.new&&(i.new=await n(i.new)),i.result){"string"==typeof i.result&&(i.result=[{[i.result]:"e::result"}]);for(let e=0;e<i.result?.length;e++){let t=i.result[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.result[e]=r}}const r=e.workflow.parent;e.context.lib=r.context.libs.find((e=>e.name===s)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Ue={hits:async function({node:e}){return e.definition.hasOwnProperty("new")},init:async function({node:e,initNode:t}){e.type="new",await ue({node:e,initNode:t}),e.resolve=qe},resolve:qe};async function Xe({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var He={hits:async function({node:e}){return e.definition.hasOwnProperty("output")},init:async function({node:e,initNode:t}){e.type="output",await ue({node:e,initNode:t}),e.resolve=Xe},resolve:Xe};class Ye{#i;#s;#r;#a;#c;#l;#p;#d;#f;#m;#u;#y;#h;#g;#w;#b;#x;#v;#j;#k;#D;#_=[];constructor(e){this.#i=new te,this.#s=e,this.#l=[],this.#p=[],this.#d={},this._expire_ttl=3600,this._expire_ttl_short=300,this.#_.push(Ve({key:"config",npm:"@fnet/config",master:"name"})),this.#_.push(Ve({key:"yaml",npm:"@fnet/yaml",master:"file"})),this.#_.push(Ve({key:"prompt",npm:"@fnet/prompt",master:"message"})),this.#_.push(Ve({key:"html-link",npm:"@flownet/lib-load-browser-link-url",master:"src"})),this.#_.push(Ve({key:"html-script",npm:"@flownet/lib-load-browser-script-url",master:"src"})),this.#_.push(Ve({key:"http-server",npm:"@fnet/node-express",master:"server_port"})),this.#_.push(Ve({key:"shell",npm:"@fnet/shell-flow",master:"commands"})),this.#_.push(Ve({key:"list-files",npm:"@fnet/list-files",master:"pattern"})),this.#_.push(Ve({key:"up-list-files",npm:"@fnet/up-list-files",master:"pattern"})),this.#_.push(Ve({key:"auto-conda-env",npm:"@fnet/auto-conda-env",master:"envDir"})),this.#_.push(Ve({key:"ollama-chat",npm:"@fnet/ollama-chat",master:"model"})),this.#_.push(Ve({key:"ai",npm:"@fnet/ai",master:"prompt",extras:{subtype:"flow"}})),this.#_.push(Ve({key:"invoke",npm:"@fnet/invoke",master:"method",extras:{}})),this.#_.push(Ve({key:"fetch",npm:"@fnet/fetch",master:"url",extras:{}})),this.#_.push(Ve({key:"filemap",npm:"@fnet/filemap",master:"target",extras:{}})),this.#k={packageDependencies:this.#l,packageDevDependencies:this.#p,setProgress:this.setProgress.bind(this),context:this.#s,Atom:D,registerToPackageManager:this.registerToPackageManager.bind(this)},this.#D={initNode:this.initNode.bind(this),cloneDeep:w,resolveTypeCommon:this.resolveTypeCommon.bind(this),resolveNextBlock:ze,transformExpression:this.transformExpression.bind(this),transformValue:this.transformValue.bind(this)}}async _cache_set(e,t,o){this._redis_client&&await this._redis_client.SETEX(e,o||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await async function(){if(!await v({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=x.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e}(),this.#u=this.#s.buildId||j(),this.#k.buildId=this.#u,this.#w=this.#s.mode,this.#b=["all","deploy","build","file"].includes(this.#w),this.#x=["all","deploy","build"].includes(this.#w),this.#v=["all","deploy"].includes(this.#w),this.#j=["all","deploy","build","file","bpmn"].includes(this.#w),this.#h=this.#s.protocol,this.#y="BUILD:"+this.#u,this.#g=(await d({optional:!0,name:"atom",dir:this.#s.projectDir,tags:this.#s.tags}))?.data;try{await this.setProgress({message:"Initialization started."});const e=this.#k.context.project;await this.initAuth(),await this.initWorkflow(),this.transformWorkflow({workflow:this.#a});const t=await this.initNodeTree({workflow:this.#a});await this.initNodeTreeIndex({root:t}),await this.initNodeCalls({root:t}),await this.initNodeCallLibs({root:t}),await this.initNodeForms({root:t}),await this.initNodeFormLibs({root:t}),await this.initEntryFiles({root:t,features:this.#r.doc.features}),await this.initFeaturesFromNodes({childs:t.childs,features:this.#r.doc.features}),await ie(this.#k),"bun"===e.runtime.type?await async function({atom:e,packageDependencies:t,packageDevDependencies:o,setProgress:n}){n("Initializing dependencies for Bun");const i=e.doc.dependencies||[];if(i.filter((e=>!e.dev)).forEach((e=>t.push(e))),i.filter((e=>e.dev)).forEach((e=>o.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let o="^18.2";n("Fetching React versions"),o=`^${(await E({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:o}),t.push({package:"react-dom",version:o}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),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&&o.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}(this.#k):await async function({atom:e,packageDependencies:t,packageDevDependencies:o,setProgress:n}){n("Initializing dependencies");const i=e.doc.dependencies||[];if(i.filter((e=>!e.dev)).forEach((e=>t.push(e))),i.filter((e=>e.dev)).forEach((e=>o.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let o="^18.2";n("Fetching React versions"),o=`^${(await E({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:o}),t.push({package:"react-dom",version:o}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),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&&o.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"}),o.push({package:"@babel/core",version:"^7"}),o.push({package:"@rollup/plugin-commonjs",version:"^28"}),o.push({package:"@rollup/plugin-node-resolve",version:"^16"}),o.push({package:"@rollup/plugin-replace",version:"^6"}),o.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&o.push({package:"rollup-plugin-dts",version:"^6"}),o.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),o.push({package:"@rollup/plugin-alias",version:"^5"}),o.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(o.push({package:"@rollup/plugin-babel",version:"^6"}),o.push({package:"@babel/preset-env",version:"^7"}),o.push({package:"@babel/preset-react",version:"^7"}),e.doc.features.babel?.options?.plugins?.forEach((e=>{switch(e[0]){case"@babel/plugin-proposal-decorators":o.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":o.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":o.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":o.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":o.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"})}}))),o.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),e.doc.features.browsersync_enabled&&o.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}(this.#k),await this.initAtomLibsAndDeps({libs:t.context.libs,packageDependencies:this.#l}),await this.resolveNodeTree({root:t}),this.#m=t}catch(e){throw await this._cache_set(this.#y,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#s.id&&(this.#f=await this.#i.init({config:this.#g}),this.#k.atomAccessToken=this.#f)}async initWorkflow(){const e=this.#s.id;this.#r=this.#s.project?.workflowAtom||await D.get({id:e}),this.#a="string"==typeof this.#r.doc.content?(await y({content:this.#r.doc.content,tags:this.#s.tags})).parsed:this.#r.doc.content;let t=this.#r.doc.bundleName;t=t||(this.#r.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#r.doc.bundleName=t,this.#r.type=this.#r.type||"workflow",this.#k.atom=this.#r,this.#r.doc.features=this.#r.doc.features||{}}#S(e){console.log("filePath",e),l.statSync(e).isDirectory()?(l.readdirSync(e).forEach((t=>{const o=i.join(e,t);this.#S(o)})),l.rmSync(e)):l.unlinkSync(e)}#E(e,t){const o=l.existsSync(e),n=o&&l.statSync(e);o&&n.isDirectory()?(l.mkdirSync(t,{recursive:!0}),l.readdirSync(e).forEach((o=>{this.#E(i.join(e,o),i.join(t,o))}))):l.copyFileSync(e,t)}async initWorkflowDir(){this.setProgress({message:"Initializing library directory."});const e=this.#s.projectDir,t=this.#s.coreDir;this.setProgress({message:"Cleaning project directory."});const o=B({dir:e,ignore:[".cache","node_modules",".conda",".bin"],absolute:!0});for(const e of o)l.rmSync(e,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."}),l.existsSync(e)||l.mkdirSync(e,{recursive:!0});const n=i.join(e,"src");l.existsSync(n)||l.mkdirSync(n,{recursive:!0});const s=i.join(n,"core");this.#E(t,s);const r=i.join(n,"default","blocks");l.existsSync(r)||l.mkdirSync(r,{recursive:!0})}async initNunjucks(){this.setProgress({message:"Initializing nunjucks."});const e=this.#s.templateDir;this.#c=g.configure(e,{watch:!1,dev:!0}),this.#k.njEnv=this.#c}transformWorkflow({workflow:e}){for(const t of Object.values(e))t.steps=t.steps||[],t.steps=t.steps.filter((e=>Object.keys(e).length>0)),t.steps=t.steps.map((e=>this.transformStep({step:e})))}transformStep({step:e}){if(Array.isArray(e))throw new Error("Step must be an object.");const[t,o]=Object.entries(e)[0];if(o.hasOwnProperty("onerror")){const{onerror:n,...i}=o;e[t]={try:i,except:n}}if(e[t].hasOwnProperty("steps")){const o=e[t].steps;if(!Array.isArray(o))throw new Error("Steps must be an array.");e[t].steps=o.map((e=>this.transformStep({step:e})))}return e}async initNodeTree({workflow:e}){const t=Object.keys(e),o={definition:e,name:void 0,type:"root",parent:void 0,childs:[],blockAutoJumpToParent:!0,blockAutoJumpToSibling:!0,index:0,depth:0,context:{libs:[],atom:this.#r}};t.forEach((t=>{const n={name:t,type:"main"===t?"workflow":"subworkflow",childs:[],parent:o,definition:e[t],index:o.childs.length,depth:o.depth+1,context:{},blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1};o.childs.push(n)}));for await(const e of o.childs)await this.initNode({node:e});return o}async initNode({node:e}){const t={...this.#D,node:e};if(e.workflow=e.parent.workflow||e,e.depth=e.parent.depth+1,await xe.hits(t))await xe.init(t);else if(await De.hits(t))await De.init(t);else if(await ge.hits(t))await ge.init(t);else if(await we.hits(t))await we.init(t);else if(await _e.hits(t))await _e.init(t);else if(await Te.hits(t))await Te.init(t);else if(await Ue.hits(t))await Ue.init(t);else if(await Ee.hits(t))await Ee.init(t);else if(await Oe.hits(t))await Oe.init(t);else if(await Be.hits(t))await Be.init(t);else if(await Ke.hits(t))await Ke.init(t);else if(await Fe.hits(t))await Fe.init(t);else if(await Le.hits(t))await Le.init(t);else if(await We.hits(t))await We.init(t);else if(await Pe.hits(t))await Pe.init(t);else if(this.#_.find((e=>e.hits(t))))await this.#_.find((e=>e.hits(t))).init(t);else if(await je.hits(t))await je.init(t);else{if(!await He.hits(t))throw new Error("Undefined step type.");await He.init(t)}}async initNodeTreeIndex({root:e}){const t={};e.indexKey="/";for await(const o of e.childs)await this.initNodeIndex({node:o,index:t});return e.context.index=t,t}async initNodeIndex({node:e,index:t}){const o=i.join(e.parent.indexKey,e.name);e.indexKey=o,t[o]=e;const n=[];let s=e;for(;s?.parent;)n.push(s.index),s=s.parent;n.reverse(),e.codeKey=`B_${n.join("_")}_${e.type}`,e.pathKey=`${n.join(".")}`,e.typeId=j();for await(const o of e.childs)await this.initNodeIndex({node:o,index:t})}async initNodeCalls({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"call"!==n.type&&"new"!==n.type||o.push(n)}return e.context.calls=o,o}async initNodeCallLibs({root:e}){const t=[],o=e.context.calls;for await(const e of o){const o=e.definition.from||e.definition.import||e.definition.call,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom",definition:e.definition},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.callLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeCallTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.call,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeCallTarget({refNode:e,curNode:t.parent})}async initNodeForms({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"form"===n.type&&o.push(n)}return e.context.forms=o,o}async initNodeFormLibs({root:e}){const t=[],o=e.context.forms;for await(const e of o){const o=e.definition.from||e.definition.import||e.definition.form,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom"},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.formLibs=t,e.context.libs=[...e.context.libs,...t],t}async initFeaturesFromNodes({childs:e,features:t}){for await(const o of e)"form"!==o.type||Reflect.has(t,"form")||(t.form=!0),await this.initFeaturesFromNodes({childs:o.childs,features:t})}async initEntryFiles({root:e,features:t}){for await(const o of e.childs){let e;if("main"===o.name)e="index.js";else if("cli"===o.name)e="cli.js";else if("app"===o.name)e="app.js";else{if("api"!==o.name)continue;e="api.js"}t[`${o.name}_default_entry_file`]=e,o.entryFile=e}}async findNodeFormTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.form,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeFormTarget({refNode:e,curNode:t.parent})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const o=e.filter((e=>"atom"===e.type));for(let e=0;e<o.length;e++){const n=o[e],i=await this.findAtomLibrary({url:n.name,libRef:n});n.atom=i;const s=i.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));s?.forEach((e=>{const o=t.find((t=>t.package===e.package));o?"string"==typeof e.path?(o.path||[]).some((t=>t===e.path))||(o.path=o.path||[],o.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(o.path||[]).some((t=>t===e))||(o.path=o.path||[],o.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e,libRef:t}){const o=F({url:e});if(!o)throw new Error(`Invalid package name: ${e}`);if(o.protocol||(o.protocol=this.#h),"ac:"===o.protocol){const t=o.pathname.split("/");if(1===t.length)return await D.first({where:{name:e,parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===t.length){const e=await D.first({where:{name:t[0],parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"folder"}});return await D.first({where:{name:t[1],parent_id:e.id,type:"workflow.lib"}})}}else{if("local:"===o.protocol){const e=i.resolve(this.#s.projectSrcDir,`${o.pathname}.js`),t=[],n=(await S({file:e,recursive:!0})).all;for await(const e of n){if("npm"!==e.type)continue;if(t.find((t=>t.package===e.package)))continue;const o=await se({name:e.package,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});t.push({package:e.package,subpath:e.subpath,version:o.minorRange,type:"npm"})}return{name:o.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:t},protocol:o.protocol}}if("npm:"===o.protocol){const e=K({path:o.pathname}),n=await se({name:e.package,subpath:e.subpath,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});return{name:o.pathname,doc:{type:"workflow.lib",subtype:"flow"===t?.definition?.subtype?"workflow":null,"content-type":"javascript",language:"js",dependencies:[{package:e.package,version:n.minorRange,type:"npm"}]},protocol:o.protocol}}if("node:"===o.protocol){return{name:o.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:[]},protocol:o.protocol}}if("use:"===o.protocol){return{name:o.pathname,doc:{type:"function",dependencies:[]},protocol:o.protocol}}}}async resolveNodeTree({root:e}){for await(const t of e.childs)await this.resolveTypeWorkflow({node:t})}async resolveTypeWorkflow({node:e}){e.context.transform=e.context.transform||w(e.definition);const t=e.context.transform;for(let e=0;e<t.params?.length;e++){const o=t.params[e];if("string"==typeof o)t.params[e]={key:o,hasDefault:!1};else{const n=Object.keys(o)[0];t.params[e]={key:n,hasDefault:!0,default:o[n],type:typeof o[n]}}}e.context.next=e.childs[0];for await(const t of e.childs)await this.resolveType({node:t})}async resolveType({node:e}){const t={...this.#D,node:e};"function"==typeof e.resolve&&await e.resolve(t);for await(const t of e.childs)await this.resolveType({node:t})}async resolveTypeCommon({node:e}){const t=e.context.transform;t.hasOwnProperty("page")&&(t.page=await this.transformExpression(t.page)),t.hasOwnProperty("print")&&(t.print=await this.transformExpression(t.print)),t.hasOwnProperty("sleep")&&(t.sleep=await this.transformExpression(t.sleep)),t.hasOwnProperty("assert")&&(t.assert=await this.transformExpression(t.assert))}async createAtomLibFiles({root:e}){await this.setProgress({message:"Creating external lib files."}),this.#r.typesDir="./types";const t=e.context.libs.filter((e=>"atom"===e.type));for(let e=0;e<t.length;e++){const o=t[e].atom,n=this.#s.projectDir;if("local:"===o.protocol){const e=i.resolve(this.#s.projectSrcDir,`${o.fileName||o.name}.js`),t=i.relative(`${this.#s.projectDir}/src/default/blocks`,e);if(!l.existsSync(e)){l.mkdirSync(i.dirname(e),{recursive:!0});let t="export default async (input)=>{\n";t+="}",l.writeFileSync(e,t,"utf8")}o.relativePath=t.split(i.sep).join("/"),this.#r.typesDir=`./types/${i.basename(n)}/src`}else if("npm:"===o.protocol)o.relativePath=o.name;else if("node:"===o.protocol)o.relativePath=o.name;else if("use:"===o.protocol);else{const e=`${n}/src/libs/${o.id}.js`,t=o.doc.contents?.find((e=>"esm"===e.format))||o.doc;l.writeFileSync(i.normalize(e),t.content,"utf8")}}}async createEngine({root:e}){await this.setProgress({message:"Creating engine file."});const t=this.#s.templateDir,o=g.compile(l.readFileSync(i.resolve(t,"src/default/engine.js.njk"),"utf8"),this.#c);for(let t=0;t<e.childs.length;t++){const n=e.childs[t];if(!n.entryFile)continue;const s=o.render({flow:n,ui:{package:"@fnet/react-app"}}),r=this.#s.projectDir,a=i.resolve(r,`src/default/${n.entryFile}`);l.writeFileSync(a,s,"utf8")}}async createNodeTree({root:e}){await this.setProgress({message:"Creating block files."});for await(const t of e.childs)await this.createTypeWorkflow({node:t})}async createTypeWorkflow({node:e}){const t=this.#s.templateDir,o=g.compile(l.readFileSync(i.resolve(t,"src/default/workflow.js.njk"),"utf8"),this.#c).render(e),n=this.#s.projectDir,s=i.resolve(n,`src/default/${e.codeKey}.js`);l.writeFileSync(s,o,"utf8");for await(const t of e.childs)await this.createType({node:t})}async createType({node:e}){switch(e.type){case"assign":case"steps":case"return":case"call":case"new":case"form":case"raise":case"switch":case"next":case"tryexcept":case"for":case"signal":case"wait":case"modules":case"output":this.createBlockFromTemplate({node:e})}for await(const t of e.childs)await this.createType({node:t})}createBlockFromTemplate({node:e}){const t=this.getBlockTemplate({node:e});e.context.render=t.render(e),this.createStepFile({node:e})}getBlockTemplate({node:e}){let t=this.#d[e.type];if(t)return t;const o=this.#s.templateDir;return t=g.compile(l.readFileSync(i.resolve(o,`src/default/blocks/${e.type}.js.njk`),"utf8"),this.#c),this.#d[e.type]=t,t}createStepFile({node:e}){const t=this.#s.projectDir,o=`${e.codeKey}.js`,n=i.resolve(t,`src/default/blocks/${o}`);l.writeFileSync(n,e.context.render,"utf8"),e.context.fileName=o,e.context.filePath=n}async transformExpression(e){let t=await this.transformValue(e);return t=JSON.stringify(t),t=this.replaceSpecialPattern(t),t}async transformValue(e){if(Array.isArray(e))for(let t=0;t<e.length;t++)e[t]=await this.transformValue(e[t]);else if(b(e)){const t=Object.keys(e);for(let o=0;o<t.length;o++){const n=t[o],i=A({expression:n});if(i)if("e"===i.processor){const t=e[n].replace(/(\r\n|\n|\r)/g,"");e[i.statement]=`$::${t}::`,delete e[n]}else e[n]=await this.transformValue(e[n]);else e[n]=await this.transformValue(e[n])}}else if("string"==typeof e){const t=A({expression:e});if(t){const{processor:o,statement:n}=t;switch(o){case"v":e=`$::v.${n}::`;break;case"e":e=`$::${n}::`;break;case"m":e=`$::c.module?.${n}||flow.module?.${n}::`;break;case"f":e=`$::c.form.${n}::`;break;case"for":e=`$::caller.for.${n}::`}}}return e}replaceSpecialPattern(e){return e.replace(/"\$::(.*?)::"/g,"$1")}replaceExpressionLegacy(e){return e.replaceAll(/(?<outer>"\${(?<inner>[^{]*)}")/g,"$2")}async createProjectYaml(){const e="fnet.yaml",t=`Creating ${e}`;await this.setProgress({message:t});const{content:o,...n}=this.#r.doc,s=this.#s.projectDir,r=i.resolve(s,`${e}`);l.writeFileSync(r,h.stringify(n),"utf8")}async createProjectMainYaml(){const e="flow.main.yaml",t=`Creating ${e}`;await this.setProgress({message:t});const o={content:h.stringify(this.#a)},n=this.#s.templateDir,s=g.compile(l.readFileSync(i.resolve(n,`${e}.njk`),"utf8"),this.#c).render(o),r=this.#s.projectDir,a=i.resolve(r,`${e}`);l.writeFileSync(a,s,"utf8")}async runPrettifier(){const e=this.#s.projectDir;if(q("bun")){const t=await u("prettier --write .",{cwd:i.resolve(e,"src")});if(0!==t.code)throw new Error(t.stderr)}else{const t=await u("prettier --write .",{cwd:i.resolve(e,"src")});if(0!==t.code)throw new Error(t.stderr)}}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#s.project?.devops){const e=[this.#s.project?.devops];for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&await o.save()}}else if(this.#r.id){const e=await D.list({type:"workflow.deploy",parent_id:this.#r.id});for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&(o=await D.update(o,{id:o.id}))}}}async deployProject(e){const{deploymentProject:t}=e,{yamlDocument:o}=t;if(t.doc.targets&&Array.isArray(t.doc.targets))throw new Error("Deployment project targets are deprecated. Please update targets in the yaml file.");const n=Object.keys(t.doc||{}),i=o||{};for(let e=0;e<n.length;e++){const o=t.doc[n[e]];o.name=n[e];const s=i.get(n[e]);await re({...this.#k,deploymentProject:t,deploymentProjectTarget:o,yamlTarget:s})}}async registerToPackageManager(e){const{target:t,packageJSON:o}=e;if(!this.#s.id)return;let n=await D.first({name:t.params.name,parent_id:this.#g.env.ATOM_PACKAGES_ID});n?(n.doc.versions.splice(0,0,{v:o.version}),await D.update(n,{id:n.id})):n=await D.create({parent_id:this.#g.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:o.version}]}})}async setProgress(e){const o="string"==typeof e?e:e?.message;console.log(t.blue(o)),await this._cache_set(this.#y,{status:"IN_PROGRESS",message:o})}async build(){if(this.#j&&!this.#b)return await this.createNetwork();try{const e=this.#j?await me({root:this.#m}):void 0;if(this.#b){const t=this.#k.context.project;if(await this.initWorkflowDir(),await this.initNunjucks(),this.#j){let t=this.#s.project?.projectDir||this.#s.projectDir;t=i.resolve(t,"fnet"),l.existsSync(t)&&(l.existsSync(i.resolve(t,"flow.bpmn"))&&l.unlinkSync(i.resolve(t,"flow.bpmn")),l.writeFileSync(i.resolve(t,"flows.bpmn"),e.diagramXML,"utf8"))}await this.createAtomLibFiles({root:this.#m}),await this.createEngine({root:this.#m}),await this.createNodeTree({root:this.#m}),await this.createProjectYaml(),await async function({atom:e,context:t,setProgress:o,Atom:n}){const s="readme.md",r=`Creating ${s}`;if(await o({message:r}),t.project?.readme){const e=t.projectDir,o={content:t.project.readme.doc.content},n=i.resolve(t.project.projectDir,"fnet/how-to.md");if(l.existsSync(n)){const e=l.readFileSync(n,"utf8");o.howto=e}const r=i.resolve(t.project.projectDir,"fnet/input.yaml");if(l.existsSync(r)){const e=await y({file:r,tags:t.tags});o.input=e.content}const a=i.resolve(t.project.projectDir,"fnet/output.yaml");if(l.existsSync(a)){const e=await y({file:a,tags:t.tags});o.output=e.content}const c=t.templateDir,p=g.compile(l.readFileSync(i.resolve(c,`${s}.njk`),"utf8"),g.configure(c)).render(o),d=i.resolve(e,`${s}`);l.writeFileSync(d,p,"utf8")}else if(e.id){const o=await n.first({type:"wiki",parent_id:e.id});if(!o||"markdown"!==o.doc?.["content-type"])return;const{content:r,...a}=o.doc,c={content:r},p=t.templateDir,d=g.compile(l.readFileSync(i.resolve(p,`${s}.njk`),"utf8"),g.configure(p)).render(c),f=t.projectDir,m=i.resolve(f,`${s}`);l.writeFileSync(m,d,"utf8")}}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating tsconfig.json."});const s={atom:e,packageDependencies:n},r=o.templateDir,a=g.compile(l.readFileSync(i.resolve(r,"tsconfig.json.njk"),"utf8"),g.configure(r)).render(s),c=o.projectDir,p=i.resolve(c,"tsconfig.json");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating .gitignore"});const s={atom:e,packageDependencies:n},r=o.templateDir,a=g.compile(l.readFileSync(i.resolve(r,".gitignore.njk"),"utf8"),g.configure(r)).render(s),c=o.projectDir,p=i.resolve(c,".gitignore");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:e,setProgress:t,context:o,njEnv:n}){if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating input args."});let s={};if(s=e.doc.input?e.doc.input:{type:"object",properties:{},required:[]},e.doc.features.cli.fargs&&!1!==e.doc.features.cli.fargs?.enabled){const t=e.doc.features.cli.fargs;Reflect.has(t,"default")&&t.default}const r={imports:[],atom:e},a=o.templateDir,c=g.compile(l.readFileSync(i.resolve(a,"src/default/input.args.js.njk"),"utf8"),n).render(r),p=o.projectDir,d=i.resolve(p,"src/default/input.args.js");l.writeFileSync(d,c,"utf8");const f=new N({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});C(f);const m=f.compile(s),u=T(f,m)+"\nexport { schema31 as schema };";l.writeFileSync(i.resolve(p,"src/default/validate_input.js"),u,"utf8")}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating cli."});const s={atom:e,packageDependencies:n},r=o.templateDir,a=i.resolve(o.projectDir,"src/cli");l.existsSync(a)||l.mkdirSync(a,{recursive:!0}),await m({pattern:["index.js.njk"],dir:i.resolve(r,"src/cli"),outDir:a,context:s})}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){if(!0!==e.doc.features.app.enabled)return;await t({message:"Creating app folder"});const s={atom:e,packageDependencies:n,ts:Date.now()},r=o.templateDir,a=i.resolve(o.projectDir,"src/app");l.existsSync(a)||l.mkdirSync(a,{recursive:!0});let c=["index.js.njk"];!1!==e.doc.features.app.html&&c.push("index.html.njk"),await m({pattern:c,dir:i.resolve(r,"src/app"),outDir:a,context:s})}(this.#k),"bun"===t.runtime.type?await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating build.js file."});const s={atom:e,packageDependencies:n},r=o.templateDir,a=g.compile(l.readFileSync(i.resolve(r,"build.js.njk"),"utf8"),g.configure(r)).render(s),c=o.projectDir,p=i.resolve(c,"build.js");l.writeFileSync(p,a,"utf8"),l.chmodSync(p,"755")}(this.#k):await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating rollup file."});const s={atom:e,packageDependencies:n},r=i.resolve(o.projectDir,"src","default/index.js");if(!l.existsSync(r))throw new Error(`Entry file not found: ${r}`);const a=(await S({file:r,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),c=e.doc.features.rollup_output,p=Object.keys(c);for(let e=0;e<p.length;e++){const t=c[p[e]];if(!0===t.browser&&a.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(a.map((e=>({key:e,value:e})))),t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{};for(let e=0;e<a.length;e++){const o=a[e];t.alias.entries[o]=`node:${o}`,t.alias.entries[`node:${o}`]=o}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(a)}}const d=o.templateDir;let f=g.compile(l.readFileSync(i.resolve(d,"rollup.config.mjs.njk"),"utf8"),g.configure(d)).render(s);const m=o.projectDir;let u=i.resolve(m,"rollup.config.mjs");l.writeFileSync(u,f,"utf8")}(this.#k),await async function({atom:e,context:t,packageDependencies:o,packageDevDependencies:n,setProgress:s}){await s({message:"Creating package.json."}),o.filter((e=>!0===e.dev)).forEach((e=>{n.find((t=>t.package===e.package))||n.push(e);const t=o.findIndex((t=>t.package===e.package));o.splice(t,1)}));const r=o.find((e=>"react"===e.package)),a=o.find((e=>"react-dom"===e.package));r&&!a?o.push({package:"react-dom",version:r.version}):r&&a&&(a.version=r.version),r&&e.doc.features.react_version>=17&&(o.find((e=>"@emotion/react"===e.package))||o.push({package:"@emotion/react",version:"^11"}),o.find((e=>"@emotion/styled"===e.package))||o.push({package:"@emotion/styled",version:"^11"}));const c=[];!0===e.doc.features.app.enabled&&c.push({file:i.resolve(t.projectDir,"src/app/index.js"),dev:!1!==e.doc.features.app.dev}),!0===e.doc.features.cli.enabled&&c.push({file:i.resolve(t.projectDir,"src/cli/index.js"),dev:!1!==e.doc.features.cli.dev});for await(const e of c){const i=e.file;if(!l.existsSync(i))throw new Error(`App file not found: ${i}`);const r=(await S({file:i,recursive:!0,verbose:!1})).all;for await(const i of r){if("npm"!==i.type)continue;if(o.find((e=>e.package===i.package)))continue;if(n.find((e=>e.package===i.package)))continue;const r=await se({name:i.package,projectDir:t.projectDir,setProgress:s});(!0===e.dev?n:o).push({package:i.package,subpath:i.subpath,version:r.minorRange,type:"npm"})}}const p={atom:e,packageDependencies:o,packageDevDependencies:n},d=t.templateDir,f=g.compile(l.readFileSync(i.resolve(d,"package.json.njk"),"utf8"),g.configure(d)).render(p),m=t.projectDir,u=i.resolve(m,"package.json");l.writeFileSync(u,f,"utf8");const y=i.resolve(t.project.projectDir,"fnet");if(l.existsSync(y)){const e=i.resolve(t.projectDir,"fnet");l.existsSync(e)||l.mkdirSync(e);const o=l.readdirSync(y);for(const t of o){const o=i.resolve(y,t);if(!l.lstatSync(o).isFile())continue;const n=i.resolve(e,t);l.copyFileSync(o,n)}}}(this.#k),await async function({setProgress:e,context:t}){const o=t.projectDir;await e({message:"Prettifiying source files."});let n=i.join("src","**","*");if(q("bun")){const e=await u(`prettier --write ${n} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:o});if(0!==e.code)throw new Error(e.stderr)}else{const e=await u(`prettier --write ${n} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:o});if(0!==e.code)throw new Error(e.stderr)}}(this.#k),await async function({atom:e,setProgress:t,context:o}){if(!e.doc.features.dts_enabled)return;const n=o.projectDir;if(await t({message:"Creating .d.ts"}),0!==(await u("tsc",{cwd:n})).code)throw new Error("Couldnt create .d.ts files.")}(this.#k),this.#x&&(await async function({setProgress:e,atom:t,context:o}){const n=o.projectDir;if(await e({message:"Installing npm packages."}),q("bun")){if(0!==(await u(`bun install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}else if(0!==(await u(`npm install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}(this.#k),await async function({setProgress:e,context:t}){const o=t.projectDir;if(await e({message:"Building main project."}),q("bun")){if(0!==(await u(t.dev?"bun run build:dev":"bun run build",{cwd:o})).code)throw new Error("Couldnt build project.")}else if(0!==(await u(t.dev?"npm run build:dev":"npm run build",{cwd:o})).code)throw new Error("Couldnt build project.")}(this.#k),this.#v&&await this.deploy())}await this._cache_set(this.#y,{status:"COMPLETED",data:{network:e}})}catch(e){throw await this._cache_set(this.#y,{status:"FAILED",message:e.message||e}),e}}async createNetwork(){try{const e=await me({root:this.#m});await this._cache_set(this.#y,{status:"COMPLETED",data:{...e}})}catch(e){throw await this._cache_set(this.#y,{status:"FAILED",message:e.message||e}),e}}}const Qe={command:"build",describe:"Build flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{const t=await Q(e),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},Ze={command:"build:dev",describe:"Build flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{e.dev=!0;const t=await Q(e),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},et={command:"deploy",describe:"Build and deploy flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Q({...e,mode:"all"}),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},tt={command:"file",describe:"Just create files",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Q({...e,mode:"file"}),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},ot={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 t=await Q(e),{project:o}=t,{projectDir:n,projectFileParsed:s}=o,r=s.input;if(!r)throw new Error("Config schema not found in project file.");if(!Reflect.has(e,"name")){const{inputName:t}=await M({type:"input",name:"inputName",message:"Input name:",initial:"dev"});e.name=t}const a=i.resolve(n,".fnet");l.existsSync(a)||l.mkdirSync(a);const c=i.resolve(a,`${e.name}.fnet`),p=l.existsSync(c),d=(await import("@fnet/object-from-schema")).default,f=await d({schema:r,format:"yaml",ref:p?c:void 0});l.writeFileSync(c,f)}catch(e){console.error(e.message),process.exit(1)}}};var nt={promptForSelection:async function(e){const{items:o,message:n,nameField:i="name",valueField:s="name",initialValue:r=null,allowAbort:a=!0}=e;if(!o||0===o.length)return console.log(t.yellow("No items available for selection.")),null;if(1===o.length&&!a){const e=o[0],n="string"==typeof e?e:e[s];return console.log(t.blue(`Only one option available: ${"string"==typeof e?e:e[i]}`)),n}let c=o.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[s],value:e[s],message:e[i]||e[s]}));a&&c.push({name:"cancel",value:null,message:t.yellow("Cancel")});let l=null;if(r){const e=c.findIndex((e=>e.name===r));-1!==e&&(l=e)}const p="selectedItem",{[p]:d}=await M({type:"select",name:p,message:n,choices:c,initial:l});return"cancel"===d?null:d},promptForMultipleSelection:async function(e){const{items:o,message:n,nameField:i="name",valueField:s="name",initialValues:r=[],allowAbort:a=!0}=e;if(!o||0===o.length)return console.log(t.yellow("No items available for selection.")),null;let c=o.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[s],value:e[s],message:e[i]||e[s]})),l=[];r&&r.length>0&&(l=c.map(((e,t)=>r.includes(e.name)?t:-1)).filter((e=>-1!==e)));const p="selectedItems",d=await M({type:"multiselect",name:p,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===d[p].length?null:d[p]}};const it=i.join(f.homedir(),".fnet","express");async function st(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)",type:"string",choices:["node"],default:"node"})),(async e=>{await async function(e){try{l.existsSync(it)||l.mkdirSync(it,{recursive:!0});const o=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=i.join(it,o);l.existsSync(n)||l.mkdirSync(n,{recursive:!0});let s,r=e.projectName,a=e.runtime;if(e.yes){if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=e.length>0?Math.max(...e)+1:1;r=`fnet-${t}`}a||(a="node")}else{if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=`fnet-${e.length>0?Math.max(...e)+1:1}`,o=await M([{type:"input",name:"projectName",message:"Enter project name:",default:t}]);r=o.projectName}const e=a||"node";a=(await M({type:"select",name:"runtime",message:"Select runtime:",choices:["node"],initial:e})).runtime}if(s=i.join(n,r),l.existsSync(s)){let e=1;for(;l.existsSync(i.join(n,`${r}-${e}`));)e++;r=`${r}-${e}`,s=i.join(n,r)}if(!e.yes){if(!(await M([{type:"confirm",name:"proceed",message:`Create express project "${r}" in ${s}?`,default:!0}])).proceed)return void console.log(t.yellow("Project creation cancelled."))}console.log(t.blue(`Creating express project "${r}" in ${s}...`));const p=i.dirname(s),d=["create","--name",i.basename(s)];d.push("--runtime",a),e.yes&&d.push("--yes"),l.existsSync(p)||l.mkdirSync(p,{recursive:!0});const f=c("fnet",d,{stdio:"inherit",shell:!0,cwd:p});return new Promise(((o,n)=>{f.on("close",(i=>{0===i?(console.log(t.green(`\nExpress project "${r}" created successfully!`)),console.log(t.blue(`\nProject location: ${s}`)),e.yes?o():async function(e){try{(await M({type:"confirm",name:"openIDE",message:"Would you like to open the project in an IDE?",initial:!0})).openIDE&&await lt(e)}catch(e){console.error(t.red(`Error opening IDE: ${e.message}`))}}(s)):(console.error(t.red(`\nFailed to create express project "${r}".`)),n(new Error(`Process exited with code ${i}`)))}))}))}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));const o=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(e.today){const e=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=o.indexOf(e);if(-1===n)return void console.log(t.yellow("No express projects found for today."));o.splice(0,n),o.splice(1)}const n=[];e.type||e.all||(e.type="fnet");for(const t of o){const o=i.join(it,t),s=l.readdirSync(o);for(const r of s){const s=i.join(o,r),a=l.statSync(s);let c="unknown";if(r.startsWith("fnode-")||l.existsSync(i.join(s,"fnode.yaml"))?c="fnode":(r.startsWith("fnet-")||l.existsSync(i.join(s,"fnet.yaml")))&&(c="fnet"),e.type&&c!==e.type)continue;if(e.name&&!r.includes(e.name))continue;const p=`${t.slice(0,4)}-${t.slice(4,6)}-${t.slice(6,8)}`;n.push({name:r,type:c,date:p,path:s,created:a.birthtime})}}if(n.sort(((e,t)=>t.created-e.created)),0===n.length)return void console.log(t.yellow("No express projects found matching the criteria."));console.log(t.blue("\nExpress Projects:"));const s=(await import("./index.-SGbq2cI.js")).default,r=["NAME","TYPE","DATE","PATH"],a=s.createTable(r,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});for(const e of n){let o=e.path;o.startsWith(f.homedir())&&(o="~"+o.substring(f.homedir().length)),a.push([t.white(e.name),"fnet"===e.type?t.cyan(e.type):"fnode"===e.type?t.green(e.type):e.type,e.date,o])}console.log(a.toString()),console.log(t.blue(`\nTotal: ${n.length} projects`))}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));let o;if(e.latest){if(o=await rt(),!o)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(o=await at(e.projectName),!o)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));o=i.join(it,e)}await lt(o)}catch(e){console.error(t.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 o=process.cwd();let n;if(o.includes(it))n=o,console.log(t.blue(`Using current express project: ${i.basename(n)}`));else if(e.latest){if(n=await rt(),!n)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(n=await at(e.projectName),!n)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));n=i.join(it,e)}let s=e.destination;if(!s){s=(await M({type:"input",name:"destination",message:"Enter destination directory:",initial:i.join(process.cwd(),i.basename(n))})).destination}if(s.startsWith("~")&&(s=i.join(f.homedir(),s.slice(1))),s=i.resolve(s),s.startsWith(n+i.sep)||s===n)return void console.log(t.red("Destination cannot be inside the source directory."));if(l.existsSync(s)){if(!l.statSync(s).isDirectory())return void console.log(t.red(`Destination "${s}" is not a directory.`));if(l.readdirSync(s).length>0){if(!(await M({type:"confirm",name:"overwrite",message:`Destination "${s}" is not empty. Continue anyway?`,initial:!1})).overwrite)return void console.log(t.yellow("Project move cancelled."))}}else l.mkdirSync(s,{recursive:!0});console.log(t.blue(`Moving project from ${n} to ${s}...`)),dt(n,s),console.log(t.green(`\nProject moved successfully to ${s}`));(await M({type:"confirm",name:"deleteOriginal",message:"Delete the original express project?",initial:!1})).deleteOriginal&&(l.rmSync(n,{recursive:!0,force:!0}),console.log(t.green("Original project deleted."))),await lt(s)}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));let o;if(e.latest){if(o=await rt(),!o)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(o=await at(e.projectName),!o)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));o=i.join(it,e)}const n=i.basename(o);if(!e.yes){if(!(await M({type:"confirm",name:"confirm",message:`Are you sure you want to remove project "${n}"?`,initial:!1})).confirm)return void console.log(t.yellow("Project removal cancelled."))}console.log(t.blue(`Removing project "${n}"...`)),l.rmSync(o,{recursive:!0,force:!0}),console.log(t.green(`Project "${n}" removed successfully.`))}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));let o;if(e.latest){if(o=await rt(),!o)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(o=await at(e.projectName),!o)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));o=i.join(it,e)}console.log(t.blue(`Entering project directory: ${o}`)),console.log(t.yellow("\nOpening a new shell in the project directory..."));const n=process.env.SHELL||"/bin/bash",s=c(n,[],{stdio:"inherit",cwd:o,shell:!0});return new Promise((e=>{s.on("close",(()=>{console.log(t.green("\nReturned from project directory.")),e()}))}))}catch(e){console.error(t.red(`Error entering express project directory: ${e.message}`)),process.exit(1)}}(e)})).demandCommand(1,"You need to specify a command").help()}async function rt(){const e=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(0===e.length)return null;const t=e[0],o=i.join(it,t),n=l.readdirSync(o);if(0===n.length)return null;let s=null,r=0;for(const e of n){const t=i.join(o,e),n=l.statSync(t);n.birthtimeMs>r&&(r=n.birthtimeMs,s=t)}return s}async function at(e){const o=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const n of o){const o=i.join(it,n),s=l.readdirSync(o);if(s.includes(e))return i.join(o,e);const r=s.filter((t=>t.includes(e)));if(r.length>0){if(1===r.length)return i.join(o,r[0]);{const s=r.map((e=>({name:i.join(o,e),value:i.join(o,e),message:`${e} (${n})`}))),a=await nt.promptForSelection({items:s,message:`Multiple projects match "${e}". Please select one:`,nameField:"message",valueField:"value",allowAbort:!0});return null===a?(console.log(t.yellow("Operation cancelled.")),null):a}}}return null}async function ct(){const e=[],o=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const t of o){const o=i.join(it,t),n=l.readdirSync(o);for(const s of n){const n=i.join(o,s),r=l.statSync(n),a=`${t}/${s}`;e.push({name:a,value:a,created:r.birthtime})}}if(e.sort(((e,t)=>t.created-e.created)),0===e.length)return null;const n=await nt.promptForSelection({items:e,message:"Select a project:",nameField:"value",valueField:"value",allowAbort:!0});return null===n?(console.log(t.yellow("Operation cancelled.")),null):n}async function lt(e){const o=await pt("code --version"),n=await pt("code-insiders --version");let i=null;if(o&&n){const e=await M({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"}]});i=e.ide}else if(o)i="code";else{if(!n)return console.log(t.yellow("No supported IDE found. Please open the project manually.")),void console.log(t.blue(`Project path: ${e}`));i="code-insiders"}console.log(t.blue(`Opening project in ${i}...`)),console.log(t.blue(`Project path: ${e}`));const s=c(i,[e],{stdio:"inherit",shell:!0});return new Promise(((e,o)=>{s.on("close",(n=>{0===n?(console.log(t.green(`Project opened in ${i}.`)),e()):(console.error(t.red(`Failed to open project in ${i}.`)),o(new Error(`Process exited with code ${n}`)))}))}))}async function pt(e){return new Promise((t=>{c(e,{shell:!0,stdio:"ignore"}).on("close",(e=>{t(0===e)}))}))}function dt(e,t){l.existsSync(t)||l.mkdirSync(t,{recursive:!0});const o=l.readdirSync(e,{withFileTypes:!0});for(const n of o){const o=i.join(e,n.name),s=i.join(t,n.name);if(n.isDirectory()){if(".git"===n.name||".workspace"===n.name)continue;dt(o,s)}else l.copyFileSync(o,s)}}const ft=i.dirname(a(import.meta.url));const mt=i.dirname(a(import.meta.url)),ut=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(){d({name:["redis"],dir:ut,optional:!0});const e=function({baseDir:e}){let t=e=e||ft;for(;t!==i.parse(t).root;){const e=i.join(t,"node_modules");if(l.existsSync(e))return e;t=i.dirname(t)}return null}({baseDir:mt}),t="win32"===process.platform?";":":";e&&(process.env.PATH=`${i.join(e,"/.bin")}${t}${process.env.PATH}`)}(),async function(){try{let o=e(process.argv.slice(2)).usage("Usage: $0 <command> [options]").command(Y).command(ee).command(Qe).command(Ze).command(et).command(tt).command(ot).command("express","Create and manage express projects",st);o=G(o,{bin:"npm"}),o=G(o,{bin:"node"}),o=G(o,{bin:"bun"}),o=G(o,{name:"serve",bin:"bun",preArgs:["run","serve","--"]}),o=G(o,{name:"watch",bin:"bun",preArgs:["run","watch","--"]}),o=G(o,{name:"app",bin:"bun",preArgs:["run","app","--"]}),o=G(o,{name:"cli",bin:"bun",preArgs:["run","cli","--"]}),o=G(o,{name:"cli:dev",bin:"bun",preArgs:["run","cli:dev","--"]}),o=G(o,{name:"cli:compile",bin:"bun",preArgs:["run","cli:compile","--"]}),o=G(o,{name:"cli:compile:dev",bin:"bun",preArgs:["run","cli:compile:dev","--"]}),o=G(o,{name:"cli:install",bin:"bun",preArgs:["run","cli:install","--"]}),o=G(o,{name:"compile",bin:"bun",preArgs:["run","compile","--"]}),o=function(e,{name:o}){return e.command(`${o} [options]`,"Install the project as a binary",(e=>e.option("name",{alias:"n",describe:"Name to use for the installed binary",type:"string"}).option("force",{alias:"f",describe:"Force overwrite if binary already exists",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Automatically answer yes to all prompts",type:"boolean",default:!1})),(async e=>{try{const o=await V(e),{projectDir:n}=o;console.log(t.blue("Compiling project..."));const s=i.join(n,".bin");l.existsSync(s)||l.mkdirSync(s,{recursive:!0});const r=i.basename(i.dirname(n)),a=o.project?.projectFileParsed?.features?.cli?.bin,c=e.name||a||r;console.log(t.blue(`Using binary name: ${c}`));const p=i.join(s,c),{spawn:d}=await import("child_process"),f=d("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${p}`],{cwd:n,stdio:"inherit",shell:!0});await new Promise(((e,t)=>{f.on("close",(o=>{0===o?e():t(new Error(`Compilation failed with code ${o}`))})),f.on("error",(e=>{t(e)}))})),"win32"!==process.platform&&l.chmodSync(p,493),console.log(t.green(`Binary compiled successfully: ${p}`)),console.log(t.blue("Installing binary..."));const m=["install",p];e.name&&m.push("--name",e.name),e.force&&m.push("--force"),e.yes&&m.push("--yes");const u=d("fbin",m,{stdio:"inherit",shell:!0});await new Promise(((e,t)=>{u.on("close",(o=>{0===o?e():t(new Error(`Installation failed with code ${o}`))})),u.on("error",(e=>{t(e)}))}))}catch(e){console.error(t.red(`Failed to install binary: ${e.message}`)),process.exit(1)}}))}(o,{name:"install"}),o=G(o,{bin:"npx"}),o=G(o,{bin:"cdk"}),o=G(o,{bin:"aws"}),o=function(e,{name:t,preArgs:o=[]}){return e.command(`${t} <config> <command> [options..]`,"Run a command with a config context",(e=>e.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await V(e),{projectDir:n}=t,i=e.config,s=await d({name:i,dir:n,transferEnv:!1,optional:!0,tags:t.tags}),r=s?.data?.env||void 0,a=e.command,p=process.argv.slice(5);z(c(a,[...o,...p],{cwd:l.existsSync(n)?n:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...r}}))}catch(e){console.error(e.message),process.exit(1)}}))}(o,{name:"with"}),o=function(e,{name:t,projectType:o="auto"}){return e.command(`${t} group [options..]`,"Run a command group.",(e=>e.positional("group",{type:"string"}).option("ftag",{type:"array"}).help(!1).version(!1)),(async e=>{try{const{runCommandGroup:t}=await import("./index.DrwlOzAe.js");await t({projectType:o,group:e.group,tags:e.ftag,args:e,argv:process.argv})}catch(e){console.error(e.message),process.exit(1)}}))}(o,{name:"run",projectType:"fnet"}),o.demandCommand(1,"You need at least one command before moving on").help().version().argv}catch(e){console.error(t.red(`Fatal error: ${e.message}`)),process.exit(1)}}().catch((e=>{console.error(t.red(`Fatal error: ${e.message}`)),process.exit(1)}));export{H as r,q as w};
2
+ import e from"yargs";import t from"chalk";import{promisify as o}from"node:util";import n from"tree-kill";import i,{delimiter as s,join as r}from"node:path";import{fileURLToPath as a}from"node:url";import{spawn as c}from"node:child_process";import l,{existsSync as p}from"node:fs";import d from"@fnet/config";import f from"node:os";import m from"@flownet/lib-render-templates-dir";import u from"@fnet/shelljs";import y from"@fnet/yaml";import h from"yaml";import g from"nunjucks";import w from"lodash.clonedeep";import b from"isobject";import x from"redis";import v from"@flownet/lib-is-redis-online";import{randomUUID as j}from"node:crypto";import{Api as k,Atom as D}from"@flownet/lib-atom-api-js";import _ from"lodash.merge";import S from"@flownet/lib-parse-imports-js";import E from"@fnet/npm-list-versions";import $ from"@fnet/npm-pick-versions";import P from"object-hash";import N from"ajv/dist/2020.js";import T from"ajv/dist/standalone/index.js";import C from"ajv-formats";import F from"@flownet/lib-parse-node-url";import I from"bpmn-moddle";import O from"dagre";import A from"@fnet/expression";import B from"@fnet/list-files";import R from"@fnet/key-value-transformer";import K from"@flownet/lib-parse-npm-path";import M from"@fnet/prompt";const L=o(n);let J=!1;async function W(e,t){if(J)return;if(J=!0,!e.killed&&e.pid)try{await L(e.pid,"SIGTERM").catch((()=>{})),await new Promise((e=>setTimeout(e,500))),e.killed||await L(e.pid,"SIGKILL").catch((()=>{}))}catch(e){}await new Promise((e=>setTimeout(e,100)));const o="SIGINT"===t?130:"SIGTERM"===t?143:1;process.exit(o)}function z(e){["SIGINT","SIGTERM","SIGQUIT"].forEach((t=>{process.once(t,(async()=>{await W(e,t)}))})),process.on("uncaughtException",(async t=>{await W(e)})),process.on("unhandledRejection",(async t=>{await W(e)})),e.on("close",(e=>{J||process.exit(e)}))}function G(e,{name:t,bin:o,preArgs:n=[]}){return"function"==typeof o&&(o=o()),e.command(`${t||o} [commands..]`,`${o} ${n.join(" ")}`,(e=>e.help(!1).version(!1)),(async e=>{try{const t=await U(e),{projectDir:s}=t,r=e=>e.includes(" ")?"win32"===process.platform?`"${e.replace(/(["^])/g,"^$1")}"`:`"${e.replace(/(["\\$`])/g,"\\$1")}"`:e,a=process.argv.slice(3).map(r),l={...process.env},p=i.join(s,"node_modules");l.NODE_PATH=p;const d=l.NODE_OPTIONS||"";l.NODE_OPTIONS=`${d} --preserve-symlinks`.trim();z(c(o,[...n,...a],{cwd:s,stdio:"inherit",shell:!0,detached:!0,env:l}))}catch(e){console.error(e.message),process.exit(1)}}))}async function U(e){try{const t=process.argv[1].split("/").pop().split(".")[0];if("fnode"===t){const{createContext:t}=await import("./index.DOYkqsYT.js");return t(e)}if("fnet"===t){const{createContext:t}=await Promise.resolve().then((function(){return Z}));return t(e)}if("frun"===t){const{createContext:t}=await import("./index.CuMyez3E.js");return t(e)}if("fbin"===t){const{createContext:t}=await import("./index.DWpw12No.js");return t(e)}}catch(e){console.warn(`Warning: Could not import context from CLI tool: ${e.message}`)}return{projectDir:process.cwd(),tags:e.ftag}}var V=e=>{const t=process.env.PATH||"",o="win32"===process.platform?(process.env.PATHEXT||".EXE;.CMD;.BAT;.COM").split(";"):[""],n=t.split(s);for(const t of n)for(const n of o){const o=r(t,"win32"===process.platform?e+n:e);if(p(o))return o}return null};const q=i.dirname(a(import.meta.url)),X=process.cwd();function H(e){const t=i.resolve(X,e);if(l.existsSync(t))return t;const o=i.resolve(q,"../..",e);if(l.existsSync(o))return o;throw new Error(`Template path not found: ${e}`)}const Y={command:"create",describe:"Initialize a new fnet project",builder:e=>e.option("name",{type:"string",describe:"Project name"}).option("vscode",{type:"boolean",default:!0,alias:"vs",describe:"Open in VS Code after creation"}).option("runtime",{type:"string",default:"node",choices:["node"],describe:"Runtime environment"}),handler:async e=>{try{const t=process.cwd(),o=H("./template/fnet/project"),n=i.resolve(t,e.name);l.existsSync(n)||l.mkdirSync(n),await m({dir:o,outDir:n,context:e,copyUnmatchedAlso:!0,platform:f.platform()});let s=await u("fnet build",{cwd:n});if(0!==s.code)throw new Error("Failed to build project.");if(V("git")&&(s=await u("git init --initial-branch=main",{cwd:n}),0!==s.code))throw new Error("Failed to initialize git.");if(V("code")&&e.vscode&&(s=await u(`cd ${n} && code .`),0!==s.code))throw new Error("Failed to open vscode.");console.log("Creating project succeeded!"),process.exit(0)}catch(e){console.error("Initialization failed!",e.message),process.exit(1)}}};async function Q(e){if(e.id)return{id:e.id,buildId:e.buildId,mode:e.mode,protocol:e.protocol||"ac:",templateDir:H("./template/fnet/node"),coreDir:H("./template/fnet/core"),projectDir:i.resolve(process.cwd(),`./.output/${e.id}`),tags:e.ftag,dev:e.dev};try{const t=await async function({tags:e}){let t=(o=process.cwd(),i.resolve(o,"fnet.yaml"));var o;if(!l.existsSync(t))throw new Error("fnet.yaml file not found in current directory.");const{raw:n,parsed:s}=await y({file:t,tags:e}),r=i.dirname(t);s.features=s.features||{};const a=s.features;let c;if(a.runtime=a.runtime||{},a.runtime.type=a.runtime.type||"node","object"==typeof s.flows)c=s.flows;else{let t="flow.main.yaml";l.existsSync(i.join(r,"fnet","flows.yaml"))&&(t=i.join("fnet","flows.yaml"));const o=s.main||t;let n=i.resolve(r,o);if(l.existsSync(n)){const{parsed:t}=await y({file:n,tags:e});c=t}else c={main:{steps:[]}}}const p={workflowAtom:{doc:{...s,content:c}},projectDir:r,projectFilePath:t,projectFileContent:n,projectFileParsed:s,runtime:a.runtime};let d=i.resolve(r,"fnet/targets.yaml");if(l.existsSync(d)){const{raw:t,parsed:o}=await y({file:d,tags:e}),n=h.parseDocument(t);p.devops={filePath:d,fileContent:t,yamlDocument:n,doc:{...o},type:"workflow.deploy",save:async()=>{l.writeFileSync(p.devops.filePath,n.toString())}}}const f=i.resolve(r,"readme.md");if(l.existsSync(f)){const e=l.readFileSync(f,"utf8");p.readme={filePath:f,fileContent:e,doc:{content:e,"content-type":"markdown"},type:"wiki"}}return p}({tags:e.ftag});return{buildId:e.buildId,mode:e.mode,protocol:e.protocol||"local:",templateDir:H("./template/fnet/node"),coreDir:H("./template/fnet/core"),projectDir:i.resolve(t.projectDir,"./.workspace"),projectSrcDir:i.resolve(t.projectDir,"./src"),project:t,tags:e.ftag,dev:e.dev}}catch(t){return console.warn(`Warning: Could not load project: ${t.message}`),{projectDir:process.cwd(),tags:e.ftag}}}var Z=Object.freeze({__proto__:null,createContext:Q});const ee={command:"project",describe:"Manage fnet project",builder:e=>e.option("update",{type:"boolean",default:!1,alias:"-u",describe:"Update project files"}),handler:async e=>{try{const t=H("./template/fnet/project"),o=process.cwd(),n=await Q(e);if(e.update){if(await m({dir:t,outDir:o,context:{name:n.project.projectFileParsed.name,runtime:"node"},copyUnmatchedAlso:!0,platform:f.platform()}),0!==(await u("fnet build",{cwd:o})).code)throw new Error("Failed to build project.");console.log("Updating project succeeded!")}process.exit(0)}catch(e){console.error("Project failed.",e.message),process.exit(1)}}};class te{init({config:e,accessToken:t}){return new Promise(((o,n)=>{if(k.set_api_url(e.data.url),t)return k.set_req_token(t),void o(t);fetch(`${e.data.issuer}/protocol/openid-connect/token`,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams(e.data.grant.params)}).then((async e=>{if(!e.ok)throw new Error(await e.text());return e.json()})).then((e=>{k.set_req_token(e.access_token),o(e.access_token)})).catch((e=>{k.set_req_token(),n(e)}))}))}}function oe({feature:e,features:t,packageDevDependencies:o}){const{name:n,packages:i,options:s,extraCheck:r,explicit:a}=e,c=`${n}_enabled`,l=t.rollup_output||{},p=Object.keys(l);let d=s||{};const f=t[n]?.options;f&&(d=_(d,f));const m=!t[n]||!1===t[n]?.enabled;p.forEach((e=>{const o=t.rollup_output[e];if(o){if(Reflect.has(o,n)){if(m||!o[n]||!1===o[n]?.enabled)return void delete o[n];!0===o[n]&&(o[n]={enabled:!0,options:d})}else{if(m||a||!1===t[c])return;o[n]={enabled:!0}}o[n]=o[n]||{},o[n].options={...d,...o[n].options}}}));let u=p.some((e=>!0===t.rollup_output[e][n]?.enabled));r&&(u=r()&&u),t[c]=u,u&&i.forEach((e=>o.push({package:e[0],version:e[1]})))}function ne({dir:e,name:t="index"}){let o=i.resolve(e,`./${t}.tsx`);if(l.existsSync(o)||(o=i.resolve(e,`./${t}.ts`)),l.existsSync(o)||(o=i.resolve(e,`./${t}.jsx`)),l.existsSync(o)||(o=i.resolve(e,`./${t}.js`)),!l.existsSync(o))return{};const n=o,s=i.extname(o);return{file:n,ext:s,ts:".ts"===s||".tsx"===s,name:t}}async function ie(e){const{atom:t,context:o,setProgress:n}=e;n("Initializing features..."),t.doc.features=t.doc.features||{};const s=t.doc.features;s.project=s.project||{},s.project.format=s.project.format||s.project_format||"esm",s.project_format=s.project.format,s.dts_enabled=!0===s.dts||void 0!==s.dts&&!1!==s.dts;const r=i.resolve(o.project.projectDir),a=ne({dir:i.resolve(r,"./app")});if(a.file){n("Parsing app entry imports...");let e=await S({file:a.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.app_uses_jsx=t,s.app_has_entry=!0,e=await S({file:a.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.app_entry_uses_jsx=t,s.app_entry_is_ts=a.ts,s.app_entry_ext=a.ext}const c=ne({dir:i.resolve(r,"./cli")});if(c.file){n("Parsing cli entry imports...");let e=await S({file:c.file,recursive:!0}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.cli_uses_jsx=t,s.cli_has_entry=!0,e=await S({file:c.file}),t=e.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.cli_entry_uses_jsx=t,s.cli_entry_is_ts=c.ts,s.cli_entry_ext=c.ext}if("workflow.lib"===t.type){const e=ne({dir:i.resolve(r,"./src")});if(e.file){n("Parsing src entry imports...");let t=await S({file:e.file,recursive:!0}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type));s.src_uses_jsx=o,s.src_has_entry=!0,t=await S({file:e.file}),o=t.all.some((e=>!0===e.usesJSX&&"local"===e.type)),s.src_entry_uses_jsx=o,s.src_entry_is_ts=e.ts,s.src_entry_ext=e.ext}}const l=Reflect.has(s,"app_entry_uses_jsx")?!0===s.app_entry_uses_jsx:!0===s.src_entry_uses_jsx,p=Reflect.has(s,"cli_entry_uses_jsx")?!0===s.cli_entry_uses_jsx:!0===s.src_entry_uses_jsx;s.form_enabled=l||p||!0===s.form||!0===s.form?.enabled,s.multiple_enabled=s.multiple_enabled||!0===s.multiple||!0===s.multiple?.enabled,!1===s.app?s.app={enabled:!1}:!0===s.app?s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l}:s.app={enabled:!0,extend:!0===s.app_has_entry,export:!0,react:l,...s.app||{}},s.app.enabled=!0===s.app.enabled&&(!0===t.doc.features.form_enabled||!0===s.app.extend||!0===s.app.enabled),s.app.format=s.app.format||"esm",s.app.folder=s.app.folder||s.app.format||"default",!1===s.cli?s.cli={enabled:!1}:!0===s.cli?s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p}:s.cli={enabled:!0,extend:!0===s.cli_has_entry,export:!0,react:p,...s.cli||{}},s.cli.enabled=!0===s.cli.enabled&&(!1===t.doc.features.form_enabled||!0===s.cli.extend||!0===s.cli.enabled),s.cli.format=s.cli.format||"esm",s.cli.folder=s.cli.folder||s.cli.folder||"esm",s.cli.node_options=s.cli.node?.options||s.cli.node_options||"",s.cli.bin=s.cli.bin||t.doc.name,s.cli.installable=!0===s.cli.installable,s.cli.enabled&&(t.doc["npm::bin"]=s.cli.bin),s.json=s.cli.enabled||s.json;const d={cjs:{format:"cjs",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!0,enabled:!1!==s.cjs,copy:!1},esm:{format:"esm",context:s.form_enabled?"window":"global",babel:!0===s.src_uses_jsx||!1,browser:!1,replace:!0,terser:!1,enabled:!1!==s.esm,copy:!0},iife:{format:"iife",context:s.form_enabled?"window":"global",babel:!0,browser:!0,replace:!0,enabled:!0===s.iife,terser:!0,copy:!1}};!0===s.webos&&(d.webos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,input:"./src/app/index.js",output_dir:"./dist/app/webos",copy:!1,babel_options:{targets:{chrome:"79"}}}),!0===s.electron&&(d.electron={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/electron"}),!0===s.nextjs&&(d.nextjs={format:"esm",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/nextjs"}),!0===s.ios&&(d.ios={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/ios"}),!0===s.macos&&(d.macos={format:"iife",browser:!0,babel:!0,context:"window",replace:!0,terser:!0,copy:!1,input:"./src/app/index.js",output_dir:"./dist/app/macos"}),!0===s.app.enabled&&(s.app.dir=`./dist/app/${s.app.folder}`,s.app.output={file:`./dist/app/${s.app.folder}/index.js`,dir:`./dist/app/${s.app.folder}/`,...s.app.output||{}},s.app.input={file:"./src/app/index.js",dir:"./src/app/",...s.app.input||{}},d.app={format:s.app.format,browser:!0,babel:!0,context:"window",replace:!0,input:s.app.input.file,output_dir:s.app.dir,terser:!0,output_exports:!1===s.app.export?"none":"auto",browsersync:!0}),!0===s.cli.enabled&&(s.cli.dir=`./dist/cli/${s.cli.folder}`,s.cli.output={file:`./dist/cli/${s.cli.folder}/index.js`,dir:`./dist/cli/${s.cli.folder}/`,...s.cli.output||{}},s.cli.input={file:"./src/cli/index.js",dir:"./src/cli/",...s.cli.input||{}},d.cli={format:s.cli.format,context:"global",babel:!0===s.src_uses_jsx||!0===s.cli_uses_jsx||!1,browser:!1,replace:!0,enabled:!0,input:s.cli.input.file,output_dir:s.cli.dir,banner:"#!/usr/bin/env node",terser:!0,output_exports:!1===s.cli.export?"none":"auto"});const f={server:".",startPath:`${i.normalize(s.app.dir||".")}`,files:[i.normalize("./dist/**/*")],cors:!0,open:!1};s.babel_options=_({targets:{browsers:"last 9 versions, not dead",node:"18"}},s.babel_options||s.babel?.options),s.browsersync_options=_(f,s.browsersync_options||s.browsersync?.options||{}),s.replace_options=_({},s.replace_options||s.replace?.options||{}),Reflect.has(s.browsersync_options,"proxy")&&delete s.browsersync_options.server,s.rollup=s.rollup||{},s.rollup_output=_(d,s.rollup_output||s.rollup?.output||{}),s.preact_enabled=!0===s.preact||s.preact&&!1!==s.preact?.enabled;let m=Object.keys(d);for(const e of m){const t=d[e];t&&(!1!==s.rollup[e]?(t.babel_options=t.babel_options||s.babel_options,t.browsersync_options=_(s.browsersync_options,t.browsersync_options),t.replace_options=_(s.replace_options,t.replace_options),s.preact_enabled&&(t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{},t.alias.entries.react="preact/compat",t.alias.entries["react-dom"]="preact/compat"),(s.form_enabled||s.babel)&&(t.babel=!0)):delete s.rollup_output[e])}m=Object.keys(s.rollup_output),s.babel_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browser_enabled=m.some((e=>!0===s.rollup_output[e].babel)),s.browsersync_enabled=!1!==s.browsersync&&m.some((e=>!0===s.rollup_output[e].browsersync)),s.browsersync_enabled=s.browsersync_enabled&&s.app.enabled,s.dependency_auto_enabled=!1!==s.dependency_auto&&!1!==s.dependency_auto?.enabled,s.npm_install_flags=s.npm_install_flags||"",s.react_version=s.react_version||s.react?.version||18,function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features,i=n.css&&!1!==n.css.enabled;let s=[];i&&(s.push(["rollup-plugin-postcss","^4"]),s.push(["sass","^1.66"]),(n.css?.options?.plugins||[]).forEach((e=>{switch(e.name){case"postcss-import":s.push(["postcss-import","^15"]);break;case"postcss-url":s.push(["postcss-url","^10"]);break;case"postcss-preset-env":s.push(["postcss-preset-env","^9"]);break;case"autoprefixer":s.push(["autoprefixer","^10"]);break;case"cssnano":s.push(["cssnano","^6"])}})));oe({feature:{name:"css",packages:s},features:n,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features;if("bun"===n.runtime.type)return;const i={};!0===n.app?.enabled&&(i.targets=i.targets||[],i.targets.push({src:"./src/app/index.html",dest:n.app.dir}),Reflect.has(n.app,"copy")||Reflect.has(n,"copy")||(n.copy=!0)),oe({feature:{name:"copy",packages:[["rollup-plugin-copy","^3"],["chokidar","^3"]],options:i},features:n,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"wasm",packages:[["@rollup/plugin-wasm","^6"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"terser",packages:[["@rollup/plugin-terser","^0.4"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e,n=t.doc.features;"bun"!==n.runtime.type&&oe({feature:{name:"json",packages:[["@rollup/plugin-json","^6"]]},features:n,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"string",packages:[["rollup-plugin-string","^3"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"image",packages:[["@rollup/plugin-image","^3"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"analyzer",packages:[["rollup-plugin-analyzer","^3"]],options:{summaryOnly:!0,limit:12},explicit:!0},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"visualizer",packages:[["rollup-plugin-visualizer","^5"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"polyfill",packages:[["rollup-plugin-node-polyfills","^0.2"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"nunjucks",packages:[["@fnet/rollup-plugin-nunjucks","0.1.8"]]},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"workbox",packages:[["rollup-plugin-workbox","^8"]],options:{generate:{swDest:"dist/app/esm/sw.js",globDirectory:"dist/app/esm",globPatterns:["**/*.{html,js,css,png,jpg}"],skipWaiting:!0,clientsClaim:!0}},explicit:!0},features:t.doc.features,packageDevDependencies:o})}(e),function(e){const{atom:t,packageDevDependencies:o}=e;oe({feature:{name:"gzip",packages:[["rollup-plugin-gzip","^4"]],explicit:!0},features:t.doc.features,packageDevDependencies:o})}(e)}async function se({projectDir:e,name:t,setProgress:o,count:n=1}){let s;const r=P(["npm-pick-versions",t,n]),a=i.join(e,".cache"),c=i.join(a,r+".json");return l.existsSync(c)?(o&&o(`Picking npm version of ${t} from cache ...`),s=JSON.parse(l.readFileSync(c,"utf8"))):(o&&o(`Picking npm version of ${t} ...`),s=await $({name:t,count:n}),l.mkdirSync(a,{recursive:!0}),l.writeFileSync(c,JSON.stringify(s),"utf8")),s}var re=async e=>{const{atom:t,packageDependencies:o,context:n,deploymentProjectTarget:i,setProgress:s,deploymentProject:r,yamlTarget:a}=e;if(!0!==i.enabled)return;const c=i.type;try{if("lib"===c)await(await import("./index.DG8TqL-1.js")).default({...e});else if("red"===c)await(await import("./index.CmMM-Ek9.js")).default({...e});else if("npm"===c)await(await import("./index.C0YpfQ5j.js")).default({...e});else if("gcs"===c)await(await import("./index.Bft2w7m3.js")).default({...e});else if("gitlab"===c)await(await import("./index.DI3yyTtl.js")).default({...e});else if("fnet-package"===c)await(await import("./index.D3p7pncT.js")).default({...e});else if("fnet-form"===c)await(await import("./index.Q-CYRcna.js")).default({...e});else if("fnet-node"===c)await(await import("./index.C2S9JYhS.js")).default({...e});else if("fnet-flow"===c)await(await import("./index.BuYxdKtK.js")).default({...e});else if("nextjs"===c)await(await import("./index.CDct_kkF.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("webos"===c)await(await import("./index.CMC8mlye.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("electron"===c)await(await import("./index.xd8c7XMr.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("docker"===c)await(await import("./index.D2N9YZmA.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("ios"===c)await(await import("./index.B5XE4ChJ.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("macos"===c)await(await import("./index.W6RYgypK.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else if("rust"===c)await(await import("./index.CzAV0S36.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0;else{if("pypi"!==c)return void console.warn(`No deployer found for type: ${c}`);await(await import("./index.C7saWH6d.js")).default({atom:t,target:i,onProgress:s,projectDir:n.projectDir,dependencies:o,context:n,yamlTarget:a}),r.isDirty=!0}}catch(e){throw console.error(`Error during deployment for type "${c}":`,e),e}},ae={name:"ATOM",uri:"http://atom.org/bpmn",prefix:"atom",types:[{name:"AtomExtension",extends:["bpmn:BaseElement"],properties:[{name:"atom",type:"atom:Atom",isMany:!1}]},{name:"Atom",properties:[{name:"type",type:"String",isAttr:!0}]}]};function ce(e,t){return e.filter(((e,o,n)=>n.map((e=>e[t])).indexOf(e[t])===o))}function le(e){const{nodes:t,nodeIndex:o,root:n}=e,i=e.targetNodes||n.childs;i.forEach((t=>{const o="workflow"===t.type||"subworkflow"===t.type,n=!o&&t.childs.filter((e=>!e.virtual)).length>0;if(n&&(t.bpmn.type="bpmn:SubProcess"),o||n){const o=t.childs.filter((e=>!0!==e.module))[0];t.childs.filter((e=>!0===e.module)).forEach((o=>{const n=pe({...e,parent:t,bpmnType:"bpmn:IntermediateCatchEvent",type:"inter",definitions:[{type:"bpmn:SignalEventDefinition"}]});n.bpmn.edges=[{from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const n=t.childs.find((e=>"try"===e.name&&"tryexcept"===t.type)),s=t.childs.filter((e=>"except"===e.name&&"tryexcept"===t.type));n&&s.length&&s.forEach((o=>{const i=pe({location:t.childs.indexOf(o),...e,parent:t,bpmnType:"bpmn:BoundaryEvent",type:"boundary",attrs:{attachedToRef:n},definitions:[{type:"bpmn:ErrorEventDefinition"}]});i.bpmn.edges=[{from:i.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}));const r=t.childs.find((e=>"raise"===e.type));if(r){const o=pe({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:"ERROR",definitions:[{type:"bpmn:ErrorEventDefinition"}]});r.bpmn.edges=[{from:r.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"}]}if(o)if(t.bpmn.starts.length>1){const o=pe({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"}),n=pe({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch"});o.bpmn.edges=[{from:o.indexKey,to:n.indexKey,type:"bpmn:SequenceFlow"}],n.bpmn.edges=t.bpmn.starts.map((e=>({...e,from:n.indexKey})));const i=n.bpmn.edges.find((e=>!0===e.next));if(i){const o=pe({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:i.to});i.to=o.indexKey}}else{const n=pe({...e,parent:t,bpmnType:"bpmn:StartEvent",type:"start"});n.bpmn.edges.push({from:n.indexKey,to:o.indexKey,type:"bpmn:SequenceFlow"})}t.childs.filter((e=>!0!==e.virtual&&e.bpmn.outside.length&&"bpmn:EndEvent"!==e.bpmn.type)).forEach((o=>{o.bpmn.outside.forEach((n=>{const s=i.indexOf(t),r=pe({...e,parent:t,bpmnType:"bpmn:EndEvent",type:"end",name:n.to,location:s+1});o.bpmn.edges.push({from:o.indexKey,to:r.indexKey,type:"bpmn:SequenceFlow"})}))}));t.childs.filter((e=>!0!==e.virtual&&e.bpmn.edges.length>1)).forEach((o=>{const n=i.indexOf(o),s=pe({...e,parent:t,bpmnType:"bpmn:ExclusiveGateway",type:"switch",location:n+1});s.bpmn.edges=o.bpmn.edges.map((e=>({...e,from:s.indexKey}))),o.bpmn.edges=[{from:o.indexKey,to:s.indexKey,type:"bpmn:SequenceFlow"}],o.bpmn.outside=[]}))}le({...e,targetNodes:t.childs})}))}function pe(e){const{parent:t,nodes:o,nodeIndex:n,bpmnType:i,type:s,name:r,outside:a,location:c,definitions:l,attrs:p}=e,d=t.childs.filter((e=>e.type===`v${s}`)).length,f={indexKey:`${t.indexKey}/_${s}${d}`,pathKey:`${t.pathKey}._${s}${d}`,type:`v${s}`,name:r,bpmn:{edges:[],outside:[],type:i,width:36,height:36,fill:"#c8e6c9",stroke:"#205022",definitions:l,attrs:p},virtual:!0,childs:[]};return t.childs.splice(c||0,0,f),o.push(f),n[f.indexKey]=f,f}function de(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a,nodes:c}=e;!function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,nodes:a}=e,c=o.get("flowElements");o.$nodes=o.$nodes||[],t.childs.forEach((e=>{const t=i.create(e.bpmn.type,{id:`node.${e.pathKey}`,name:e.definition?.title||e.name});if(s[t.id]=t,t.$isNode=!0,t.$node=e,e.$flow=t,o.$nodes.push(t),c.push(t),e.bpmn.attrs){Object.keys(e.bpmn.attrs).forEach((o=>{"attachedToRef"===o&&t.set(o,e.bpmn.attrs[o].$flow)}))}if(e.bpmn.definitions){const o=e.bpmn.definitions.map((e=>{const t=i.create(e.type);return Object.keys(e.attrs||{}).forEach((o=>{t.set(o,e.attrs[o])})),t}));t.eventDefinitions=o}}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=o.get("flowElements");o.$edges=o.$edges||[],t.childs.forEach((e=>{e.bpmn.edges.forEach((t=>{const n=e,c=r[t.to],l=`edge.${n.pathKey}_${c.pathKey}`;if(s[l])return;const p=s[`node.${n.pathKey}`],d=s[`node.${c.pathKey}`],f=i.create(t.type,{id:l,sourceRef:p,targetRef:d});s[f.id]=f,f.$is_edge=!0,p.get("outgoing").push(f),d.get("incoming").push(f),o.$edges.push({from:p,to:d,flow:f}),a.push(f)}))}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r}=e,a=120,c=80,l=160,p=160,d=new O.graphlib.Graph;d.setDefaultEdgeLabel((()=>({}))),d.setGraph({rankdir:"TB",nodesep:a,ranksep:c,xranker:"longest-path"}),o.$nodes.forEach((e=>{d.setNode(e.id,{width:e.$node?.bpmn.width||a,height:e.$node?.bpmn.height||c,label:e.id})})),o.$edges.forEach((e=>{d.setEdge(e.from.id,e.to.id)})),O.layout(d),o.$nodes.forEach((e=>{const t=d.node(e.id);let o=t.width,s=t.height;const r=i.create("bpmndi:BPMNShape",{id:`shape.${e.id}`,bpmnElement:e,bounds:i.create("dc:Bounds",{x:l+t.x-t.width/2,y:p+t.y-t.height/2,width:o,height:s}),label:i.create("bpmndi:BPMNLabel")});e.$node.bpmn.fill&&r.set("bioc:fill",e.$node.bpmn.fill),e.$node.bpmn.stroke&&r.set("bioc:stroke",e.$node.bpmn.stroke);n.get("planeElement").push(r)})),o.$edges.forEach((e=>{const t=d.edge(e.from.id,e.to.id),o=i.create("bpmndi:BPMNEdge",{id:`edge.${e.from.id}_${e.to.id}`,bpmnElement:e.flow,label:i.create("bpmndi:BPMNLabel")});t.points.forEach((e=>{const t=i.create("dc:Point",{x:l+e.x,y:p+e.y});o.get("waypoint").push(t)}));n.get("planeElement").push(o)}))}(e),function(e){const{targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:n,moddle:i,elementIndex:s,nodeIndex:r,diagrams:a}=e,c=t.childs.filter((e=>"bpmn:SubProcess"===e.bpmn.type));c.forEach((t=>{const o=s[`node.${t.pathKey}`],n=i.create("bpmndi:BPMNDiagram",{id:`diagram_${t.pathKey}`});s[n.id]=n,a.push(n);const r=i.create("bpmndi:BPMNPlane",{id:`plane_${t.pathKey}`});s[r.id]=r,n.plane=r,r.bpmnElement=o,de({...e,targetNode:t,targetFlowElementsContainer:o,targetPlaneElement:r})}))}(e)}async function fe(e){const t=e.root,o=t.context.index,n=Object.keys(o).map((e=>o[e]));!function(e){const{nodes:t}=e;t.forEach((e=>{const t=[],o=[],n=i=>{i.context.next&&(t.push({from:i,to:i.context.next,type:"bpmn:SequenceFlow"}),i===e&&o.push({to:i.context.next,type:"bpmn:SequenceFlow",next:!0})),i.childs.forEach((t=>{i===e&&"switch"===e.type&&o.push({to:t,type:"bpmn:SequenceFlow"}),n(t)}))};n(e);const i=t.filter((t=>t.to.parent.indexKey===e.parent.indexKey)).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),s=t.filter((t=>t.to.parent.indexKey!==e.parent.indexKey&&!t.to.indexKey.startsWith(e.indexKey+"/"))).map((t=>({...t,from:e.indexKey,to:t.to.indexKey}))),r=o.map((e=>({...e,to:e.to.indexKey})));e.bpmn=e.bpmn||{},e.bpmn.edges=ce(i,"to"),e.bpmn.outside=ce(s,"to"),e.bpmn.starts=ce(r,"to"),e.bpmn.type=function(e){return"call"===e.type?"bpmn:ServiceTask":"form"===e.type?"bpmn:UserTask":"return"===e.type?"bpmn:EndEvent":"bpmn:Task"}(e),e.bpmn.width=120,e.bpmn.height=80,"return"===e.type&&(e.bpmn.width=36,e.bpmn.height=36)}))}({nodes:n}),le({nodes:n,nodeIndex:o,root:t});const i=new I({atom:ae}),s={},r=i.create("bpmn:Definitions",{id:"definitions_0"});s[r.id]=r;for await(const e of t.childs){const t=r.get("rootElements"),a=r.get("diagrams"),c=i.create("bpmn:Process",{id:`process_${e.pathKey}`,name:e.name,documentation:[i.create("bpmn:Documentation",{text:`Workflow - ${e.name}`})]});s[c.id]=c,c.isExecutable=!0,t.push(c);const l=i.create("bpmndi:BPMNDiagram",{id:`diagram_${e.pathKey}`});s[l.id]=l,a.push(l);const p=i.create("bpmndi:BPMNPlane",{id:`plane_${e.pathKey}`});s[p.id]=p,l.plane=p,p.bpmnElement=c;de({targetNode:e,targetFlowElementsContainer:c,targetPlaneElement:p,moddle:i,elementIndex:s,nodeIndex:o,nodes:n,diagrams:a})}return{diagramXML:(await i.toXML(r,{format:!0})).xml}}async function me(e={}){return await fe(w(e))}async function ue({node:e,initNode:t,extra:o=!0}){if(Reflect.has(e.definition,"modules")&&!Array.isArray(e.definition.modules)){const t=e.definition.modules;e.definition.modules=[],Object.keys(t).forEach((o=>{const n={...t[o]};"boolean"==typeof n.export?n.export=!0===n.export&&o:"string"==typeof n.export?n.export=n.export:delete n.export,e.definition.modules.push({[o]:n})}))}if(o){const t=[],o=await R({data:e.definition,callback:(e,o,n)=>{const i=A({expression:e});if("m"===i?.processor){const e=n.slice(0,-1);e.push(i.statement);const s=e.join("_");return t.push({[s]:o}),[i.statement,`m::${s}`]}return[e,o]}});t.length>0&&(e.definition=o,e.definition.modules=e.definition.modules||[],e.definition.modules=e.definition.modules.concat(t))}e.hasModules=e.definition.modules?.length>0;for(let o=0;o<e.definition.modules?.length;o++){const n=e.definition.modules[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],module:!0,blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}}async function ye({node:e,transformExpression:t}){const o=e.context.transform;if(Reflect.has(o,"export")&&(o.export=await t(o.export)),Reflect.has(o,"return")&&(e.hasReturn=!0,o.return=await t(o.return)),Reflect.has(o,"output")&&(o.output=await t(o.output)),Reflect.has(o,"assign"))for(let e=0;e<o.assign?.length;e++){let n=o.assign[e],i=Object.keys(n)[0],s=n[i],r={key:await t(i),value:await t(s)};o.assign[e]=r}}async function he({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform;for(const t of e.childs)t.context.transform=t.context.transform||w(t.definition),t.definition.hasOwnProperty("condition")&&(t.context.transform.condition=await n(t.definition.condition));await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var ge={hits:async function({node:e}){return!!e.definition.hasOwnProperty("switch")},init:async function({node:e,initNode:t}){e.type="switch";const o=e.definition.switch||[];if(!o.every((e=>e.hasOwnProperty("condition")||e.hasOwnProperty("default"))))throw new Error("Switch must have condition or default");if(0===o.filter((e=>e.hasOwnProperty("condition"))).length)throw new Error("Switch must have at least one condition");const n=o.filter((e=>e.hasOwnProperty("default")));if(n.length>1)throw new Error("Switch must have only one default");if(1===n.length&&!o[o.length-1].hasOwnProperty("default"))throw new Error("Switch default must be the last child");e.hasDefaultCondition=1===n.length,await ue({node:e,initNode:t,extra:!1}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0;for(let o=0;o<e.definition.switch.length;o++){let n=e.definition.switch[o],i=`${o}`;n.hasOwnProperty("default")&&(i="default",n=n.default);const s={name:n.condition||i,childs:[],parent:e,definition:n,index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=he},resolve:he};var we={hits:async function({node:e}){return 1===Object.keys(e.definition).map((e=>A({expression:e}))).filter((e=>"if"===e?.processor)).length||!(!e.definition.if||"object"!=typeof e.definition.if)},init:async function(e){const{node:t}=e,o=Object.keys(t.definition).map((e=>A({expression:e}))),n=[],i=o.find((e=>"if"===e?.processor));if(i){const e=t.definition[i.expression];n.push({name:`${t.name}_if`,definition:e,processor:i}),delete t.definition[i.expression]}else if(t.definition.if){const{condition:e,...o}=t.definition.if;n.push({name:`${t.name}_if`,definition:o,processor:{expression:`if::${e}`,statement:e}}),delete t.definition.if}const s=o.filter((e=>"elseif"===e?.processor));let r=0;for(const e of s){const o=t.definition[e.expression];n.push({name:`${t.name}_elseif_${r++}`,definition:o,processor:e}),delete t.definition[e.expression]}if(t.definition.elseif){const{condition:e,...o}=t.definition.elseif;n.push({name:`${t.name}_elseif_${r++}`,definition:o,processor:{expression:`elseif::${e}`,statement:e}}),delete t.definition.elseif}t.definition.switch=[];for(const e of n)t.definition.switch.push({condition:e.processor.statement,...e.definition});if(t.definition?.else){const e=t.definition.else;t.definition.switch.push({default:e}),delete t.definition.else}await ge.init(e)}};async function be({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){if(e.context.transform=e.context.transform||w(e.definition),e.context.transform,e.context.try=e.childs.find((e=>"try"===e.name)),e.context.except=e.childs.find((e=>"except"===e.name)),e.context.except){const t=e.context.except;t.context.transform=t.context.transform||w(t.definition),t.context.transform.hasOwnProperty("as")||(t.context.transform.as="error")}await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var xe={hits:async function({node:e}){return e.definition.hasOwnProperty("try")&&e.definition.hasOwnProperty("except")},init:async function({node:e,initNode:t}){if(e.type="tryexcept",await ue({node:e,initNode:t,extra:!1}),e.blockAutoJumpToParent=!1,e.blockAutoJumpToSibling=!0,e.definition.try){const o="try",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}if(e.definition.except){const o="except",n={name:o,childs:[],parent:e,definition:e.definition[o],index:e.childs.length,context:{}};e.childs.push(n),await t({node:n})}e.resolve=be},resolve:be};async function ve({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform,await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var je={hits:async function({node:e}){return e.definition.hasOwnProperty("assign")},init:async function({node:e,initNode:t}){e.type="assign",await ue({node:e,initNode:t}),e.resolve=ve},resolve:ve};async function ke({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);e.context.transform.for.in=await n(e.definition.for.in),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var De={hits:async function({node:e}){return e.definition.hasOwnProperty("for")},init:async function({node:e,initNode:t}){if(e.type="for",await ue({node:e,initNode:t,extra:!1}),e.blockAutoJumpToParent=!0,e.blockAutoJumpToSibling=!1,!e.definition.for.hasOwnProperty("steps")){const{value:t,in:o,...n}=e.definition.for,i={};void 0!==t&&(i.value=t),void 0!==o&&(i.in=o),e.definition.for=i,e.definition.for.steps=[{[`${e.name}_step`]:n}]}Array.isArray(e.definition.for.steps)||(e.definition.for.steps=[{[`${e.name}_step`]:e.definition.for.steps}]);for(let o=0;o<e.definition.for.steps.length;o++){const n=e.definition.for.steps[o],i=Object.keys(n)[0],s={name:i,childs:[],parent:e,definition:n[i],index:e.childs.length,context:{}};e.childs.push(s),await t({node:s})}e.resolve=ke},resolve:ke};var _e={hits:async function({node:e}){return!1},init:async function({node:e,initNode:t}){},resolve:async function({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){}};async function Se({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;n.raise=await o(n.raise),await t({node:e})}var Ee={hits:async function({node:e}){return e.definition.hasOwnProperty("raise")},init:async function({node:e,initNode:t}){e.type="raise",e.resolve=Se},resolve:Se};async function $e({node:e,resolveTypeCommon:t,transformExpression:o}){e.context.transform=e.context.transform||w(e.definition);const n=e.context.transform;e.hasReturn=!0,n.return=await o(n.return),await t({node:e})}var Pe={hits:async function({node:e}){return e.definition.hasOwnProperty("return")},init:async function({node:e,initNode:t}){e.type="return",e.resolve=$e},resolve:$e};async function Ne({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;let s=i.from||i.import||i.call;if("function"===e.target?.atom?.doc?.type)Reflect.has(i,"from")?(s=i.from,i.from=await n(e.target.atom.name)):Reflect.has(i,"import")?(s=i.import,i.import=await n(e.target.atom.name)):Reflect.has(i,"call")&&(i.call=await n(e.target.atom.name),s=i.call);else if((Reflect.has(i,"from")||Reflect.has(i,"import"))&&i.call.startsWith("use:e::")){const e=i.call.substring(7);i.libExp=await n(`e::LIBRARY.${e}`)}if(i.args&&(i.args=await n(i.args)),i.new&&(i.new=await n(i.new)),i.context&&(i.context=await n(i.context)),i.result){"string"==typeof i.result&&(i.result=[{[i.result]:"e::result"}]);for(let e=0;e<i.result?.length;e++){let t=i.result[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.result[e]=r}}const r=e.workflow.parent;e.context.lib=r.context.libs.find((e=>e.name===s)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Te={hits:async function({node:e}){return e.definition.hasOwnProperty("call")},init:async function({node:e,initNode:t}){e.type="call",await ue({node:e,initNode:t}),e.resolve=Ne},resolve:Ne};async function Ce({node:e,transformExpression:t}){e.context.next=e.childs[0],e.context.transform=e.context.transform||w(e.definition),await ye({node:e,transformExpression:t})}var Fe={hits:async function({node:e}){return e.definition.hasOwnProperty("steps")},init:async function({node:e,initNode:t}){e.type||(e.type="steps");const o=e.definition.steps||[];for await(const n of o){const o=Object.keys(n)[0],i={name:o,childs:[],parent:e,definition:n[o],index:e.childs.length,context:{}};e.childs.push(i),await t({node:i})}e.resolve=Ce},resolve:Ce};async function Ie({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.props&&(i.props=await n(i.props));const s=e.workflow.parent;e.context.lib=s.context.libs.find((e=>e.name===i.form)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Oe={hits:async function({node:e}){return e.definition.hasOwnProperty("form")},init:async function({node:e,initNode:t}){e.type="form",await ue({node:e,initNode:t}),e.resolve=Ie},resolve:Ie};async function Ae({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){e.context.transform=e.context.transform||w(e.definition),await t({node:e}),o({node:e})}var Be={hits:async function({node:e}){return e.definition.hasOwnProperty("signal")},init:async function({node:e,initNode:t}){e.type="signal",e.resolve=Ae},resolve:Ae};async function Re({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n,transformValue:i}){e.context.transform=e.context.transform||w(e.definition),await t({node:e}),o({node:e})}var Ke={hits:async function({node:e}){return e.definition.hasOwnProperty("wait")},init:async function({node:e,initNode:t}){e.type="wait",e.resolve=Re},resolve:Re};async function Me({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;i.next=await n(i.next),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var Le={hits:async function({node:e}){return e.definition.hasOwnProperty("next")},init:async function({node:e,initNode:t}){e.type="next",e.resolve=Me},resolve:Me};async function Je({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),e.context.transform,await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var We={hits:async function({node:e}){return e.definition.hasOwnProperty("modules")},init:async function({node:e,initNode:t}){e.type="modules",await ue({node:e,initNode:t}),e.resolve=Je},resolve:Je};function ze({node:e}){const t=e.definition;if(!e.hasReturn)if("end"===t.next);else if("stop"===t.next);else if("none"===t.next);else if(t.next){let o=e.parent;for(;o.parent;){const n=o.childs.find((e=>e.name===t.next));if(n){e.context.next=n;break}o=o.parent}}else{if(!0===e.module)return;let t=e.parent,o=e.index+1;for(;t.parent&&(!t.blockAutoJumpToParent||!t.blockAutoJumpToSibling);)if(Reflect.has(t,"blockAutoJumpToParent")||Reflect.has(t,"blockAutoJumpToSibling")){if(t.blockAutoJumpToParent){const n=t.childs.find((e=>e.index===o));n&&(e.context.next=n);break}t.blockAutoJumpToParent||(o=t.index+1,t=t.parent)}else{const n=t.childs.find((e=>e.index===o));if(n){e.context.next=n;break}o=t.index+1,t=t.parent}}}class Ge{#e;#t;#o;#n;constructor({key:e,npm:t,master:o,extras:n}){this.#e=e,this.#t=t,this.#o=o,this.#n=n}hits({node:e}){return e.definition.hasOwnProperty(this.#e)}async init(e){const{node:t}=e,o=this.#e,n=t.definition,i=typeof n[o];if(n.call=`npm:${this.#t}`,n.args="object"!==i?{...n.args,[`${this.#o}`]:n[o]}:n[o],delete n[o],this.#n)for(const e in this.#n)n[e]=this.#n[e];console.log(`[npm-block] ${this.#e} --\x3e ${this.#t}`),await Te.init(e)}}function Ue(e){return new Ge(e)}async function Ve({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition);const i=e.context.transform;let s=i.from||i.import;if("function"===e.target?.atom?.doc?.type&&(Reflect.has(i,"from")?(s=i.from,i.from=await n(e.target.atom.name)):Reflect.has(i,"import")&&(s=i.import,i.import=await n(e.target.atom.name))),i.args&&(i.args=await n(i.args)),i.new&&(i.new=await n(i.new)),i.result){"string"==typeof i.result&&(i.result=[{[i.result]:"e::result"}]);for(let e=0;e<i.result?.length;e++){let t=i.result[e],o=Object.keys(t)[0],s=t[o],r={key:await n(o),value:await n(s)};i.result[e]=r}}const r=e.workflow.parent;e.context.lib=r.context.libs.find((e=>e.name===s)),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var qe={hits:async function({node:e}){return e.definition.hasOwnProperty("new")},init:async function({node:e,initNode:t}){e.type="new",await ue({node:e,initNode:t}),e.resolve=Ve},resolve:Ve};async function Xe({node:e,resolveTypeCommon:t,resolveNextBlock:o,transformExpression:n}){e.context.transform=e.context.transform||w(e.definition),await ye({node:e,transformExpression:n}),await t({node:e}),o({node:e})}var He={hits:async function({node:e}){return e.definition.hasOwnProperty("output")},init:async function({node:e,initNode:t}){e.type="output",await ue({node:e,initNode:t}),e.resolve=Xe},resolve:Xe};class Ye{#i;#s;#r;#a;#c;#l;#p;#d;#f;#m;#u;#y;#h;#g;#w;#b;#x;#v;#j;#k;#D;#_=[];constructor(e){this.#i=new te,this.#s=e,this.#l=[],this.#p=[],this.#d={},this._expire_ttl=3600,this._expire_ttl_short=300,this.#_.push(Ue({key:"config",npm:"@fnet/config",master:"name"})),this.#_.push(Ue({key:"yaml",npm:"@fnet/yaml",master:"file"})),this.#_.push(Ue({key:"prompt",npm:"@fnet/prompt",master:"message"})),this.#_.push(Ue({key:"html-link",npm:"@flownet/lib-load-browser-link-url",master:"src"})),this.#_.push(Ue({key:"html-script",npm:"@flownet/lib-load-browser-script-url",master:"src"})),this.#_.push(Ue({key:"http-server",npm:"@fnet/node-express",master:"server_port"})),this.#_.push(Ue({key:"shell",npm:"@fnet/shell-flow",master:"commands"})),this.#_.push(Ue({key:"list-files",npm:"@fnet/list-files",master:"pattern"})),this.#_.push(Ue({key:"up-list-files",npm:"@fnet/up-list-files",master:"pattern"})),this.#_.push(Ue({key:"auto-conda-env",npm:"@fnet/auto-conda-env",master:"envDir"})),this.#_.push(Ue({key:"ollama-chat",npm:"@fnet/ollama-chat",master:"model"})),this.#_.push(Ue({key:"ai",npm:"@fnet/ai",master:"prompt",extras:{subtype:"flow"}})),this.#_.push(Ue({key:"invoke",npm:"@fnet/invoke",master:"method",extras:{}})),this.#_.push(Ue({key:"fetch",npm:"@fnet/fetch",master:"url",extras:{}})),this.#_.push(Ue({key:"filemap",npm:"@fnet/filemap",master:"target",extras:{}})),this.#k={packageDependencies:this.#l,packageDevDependencies:this.#p,setProgress:this.setProgress.bind(this),context:this.#s,Atom:D,registerToPackageManager:this.registerToPackageManager.bind(this)},this.#D={initNode:this.initNode.bind(this),cloneDeep:w,resolveTypeCommon:this.resolveTypeCommon.bind(this),resolveNextBlock:ze,transformExpression:this.transformExpression.bind(this),transformValue:this.transformValue.bind(this)}}async _cache_set(e,t,o){this._redis_client&&await this._redis_client.SETEX(e,o||this._expire_ttl,JSON.stringify(t)).catch(console.error)}async init(){this._redis_client=await async function(){if(!await v({host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}))return;const e=x.createClient({socket:{host:process.env.REDIS_HOST,port:process.env.REDIS_PORT}});return await e.connect(),e}(),this.#u=this.#s.buildId||j(),this.#k.buildId=this.#u,this.#w=this.#s.mode,this.#b=["all","deploy","build","file"].includes(this.#w),this.#x=["all","deploy","build"].includes(this.#w),this.#v=["all","deploy"].includes(this.#w),this.#j=["all","deploy","build","file","bpmn"].includes(this.#w),this.#h=this.#s.protocol,this.#y="BUILD:"+this.#u,this.#g=(await d({optional:!0,name:"atom",dir:this.#s.projectDir,tags:this.#s.tags}))?.data;try{await this.setProgress({message:"Initialization started."});const e=this.#k.context.project;await this.initAuth(),await this.initWorkflow(),this.transformWorkflow({workflow:this.#a});const t=await this.initNodeTree({workflow:this.#a});await this.initNodeTreeIndex({root:t}),await this.initNodeCalls({root:t}),await this.initNodeCallLibs({root:t}),await this.initNodeForms({root:t}),await this.initNodeFormLibs({root:t}),await this.initEntryFiles({root:t,features:this.#r.doc.features}),await this.initFeaturesFromNodes({childs:t.childs,features:this.#r.doc.features}),await ie(this.#k),"bun"===e.runtime.type?await async function({atom:e,packageDependencies:t,packageDevDependencies:o,setProgress:n}){n("Initializing dependencies for Bun");const i=e.doc.dependencies||[];if(i.filter((e=>!e.dev)).forEach((e=>t.push(e))),i.filter((e=>e.dev)).forEach((e=>o.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let o="^18.2";n("Fetching React versions"),o=`^${(await E({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:o}),t.push({package:"react-dom",version:o}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),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&&o.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"})}(this.#k):await async function({atom:e,packageDependencies:t,packageDevDependencies:o,setProgress:n}){n("Initializing dependencies");const i=e.doc.dependencies||[];if(i.filter((e=>!e.dev)).forEach((e=>t.push(e))),i.filter((e=>e.dev)).forEach((e=>o.push(e))),"workflow"===e.type&&(t.push({package:"get-value",version:"^3"}),t.push({package:"set-value",version:"^4"})),e.doc.features.form_enabled&&e.doc.features.dependency_auto_enabled){let o="^18.2";n("Fetching React versions"),o=`^${(await E({name:"react",groupBy:{major:!0}})).find((t=>t[0]===e.doc.features.react_version.toString()))[0]}`,t.push({package:"react",version:o}),t.push({package:"react-dom",version:o}),"workflow"===e.type&&(t.push({package:"@fnet/react-app",version:"^0.1"}),t.push({package:"@fnet/react-app-state",version:"^0.1"}))}e.doc.features.preact_enabled&&t.push({package:"preact",version:"^10"}),!0===e.doc.features.cli.enabled&&(t.push({package:"@fnet/args",version:"^0.1"}),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&&o.push({package:"@flownet/lib-render-templates-dir",version:"0.1.19"}),o.push({package:"@babel/core",version:"^7"}),o.push({package:"@rollup/plugin-commonjs",version:"^28"}),o.push({package:"@rollup/plugin-node-resolve",version:"^16"}),o.push({package:"@rollup/plugin-replace",version:"^6"}),o.push({package:"rollup",version:"^4"}),e.doc.features.dts_enabled&&o.push({package:"rollup-plugin-dts",version:"^6"}),o.push({package:"rollup-plugin-peer-deps-external",version:"^2"}),o.push({package:"@rollup/plugin-alias",version:"^5"}),o.push({package:"fs-extra",version:"^11"}),e.doc.features.babel_enabled&&(o.push({package:"@rollup/plugin-babel",version:"^6"}),o.push({package:"@babel/preset-env",version:"^7"}),o.push({package:"@babel/preset-react",version:"^7"}),e.doc.features.babel?.options?.plugins?.forEach((e=>{switch(e[0]){case"@babel/plugin-proposal-decorators":o.push({package:"@babel/plugin-proposal-decorators",version:"^7"});break;case"@babel/plugin-proposal-class-properties":o.push({package:"@babel/plugin-proposal-class-properties",version:"^7"});break;case"@babel/plugin-proposal-private-methods":o.push({package:"@babel/plugin-proposal-private-methods",version:"^7"});break;case"@babel/plugin-proposal-private-property-in-object":o.push({package:"@babel/plugin-proposal-private-property-in-object",version:"^7"});break;case"@babel/plugin-proposal-optional-chaining":o.push({package:"@babel/plugin-proposal-optional-chaining",version:"^7"})}}))),o.push({package:"@fnet/rollup-plugin-delete",version:"0.1.10"}),e.doc.features.browsersync_enabled&&o.push({package:"@fnet/rollup-plugin-browsersync",version:"0.1.11"})}(this.#k),await this.initAtomLibsAndDeps({libs:t.context.libs,packageDependencies:this.#l}),await this.resolveNodeTree({root:t}),this.#m=t}catch(e){throw await this._cache_set(this.#y,{status:"FAILED",message:e?.message||e}),e}}async initAuth(){this.#s.id&&(this.#f=await this.#i.init({config:this.#g}),this.#k.atomAccessToken=this.#f)}async initWorkflow(){const e=this.#s.id;this.#r=this.#s.project?.workflowAtom||await D.get({id:e}),this.#a="string"==typeof this.#r.doc.content?(await y({content:this.#r.doc.content,tags:this.#s.tags})).parsed:this.#r.doc.content;let t=this.#r.doc.bundleName;t=t||(this.#r.doc.name||"").toUpperCase().replace(/[^A-Z0-9]/g,"_"),this.#r.doc.bundleName=t,this.#r.type=this.#r.type||"workflow",this.#k.atom=this.#r,this.#r.doc.features=this.#r.doc.features||{}}#S(e){console.log("filePath",e),l.statSync(e).isDirectory()?(l.readdirSync(e).forEach((t=>{const o=i.join(e,t);this.#S(o)})),l.rmSync(e)):l.unlinkSync(e)}#E(e,t){const o=l.existsSync(e),n=o&&l.statSync(e);o&&n.isDirectory()?(l.mkdirSync(t,{recursive:!0}),l.readdirSync(e).forEach((o=>{this.#E(i.join(e,o),i.join(t,o))}))):l.copyFileSync(e,t)}async initWorkflowDir(){this.setProgress({message:"Initializing library directory."});const e=this.#s.projectDir,t=this.#s.coreDir;this.setProgress({message:"Cleaning project directory."});const o=B({dir:e,ignore:[".cache","node_modules",".conda",".bin"],absolute:!0});for(const e of o)l.rmSync(e,{recursive:!0,force:!0});this.setProgress({message:"Creating project directory."}),l.existsSync(e)||l.mkdirSync(e,{recursive:!0});const n=i.join(e,"src");l.existsSync(n)||l.mkdirSync(n,{recursive:!0});const s=i.join(n,"core");this.#E(t,s);const r=i.join(n,"default","blocks");l.existsSync(r)||l.mkdirSync(r,{recursive:!0})}async initNunjucks(){this.setProgress({message:"Initializing nunjucks."});const e=this.#s.templateDir;this.#c=g.configure(e,{watch:!1,dev:!0}),this.#k.njEnv=this.#c}transformWorkflow({workflow:e}){for(const t of Object.values(e))t.steps=t.steps||[],t.steps=t.steps.filter((e=>Object.keys(e).length>0)),t.steps=t.steps.map((e=>this.transformStep({step:e})))}transformStep({step:e}){if(Array.isArray(e))throw new Error("Step must be an object.");const[t,o]=Object.entries(e)[0];if(o.hasOwnProperty("onerror")){const{onerror:n,...i}=o;e[t]={try:i,except:n}}if(e[t].hasOwnProperty("steps")){const o=e[t].steps;if(!Array.isArray(o))throw new Error("Steps must be an array.");e[t].steps=o.map((e=>this.transformStep({step:e})))}return e}async initNodeTree({workflow:e}){const t=Object.keys(e),o={definition:e,name:void 0,type:"root",parent:void 0,childs:[],blockAutoJumpToParent:!0,blockAutoJumpToSibling:!0,index:0,depth:0,context:{libs:[],atom:this.#r}};t.forEach((t=>{const n={name:t,type:"main"===t?"workflow":"subworkflow",childs:[],parent:o,definition:e[t],index:o.childs.length,depth:o.depth+1,context:{},blockAutoJumpToParent:!0,blockAutoJumpToSibling:!1};o.childs.push(n)}));for await(const e of o.childs)await this.initNode({node:e});return o}async initNode({node:e}){const t={...this.#D,node:e};if(e.workflow=e.parent.workflow||e,e.depth=e.parent.depth+1,await xe.hits(t))await xe.init(t);else if(await De.hits(t))await De.init(t);else if(await ge.hits(t))await ge.init(t);else if(await we.hits(t))await we.init(t);else if(await _e.hits(t))await _e.init(t);else if(await Te.hits(t))await Te.init(t);else if(await qe.hits(t))await qe.init(t);else if(await Ee.hits(t))await Ee.init(t);else if(await Oe.hits(t))await Oe.init(t);else if(await Be.hits(t))await Be.init(t);else if(await Ke.hits(t))await Ke.init(t);else if(await Fe.hits(t))await Fe.init(t);else if(await Le.hits(t))await Le.init(t);else if(await We.hits(t))await We.init(t);else if(await Pe.hits(t))await Pe.init(t);else if(this.#_.find((e=>e.hits(t))))await this.#_.find((e=>e.hits(t))).init(t);else if(await je.hits(t))await je.init(t);else{if(!await He.hits(t))throw new Error("Undefined step type.");await He.init(t)}}async initNodeTreeIndex({root:e}){const t={};e.indexKey="/";for await(const o of e.childs)await this.initNodeIndex({node:o,index:t});return e.context.index=t,t}async initNodeIndex({node:e,index:t}){const o=i.join(e.parent.indexKey,e.name);e.indexKey=o,t[o]=e;const n=[];let s=e;for(;s?.parent;)n.push(s.index),s=s.parent;n.reverse(),e.codeKey=`B_${n.join("_")}_${e.type}`,e.pathKey=`${n.join(".")}`,e.typeId=j();for await(const o of e.childs)await this.initNodeIndex({node:o,index:t})}async initNodeCalls({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"call"!==n.type&&"new"!==n.type||o.push(n)}return e.context.calls=o,o}async initNodeCallLibs({root:e}){const t=[],o=e.context.calls;for await(const e of o){const o=e.definition.from||e.definition.import||e.definition.call,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom",definition:e.definition},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.callLibs=t,e.context.libs=[...e.context.libs,...t],t}async findNodeCallTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.call,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeCallTarget({refNode:e,curNode:t.parent})}async initNodeForms({root:e}){const t=e.context.index,o=[];for await(const e of Object.keys(t)){const n=t[e];"form"===n.type&&o.push(n)}return e.context.forms=o,o}async initNodeFormLibs({root:e}){const t=[],o=e.context.forms;for await(const e of o){const o=e.definition.from||e.definition.import||e.definition.form,n=await this.findNodeCallTarget({refNode:e,curNode:e.parent})||{name:o,type:"atom"},i=t.find((e=>e.name===n.name&&e.type===n.type));i||t.push(n),e.target=i||n}return e.context.formLibs=t,e.context.libs=[...e.context.libs,...t],t}async initFeaturesFromNodes({childs:e,features:t}){for await(const o of e)"form"!==o.type||Reflect.has(t,"form")||(t.form=!0),await this.initFeaturesFromNodes({childs:o.childs,features:t})}async initEntryFiles({root:e,features:t}){for await(const o of e.childs){let e;if("main"===o.name)e="index.js";else if("cli"===o.name)e="cli.js";else if("app"===o.name)e="app.js";else{if("api"!==o.name)continue;e="api.js"}t[`${o.name}_default_entry_file`]=e,o.entryFile=e}}async findNodeFormTarget({refNode:e,curNode:t}){if(!t)return;const o=e.definition.form,n=t.childs.find((e=>e.name===o&&"subworkflow"===e.type));return n||await this.findNodeFormTarget({refNode:e,curNode:t.parent})}async initAtomLibsAndDeps({libs:e,packageDependencies:t}){const o=e.filter((e=>"atom"===e.type));for(let e=0;e<o.length;e++){const n=o[e],i=await this.findAtomLibrary({url:n.name,libRef:n});n.atom=i;const s=i.doc.dependencies?.filter((e=>void 0===e.repo||"npm"===e.repo));s?.forEach((e=>{const o=t.find((t=>t.package===e.package));o?"string"==typeof e.path?(o.path||[]).some((t=>t===e.path))||(o.path=o.path||[],o.path.push(e.path)):Array.isArray(e.path)&&e.path.forEach((e=>{(o.path||[]).some((t=>t===e))||(o.path=o.path||[],o.path.push(e))})):t.push(e)}))}t.sort(((e,t)=>e.package?.localeCompare(t.package)))}async findAtomLibrary({url:e,libRef:t}){const o=F({url:e});if(!o)throw new Error(`Invalid package name: ${e}`);if(o.protocol||(o.protocol=this.#h),"ac:"===o.protocol){const t=o.pathname.split("/");if(1===t.length)return await D.first({where:{name:e,parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"workflow.lib"}});if(2===t.length){const e=await D.first({where:{name:t[0],parent_id:this.#g.env.ATOM_LIBRARIES_ID,type:"folder"}});return await D.first({where:{name:t[1],parent_id:e.id,type:"workflow.lib"}})}}else{if("local:"===o.protocol){const e=i.resolve(this.#s.projectSrcDir,`${o.pathname}.js`),t=[],n=(await S({file:e,recursive:!0})).all;for await(const e of n){if("npm"!==e.type)continue;if(t.find((t=>t.package===e.package)))continue;const o=await se({name:e.package,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});t.push({package:e.package,subpath:e.subpath,version:o.minorRange,type:"npm"})}return{name:o.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:t},protocol:o.protocol}}if("npm:"===o.protocol){const e=K({path:o.pathname}),n=await se({name:e.package,subpath:e.subpath,projectDir:this.#s.projectDir,setProgress:this.#k.setProgress});return{name:o.pathname,doc:{type:"workflow.lib",subtype:"flow"===t?.definition?.subtype?"workflow":null,"content-type":"javascript",language:"js",dependencies:[{package:e.package,version:n.minorRange,type:"npm"}]},protocol:o.protocol}}if("node:"===o.protocol){return{name:o.pathname,doc:{type:"workflow.lib","content-type":"javascript",language:"js",dependencies:[]},protocol:o.protocol}}if("use:"===o.protocol){return{name:o.pathname,doc:{type:"function",dependencies:[]},protocol:o.protocol}}}}async resolveNodeTree({root:e}){for await(const t of e.childs)await this.resolveTypeWorkflow({node:t})}async resolveTypeWorkflow({node:e}){e.context.transform=e.context.transform||w(e.definition);const t=e.context.transform;for(let e=0;e<t.params?.length;e++){const o=t.params[e];if("string"==typeof o)t.params[e]={key:o,hasDefault:!1};else{const n=Object.keys(o)[0];t.params[e]={key:n,hasDefault:!0,default:o[n],type:typeof o[n]}}}e.context.next=e.childs[0];for await(const t of e.childs)await this.resolveType({node:t})}async resolveType({node:e}){const t={...this.#D,node:e};"function"==typeof e.resolve&&await e.resolve(t);for await(const t of e.childs)await this.resolveType({node:t})}async resolveTypeCommon({node:e}){const t=e.context.transform;t.hasOwnProperty("page")&&(t.page=await this.transformExpression(t.page)),t.hasOwnProperty("print")&&(t.print=await this.transformExpression(t.print)),t.hasOwnProperty("sleep")&&(t.sleep=await this.transformExpression(t.sleep)),t.hasOwnProperty("assert")&&(t.assert=await this.transformExpression(t.assert))}async createAtomLibFiles({root:e}){await this.setProgress({message:"Creating external lib files."}),this.#r.typesDir="./types";const t=e.context.libs.filter((e=>"atom"===e.type));for(let e=0;e<t.length;e++){const o=t[e].atom,n=this.#s.projectDir;if("local:"===o.protocol){const e=i.resolve(this.#s.projectSrcDir,`${o.fileName||o.name}.js`),t=i.relative(`${this.#s.projectDir}/src/default/blocks`,e);if(!l.existsSync(e)){l.mkdirSync(i.dirname(e),{recursive:!0});let t="export default async (input)=>{\n";t+="}",l.writeFileSync(e,t,"utf8")}o.relativePath=t.split(i.sep).join("/"),this.#r.typesDir=`./types/${i.basename(n)}/src`}else if("npm:"===o.protocol)o.relativePath=o.name;else if("node:"===o.protocol)o.relativePath=o.name;else if("use:"===o.protocol)console.log("USE:",o.name);else{const e=`${n}/src/libs/${o.id}.js`,t=o.doc.contents?.find((e=>"esm"===e.format))||o.doc;l.writeFileSync(i.normalize(e),t.content,"utf8")}}}async createEngine({root:e}){await this.setProgress({message:"Creating engine file."});const t=this.#s.templateDir,o=g.compile(l.readFileSync(i.resolve(t,"src/default/engine.js.njk"),"utf8"),this.#c);for(let t=0;t<e.childs.length;t++){const n=e.childs[t];if(!n.entryFile)continue;const s=o.render({flow:n,ui:{package:"@fnet/react-app"}}),r=this.#s.projectDir,a=i.resolve(r,`src/default/${n.entryFile}`);l.writeFileSync(a,s,"utf8")}}async createNodeTree({root:e}){await this.setProgress({message:"Creating block files."});for await(const t of e.childs)await this.createTypeWorkflow({node:t})}async createTypeWorkflow({node:e}){const t=this.#s.templateDir,o=g.compile(l.readFileSync(i.resolve(t,"src/default/workflow.js.njk"),"utf8"),this.#c).render(e),n=this.#s.projectDir,s=i.resolve(n,`src/default/${e.codeKey}.js`);l.writeFileSync(s,o,"utf8");for await(const t of e.childs)await this.createType({node:t})}async createType({node:e}){switch(e.type){case"assign":case"steps":case"return":case"call":case"new":case"form":case"raise":case"switch":case"next":case"tryexcept":case"for":case"signal":case"wait":case"modules":case"output":this.createBlockFromTemplate({node:e})}for await(const t of e.childs)await this.createType({node:t})}createBlockFromTemplate({node:e}){const t=this.getBlockTemplate({node:e});e.context.render=t.render(e),this.createStepFile({node:e})}getBlockTemplate({node:e}){let t=this.#d[e.type];if(t)return t;const o=this.#s.templateDir;return t=g.compile(l.readFileSync(i.resolve(o,`src/default/blocks/${e.type}.js.njk`),"utf8"),this.#c),this.#d[e.type]=t,t}createStepFile({node:e}){const t=this.#s.projectDir,o=`${e.codeKey}.js`,n=i.resolve(t,`src/default/blocks/${o}`);l.writeFileSync(n,e.context.render,"utf8"),e.context.fileName=o,e.context.filePath=n}async transformExpression(e){let t=await this.transformValue(e);return t=JSON.stringify(t),t=this.replaceSpecialPattern(t),t}async transformValue(e){if(Array.isArray(e))for(let t=0;t<e.length;t++)e[t]=await this.transformValue(e[t]);else if(b(e)){const t=Object.keys(e);for(let o=0;o<t.length;o++){const n=t[o],i=A({expression:n});if(i)if("e"===i.processor){const t=e[n].replace(/(\r\n|\n|\r)/g,"");e[i.statement]=`$::${t}::`,delete e[n]}else e[n]=await this.transformValue(e[n]);else e[n]=await this.transformValue(e[n])}}else if("string"==typeof e){const t=A({expression:e});if(t){const{processor:o,statement:n}=t;switch(o){case"v":e=`$::v.${n}::`;break;case"e":e=`$::${n}::`;break;case"m":e=`$::c.module?.${n}||flow.module?.${n}::`;break;case"f":e=`$::c.form.${n}::`;break;case"for":e=`$::caller.for.${n}::`}}}return e}replaceSpecialPattern(e){return e.replace(/"\$::(.*?)::"/g,"$1")}replaceExpressionLegacy(e){return e.replaceAll(/(?<outer>"\${(?<inner>[^{]*)}")/g,"$2")}async createProjectYaml(){const e="fnet.yaml",t=`Creating ${e}`;await this.setProgress({message:t});const{content:o,...n}=this.#r.doc,s=this.#s.projectDir,r=i.resolve(s,`${e}`);l.writeFileSync(r,h.stringify(n),"utf8")}async createProjectMainYaml(){const e="flow.main.yaml",t=`Creating ${e}`;await this.setProgress({message:t});const o={content:h.stringify(this.#a)},n=this.#s.templateDir,s=g.compile(l.readFileSync(i.resolve(n,`${e}.njk`),"utf8"),this.#c).render(o),r=this.#s.projectDir,a=i.resolve(r,`${e}`);l.writeFileSync(a,s,"utf8")}async runPrettifier(){const e=this.#s.projectDir;if(V("bun")){const t=await u("prettier --write .",{cwd:i.resolve(e,"src")});if(0!==t.code)throw new Error(t.stderr)}else{const t=await u("prettier --write .",{cwd:i.resolve(e,"src")});if(0!==t.code)throw new Error(t.stderr)}}async deploy(){if(await this.setProgress({message:"Deploying."}),this.#s.project?.devops){const e=[this.#s.project?.devops];for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&await o.save()}}else if(this.#r.id){const e=await D.list({type:"workflow.deploy",parent_id:this.#r.id});for(let t=0;t<e.length;t++){let o=e[t];await this.deployProject({deploymentProject:o}),!0===o.isDirty&&(o=await D.update(o,{id:o.id}))}}}async deployProject(e){const{deploymentProject:t}=e,{yamlDocument:o}=t;if(t.doc.targets&&Array.isArray(t.doc.targets))throw new Error("Deployment project targets are deprecated. Please update targets in the yaml file.");const n=Object.keys(t.doc||{}),i=o||{};for(let e=0;e<n.length;e++){const o=t.doc[n[e]];o.name=n[e];const s=i.get(n[e]);await re({...this.#k,deploymentProject:t,deploymentProjectTarget:o,yamlTarget:s})}}async registerToPackageManager(e){const{target:t,packageJSON:o}=e;if(!this.#s.id)return;let n=await D.first({name:t.params.name,parent_id:this.#g.env.ATOM_PACKAGES_ID});n?(n.doc.versions.splice(0,0,{v:o.version}),await D.update(n,{id:n.id})):n=await D.create({parent_id:this.#g.env.ATOM_PACKAGES_ID,doc:{name:t.params.name,type:"pm",versions:[{v:o.version}]}})}async setProgress(e){const o="string"==typeof e?e:e?.message;console.log(t.blue(o)),await this._cache_set(this.#y,{status:"IN_PROGRESS",message:o})}async build(){if(this.#j&&!this.#b)return await this.createNetwork();try{const e=this.#j?await me({root:this.#m}):void 0;if(this.#b){const t=this.#k.context.project;if(await this.initWorkflowDir(),await this.initNunjucks(),this.#j){let t=this.#s.project?.projectDir||this.#s.projectDir;t=i.resolve(t,"fnet"),l.existsSync(t)&&(l.existsSync(i.resolve(t,"flow.bpmn"))&&l.unlinkSync(i.resolve(t,"flow.bpmn")),l.writeFileSync(i.resolve(t,"flows.bpmn"),e.diagramXML,"utf8"))}await this.createAtomLibFiles({root:this.#m}),await this.createEngine({root:this.#m}),await this.createNodeTree({root:this.#m}),await this.createProjectYaml(),await async function({atom:e,context:t,setProgress:o,Atom:n}){const s="readme.md",r=`Creating ${s}`;if(await o({message:r}),t.project?.readme){const e=t.projectDir,o={content:t.project.readme.doc.content},n=i.resolve(t.project.projectDir,"fnet/how-to.md");if(l.existsSync(n)){const e=l.readFileSync(n,"utf8");o.howto=e}const r=i.resolve(t.project.projectDir,"fnet/input.yaml");if(l.existsSync(r)){const e=await y({file:r,tags:t.tags});o.input=e.content}const a=i.resolve(t.project.projectDir,"fnet/output.yaml");if(l.existsSync(a)){const e=await y({file:a,tags:t.tags});o.output=e.content}const c=t.templateDir,p=g.compile(l.readFileSync(i.resolve(c,`${s}.njk`),"utf8"),g.configure(c)).render(o),d=i.resolve(e,`${s}`);l.writeFileSync(d,p,"utf8")}else if(e.id){const o=await n.first({type:"wiki",parent_id:e.id});if(!o||"markdown"!==o.doc?.["content-type"])return;const{content:r,...a}=o.doc,c={content:r},p=t.templateDir,d=g.compile(l.readFileSync(i.resolve(p,`${s}.njk`),"utf8"),g.configure(p)).render(c),f=t.projectDir,m=i.resolve(f,`${s}`);l.writeFileSync(m,d,"utf8")}}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating tsconfig.json."});const s={atom:e,packageDependencies:n},r=o.templateDir,a=g.compile(l.readFileSync(i.resolve(r,"tsconfig.json.njk"),"utf8"),g.configure(r)).render(s),c=o.projectDir,p=i.resolve(c,"tsconfig.json");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating .gitignore"});const s={atom:e,packageDependencies:n},r=o.templateDir,a=g.compile(l.readFileSync(i.resolve(r,".gitignore.njk"),"utf8"),g.configure(r)).render(s),c=o.projectDir,p=i.resolve(c,".gitignore");l.writeFileSync(p,a,"utf8")}(this.#k),await async function({atom:e,setProgress:t,context:o,njEnv:n}){if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating input args."});let s={};if(s=e.doc.input?e.doc.input:{type:"object",properties:{},required:[]},e.doc.features.cli.fargs&&!1!==e.doc.features.cli.fargs?.enabled){const t=e.doc.features.cli.fargs;Reflect.has(t,"default")&&t.default}const r={imports:[],atom:e},a=o.templateDir,c=g.compile(l.readFileSync(i.resolve(a,"src/default/input.args.js.njk"),"utf8"),n).render(r),p=o.projectDir,d=i.resolve(p,"src/default/input.args.js");l.writeFileSync(d,c,"utf8");const f=new N({allErrors:!0,useDefaults:!0,formats:{},strict:!1,code:{esm:!0,lines:!0,optimize:!1,source:!0}});C(f);const m=f.compile(s),u=T(f,m)+"\nexport { schema31 as schema };";l.writeFileSync(i.resolve(p,"src/default/validate_input.js"),u,"utf8")}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){if(!0!==e.doc.features.cli.enabled)return;await t({message:"Creating cli."});const s={atom:e,packageDependencies:n},r=o.templateDir,a=i.resolve(o.projectDir,"src/cli");l.existsSync(a)||l.mkdirSync(a,{recursive:!0}),await m({pattern:["index.js.njk"],dir:i.resolve(r,"src/cli"),outDir:a,context:s})}(this.#k),await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){if(!0!==e.doc.features.app.enabled)return;await t({message:"Creating app folder"});const s={atom:e,packageDependencies:n,ts:Date.now()},r=o.templateDir,a=i.resolve(o.projectDir,"src/app");l.existsSync(a)||l.mkdirSync(a,{recursive:!0});let c=["index.js.njk"];!1!==e.doc.features.app.html&&c.push("index.html.njk"),await m({pattern:c,dir:i.resolve(r,"src/app"),outDir:a,context:s})}(this.#k),"bun"===t.runtime.type?await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating build.js file."});const s={atom:e,packageDependencies:n},r=o.templateDir,a=g.compile(l.readFileSync(i.resolve(r,"build.js.njk"),"utf8"),g.configure(r)).render(s),c=o.projectDir,p=i.resolve(c,"build.js");l.writeFileSync(p,a,"utf8"),l.chmodSync(p,"755")}(this.#k):await async function({atom:e,setProgress:t,context:o,packageDependencies:n}){await t({message:"Creating rollup file."});const s={atom:e,packageDependencies:n},r=i.resolve(o.projectDir,"src","default/index.js");if(!l.existsSync(r))throw new Error(`Entry file not found: ${r}`);const a=(await S({file:r,recursive:!0})).all.filter((e=>"node"===e.type)).map((e=>e.path)),c=e.doc.features.rollup_output,p=Object.keys(c);for(let e=0;e<p.length;e++){const t=c[p[e]];if(!0===t.browser&&a.length>0){t.globals_enabled=!0,t.globals=t.globals||[],t.globals=t.globals.concat(a.map((e=>({key:e,value:e})))),t.alias_enabled=!0,t.alias=t.alias||{},t.alias.entries=t.alias.entries||{};for(let e=0;e<a.length;e++){const o=a[e];t.alias.entries[o]=`node:${o}`,t.alias.entries[`node:${o}`]=o}t.external_enabled=!0,t.external=t.external||[],t.external=t.external.concat(a)}}const d=o.templateDir;let f=g.compile(l.readFileSync(i.resolve(d,"rollup.config.mjs.njk"),"utf8"),g.configure(d)).render(s);const m=o.projectDir;let u=i.resolve(m,"rollup.config.mjs");l.writeFileSync(u,f,"utf8")}(this.#k),await async function({atom:e,context:t,packageDependencies:o,packageDevDependencies:n,setProgress:s}){await s({message:"Creating package.json."}),o.filter((e=>!0===e.dev)).forEach((e=>{n.find((t=>t.package===e.package))||n.push(e);const t=o.findIndex((t=>t.package===e.package));o.splice(t,1)}));const r=o.find((e=>"react"===e.package)),a=o.find((e=>"react-dom"===e.package));r&&!a?o.push({package:"react-dom",version:r.version}):r&&a&&(a.version=r.version),r&&e.doc.features.react_version>=17&&(o.find((e=>"@emotion/react"===e.package))||o.push({package:"@emotion/react",version:"^11"}),o.find((e=>"@emotion/styled"===e.package))||o.push({package:"@emotion/styled",version:"^11"}));const c=[];!0===e.doc.features.app.enabled&&c.push({file:i.resolve(t.projectDir,"src/app/index.js"),dev:!1!==e.doc.features.app.dev}),!0===e.doc.features.cli.enabled&&c.push({file:i.resolve(t.projectDir,"src/cli/index.js"),dev:!1!==e.doc.features.cli.dev});for await(const e of c){const i=e.file;if(!l.existsSync(i))throw new Error(`App file not found: ${i}`);const r=(await S({file:i,recursive:!0,verbose:!1})).all;for await(const i of r){if("npm"!==i.type)continue;if(o.find((e=>e.package===i.package)))continue;if(n.find((e=>e.package===i.package)))continue;const r=await se({name:i.package,projectDir:t.projectDir,setProgress:s});(!0===e.dev?n:o).push({package:i.package,subpath:i.subpath,version:r.minorRange,type:"npm"})}}const p={atom:e,packageDependencies:o,packageDevDependencies:n},d=t.templateDir,f=g.compile(l.readFileSync(i.resolve(d,"package.json.njk"),"utf8"),g.configure(d)).render(p),m=t.projectDir,u=i.resolve(m,"package.json");l.writeFileSync(u,f,"utf8");const y=i.resolve(t.project.projectDir,"fnet");if(l.existsSync(y)){const e=i.resolve(t.projectDir,"fnet");l.existsSync(e)||l.mkdirSync(e);const o=l.readdirSync(y);for(const t of o){const o=i.resolve(y,t);if(!l.lstatSync(o).isFile())continue;const n=i.resolve(e,t);l.copyFileSync(o,n)}}}(this.#k),await async function({setProgress:e,context:t}){const o=t.projectDir;await e({message:"Prettifiying source files."});let n=i.join("src","**","*");if(V("bun")){const e=await u(`prettier --write ${n} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:o});if(0!==e.code)throw new Error(e.stderr)}else{const e=await u(`prettier --write ${n} *.{js,cjs,mjs,json,yaml,html} --no-error-on-unmatched-pattern`,{cwd:o});if(0!==e.code)throw new Error(e.stderr)}}(this.#k),await async function({atom:e,setProgress:t,context:o}){if(!e.doc.features.dts_enabled)return;const n=o.projectDir;if(await t({message:"Creating .d.ts"}),0!==(await u("tsc",{cwd:n})).code)throw new Error("Couldnt create .d.ts files.")}(this.#k),this.#x&&(await async function({setProgress:e,atom:t,context:o}){const n=o.projectDir;if(await e({message:"Installing npm packages."}),V("bun")){if(0!==(await u(`bun install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}else if(0!==(await u(`npm install ${t.doc.features.npm_install_flags}`,{cwd:n})).code)throw new Error("Couldnt install npm packages.")}(this.#k),await async function({setProgress:e,context:t}){const o=t.projectDir;if(await e({message:"Building main project."}),V("bun")){if(0!==(await u(t.dev?"bun run build:dev":"bun run build",{cwd:o})).code)throw new Error("Couldnt build project.")}else if(0!==(await u(t.dev?"npm run build:dev":"npm run build",{cwd:o})).code)throw new Error("Couldnt build project.")}(this.#k),this.#v&&await this.deploy())}await this._cache_set(this.#y,{status:"COMPLETED",data:{network:e}})}catch(e){throw await this._cache_set(this.#y,{status:"FAILED",message:e.message||e}),e}}async createNetwork(){try{const e=await me({root:this.#m});await this._cache_set(this.#y,{status:"COMPLETED",data:{...e}})}catch(e){throw await this._cache_set(this.#y,{status:"FAILED",message:e.message||e}),e}}}const Qe={command:"build",describe:"Build flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{const t=await Q(e),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},Ze={command:"build:dev",describe:"Build flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("mode",{type:"string",default:"build",choices:["all","file","build","deploy","bpmn"],describe:"Build mode"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}).option("dev",{type:"boolean",default:!1,describe:"Development mode"}),handler:async e=>{try{e.dev=!0;const t=await Q(e),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},et={command:"deploy",describe:"Build and deploy flownet project",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Q({...e,mode:"all"}),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},tt={command:"file",describe:"Just create files",builder:e=>e.option("id",{type:"string",describe:"Project ID"}).option("buildId",{type:"string",alias:"bid",describe:"Build ID"}).option("ftag",{type:"array",describe:"Tags for conditional configuration"}),handler:async e=>{try{const t=await Q({...e,mode:"file"}),o=new Ye(t);await o.init(),await o.build(),console.log("Building workflow succeeded!"),process.exit(0)}catch(e){console.error("Building workflow failed!",e.message),process.exit(1)}}},ot={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 t=await Q(e),{project:o}=t,{projectDir:n,projectFileParsed:s}=o,r=s.input;if(!r)throw new Error("Config schema not found in project file.");if(!Reflect.has(e,"name")){const{inputName:t}=await M({type:"input",name:"inputName",message:"Input name:",initial:"dev"});e.name=t}const a=i.resolve(n,".fnet");l.existsSync(a)||l.mkdirSync(a);const c=i.resolve(a,`${e.name}.fnet`),p=l.existsSync(c),d=(await import("@fnet/object-from-schema")).default,f=await d({schema:r,format:"yaml",ref:p?c:void 0});l.writeFileSync(c,f)}catch(e){console.error(e.message),process.exit(1)}}};var nt={promptForSelection:async function(e){const{items:o,message:n,nameField:i="name",valueField:s="name",initialValue:r=null,allowAbort:a=!0}=e;if(!o||0===o.length)return console.log(t.yellow("No items available for selection.")),null;if(1===o.length&&!a){const e=o[0],n="string"==typeof e?e:e[s];return console.log(t.blue(`Only one option available: ${"string"==typeof e?e:e[i]}`)),n}let c=o.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[s],value:e[s],message:e[i]||e[s]}));a&&c.push({name:"cancel",value:null,message:t.yellow("Cancel")});let l=null;if(r){const e=c.findIndex((e=>e.name===r));-1!==e&&(l=e)}const p="selectedItem",{[p]:d}=await M({type:"select",name:p,message:n,choices:c,initial:l});return"cancel"===d?null:d},promptForMultipleSelection:async function(e){const{items:o,message:n,nameField:i="name",valueField:s="name",initialValues:r=[],allowAbort:a=!0}=e;if(!o||0===o.length)return console.log(t.yellow("No items available for selection.")),null;let c=o.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[s],value:e[s],message:e[i]||e[s]})),l=[];r&&r.length>0&&(l=c.map(((e,t)=>r.includes(e.name)?t:-1)).filter((e=>-1!==e)));const p="selectedItems",d=await M({type:"multiselect",name:p,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===d[p].length?null:d[p]}};const it=i.join(f.homedir(),".fnet","express");async function st(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)",type:"string",choices:["node"],default:"node"})),(async e=>{await async function(e){try{l.existsSync(it)||l.mkdirSync(it,{recursive:!0});const o=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=i.join(it,o);l.existsSync(n)||l.mkdirSync(n,{recursive:!0});let s,r=e.projectName,a=e.runtime;if(e.yes){if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=e.length>0?Math.max(...e)+1:1;r=`fnet-${t}`}a||(a="node")}else{if(!r){const e=l.readdirSync(n).filter((e=>e.startsWith("fnet-"))).map((e=>parseInt(e.replace("fnet-",""),10))).filter((e=>!isNaN(e))),t=`fnet-${e.length>0?Math.max(...e)+1:1}`,o=await M([{type:"input",name:"projectName",message:"Enter project name:",default:t}]);r=o.projectName}const e=a||"node";a=(await M({type:"select",name:"runtime",message:"Select runtime:",choices:["node"],initial:e})).runtime}if(s=i.join(n,r),l.existsSync(s)){let e=1;for(;l.existsSync(i.join(n,`${r}-${e}`));)e++;r=`${r}-${e}`,s=i.join(n,r)}if(!e.yes){if(!(await M([{type:"confirm",name:"proceed",message:`Create express project "${r}" in ${s}?`,default:!0}])).proceed)return void console.log(t.yellow("Project creation cancelled."))}console.log(t.blue(`Creating express project "${r}" in ${s}...`));const p=i.dirname(s),d=["create","--name",i.basename(s)];d.push("--runtime",a),e.yes&&d.push("--yes"),l.existsSync(p)||l.mkdirSync(p,{recursive:!0});const f=c("fnet",d,{stdio:"inherit",shell:!0,cwd:p});return new Promise(((o,n)=>{f.on("close",(i=>{0===i?(console.log(t.green(`\nExpress project "${r}" created successfully!`)),console.log(t.blue(`\nProject location: ${s}`)),e.yes?o():async function(e){try{(await M({type:"confirm",name:"openIDE",message:"Would you like to open the project in an IDE?",initial:!0})).openIDE&&await lt(e)}catch(e){console.error(t.red(`Error opening IDE: ${e.message}`))}}(s)):(console.error(t.red(`\nFailed to create express project "${r}".`)),n(new Error(`Process exited with code ${i}`)))}))}))}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));const o=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(e.today){const e=(new Date).toISOString().slice(0,10).replace(/-/g,""),n=o.indexOf(e);if(-1===n)return void console.log(t.yellow("No express projects found for today."));o.splice(0,n),o.splice(1)}const n=[];e.type||e.all||(e.type="fnet");for(const t of o){const o=i.join(it,t),s=l.readdirSync(o);for(const r of s){const s=i.join(o,r),a=l.statSync(s);let c="unknown";if(r.startsWith("fnode-")||l.existsSync(i.join(s,"fnode.yaml"))?c="fnode":(r.startsWith("fnet-")||l.existsSync(i.join(s,"fnet.yaml")))&&(c="fnet"),e.type&&c!==e.type)continue;if(e.name&&!r.includes(e.name))continue;const p=`${t.slice(0,4)}-${t.slice(4,6)}-${t.slice(6,8)}`;n.push({name:r,type:c,date:p,path:s,created:a.birthtime})}}if(n.sort(((e,t)=>t.created-e.created)),0===n.length)return void console.log(t.yellow("No express projects found matching the criteria."));console.log(t.blue("\nExpress Projects:"));const s=(await import("./index.-SGbq2cI.js")).default,r=["NAME","TYPE","DATE","PATH"],a=s.createTable(r,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});for(const e of n){let o=e.path;o.startsWith(f.homedir())&&(o="~"+o.substring(f.homedir().length)),a.push([t.white(e.name),"fnet"===e.type?t.cyan(e.type):"fnode"===e.type?t.green(e.type):e.type,e.date,o])}console.log(a.toString()),console.log(t.blue(`\nTotal: ${n.length} projects`))}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));let o;if(e.latest){if(o=await rt(),!o)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(o=await at(e.projectName),!o)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));o=i.join(it,e)}await lt(o)}catch(e){console.error(t.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 o=process.cwd();let n;if(o.includes(it))n=o,console.log(t.blue(`Using current express project: ${i.basename(n)}`));else if(e.latest){if(n=await rt(),!n)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(n=await at(e.projectName),!n)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));n=i.join(it,e)}let s=e.destination;if(!s){s=(await M({type:"input",name:"destination",message:"Enter destination directory:",initial:i.join(process.cwd(),i.basename(n))})).destination}if(s.startsWith("~")&&(s=i.join(f.homedir(),s.slice(1))),s=i.resolve(s),s.startsWith(n+i.sep)||s===n)return void console.log(t.red("Destination cannot be inside the source directory."));if(l.existsSync(s)){if(!l.statSync(s).isDirectory())return void console.log(t.red(`Destination "${s}" is not a directory.`));if(l.readdirSync(s).length>0){if(!(await M({type:"confirm",name:"overwrite",message:`Destination "${s}" is not empty. Continue anyway?`,initial:!1})).overwrite)return void console.log(t.yellow("Project move cancelled."))}}else l.mkdirSync(s,{recursive:!0});console.log(t.blue(`Moving project from ${n} to ${s}...`)),dt(n,s),console.log(t.green(`\nProject moved successfully to ${s}`));(await M({type:"confirm",name:"deleteOriginal",message:"Delete the original express project?",initial:!1})).deleteOriginal&&(l.rmSync(n,{recursive:!0,force:!0}),console.log(t.green("Original project deleted."))),await lt(s)}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));let o;if(e.latest){if(o=await rt(),!o)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(o=await at(e.projectName),!o)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));o=i.join(it,e)}const n=i.basename(o);if(!e.yes){if(!(await M({type:"confirm",name:"confirm",message:`Are you sure you want to remove project "${n}"?`,initial:!1})).confirm)return void console.log(t.yellow("Project removal cancelled."))}console.log(t.blue(`Removing project "${n}"...`)),l.rmSync(o,{recursive:!0,force:!0}),console.log(t.green(`Project "${n}" removed successfully.`))}catch(e){console.error(t.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(it))return void console.log(t.yellow("No express projects found."));let o;if(e.latest){if(o=await rt(),!o)return void console.log(t.yellow("No express projects found."))}else if(e.projectName){if(o=await at(e.projectName),!o)return void console.log(t.yellow(`Project "${e.projectName}" not found.`))}else{const e=await ct();if(!e)return void console.log(t.yellow("No project selected."));o=i.join(it,e)}console.log(t.blue(`Entering project directory: ${o}`)),console.log(t.yellow("\nOpening a new shell in the project directory..."));const n=process.env.SHELL||"/bin/bash",s=c(n,[],{stdio:"inherit",cwd:o,shell:!0});return new Promise((e=>{s.on("close",(()=>{console.log(t.green("\nReturned from project directory.")),e()}))}))}catch(e){console.error(t.red(`Error entering express project directory: ${e.message}`)),process.exit(1)}}(e)})).demandCommand(1,"You need to specify a command").help()}async function rt(){const e=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));if(0===e.length)return null;const t=e[0],o=i.join(it,t),n=l.readdirSync(o);if(0===n.length)return null;let s=null,r=0;for(const e of n){const t=i.join(o,e),n=l.statSync(t);n.birthtimeMs>r&&(r=n.birthtimeMs,s=t)}return s}async function at(e){const o=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const n of o){const o=i.join(it,n),s=l.readdirSync(o);if(s.includes(e))return i.join(o,e);const r=s.filter((t=>t.includes(e)));if(r.length>0){if(1===r.length)return i.join(o,r[0]);{const s=r.map((e=>({name:i.join(o,e),value:i.join(o,e),message:`${e} (${n})`}))),a=await nt.promptForSelection({items:s,message:`Multiple projects match "${e}". Please select one:`,nameField:"message",valueField:"value",allowAbort:!0});return null===a?(console.log(t.yellow("Operation cancelled.")),null):a}}}return null}async function ct(){const e=[],o=l.readdirSync(it).filter((e=>/^\d{8}$/.test(e))).sort(((e,t)=>t.localeCompare(e)));for(const t of o){const o=i.join(it,t),n=l.readdirSync(o);for(const s of n){const n=i.join(o,s),r=l.statSync(n),a=`${t}/${s}`;e.push({name:a,value:a,created:r.birthtime})}}if(e.sort(((e,t)=>t.created-e.created)),0===e.length)return null;const n=await nt.promptForSelection({items:e,message:"Select a project:",nameField:"value",valueField:"value",allowAbort:!0});return null===n?(console.log(t.yellow("Operation cancelled.")),null):n}async function lt(e){const o=await pt("code --version"),n=await pt("code-insiders --version");let i=null;if(o&&n){const e=await M({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"}]});i=e.ide}else if(o)i="code";else{if(!n)return console.log(t.yellow("No supported IDE found. Please open the project manually.")),void console.log(t.blue(`Project path: ${e}`));i="code-insiders"}console.log(t.blue(`Opening project in ${i}...`)),console.log(t.blue(`Project path: ${e}`));const s=c(i,[e],{stdio:"inherit",shell:!0});return new Promise(((e,o)=>{s.on("close",(n=>{0===n?(console.log(t.green(`Project opened in ${i}.`)),e()):(console.error(t.red(`Failed to open project in ${i}.`)),o(new Error(`Process exited with code ${n}`)))}))}))}async function pt(e){return new Promise((t=>{c(e,{shell:!0,stdio:"ignore"}).on("close",(e=>{t(0===e)}))}))}function dt(e,t){l.existsSync(t)||l.mkdirSync(t,{recursive:!0});const o=l.readdirSync(e,{withFileTypes:!0});for(const n of o){const o=i.join(e,n.name),s=i.join(t,n.name);if(n.isDirectory()){if(".git"===n.name||".workspace"===n.name)continue;dt(o,s)}else l.copyFileSync(o,s)}}const ft=i.dirname(a(import.meta.url));const mt=i.dirname(a(import.meta.url)),ut=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(){d({name:["redis"],dir:ut,optional:!0});const e=function({baseDir:e}){let t=e=e||ft;for(;t!==i.parse(t).root;){const e=i.join(t,"node_modules");if(l.existsSync(e))return e;t=i.dirname(t)}return null}({baseDir:mt}),t="win32"===process.platform?";":":";e&&(process.env.PATH=`${i.join(e,"/.bin")}${t}${process.env.PATH}`)}(),async function(){try{let o=e(process.argv.slice(2)).usage("Usage: $0 <command> [options]").command(Y).command(ee).command(Qe).command(Ze).command(et).command(tt).command(ot).command("express","Create and manage express projects",st);o=G(o,{bin:"npm"}),o=G(o,{bin:"node"}),o=G(o,{bin:"bun"}),o=G(o,{name:"serve",bin:"bun",preArgs:["run","serve","--"]}),o=G(o,{name:"watch",bin:"bun",preArgs:["run","watch","--"]}),o=G(o,{name:"app",bin:"bun",preArgs:["run","app","--"]}),o=G(o,{name:"cli",bin:"bun",preArgs:["run","cli","--"]}),o=G(o,{name:"cli:dev",bin:"bun",preArgs:["run","cli:dev","--"]}),o=G(o,{name:"cli:compile",bin:"bun",preArgs:["run","cli:compile","--"]}),o=G(o,{name:"cli:compile:dev",bin:"bun",preArgs:["run","cli:compile:dev","--"]}),o=G(o,{name:"cli:install",bin:"bun",preArgs:["run","cli:install","--"]}),o=G(o,{name:"compile",bin:"bun",preArgs:["run","compile","--"]}),o=function(e,{name:o}){return e.command(`${o} [options]`,"Install the project as a binary",(e=>e.option("name",{alias:"n",describe:"Name to use for the installed binary",type:"string"}).option("force",{alias:"f",describe:"Force overwrite if binary already exists",type:"boolean",default:!1}).option("yes",{alias:"y",describe:"Automatically answer yes to all prompts",type:"boolean",default:!1})),(async e=>{try{const o=await U(e),{projectDir:n}=o;console.log(t.blue("Compiling project..."));const s=i.join(n,".bin");l.existsSync(s)||l.mkdirSync(s,{recursive:!0});const r=i.basename(i.dirname(n)),a=o.project?.projectFileParsed?.features?.cli?.bin,c=e.name||a||r;console.log(t.blue(`Using binary name: ${c}`));const p=i.join(s,c),{spawn:d}=await import("child_process"),f=d("bun",["build","./dist/cli/esm/index.js","--compile",`--outfile=${p}`],{cwd:n,stdio:"inherit",shell:!0});await new Promise(((e,t)=>{f.on("close",(o=>{0===o?e():t(new Error(`Compilation failed with code ${o}`))})),f.on("error",(e=>{t(e)}))})),"win32"!==process.platform&&l.chmodSync(p,493),console.log(t.green(`Binary compiled successfully: ${p}`)),console.log(t.blue("Installing binary..."));const m=["install",p];e.name&&m.push("--name",e.name),e.force&&m.push("--force"),e.yes&&m.push("--yes");const u=d("fbin",m,{stdio:"inherit",shell:!0});await new Promise(((e,t)=>{u.on("close",(o=>{0===o?e():t(new Error(`Installation failed with code ${o}`))})),u.on("error",(e=>{t(e)}))}))}catch(e){console.error(t.red(`Failed to install binary: ${e.message}`)),process.exit(1)}}))}(o,{name:"install"}),o=G(o,{bin:"npx"}),o=G(o,{bin:"cdk"}),o=G(o,{bin:"aws"}),o=function(e,{name:t,preArgs:o=[]}){return e.command(`${t} <config> <command> [options..]`,"Run a command with a config context",(e=>e.positional("config",{type:"string"}).positional("command",{type:"string"}).help(!1).version(!1)),(async e=>{try{const t=await U(e),{projectDir:n}=t,i=e.config,s=await d({name:i,dir:n,transferEnv:!1,optional:!0,tags:t.tags}),r=s?.data?.env||void 0,a=e.command,p=process.argv.slice(5);z(c(a,[...o,...p],{cwd:l.existsSync(n)?n:process.cwd(),stdio:"inherit",shell:!0,detached:!0,env:{...process.env,...r}}))}catch(e){console.error(e.message),process.exit(1)}}))}(o,{name:"with"}),o=function(e,{name:t,projectType:o="auto"}){return e.command(`${t} group [options..]`,"Run a command group.",(e=>e.positional("group",{type:"string"}).option("ftag",{type:"array"}).help(!1).version(!1)),(async e=>{try{const{runCommandGroup:t}=await import("./index.DrwlOzAe.js");await t({projectType:o,group:e.group,tags:e.ftag,args:e,argv:process.argv})}catch(e){console.error(e.message),process.exit(1)}}))}(o,{name:"run",projectType:"fnet"}),o.demandCommand(1,"You need at least one command before moving on").help().version().argv}catch(e){console.error(t.red(`Fatal error: ${e.message}`)),process.exit(1)}}().catch((e=>{console.error(t.red(`Fatal error: ${e.message}`)),process.exit(1)}));export{H as r,V as w};
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import e from"yargs";import{hideBin as t}from"yargs/helpers";import n from"chalk";import i from"node:fs";import r from"node:path";import o from"@fnet/object-from-schema";import s from"@fnet/prompt";import a from"node:os";import c from"yaml";import l from"@fnet/service";import d from"cli-table3";import{createRequire as m}from"module";function f(){return r.join(a.homedir(),".fnet","bin")}function u(){return r.join(a.homedir(),".fnet","metadata")}function p(){return r.join(u(),"binaries.json")}function g(){try{if("win32"===process.platform)return process.env.PSModulePath&&process.env.PSModulePath.includes("PowerShell")?"powershell-core":process.env.PSModulePath?"powershell":"cmd";const e=process.env.SHELL||"";return e.includes("bash")?"bash":e.includes("zsh")?"zsh":e.includes("fish")?"fish":e.includes("ksh")?"ksh":e.includes("csh")||e.includes("tcsh")?"csh":i.existsSync(r.join(a.homedir(),".bashrc"))?"bash":i.existsSync(r.join(a.homedir(),".zshrc"))?"zsh":i.existsSync(r.join(a.homedir(),".config","fish","config.fish"))?"fish":"unknown"}catch(e){return"unknown"}}function v(e){const t=a.homedir(),n=[];switch(e){case"bash":n.push({name:".bashrc",path:r.join(t,".bashrc")}),n.push({name:".bash_profile",path:r.join(t,".bash_profile")}),n.push({name:".profile",path:r.join(t,".profile")});break;case"zsh":n.push({name:".zshrc",path:r.join(t,".zshrc")}),n.push({name:".zprofile",path:r.join(t,".zprofile")});break;case"fish":n.push({name:"config.fish",path:r.join(t,".config","fish","config.fish")});break;case"ksh":n.push({name:".kshrc",path:r.join(t,".kshrc")}),n.push({name:".profile",path:r.join(t,".profile")});break;case"csh":n.push({name:".cshrc",path:r.join(t,".cshrc")}),n.push({name:".tcshrc",path:r.join(t,".tcshrc")});break;case"powershell":n.push({name:"Microsoft.PowerShell_profile.ps1",path:r.join(t,"Documents","WindowsPowerShell","Microsoft.PowerShell_profile.ps1")}),n.push({name:"profile.ps1",path:r.join(t,"Documents","WindowsPowerShell","profile.ps1")});break;case"powershell-core":n.push({name:"Microsoft.PowerShell_profile.ps1",path:r.join(t,"Documents","PowerShell","Microsoft.PowerShell_profile.ps1")}),n.push({name:"profile.ps1",path:r.join(t,"Documents","PowerShell","profile.ps1")});break;case"cmd":n.push({name:"fnet-path.bat",path:r.join(t,"fnet-path.bat")})}return n}function y(e,t){switch(e){case"bash":case"zsh":case"ksh":default:return`export PATH="${t}:$PATH"`;case"fish":return`set -gx PATH ${t} $PATH`;case"csh":return`setenv PATH ${t}:$PATH`;case"powershell":case"powershell-core":return`$env:PATH = "${t};" + $env:PATH`;case"cmd":return`@echo off\nSETX PATH "%PATH%;${t}"\necho Path updated successfully`}}var h={getBinDirectory:f,getMetadataDirectory:u,getMetadataFilePath:p,checkIfInPath:function(e){return(process.env.PATH||"").split(r.delimiter).includes(e)},detectUserShell:g,getShellConfigPath:function(){const e=v(g());for(const t of e)if(i.existsSync(t.path))return t.path;return e.length>0?e[0].path:null},getAllShellConfigPaths:v,createBinDirectoryStructure:async function(){const e=f(),t=u(),n=p();i.existsSync(e)||i.mkdirSync(e,{recursive:!0}),i.existsSync(t)||i.mkdirSync(t,{recursive:!0}),i.existsSync(n)||i.writeFileSync(n,JSON.stringify({binaries:{},lastUpdated:(new Date).toISOString()},null,2))},getExportPathCommand:y,addBinToPath:async function(e,t,o){try{const s=y(e,o);if("cmd"===e)return i.writeFileSync(t,s),console.log(n.yellow(`Created batch file at ${t}`)),console.log(n.yellow("Run this file to add the bin directory to your PATH")),!0;if("powershell"!==e&&"powershell-core"!==e||i.existsSync(r.dirname(t))||i.mkdirSync(r.dirname(t),{recursive:!0}),!i.existsSync(t)){const r="fish"===e?"# Fish shell configuration\n\n":"powershell"===e||"powershell-core"===e?"# PowerShell profile\n\n":"# Shell configuration\n\n";i.writeFileSync(t,r),console.log(n.green(`Created config file at ${t}`))}const a=i.readFileSync(t,"utf8");if(a.includes(o))return!0;const c=`${a.trim()}\n\n# Added by @fnet/cli\n${s}\n`;return i.writeFileSync(t,c),"powershell"!==e&&"powershell-core"!==e||(console.log(n.yellow("You may need to set the PowerShell execution policy to run scripts:")),console.log(n.green("Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned"))),!0}catch(e){return console.error(n.red(`Failed to add bin directory to PATH: ${e.message}`)),!1}}};function S(){return r.join(a.homedir(),".fnet","services")}function b(){return r.join(a.homedir(),".fnet","metadata")}function w(){return r.join(b(),"services.json")}function $(){const e=w();if(!i.existsSync(e))return{services:{},lastUpdated:(new Date).toISOString()};try{return JSON.parse(i.readFileSync(e,"utf8"))}catch(e){return console.warn(n.yellow(`Failed to parse service metadata file: ${e.message}`)),{services:{},lastUpdated:(new Date).toISOString()}}}function x(e){const t=w();e.lastUpdated=(new Date).toISOString(),i.writeFileSync(t,JSON.stringify(e,null,2))}function D(e){return r.join(S(),`${e}.yaml`)}function O(e){const t=D(e);if(!i.existsSync(t))return null;try{const e=i.readFileSync(t,"utf8");return c.parse(e)}catch(e){return console.warn(n.yellow(`Failed to parse service definition file: ${e.message}`)),null}}function F(e){const t=[];if(e.name||t.push("Service name is required"),e.binary||t.push("Binary name is required"),e.binary){const n=h.getBinDirectory(),o=r.join(n,e.binary);i.existsSync(o)||t.push(`Binary '${e.binary}' not found in bin directory`)}return{valid:0===t.length,errors:t}}var E={getServicesDirectory:S,getServiceMetadataDirectory:b,getServiceMetadataFilePath:w,createServiceDirectoryStructure:async function(){const e=S(),t=b(),n=w();i.existsSync(e)||i.mkdirSync(e,{recursive:!0}),i.existsSync(t)||i.mkdirSync(t,{recursive:!0}),i.existsSync(n)||i.writeFileSync(n,JSON.stringify({services:{},lastUpdated:(new Date).toISOString()},null,2))},loadServiceMetadata:$,saveServiceMetadata:x,getServiceDefinitionPath:D,serviceDefinitionExists:function(e){const t=D(e);return i.existsSync(t)},loadServiceDefinition:O,saveServiceDefinition:function(e,t){const r=D(e);try{const e=c.stringify(t);return i.writeFileSync(r,e),!0}catch(e){return console.error(n.red(`Failed to save service definition: ${e.message}`)),!1}},deleteServiceDefinition:function(e){const t=D(e);if(!i.existsSync(t))return!1;try{return i.unlinkSync(t),!0}catch(e){return console.error(n.red(`Failed to delete service definition: ${e.message}`)),!1}},listServiceDefinitions:function(){const e=S();if(!i.existsSync(e))return[];try{return i.readdirSync(e).filter((e=>e.endsWith(".yaml"))).map((e=>e.replace(".yaml","")))}catch(e){return console.error(n.red(`Failed to list service definitions: ${e.message}`)),[]}},validateServiceDefinition:F,registerService:async function(e,t={}){const n=O(e);if(!n)throw new Error(`Service definition '${e}' not found`);const i=F(n);if(!i.valid)throw new Error(`Invalid service definition: ${i.errors.join(", ")}`);const o=h.getBinDirectory(),s=r.join(o,n.binary);try{await l({action:"register",name:n.name,description:n.description||`Service for ${n.binary}`,command:[s,...n.args||[]],env:n.env||{},wdir:n.workingDir,system:!1!==n.system,autoStart:!0===n.autoStart,restartOnFailure:!1!==n.restartOnFailure,user:n.user});const t=$();return t.services[n.name]={definition:e,binary:n.binary,registered:(new Date).toISOString(),status:"registered"},x(t),{success:!0,name:n.name,definition:e}}catch(e){throw new Error(`Failed to register service: ${e.message}`)}}};async function j(e){await E.createServiceDirectoryStructure();return{servicesDir:E.getServicesDirectory(),metadataDir:E.getServiceMetadataDirectory(),metadata:E.loadServiceMetadata(),args:e}}var P={getServiceDefinitionSchema:function(e=!0){let t=[];if(e)try{const e=h.getBinDirectory(),n=h.getMetadataFilePath();if(i.existsSync(n)){const e=JSON.parse(i.readFileSync(n,"utf8"));t=Object.keys(e.binaries).map((t=>({name:t,message:`${t} (${e.binaries[t].version||"unknown"})`})))}else i.existsSync(e)&&(t=i.readdirSync(e).map((e=>({name:e,message:e}))))}catch(e){console.warn(`Failed to get binary choices: ${e.message}`)}return{type:"object",required:["name","binary"],properties:{name:{type:"string",description:"Service name","x-prompt":{type:"input",message:"Enter service name:"}},binary:{type:"string",description:"Binary name in the bin directory","x-prompt":{type:"select",message:"Select binary:",choices:t}},description:{type:"string",description:"Service description","x-prompt":{type:"input",message:"Enter service description:"}},args:{type:"array",items:{type:"string"},description:"Command line arguments","x-prompt":{type:"input",message:"Enter command line arguments (space-separated):",result:e=>e?e.split(" "):[]}},env:{type:"object",additionalProperties:{type:"string"},description:"Environment variables","x-prompt":{type:"input",message:"Enter environment variables (KEY=VALUE format, one per line):",result:e=>e?e.split("\n").filter((e=>e.includes("="))).reduce(((e,t)=>{const[n,...i]=t.split("=");return e[n.trim()]=i.join("=").trim(),e}),{}):{}}},workingDir:{type:"string",description:"Working directory","x-prompt":{type:"input",message:"Enter working directory (optional):"}},autoStart:{type:"boolean",description:"Start on boot",default:!1,"x-prompt":{type:"confirm",message:"Start service on boot?",initial:!1}},restartOnFailure:{type:"boolean",description:"Restart on failure",default:!0,"x-prompt":{type:"confirm",message:"Restart service on failure?",initial:!0}},system:{type:"boolean",description:"System service",default:!0,"x-prompt":{type:"confirm",message:"Register as system service?",initial:!0}},user:{type:"string",description:"User to run the service as","x-prompt":{type:"input",message:"Enter user to run the service as (optional):"}},instances:{type:"integer",description:"Number of instances to run",default:1,minimum:1,"x-prompt":{type:"number",message:"Enter number of instances to run:",initial:1}},metadata:{type:"object",additionalProperties:!0,description:"Custom metadata"}}}}};var k={promptForSelection:async function(e){const{items:t,message:i,nameField:r="name",valueField:o="name",initialValue:a=null,allowAbort:c=!0}=e;if(!t||0===t.length)return console.log(n.yellow("No items available for selection.")),null;if(1===t.length&&!c){const e=t[0],i="string"==typeof e?e:e[o];return console.log(n.blue(`Only one option available: ${"string"==typeof e?e:e[r]}`)),i}let l=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[o],value:e[o],message:e[r]||e[o]}));c&&l.push({name:"cancel",value:null,message:n.yellow("Cancel")});let d=null;if(a){const e=l.findIndex((e=>e.name===a));-1!==e&&(d=e)}const m="selectedItem",{[m]:f}=await s({type:"select",name:m,message:i,choices:l,initial:d});return"cancel"===f?null:f},promptForMultipleSelection:async function(e){const{items:t,message:i,nameField:r="name",valueField:o="name",initialValues:a=[],allowAbort:c=!0}=e;if(!t||0===t.length)return console.log(n.yellow("No items available for selection.")),null;let l=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[o],value:e[o],message:e[r]||e[o]})),d=[];a&&a.length>0&&(d=l.map(((e,t)=>a.includes(e.name)?t:-1)).filter((e=>-1!==e)));const m="selectedItems",f=await s({type:"multiselect",name:m,message:i,choices:l,initial:d,hint:"(Use space to select, enter to confirm)",validate:e=>!(0===e.length&&!c)||"Please select at least one item"});return c&&0===f[m].length?null:f[m]}};const M={command:"definition <subcommand>",describe:"Manage service definitions",builder:e=>e.command({command:"create",describe:"Create a new service definition",builder:e=>e.option("name",{describe:"Service definition name",type:"string"}).option("output",{describe:"Output file path",type:"string",alias:"o"}),handler:A}).command({command:"list",describe:"List service definitions",builder:e=>e.option("format",{describe:"Output format",type:"string",choices:["json","text","table"],default:"table"}),handler:N}).command({command:"show [n]",describe:"Show service definition details",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}).option("format",{describe:"Output format",type:"string",choices:["json","yaml"],default:"yaml"}),handler:T}).command({command:"edit [n]",describe:"Edit a service definition",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}),handler:I}).command({command:"delete [n]",describe:"Delete a service definition",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}).option("force",{describe:"Force deletion without confirmation",type:"boolean",default:!1,alias:"f"}),handler:C}).command({command:"validate [n]",describe:"Validate a service definition",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}),handler:U}).demandCommand(1,"You need to specify a subcommand"),handler:()=>{}};async function A(e){try{await j(e);const t=P.getServiceDefinitionSchema(),i=await o({schema:t,format:"yaml"});let r;if(console.log("Result from fnetObjectFromSchema:",i),"string"==typeof i)try{r=(await import("yaml")).default.parse(i)}catch(e){console.warn(n.yellow(`Failed to parse YAML: ${e.message}`)),r={name:"service-"+Date.now()}}else r=i&&"object"==typeof i?i.data||i:{name:"service-"+Date.now()};console.log("Generated definition:",r);const a=e.name||(r&&r.name?r.name:"service-"+Date.now());if(E.serviceDefinitionExists(a)&&!e.force){const{confirmOverwrite:e}=await s({type:"confirm",name:"confirmOverwrite",message:`Service definition '${a}' already exists. Overwrite?`,initial:!1});if(!e)return void console.log(n.yellow("Operation cancelled."))}E.saveServiceDefinition(a,r)?(console.log(n.green(`Service definition '${a}' created successfully.`)),console.log(n.blue(`Location: ${E.getServiceDefinitionPath(a)}`))):console.error(n.red(`Failed to create service definition '${a}'.`))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function N(e){try{await j(e);const t=E.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));if("json"===e.format)console.log(JSON.stringify(t,null,2));else if("text"===e.format)t.forEach((e=>console.log(e)));else{console.log(n.bold("\nService Definitions:"));const e=(await Promise.resolve().then((function(){return q}))).default,i=["NAME","BINARY","DESCRIPTION"],r=e.createTable(i,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});for(const e of t){const t=E.loadServiceDefinition(e);t&&r.push([n.white(e),n.cyan(t.binary||"undefined"),t.description||""])}console.log(r.toString()),console.log(`Total: ${t.length} definition(s)`)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function T(e){try{await j(e);if(!e.name){const t=E.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await k.promptForSelection({items:t,message:"Select a service definition to show:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}const t=E.loadServiceDefinition(e.name);if(t||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1)),"json"===e.format)console.log(JSON.stringify(t,null,2));else{const e=(await import("yaml")).default;console.log(e.stringify(t))}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function I(e){try{await j(e);if(!e.name){const t=E.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await k.promptForSelection({items:t,message:"Select a service definition to edit:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}const t=E.loadServiceDefinition(e.name);t||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1));const i=P.getServiceDefinitionSchema(),r=(await o({schema:i,ref:t,format:"yaml"})).data;E.saveServiceDefinition(e.name,r)?console.log(n.green(`Service definition '${e.name}' updated successfully.`)):console.error(n.red(`Failed to update service definition '${e.name}'.`))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function C(e){try{await j(e);if(!e.name){const t=E.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await k.promptForSelection({items:t,message:"Select a service definition to delete:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}if(E.serviceDefinitionExists(e.name)||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1)),!e.force){const{confirmDelete:t}=await s({type:"confirm",name:"confirmDelete",message:`Are you sure you want to delete service definition '${e.name}'?`,initial:!1});if(!t)return void console.log(n.yellow("Operation cancelled."))}E.deleteServiceDefinition(e.name)?console.log(n.green(`Service definition '${e.name}' deleted successfully.`)):console.error(n.red(`Failed to delete service definition '${e.name}'.`))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function U(e){try{await j(e);if(!e.name){const t=E.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await k.promptForSelection({items:t,message:"Select a service definition to validate:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}const t=E.loadServiceDefinition(e.name);t||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1));const i=E.validateServiceDefinition(t);i.valid?console.log(n.green(`Service definition '${e.name}' is valid.`)):(console.error(n.red(`Service definition '${e.name}' is invalid:`)),i.errors.forEach((e=>{console.error(n.red(`- ${e}`))})),process.exit(1))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}const R={command:"register",describe:"Register a service definition as a system service",builder:e=>e.option("definition",{describe:"Service definition name",type:"string",demandOption:!0,alias:"d"}).option("start",{describe:"Start the service after registration",type:"boolean",default:!1}),handler:async e=>{try{await j(e);E.serviceDefinitionExists(e.definition)||(console.error(n.red(`Service definition '${e.definition}' not found.`)),process.exit(1)),console.log(n.blue(`Registering service from definition '${e.definition}'...`));const t=await E.registerService(e.definition);if(console.log(n.green(`Service '${t.name}' registered successfully.`)),e.start){console.log(n.blue(`Starting service '${t.name}'...`));const e=(await import("@fnet/service")).default;try{await e({action:"start",name:t.name}),console.log(n.green(`Service '${t.name}' started successfully.`));const i=E.loadServiceMetadata();i.services[t.name]&&(i.services[t.name].status="running",i.services[t.name].lastStarted=(new Date).toISOString(),E.saveServiceMetadata(i))}catch(e){console.error(n.red(`Failed to start service: ${e.message}`))}}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},H={command:"unregister",describe:"Unregister a service from the system",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}).option("keep-definition",{describe:"Keep the service definition",type:"boolean",default:!0}).option("force",{describe:"Force unregistration without confirmation",type:"boolean",default:!1,alias:"f"}),handler:async e=>{try{await j(e);const t=E.loadServiceMetadata();if(t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),!e.force){const{confirmUnregister:t}=await s({type:"confirm",name:"confirmUnregister",message:`Are you sure you want to unregister service '${e.name}'?`,initial:!1});if(!t)return void console.log(n.yellow("Operation cancelled."))}console.log(n.blue(`Unregistering service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=E.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);const s=!1!==o.system;try{await i({action:"stop",name:e.name,system:s}),console.log(n.blue(`Service '${e.name}' stopped.`))}catch(e){console.warn(n.yellow(`Warning: Failed to stop service: ${e.message}`))}if(await i({action:"unregister",name:e.name,system:s}),console.log(n.green(`Service '${e.name}' unregistered successfully.`)),delete t.services[e.name],E.saveServiceMetadata(t),!e.keepDefinition&&r&&E.serviceDefinitionExists(r)){E.deleteServiceDefinition(r)?console.log(n.green(`Service definition '${r}' deleted.`)):console.warn(n.yellow(`Warning: Failed to delete service definition '${r}'.`))}}catch(e){console.error(n.red(`Failed to unregister service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},B={command:"start",describe:"Start a registered service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}),handler:async e=>{try{await j(e);const t=E.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Starting service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=E.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);await i({action:"start",name:e.name,system:!1!==o.system}),console.log(n.green(`Service '${e.name}' started successfully.`)),t.services[e.name].status="running",t.services[e.name].lastStarted=(new Date).toISOString(),E.saveServiceMetadata(t)}catch(e){console.error(n.red(`Failed to start service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},z={command:"stop",describe:"Stop a running service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}),handler:async e=>{try{await j(e);const t=E.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Stopping service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=E.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);await i({action:"stop",name:e.name,system:!1!==o.system}),console.log(n.green(`Service '${e.name}' stopped successfully.`)),t.services[e.name].status="stopped",t.services[e.name].lastStopped=(new Date).toISOString(),E.saveServiceMetadata(t)}catch(e){console.error(n.red(`Failed to stop service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},_={command:"restart",describe:"Restart a service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}),handler:async e=>{try{await j(e);const t=E.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Restarting service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{await i({action:"stop",name:e.name}),console.log(n.blue(`Service '${e.name}' stopped.`)),await i({action:"start",name:e.name}),console.log(n.green(`Service '${e.name}' restarted successfully.`)),t.services[e.name].status="running",t.services[e.name].lastRestarted=(new Date).toISOString(),E.saveServiceMetadata(t)}catch(e){console.error(n.red(`Failed to restart service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},J={command:"status",describe:"Check the status of a service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}).option("format",{describe:"Output format",type:"string",choices:["json","text","table"],default:"table"}),handler:async e=>{try{await j(e);const t=E.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Checking status of service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=E.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);const s=await i({action:"status",name:e.name,system:!1!==o.system});console.log(n.green(`Service '${e.name}' status: ${s}`)),t.services[e.name].status=s||"unknown",t.services[e.name].lastChecked=(new Date).toISOString(),E.saveServiceMetadata(t),"json"===e.format?console.log(JSON.stringify({name:e.name,status:s||"unknown",definition:t.services[e.name].definition,binary:t.services[e.name].binary},null,2)):"text"===e.format?(console.log(`Name: ${e.name}`),console.log(`Status: ${s||"unknown"}`),console.log(`Definition: ${t.services[e.name].definition}`),console.log(`Binary: ${t.services[e.name].binary}`)):(console.log(n.bold("\nService Status:")),console.log(n.bold("─".repeat(50))),console.log(`${n.bold("Name:")} ${e.name}`),console.log(`${n.bold("Status:")} ${function(e){switch(e){case"running":return n.green;case"stopped":return n.yellow;case"failed":return n.red;default:return n.gray}}(s)(s||"unknown")}`),console.log(`${n.bold("Definition:")} ${t.services[e.name].definition}`),console.log(`${n.bold("Binary:")} ${t.services[e.name].binary}`),console.log(n.bold("─".repeat(50))))}catch(e){console.error(n.red(`Failed to check service status: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}};function W(e,t={}){const i={chars:{top:"─","top-mid":"─","top-left":" ","top-right":" ",bottom:"─","bottom-mid":"─","bottom-left":" ","bottom-right":" ",left:" ","left-mid":" ",mid:"─","mid-mid":"─",right:" ","right-mid":" ",middle:" "},style:{head:[],border:[],compact:!0},wordWrap:!0,...t,head:e.map((e=>n.bold(e)))};return new d(i)}function L(e,t,n={}){const i=W(e,n);return Array.isArray(t)&&t.forEach((e=>{i.push(e)})),i.toString()}function Y(e){switch(e){case"running":return n.green;case"stopped":return n.yellow;case"failed":return n.red;case"registered":return n.blue;default:return n.gray}}var V={createTable:W,createTableWithData:L,getStatusColor:Y},q=Object.freeze({__proto__:null,createTable:W,createTableWithData:L,default:V,getStatusColor:Y});const K={command:"list",describe:"List all registered services",builder:e=>e.option("binary",{describe:"Filter by binary name",type:"string",alias:"b"}).option("status",{describe:"Filter by status",type:"string",choices:["running","stopped","failed","unknown"],alias:"s"}).option("format",{describe:"Output format",type:"string",choices:["json","text","table"],default:"table"}),handler:async e=>{try{await j(e);const t=E.loadServiceMetadata();let i=Object.entries(t.services).map((([e,t])=>({name:e,...t})));if(e.binary&&(i=i.filter((t=>t.binary===e.binary))),e.status&&(i=i.filter((t=>t.status===e.status))),0===i.length)return void console.log(n.yellow("No services found."));if("json"===e.format)console.log(JSON.stringify(i,null,2));else if("text"===e.format)i.forEach((e=>{console.log(`${e.name} (${e.status||"unknown"})`)}));else{const e=["NAME","STATUS","BINARY","DEFINITION"],t=V.createTable(e,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});i.forEach((e=>{const i=V.getStatusColor(e.status);t.push([n.white(e.name),i(e.status||"unknown"),n.cyan(e.binary),e.definition])})),console.log(n.bold("\nRegistered Services:")),console.log(t.toString()),console.log(`Total: ${i.length} service(s)`)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},G=m(import.meta.url),{version:X}=G("../../package.json");e(t(process.argv)).scriptName("fservice").usage("Usage: $0 <command> [options]").version(X).command(M).command(R).command(H).command(B).command(z).command(_).command(J).command(K).demandCommand(1,"You need to specify a command").strict().help().alias("h","help").alias("v","version").fail(((e,t,i)=>{t?(console.error(n.red(`Error: ${t.message}`)),console.error(t)):console.error(n.red(`Error: ${e}`)),console.error(n.yellow("\nUsage:"),i.help()),process.exit(1)})).parse();
2
+ import e from"yargs";import{hideBin as t}from"yargs/helpers";import n from"chalk";import i from"node:fs";import r from"node:path";import o from"@fnet/object-from-schema";import s from"@fnet/prompt";import a from"node:os";import c from"yaml";import l from"@fnet/service";import d from"cli-table3";import{createRequire as m}from"module";function f(){return r.join(a.homedir(),".fnet","bin")}function u(){return r.join(a.homedir(),".fnet","metadata")}function p(){return r.join(u(),"binaries.json")}function g(){try{if("win32"===process.platform)return process.env.PSModulePath&&process.env.PSModulePath.includes("PowerShell")?"powershell-core":process.env.PSModulePath?"powershell":"cmd";const e=process.env.SHELL||"";return e.includes("bash")?"bash":e.includes("zsh")?"zsh":e.includes("fish")?"fish":e.includes("ksh")?"ksh":e.includes("csh")||e.includes("tcsh")?"csh":i.existsSync(r.join(a.homedir(),".bashrc"))?"bash":i.existsSync(r.join(a.homedir(),".zshrc"))?"zsh":i.existsSync(r.join(a.homedir(),".config","fish","config.fish"))?"fish":"unknown"}catch(e){return"unknown"}}function y(e){const t=a.homedir(),n=[];switch(e){case"bash":n.push({name:".bashrc",path:r.join(t,".bashrc")}),n.push({name:".bash_profile",path:r.join(t,".bash_profile")}),n.push({name:".profile",path:r.join(t,".profile")});break;case"zsh":n.push({name:".zshrc",path:r.join(t,".zshrc")}),n.push({name:".zprofile",path:r.join(t,".zprofile")});break;case"fish":n.push({name:"config.fish",path:r.join(t,".config","fish","config.fish")});break;case"ksh":n.push({name:".kshrc",path:r.join(t,".kshrc")}),n.push({name:".profile",path:r.join(t,".profile")});break;case"csh":n.push({name:".cshrc",path:r.join(t,".cshrc")}),n.push({name:".tcshrc",path:r.join(t,".tcshrc")});break;case"powershell":n.push({name:"Microsoft.PowerShell_profile.ps1",path:r.join(t,"Documents","WindowsPowerShell","Microsoft.PowerShell_profile.ps1")}),n.push({name:"profile.ps1",path:r.join(t,"Documents","WindowsPowerShell","profile.ps1")});break;case"powershell-core":n.push({name:"Microsoft.PowerShell_profile.ps1",path:r.join(t,"Documents","PowerShell","Microsoft.PowerShell_profile.ps1")}),n.push({name:"profile.ps1",path:r.join(t,"Documents","PowerShell","profile.ps1")});break;case"cmd":n.push({name:"fnet-path.bat",path:r.join(t,"fnet-path.bat")})}return n}function v(e,t){switch(e){case"bash":case"zsh":case"ksh":default:return`export PATH="${t}:$PATH"`;case"fish":return`set -gx PATH ${t} $PATH`;case"csh":return`setenv PATH ${t}:$PATH`;case"powershell":case"powershell-core":return`$env:PATH = "${t};" + $env:PATH`;case"cmd":return`@echo off\nSETX PATH "%PATH%;${t}"\necho Path updated successfully`}}function h(){return r.join(a.homedir(),".fnet","backups")}function S(){const e=(new Date).toISOString().replace(/:/g,"-").replace(/\..+/,""),t=r.join(h(),e);return i.existsSync(t)||i.mkdirSync(t,{recursive:!0}),t}function b(e,t,o=null){try{if(!i.existsSync(e))return!1;const n=o||r.basename(e),s=r.join(t,n),a=r.dirname(s);return i.existsSync(a)||i.mkdirSync(a,{recursive:!0}),i.copyFileSync(e,s),!0}catch(t){return console.error(n.red(`Failed to backup file ${e}: ${t.message}`)),!1}}function w(e,t={}){const n={timestamp:(new Date).toISOString(),type:t.type||"manual",message:t.message||"",command:t.command||"",files:t.files||[],...t},o=r.join(e,"metadata.json");i.writeFileSync(o,JSON.stringify(n,null,2))}function $(e){const t=r.join(h(),"latest");try{i.existsSync(t)&&i.unlinkSync(t),"win32"===process.platform?i.writeFileSync(t+".txt",e):i.symlinkSync(e,t)}catch(e){console.warn(n.yellow(`Could not create latest symlink: ${e.message}`))}}var x={getBinDirectory:f,getMetadataDirectory:u,getMetadataFilePath:p,checkIfInPath:function(e){return(process.env.PATH||"").split(r.delimiter).includes(e)},detectUserShell:g,getShellConfigPath:function(){const e=y(g());for(const t of e)if(i.existsSync(t.path))return t.path;return e.length>0?e[0].path:null},getAllShellConfigPaths:y,createBinDirectoryStructure:async function(){const e=f(),t=u(),n=p();i.existsSync(e)||i.mkdirSync(e,{recursive:!0}),i.existsSync(t)||i.mkdirSync(t,{recursive:!0}),i.existsSync(n)||i.writeFileSync(n,JSON.stringify({binaries:{},lastUpdated:(new Date).toISOString()},null,2))},getExportPathCommand:v,addBinToPath:async function(e,t,o,s={}){try{const{autoBackup:a=!0}=s,c=v(e,o);if("cmd"===e)return i.writeFileSync(t,c),console.log(n.yellow(`Created batch file at ${t}`)),console.log(n.yellow("Run this file to add the bin directory to your PATH")),!0;if("powershell"!==e&&"powershell-core"!==e||i.existsSync(r.dirname(t))||i.mkdirSync(r.dirname(t),{recursive:!0}),!i.existsSync(t)){const r="fish"===e?"# Fish shell configuration\n\n":"powershell"===e||"powershell-core"===e?"# PowerShell profile\n\n":"# Shell configuration\n\n";i.writeFileSync(t,r),console.log(n.green(`Created config file at ${t}`))}const l=i.readFileSync(t,"utf8");if(l.includes(o))return!0;if(a&&i.existsSync(t)){const e=S(),i=r.basename(t);b(t,r.join(e,"configs"),i)&&(w(e,{type:"auto",command:"addBinToPath",message:`Automatic backup before modifying ${i}`,files:[t]}),$(e),console.log(n.green(`✓ Backed up ${i} to ${e}`)))}const d=`${l.trim()}\n\n# Added by @fnet/cli\n${c}\n`;return i.writeFileSync(t,d),"powershell"!==e&&"powershell-core"!==e||(console.log(n.yellow("You may need to set the PowerShell execution policy to run scripts:")),console.log(n.green("Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned"))),!0}catch(e){return console.error(n.red(`Failed to add bin directory to PATH: ${e.message}`)),!1}},getBackupDirectory:h,createBackupDirectory:S,backupFile:b,createBackupMetadata:w,listBackups:function(){const e=h();if(!i.existsSync(e))return[];const t=[],n=i.readdirSync(e);for(const o of n){const n=r.join(e,o),s=i.statSync(n);if(s.isDirectory()&&"latest"!==o){const e=r.join(n,"metadata.json");let a={};if(i.existsSync(e))try{a=JSON.parse(i.readFileSync(e,"utf8"))}catch(e){}t.push({timestamp:o,path:n,created:s.mtime,...a})}}return t.sort(((e,t)=>new Date(t.created)-new Date(e.created))),t},updateLatestSymlink:$};function D(){return r.join(a.homedir(),".fnet","services")}function F(){return r.join(a.homedir(),".fnet","metadata")}function j(){return r.join(F(),"services.json")}function k(){const e=j();if(!i.existsSync(e))return{services:{},lastUpdated:(new Date).toISOString()};try{return JSON.parse(i.readFileSync(e,"utf8"))}catch(e){return console.warn(n.yellow(`Failed to parse service metadata file: ${e.message}`)),{services:{},lastUpdated:(new Date).toISOString()}}}function O(e){const t=j();e.lastUpdated=(new Date).toISOString(),i.writeFileSync(t,JSON.stringify(e,null,2))}function E(e){return r.join(D(),`${e}.yaml`)}function P(e){const t=E(e);if(!i.existsSync(t))return null;try{const e=i.readFileSync(t,"utf8");return c.parse(e)}catch(e){return console.warn(n.yellow(`Failed to parse service definition file: ${e.message}`)),null}}function M(e){const t=[];if(e.name||t.push("Service name is required"),e.binary||t.push("Binary name is required"),e.binary){const n=x.getBinDirectory(),o=r.join(n,e.binary);i.existsSync(o)||t.push(`Binary '${e.binary}' not found in bin directory`)}return{valid:0===t.length,errors:t}}var A={getServicesDirectory:D,getServiceMetadataDirectory:F,getServiceMetadataFilePath:j,createServiceDirectoryStructure:async function(){const e=D(),t=F(),n=j();i.existsSync(e)||i.mkdirSync(e,{recursive:!0}),i.existsSync(t)||i.mkdirSync(t,{recursive:!0}),i.existsSync(n)||i.writeFileSync(n,JSON.stringify({services:{},lastUpdated:(new Date).toISOString()},null,2))},loadServiceMetadata:k,saveServiceMetadata:O,getServiceDefinitionPath:E,serviceDefinitionExists:function(e){const t=E(e);return i.existsSync(t)},loadServiceDefinition:P,saveServiceDefinition:function(e,t){const r=E(e);try{const e=c.stringify(t);return i.writeFileSync(r,e),!0}catch(e){return console.error(n.red(`Failed to save service definition: ${e.message}`)),!1}},deleteServiceDefinition:function(e){const t=E(e);if(!i.existsSync(t))return!1;try{return i.unlinkSync(t),!0}catch(e){return console.error(n.red(`Failed to delete service definition: ${e.message}`)),!1}},listServiceDefinitions:function(){const e=D();if(!i.existsSync(e))return[];try{return i.readdirSync(e).filter((e=>e.endsWith(".yaml"))).map((e=>e.replace(".yaml","")))}catch(e){return console.error(n.red(`Failed to list service definitions: ${e.message}`)),[]}},validateServiceDefinition:M,registerService:async function(e,t={}){const n=P(e);if(!n)throw new Error(`Service definition '${e}' not found`);const i=M(n);if(!i.valid)throw new Error(`Invalid service definition: ${i.errors.join(", ")}`);const o=x.getBinDirectory(),s=r.join(o,n.binary);try{await l({action:"register",name:n.name,description:n.description||`Service for ${n.binary}`,command:[s,...n.args||[]],env:n.env||{},wdir:n.workingDir,system:!1!==n.system,autoStart:!0===n.autoStart,restartOnFailure:!1!==n.restartOnFailure,user:n.user});const t=k();return t.services[n.name]={definition:e,binary:n.binary,registered:(new Date).toISOString(),status:"registered"},O(t),{success:!0,name:n.name,definition:e}}catch(e){throw new Error(`Failed to register service: ${e.message}`)}}};async function N(e){await A.createServiceDirectoryStructure();return{servicesDir:A.getServicesDirectory(),metadataDir:A.getServiceMetadataDirectory(),metadata:A.loadServiceMetadata(),args:e}}var T={getServiceDefinitionSchema:function(e=!0){let t=[];if(e)try{const e=x.getBinDirectory(),n=x.getMetadataFilePath();if(i.existsSync(n)){const e=JSON.parse(i.readFileSync(n,"utf8"));t=Object.keys(e.binaries).map((t=>({name:t,message:`${t} (${e.binaries[t].version||"unknown"})`})))}else i.existsSync(e)&&(t=i.readdirSync(e).map((e=>({name:e,message:e}))))}catch(e){console.warn(`Failed to get binary choices: ${e.message}`)}return{type:"object",required:["name","binary"],properties:{name:{type:"string",description:"Service name","x-prompt":{type:"input",message:"Enter service name:"}},binary:{type:"string",description:"Binary name in the bin directory","x-prompt":{type:"select",message:"Select binary:",choices:t}},description:{type:"string",description:"Service description","x-prompt":{type:"input",message:"Enter service description:"}},args:{type:"array",items:{type:"string"},description:"Command line arguments","x-prompt":{type:"input",message:"Enter command line arguments (space-separated):",result:e=>e?e.split(" "):[]}},env:{type:"object",additionalProperties:{type:"string"},description:"Environment variables","x-prompt":{type:"input",message:"Enter environment variables (KEY=VALUE format, one per line):",result:e=>e?e.split("\n").filter((e=>e.includes("="))).reduce(((e,t)=>{const[n,...i]=t.split("=");return e[n.trim()]=i.join("=").trim(),e}),{}):{}}},workingDir:{type:"string",description:"Working directory","x-prompt":{type:"input",message:"Enter working directory (optional):"}},autoStart:{type:"boolean",description:"Start on boot",default:!1,"x-prompt":{type:"confirm",message:"Start service on boot?",initial:!1}},restartOnFailure:{type:"boolean",description:"Restart on failure",default:!0,"x-prompt":{type:"confirm",message:"Restart service on failure?",initial:!0}},system:{type:"boolean",description:"System service",default:!0,"x-prompt":{type:"confirm",message:"Register as system service?",initial:!0}},user:{type:"string",description:"User to run the service as","x-prompt":{type:"input",message:"Enter user to run the service as (optional):"}},instances:{type:"integer",description:"Number of instances to run",default:1,minimum:1,"x-prompt":{type:"number",message:"Enter number of instances to run:",initial:1}},metadata:{type:"object",additionalProperties:!0,description:"Custom metadata"}}}}};var I={promptForSelection:async function(e){const{items:t,message:i,nameField:r="name",valueField:o="name",initialValue:a=null,allowAbort:c=!0}=e;if(!t||0===t.length)return console.log(n.yellow("No items available for selection.")),null;if(1===t.length&&!c){const e=t[0],i="string"==typeof e?e:e[o];return console.log(n.blue(`Only one option available: ${"string"==typeof e?e:e[r]}`)),i}let l=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[o],value:e[o],message:e[r]||e[o]}));c&&l.push({name:"cancel",value:null,message:n.yellow("Cancel")});let d=null;if(a){const e=l.findIndex((e=>e.name===a));-1!==e&&(d=e)}const m="selectedItem",{[m]:f}=await s({type:"select",name:m,message:i,choices:l,initial:d});return"cancel"===f?null:f},promptForMultipleSelection:async function(e){const{items:t,message:i,nameField:r="name",valueField:o="name",initialValues:a=[],allowAbort:c=!0}=e;if(!t||0===t.length)return console.log(n.yellow("No items available for selection.")),null;let l=t.map((e=>"string"==typeof e?{name:e,value:e,message:e}:{name:e[o],value:e[o],message:e[r]||e[o]})),d=[];a&&a.length>0&&(d=l.map(((e,t)=>a.includes(e.name)?t:-1)).filter((e=>-1!==e)));const m="selectedItems",f=await s({type:"multiselect",name:m,message:i,choices:l,initial:d,hint:"(Use space to select, enter to confirm)",validate:e=>!(0===e.length&&!c)||"Please select at least one item"});return c&&0===f[m].length?null:f[m]}};const B={command:"definition <subcommand>",describe:"Manage service definitions",builder:e=>e.command({command:"create",describe:"Create a new service definition",builder:e=>e.option("name",{describe:"Service definition name",type:"string"}).option("output",{describe:"Output file path",type:"string",alias:"o"}),handler:C}).command({command:"list",describe:"List service definitions",builder:e=>e.option("format",{describe:"Output format",type:"string",choices:["json","text","table"],default:"table"}),handler:U}).command({command:"show [n]",describe:"Show service definition details",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}).option("format",{describe:"Output format",type:"string",choices:["json","yaml"],default:"yaml"}),handler:R}).command({command:"edit [n]",describe:"Edit a service definition",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}),handler:H}).command({command:"delete [n]",describe:"Delete a service definition",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}).option("force",{describe:"Force deletion without confirmation",type:"boolean",default:!1,alias:"f"}),handler:z}).command({command:"validate [n]",describe:"Validate a service definition",builder:e=>e.positional("name",{describe:"Service definition name",type:"string",demandOption:!1}),handler:J}).demandCommand(1,"You need to specify a subcommand"),handler:()=>{}};async function C(e){try{await N(e);const t=T.getServiceDefinitionSchema(),i=await o({schema:t,format:"yaml"});let r;if(console.log("Result from fnetObjectFromSchema:",i),"string"==typeof i)try{r=(await import("yaml")).default.parse(i)}catch(e){console.warn(n.yellow(`Failed to parse YAML: ${e.message}`)),r={name:"service-"+Date.now()}}else r=i&&"object"==typeof i?i.data||i:{name:"service-"+Date.now()};console.log("Generated definition:",r);const a=e.name||(r&&r.name?r.name:"service-"+Date.now());if(A.serviceDefinitionExists(a)&&!e.force){const{confirmOverwrite:e}=await s({type:"confirm",name:"confirmOverwrite",message:`Service definition '${a}' already exists. Overwrite?`,initial:!1});if(!e)return void console.log(n.yellow("Operation cancelled."))}A.saveServiceDefinition(a,r)?(console.log(n.green(`Service definition '${a}' created successfully.`)),console.log(n.blue(`Location: ${A.getServiceDefinitionPath(a)}`))):console.error(n.red(`Failed to create service definition '${a}'.`))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function U(e){try{await N(e);const t=A.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));if("json"===e.format)console.log(JSON.stringify(t,null,2));else if("text"===e.format)t.forEach((e=>console.log(e)));else{console.log(n.bold("\nService Definitions:"));const e=(await Promise.resolve().then((function(){return Z}))).default,i=["NAME","BINARY","DESCRIPTION"],r=e.createTable(i,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});for(const e of t){const t=A.loadServiceDefinition(e);t&&r.push([n.white(e),n.cyan(t.binary||"undefined"),t.description||""])}console.log(r.toString()),console.log(`Total: ${t.length} definition(s)`)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function R(e){try{await N(e);if(!e.name){const t=A.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await I.promptForSelection({items:t,message:"Select a service definition to show:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}const t=A.loadServiceDefinition(e.name);if(t||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1)),"json"===e.format)console.log(JSON.stringify(t,null,2));else{const e=(await import("yaml")).default;console.log(e.stringify(t))}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function H(e){try{await N(e);if(!e.name){const t=A.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await I.promptForSelection({items:t,message:"Select a service definition to edit:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}const t=A.loadServiceDefinition(e.name);t||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1));const i=T.getServiceDefinitionSchema(),r=(await o({schema:i,ref:t,format:"yaml"})).data;A.saveServiceDefinition(e.name,r)?console.log(n.green(`Service definition '${e.name}' updated successfully.`)):console.error(n.red(`Failed to update service definition '${e.name}'.`))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function z(e){try{await N(e);if(!e.name){const t=A.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await I.promptForSelection({items:t,message:"Select a service definition to delete:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}if(A.serviceDefinitionExists(e.name)||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1)),!e.force){const{confirmDelete:t}=await s({type:"confirm",name:"confirmDelete",message:`Are you sure you want to delete service definition '${e.name}'?`,initial:!1});if(!t)return void console.log(n.yellow("Operation cancelled."))}A.deleteServiceDefinition(e.name)?console.log(n.green(`Service definition '${e.name}' deleted successfully.`)):console.error(n.red(`Failed to delete service definition '${e.name}'.`))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}async function J(e){try{await N(e);if(!e.name){const t=A.listServiceDefinitions();if(0===t.length)return void console.log(n.yellow("No service definitions found."));const i=await I.promptForSelection({items:t,message:"Select a service definition to validate:",allowAbort:!0});if(null===i)return void console.log(n.yellow("Operation cancelled."));e.name=i}const t=A.loadServiceDefinition(e.name);t||(console.error(n.red(`Service definition '${e.name}' not found.`)),process.exit(1));const i=A.validateServiceDefinition(t);i.valid?console.log(n.green(`Service definition '${e.name}' is valid.`)):(console.error(n.red(`Service definition '${e.name}' is invalid:`)),i.errors.forEach((e=>{console.error(n.red(`- ${e}`))})),process.exit(1))}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}const _={command:"register",describe:"Register a service definition as a system service",builder:e=>e.option("definition",{describe:"Service definition name",type:"string",demandOption:!0,alias:"d"}).option("start",{describe:"Start the service after registration",type:"boolean",default:!1}),handler:async e=>{try{await N(e);A.serviceDefinitionExists(e.definition)||(console.error(n.red(`Service definition '${e.definition}' not found.`)),process.exit(1)),console.log(n.blue(`Registering service from definition '${e.definition}'...`));const t=await A.registerService(e.definition);if(console.log(n.green(`Service '${t.name}' registered successfully.`)),e.start){console.log(n.blue(`Starting service '${t.name}'...`));const e=(await import("@fnet/service")).default;try{await e({action:"start",name:t.name}),console.log(n.green(`Service '${t.name}' started successfully.`));const i=A.loadServiceMetadata();i.services[t.name]&&(i.services[t.name].status="running",i.services[t.name].lastStarted=(new Date).toISOString(),A.saveServiceMetadata(i))}catch(e){console.error(n.red(`Failed to start service: ${e.message}`))}}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},W={command:"unregister",describe:"Unregister a service from the system",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}).option("keep-definition",{describe:"Keep the service definition",type:"boolean",default:!0}).option("force",{describe:"Force unregistration without confirmation",type:"boolean",default:!1,alias:"f"}),handler:async e=>{try{await N(e);const t=A.loadServiceMetadata();if(t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),!e.force){const{confirmUnregister:t}=await s({type:"confirm",name:"confirmUnregister",message:`Are you sure you want to unregister service '${e.name}'?`,initial:!1});if(!t)return void console.log(n.yellow("Operation cancelled."))}console.log(n.blue(`Unregistering service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=A.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);const s=!1!==o.system;try{await i({action:"stop",name:e.name,system:s}),console.log(n.blue(`Service '${e.name}' stopped.`))}catch(e){console.warn(n.yellow(`Warning: Failed to stop service: ${e.message}`))}if(await i({action:"unregister",name:e.name,system:s}),console.log(n.green(`Service '${e.name}' unregistered successfully.`)),delete t.services[e.name],A.saveServiceMetadata(t),!e.keepDefinition&&r&&A.serviceDefinitionExists(r)){A.deleteServiceDefinition(r)?console.log(n.green(`Service definition '${r}' deleted.`)):console.warn(n.yellow(`Warning: Failed to delete service definition '${r}'.`))}}catch(e){console.error(n.red(`Failed to unregister service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},L={command:"start",describe:"Start a registered service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}),handler:async e=>{try{await N(e);const t=A.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Starting service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=A.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);await i({action:"start",name:e.name,system:!1!==o.system}),console.log(n.green(`Service '${e.name}' started successfully.`)),t.services[e.name].status="running",t.services[e.name].lastStarted=(new Date).toISOString(),A.saveServiceMetadata(t)}catch(e){console.error(n.red(`Failed to start service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},Y={command:"stop",describe:"Stop a running service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}),handler:async e=>{try{await N(e);const t=A.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Stopping service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=A.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);await i({action:"stop",name:e.name,system:!1!==o.system}),console.log(n.green(`Service '${e.name}' stopped successfully.`)),t.services[e.name].status="stopped",t.services[e.name].lastStopped=(new Date).toISOString(),A.saveServiceMetadata(t)}catch(e){console.error(n.red(`Failed to stop service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},V={command:"restart",describe:"Restart a service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}),handler:async e=>{try{await N(e);const t=A.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Restarting service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{await i({action:"stop",name:e.name}),console.log(n.blue(`Service '${e.name}' stopped.`)),await i({action:"start",name:e.name}),console.log(n.green(`Service '${e.name}' restarted successfully.`)),t.services[e.name].status="running",t.services[e.name].lastRestarted=(new Date).toISOString(),A.saveServiceMetadata(t)}catch(e){console.error(n.red(`Failed to restart service: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},q={command:"status",describe:"Check the status of a service",builder:e=>e.option("name",{describe:"Service name",type:"string",demandOption:!0,alias:"n"}).option("format",{describe:"Output format",type:"string",choices:["json","text","table"],default:"table"}),handler:async e=>{try{await N(e);const t=A.loadServiceMetadata();t.services[e.name]||(console.error(n.red(`Service '${e.name}' not found in metadata.`)),process.exit(1)),console.log(n.blue(`Checking status of service '${e.name}'...`));const i=(await import("@fnet/service")).default;try{const r=t.services[e.name].definition,o=A.loadServiceDefinition(r);if(!o)throw new Error(`Service definition '${r}' not found`);const s=await i({action:"status",name:e.name,system:!1!==o.system});console.log(n.green(`Service '${e.name}' status: ${s}`)),t.services[e.name].status=s||"unknown",t.services[e.name].lastChecked=(new Date).toISOString(),A.saveServiceMetadata(t),"json"===e.format?console.log(JSON.stringify({name:e.name,status:s||"unknown",definition:t.services[e.name].definition,binary:t.services[e.name].binary},null,2)):"text"===e.format?(console.log(`Name: ${e.name}`),console.log(`Status: ${s||"unknown"}`),console.log(`Definition: ${t.services[e.name].definition}`),console.log(`Binary: ${t.services[e.name].binary}`)):(console.log(n.bold("\nService Status:")),console.log(n.bold("─".repeat(50))),console.log(`${n.bold("Name:")} ${e.name}`),console.log(`${n.bold("Status:")} ${function(e){switch(e){case"running":return n.green;case"stopped":return n.yellow;case"failed":return n.red;default:return n.gray}}(s)(s||"unknown")}`),console.log(`${n.bold("Definition:")} ${t.services[e.name].definition}`),console.log(`${n.bold("Binary:")} ${t.services[e.name].binary}`),console.log(n.bold("─".repeat(50))))}catch(e){console.error(n.red(`Failed to check service status: ${e.message}`)),process.exit(1)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}};function K(e,t={}){const i={chars:{top:"─","top-mid":"─","top-left":" ","top-right":" ",bottom:"─","bottom-mid":"─","bottom-left":" ","bottom-right":" ",left:" ","left-mid":" ",mid:"─","mid-mid":"─",right:" ","right-mid":" ",middle:" "},style:{head:[],border:[],compact:!0},wordWrap:!0,...t,head:e.map((e=>n.bold(e)))};return new d(i)}function G(e,t,n={}){const i=K(e,n);return Array.isArray(t)&&t.forEach((e=>{i.push(e)})),i.toString()}function X(e){switch(e){case"running":return n.green;case"stopped":return n.yellow;case"failed":return n.red;case"registered":return n.blue;default:return n.gray}}var Q={createTable:K,createTableWithData:G,getStatusColor:X},Z=Object.freeze({__proto__:null,createTable:K,createTableWithData:G,default:Q,getStatusColor:X});const ee={command:"list",describe:"List all registered services",builder:e=>e.option("binary",{describe:"Filter by binary name",type:"string",alias:"b"}).option("status",{describe:"Filter by status",type:"string",choices:["running","stopped","failed","unknown"],alias:"s"}).option("format",{describe:"Output format",type:"string",choices:["json","text","table"],default:"table"}),handler:async e=>{try{await N(e);const t=A.loadServiceMetadata();let i=Object.entries(t.services).map((([e,t])=>({name:e,...t})));if(e.binary&&(i=i.filter((t=>t.binary===e.binary))),e.status&&(i=i.filter((t=>t.status===e.status))),0===i.length)return void console.log(n.yellow("No services found."));if("json"===e.format)console.log(JSON.stringify(i,null,2));else if("text"===e.format)i.forEach((e=>{console.log(`${e.name} (${e.status||"unknown"})`)}));else{const e=["NAME","STATUS","BINARY","DEFINITION"],t=Q.createTable(e,{chars:{mid:"","mid-mid":"","left-mid":"","right-mid":""}});i.forEach((e=>{const i=Q.getStatusColor(e.status);t.push([n.white(e.name),i(e.status||"unknown"),n.cyan(e.binary),e.definition])})),console.log(n.bold("\nRegistered Services:")),console.log(t.toString()),console.log(`Total: ${i.length} service(s)`)}}catch(e){console.error(n.red(`Error: ${e.message}`)),process.exit(1)}}},te=m(import.meta.url),{version:ne}=te("../../package.json");e(t(process.argv)).scriptName("fservice").usage("Usage: $0 <command> [options]").version(ne).command(B).command(_).command(W).command(L).command(Y).command(V).command(q).command(ee).demandCommand(1,"You need to specify a command").strict().help().alias("h","help").alias("v","version").fail(((e,t,i)=>{t?(console.error(n.red(`Error: ${t.message}`)),console.error(t)):console.error(n.red(`Error: ${e}`)),console.error(n.yellow("\nUsage:"),i.help()),process.exit(1)})).parse();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fnet/cli",
3
- "version": "0.131.2",
3
+ "version": "0.132.0",
4
4
  "files": [
5
5
  "dist",
6
6
  "template"
@@ -46,7 +46,11 @@ async function buildOutput(name, config) {
46
46
  entrypoints: config.entrypoints || [`./src/${name}/index.js`],
47
47
  outdir: outdir,
48
48
  format: config.format || 'esm',
49
- target: config.target || "browser",
49
+ {% if atom.doc.features.runtime.target === 'bun' %}
50
+ target: "bun",
51
+ {% else %}
52
+ target: config.target || "browser",
53
+ {% endif %}
50
54
  minify: config.minify !== undefined ? config.minify : false,
51
55
  sourcemap: config.sourcemap || 'external',
52
56
  splitting: true,
@@ -86,12 +86,9 @@
86
86
  ,"cli:mcp:inspect:dev": "bunx @modelcontextprotocol/inspector bun {{atom.doc.features.cli.node_options}} {{atom.doc.features.cli.input.file}} --cli-mode=mcp"
87
87
  {% endif %}
88
88
  {% endif %}
89
- ,"cli:compile": "fbin compile {{atom.doc.features.cli.output.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}}"
90
- ,"cli:compile:dev": "fbin compile {{atom.doc.features.cli.input.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}}"
89
+ ,"cli:compile": "fbin compile {{atom.doc.features.cli.output.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
90
+ ,"cli:compile:dev": "fbin compile {{atom.doc.features.cli.input.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
91
91
  ,"cli:install": "fbin install ./.bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
92
-
93
- ,"compile": "fbin compile {{atom.doc.features.cli.output.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}}"
94
- ,"install-bin": "fbin install ./.bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
95
92
  {% endif %}
96
93
 
97
94
  {% if atom.doc.features.app.enabled %}
@@ -65,7 +65,11 @@ export default function Block(context){
65
65
  {% else %}
66
66
  {# EXISTING: Normal function/method call (no 'new') #}
67
67
  {% if context.lib.type==='atom'%}
68
- const lib=LIBRARY;
68
+ {% if context.transform.libExp %}
69
+ const lib={{context.transform.libExp}};
70
+ {% else %}
71
+ const lib=LIBRARY;
72
+ {% endif %}
69
73
  {% elseif context.lib.type==='subworkflow' %}
70
74
  const lib={{context.lib.codeKey}};
71
75
  {% elseif target.atom.protocol==='use:' %}
@@ -11,7 +11,11 @@
11
11
  import { {{ context.transform.import | safe }} as LIBRARY } from "{{context.lib.atom.relativePath}}";
12
12
  {% elseif context.transform.import %}
13
13
  {# EXISTING: import pattern (e.g., import: npm:lodash, call: cloneDeep) #}
14
- import { {{ context.transform.call | safe }} as LIBRARY } from "{{context.lib.atom.relativePath}}";
14
+ {% if context.transform.libExp %}
15
+ import { default as LIBRARY } from "{{context.lib.atom.relativePath}}";
16
+ {% else %}
17
+ import { {{ context.transform.call | safe }} as LIBRARY } from "{{context.lib.atom.relativePath}}";
18
+ {% endif %}
15
19
  {% else %}
16
20
  {# EXISTING: default import #}
17
21
  import { default as LIBRARY } from "{{context.lib.atom.relativePath}}";
@@ -19,7 +23,11 @@
19
23
  {% else %}
20
24
  {% if context.transform.from and context.transform.import %}
21
25
  {# NEW: from + import pattern for non-relative paths #}
22
- import { {{ context.transform.import | safe }} as LIBRARY } from "../../libs/{{context.lib.atom.id or context.lib.atom.name}}";
26
+ {% if context.transform.libExp %}
27
+ import { default as LIBRARY } from "../../libs/{{context.lib.atom.id or context.lib.atom.name}}";
28
+ {% else %}
29
+ import { {{ context.transform.import | safe }} as LIBRARY } from "../../libs/{{context.lib.atom.id or context.lib.atom.name}}";
30
+ {% endif %}
23
31
  {% elseif context.transform.import %}
24
32
  {# EXISTING: import pattern for non-relative paths #}
25
33
  import { {{ context.transform.call | safe }} as LIBRARY } from "../../libs/{{context.lib.atom.id or context.lib.atom.name}}";
@@ -86,12 +86,9 @@
86
86
  ,"cli:mcp:inspect:dev": "bunx @modelcontextprotocol/inspector bun {{atom.doc.features.cli.node_options}} {{atom.doc.features.cli.input.file}} --cli-mode=mcp"
87
87
  {% endif %}
88
88
  {% endif %}
89
- ,"cli:compile": "fbin compile {{atom.doc.features.cli.output.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}}"
90
- ,"cli:compile:dev": "fbin compile {{atom.doc.features.cli.input.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}}"
89
+ ,"cli:compile": "fbin compile {{atom.doc.features.cli.output.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
90
+ ,"cli:compile:dev": "fbin compile {{atom.doc.features.cli.input.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
91
91
  ,"cli:install": "fbin install ./.bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
92
-
93
- ,"compile": "fbin compile {{atom.doc.features.cli.output.file}} -o .bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}}"
94
- ,"install-bin": "fbin install ./.bin/{{atom.doc['npm::bin'] or atom.doc['name'] or atom['id']}} --yes"
95
92
  {% endif %}
96
93
 
97
94
  {% if atom.doc.features.app.enabled %}