bailian-cli 0.1.2-beta.0 → 1.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/bailian.mjs CHANGED
@@ -1,376 +1,221 @@
1
1
  #!/usr/bin/env node
2
- import{createRequire as En}from"node:module";var On=Object.create;var{getPrototypeOf:cn,defineProperty:le,getOwnPropertyNames:Cn}=Object;var Ln=Object.prototype.hasOwnProperty;var ne=(e,t,n)=>{n=e!=null?On(cn(e)):{};let i=t||!e||!e.__esModule?le(n,"default",{value:e,enumerable:!0}):n;for(let $ of Cn(e))if(!Ln.call(i,$))le(i,$,{get:()=>e[$],enumerable:!0});return i};var Yt=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Vn=(e,t)=>{for(var n in t)le(e,n,{get:t[n],enumerable:!0,configurable:!0,set:(i)=>t[n]=()=>i})};var Ot=(e,t)=>()=>(e&&(t=e(e=0)),t);var ke=En(import.meta.url);var bt=Yt((ky,ft)=>{var xt={to(e,t){if(!t)return`\x1B[${e+1}G`;return`\x1B[${t+1};${e+1}H`},move(e,t){let n="";if(e<0)n+=`\x1B[${-e}D`;else if(e>0)n+=`\x1B[${e}C`;if(t<0)n+=`\x1B[${-t}A`;else if(t>0)n+=`\x1B[${t}B`;return n},up:(e=1)=>`\x1B[${e}A`,down:(e=1)=>`\x1B[${e}B`,forward:(e=1)=>`\x1B[${e}C`,backward:(e=1)=>`\x1B[${e}D`,nextLine:(e=1)=>"\x1B[E".repeat(e),prevLine:(e=1)=>"\x1B[F".repeat(e),left:"\x1B[G",hide:"\x1B[?25l",show:"\x1B[?25h",save:"\x1B7",restore:"\x1B8"},_i={up:(e=1)=>"\x1B[S".repeat(e),down:(e=1)=>"\x1B[T".repeat(e)},mi={screen:"\x1B[2J",up:(e=1)=>"\x1B[1J".repeat(e),down:(e=1)=>"\x1B[J".repeat(e),line:"\x1B[2K",lineEnd:"\x1B[K",lineStart:"\x1B[1K",lines(e){let t="";for(let n=0;n<e;n++)t+=this.line+(n<e-1?xt.up():"");if(e)t+=xt.left;return t}};ft.exports={cursor:xt,scroll:_i,erase:mi,beep:"\x07"}});var ht=Yt((qy,wt)=>{var Ve=process||{},gt=Ve.argv||[],Le=Ve.env||{},xi=!(!!Le.NO_COLOR||gt.includes("--no-color"))&&(!!Le.FORCE_COLOR||gt.includes("--color")||Ve.platform==="win32"||(Ve.stdout||{}).isTTY&&Le.TERM!=="dumb"||!!Le.CI),bi=(e,t,n=e)=>(i)=>{let $=""+i,p=$.indexOf(t,e.length);return~p?e+wi($,t,n,p)+t:e+$+t},wi=(e,t,n,i)=>{let $="",p=0;do $+=e.substring(p,i)+n,p=i+t.length,i=e.indexOf(t,p);while(~i);return $+e.substring(p)},er=(e=xi)=>{let t=e?bi:()=>String;return{isColorSupported:e,reset:t("\x1B[0m","\x1B[0m"),bold:t("\x1B[1m","\x1B[22m","\x1B[22m\x1B[1m"),dim:t("\x1B[2m","\x1B[22m","\x1B[22m\x1B[2m"),italic:t("\x1B[3m","\x1B[23m"),underline:t("\x1B[4m","\x1B[24m"),inverse:t("\x1B[7m","\x1B[27m"),hidden:t("\x1B[8m","\x1B[28m"),strikethrough:t("\x1B[9m","\x1B[29m"),black:t("\x1B[30m","\x1B[39m"),red:t("\x1B[31m","\x1B[39m"),green:t("\x1B[32m","\x1B[39m"),yellow:t("\x1B[33m","\x1B[39m"),blue:t("\x1B[34m","\x1B[39m"),magenta:t("\x1B[35m","\x1B[39m"),cyan:t("\x1B[36m","\x1B[39m"),white:t("\x1B[37m","\x1B[39m"),gray:t("\x1B[90m","\x1B[39m"),bgBlack:t("\x1B[40m","\x1B[49m"),bgRed:t("\x1B[41m","\x1B[49m"),bgGreen:t("\x1B[42m","\x1B[49m"),bgYellow:t("\x1B[43m","\x1B[49m"),bgBlue:t("\x1B[44m","\x1B[49m"),bgMagenta:t("\x1B[45m","\x1B[49m"),bgCyan:t("\x1B[46m","\x1B[49m"),bgWhite:t("\x1B[47m","\x1B[49m"),blackBright:t("\x1B[90m","\x1B[39m"),redBright:t("\x1B[91m","\x1B[39m"),greenBright:t("\x1B[92m","\x1B[39m"),yellowBright:t("\x1B[93m","\x1B[39m"),blueBright:t("\x1B[94m","\x1B[39m"),magentaBright:t("\x1B[95m","\x1B[39m"),cyanBright:t("\x1B[96m","\x1B[39m"),whiteBright:t("\x1B[97m","\x1B[39m"),bgBlackBright:t("\x1B[100m","\x1B[49m"),bgRedBright:t("\x1B[101m","\x1B[49m"),bgGreenBright:t("\x1B[102m","\x1B[49m"),bgYellowBright:t("\x1B[103m","\x1B[49m"),bgBlueBright:t("\x1B[104m","\x1B[49m"),bgMagentaBright:t("\x1B[105m","\x1B[49m"),bgCyanBright:t("\x1B[106m","\x1B[49m"),bgWhiteBright:t("\x1B[107m","\x1B[49m")}};wt.exports=er();wt.exports.createColors=er});import{stdin as Ar,stdout as ur}from"node:process";import*as we from"node:readline";import tr from"node:readline";import{WriteStream as hi}from"node:tty";function Ai({onlyFirst:e=!1}={}){let t=["[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?(?:\\u0007|\\u001B\\u005C|\\u009C))","(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-nq-uy=><~]))"].join("|");return new RegExp(t,e?void 0:"g")}function Sr(e){if(typeof e!="string")throw TypeError(`Expected a \`string\`, got \`${typeof e}\``);return e.replace(ui,"")}function kr(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,"default")?e.default:e}function ze(e,t={}){if(typeof e!="string"||e.length===0||(t={ambiguousIsNarrow:!0,...t},e=Sr(e),e.length===0))return 0;e=e.replace(oi()," ");let n=t.ambiguousIsNarrow?1:2,i=0;for(let $ of e){let p=$.codePointAt(0);if(p<=31||p>=127&&p<=159||p>=768&&p<=879)continue;switch(ki.eastAsianWidth($)){case"F":case"W":i+=2;break;case"A":i+=n;break;default:i+=1}}return i}function Ni(){let e=new Map;for(let[t,n]of Object.entries(C)){for(let[i,$]of Object.entries(n))C[i]={open:`\x1B[${$[0]}m`,close:`\x1B[${$[1]}m`},n[i]=C[i],e.set($[0],$[1]);Object.defineProperty(C,t,{value:n,enumerable:!1})}return Object.defineProperty(C,"codes",{value:e,enumerable:!1}),C.color.close="\x1B[39m",C.bgColor.close="\x1B[49m",C.color.ansi=rr(),C.color.ansi256=nr(),C.color.ansi16m=ir(),C.bgColor.ansi=rr(At),C.bgColor.ansi256=nr(At),C.bgColor.ansi16m=ir(At),Object.defineProperties(C,{rgbToAnsi256:{value:(t,n,i)=>t===n&&n===i?t<8?16:t>248?231:Math.round((t-8)/247*24)+232:16+36*Math.round(t/255*5)+6*Math.round(n/255*5)+Math.round(i/255*5),enumerable:!1},hexToRgb:{value:(t)=>{let n=/[a-f\d]{6}|[a-f\d]{3}/i.exec(t.toString(16));if(!n)return[0,0,0];let[i]=n;i.length===3&&(i=[...i].map((p)=>p+p).join(""));let $=Number.parseInt(i,16);return[$>>16&255,$>>8&255,$&255]},enumerable:!1},hexToAnsi256:{value:(t)=>C.rgbToAnsi256(...C.hexToRgb(t)),enumerable:!1},ansi256ToAnsi:{value:(t)=>{if(t<8)return 30+t;if(t<16)return 90+(t-8);let n,i,$;if(t>=232)n=((t-232)*10+8)/255,i=n,$=n;else{t-=16;let y=t%36;n=Math.floor(t/36)/5,i=Math.floor(y/6)/5,$=y%6/5}let p=Math.max(n,i,$)*2;if(p===0)return 30;let r=30+(Math.round($)<<2|Math.round(i)<<1|Math.round(n));return p===2&&(r+=60),r},enumerable:!1},rgbToAnsi:{value:(t,n,i)=>C.ansi256ToAnsi(C.rgbToAnsi256(t,n,i)),enumerable:!1},hexToAnsi:{value:(t)=>C.ansi256ToAnsi(C.hexToAnsi256(t)),enumerable:!1}}),C}function yr(e,t,n){return String(e).normalize().replace(/\r\n/g,`
2
+
3
+ import{BailianError as e,DOCS_HOSTS as t,ExitCode as n,GLOBAL_OPTIONS as r,McpClient as i,appCompletionEndpoint as a,chatEndpoint as o,clearApiKey as s,defineCommand as c,detectOutputFormat as l,formatOutput as u,generateFilename as d,generateToolSchema as f,getConfigDir as p,getConfigPath as m,imageEndpoint as h,imageSyncEndpoint as g,isInteractive as _,isLocalFile as v,loadApiKeyFromConfig as y,loadConfig as b,maskToken as x,mcpWebSearchEndpoint as S,memoryAddEndpoint as ee,memoryListEndpoint as te,memoryNodeEndpoint as C,memorySearchEndpoint as ne,parseSSE as re,profileSchemaEndpoint as ie,readConfigFile as w,request as ae,requestJson as T,resolveCredential as E,resolveFileUrl as D,resolveOutputDir as O,signRequest as oe,speechRecognizeEndpoint as se,speechSynthesizeEndpoint as ce,stripUndefined as le,taskEndpoint as k,trackingHeaders as ue,uploadFile as de,userProfileEndpoint as fe,videoGenerateEndpoint as pe,writeConfigFile as me}from"bailian-cli-core";import A,{stdin as he,stdout as ge}from"node:process";import*as _e from"node:readline";import ve from"node:readline";import{WriteStream as ye}from"node:tty";import{createWriteStream as be,existsSync as xe,mkdirSync as Se,readFileSync as Ce,unlinkSync as we,writeFileSync as Te}from"fs";import{dirname as Ee,extname as De,join as j}from"path";import{execSync as Oe}from"child_process";import{homedir as ke}from"os";var Ae=Object.create,je=Object.defineProperty,Me=Object.getOwnPropertyDescriptor,Ne=Object.getOwnPropertyNames,Pe=Object.getPrototypeOf,Fe=Object.prototype.hasOwnProperty,Ie=(e,t)=>()=>(e&&(t=e(e=0)),t),Le=(e,t)=>()=>(t||(e((t={exports:{}}).exports,t),e=null),t.exports),Re=(e,t)=>{let n={};for(var r in e)je(n,r,{get:e[r],enumerable:!0});return t||je(n,Symbol.toStringTag,{value:`Module`}),n},ze=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var i=Ne(t),a=0,o=i.length,s;a<o;a++)s=i[a],!Fe.call(e,s)&&s!==n&&je(e,s,{get:(e=>t[e]).bind(null,s),enumerable:!(r=Me(t,s))||r.enumerable});return e},Be=(e,t,n)=>(n=e==null?{}:Ae(Pe(e)),ze(t||!e||!e.__esModule?je(n,`default`,{value:e,enumerable:!0}):n,e));function Ve(e){return e.replace(/-([a-z])/g,(e,t)=>t.toUpperCase())}function He(e){let t=e.flag.match(/^--([a-z][a-z0-9-]*)/i);return t?Ve(t[1]):null}function Ue(e){return e.type===`boolean`?!0:e.type===`string`||e.type===`number`||e.type===`array`?!1:!e.flag.includes(`<`)&&!e.flag.includes(`[`)}function We(e){let t=new Set,n=new Set,r=new Set;for(let i of e){let e=He(i);e&&(Ue(i)?t.add(e):i.type===`number`?n.add(e):i.type===`array`&&r.add(e))}return{booleans:t,numbers:n,arrays:r}}function Ge(e,t=[]){let n=We(t),r=[],i=0;for(;i<e.length;){let t=e[i];if(t===`--`)break;if(t.startsWith(`--`)){let e=t.indexOf(`=`),r=Ve(e===-1?t.slice(2):t.slice(2,e));!n.booleans.has(r)&&e===-1?i+=2:i+=1;continue}if(t.startsWith(`-`)){i++;continue}r.push(t),i++}return r}function Ke(t,r){let i=We(r),a={quiet:!1,verbose:!1,noColor:!1,yes:!1,dryRun:!1,help:!1,nonInteractive:!1,async:!1},o=0;for(;o<t.length;){let r=t[o];if(r===`--help`||r===`-h`){a.help=!0,o++;continue}if(r===`--`)break;if(r.startsWith(`--`)){let s=r.indexOf(`=`),c,l;s===-1?c=r.slice(2):(c=r.slice(2,s),l=r.slice(s+1));let u=Ve(c);if(i.booleans.has(u)){a[u]=!0,o++;continue}if(l===void 0&&(o++,l=t[o]),l===void 0)throw new e(`Flag --${c} requires a value.`,n.USAGE);if(i.arrays.has(u)){let e=a[u];e?e.push(l):a[u]=[l]}else if(i.numbers.has(u)){let t=Number(l);if(!Number.isFinite(t))throw new e(`Flag --${c} requires a finite number.`,n.USAGE);a[u]=t}else a[u]=l}o++}return a}function M(e,t){process.stdout.write(u(e,t)+`
4
+ `)}function N(e){process.stdout.write(e+`
5
+ `)}var qe=Le(((e,t)=>{let n={to(e,t){return t?`[${t+1};${e+1}H`:`[${e+1}G`},move(e,t){let n=``;return e<0?n+=`[${-e}D`:e>0&&(n+=`[${e}C`),t<0?n+=`[${-t}A`:t>0&&(n+=`[${t}B`),n},up:(e=1)=>`[${e}A`,down:(e=1)=>`[${e}B`,forward:(e=1)=>`[${e}C`,backward:(e=1)=>`[${e}D`,nextLine:(e=1)=>`\x1B[E`.repeat(e),prevLine:(e=1)=>`\x1B[F`.repeat(e),left:`\x1B[G`,hide:`\x1B[?25l`,show:`\x1B[?25h`,save:`\x1B7`,restore:`\x1B8`};t.exports={cursor:n,scroll:{up:(e=1)=>`\x1B[S`.repeat(e),down:(e=1)=>`\x1B[T`.repeat(e)},erase:{screen:`\x1B[2J`,up:(e=1)=>`\x1B[1J`.repeat(e),down:(e=1)=>`\x1B[J`.repeat(e),line:`\x1B[2K`,lineEnd:`\x1B[K`,lineStart:`\x1B[1K`,lines(e){let t=``;for(let r=0;r<e;r++)t+=this.line+(r<e-1?n.up():``);return e&&(t+=n.left),t}},beep:`\x07`}})),Je=Le(((e,t)=>{let n=process||{},r=n.argv||[],i=n.env||{},a=!(i.NO_COLOR||r.includes(`--no-color`))&&(!!i.FORCE_COLOR||r.includes(`--color`)||n.platform===`win32`||(n.stdout||{}).isTTY&&i.TERM!==`dumb`||!!i.CI),o=(e,t,n=e)=>r=>{let i=``+r,a=i.indexOf(t,e.length);return~a?e+s(i,t,n,a)+t:e+i+t},s=(e,t,n,r)=>{let i=``,a=0;do i+=e.substring(a,r)+n,a=r+t.length,r=e.indexOf(t,a);while(~r);return i+e.substring(a)},c=(e=a)=>{let t=e?o:()=>String;return{isColorSupported:e,reset:t(`\x1B[0m`,`\x1B[0m`),bold:t(`\x1B[1m`,`\x1B[22m`,`\x1B[22m\x1B[1m`),dim:t(`\x1B[2m`,`\x1B[22m`,`\x1B[22m\x1B[2m`),italic:t(`\x1B[3m`,`\x1B[23m`),underline:t(`\x1B[4m`,`\x1B[24m`),inverse:t(`\x1B[7m`,`\x1B[27m`),hidden:t(`\x1B[8m`,`\x1B[28m`),strikethrough:t(`\x1B[9m`,`\x1B[29m`),black:t(`\x1B[30m`,`\x1B[39m`),red:t(`\x1B[31m`,`\x1B[39m`),green:t(`\x1B[32m`,`\x1B[39m`),yellow:t(`\x1B[33m`,`\x1B[39m`),blue:t(`\x1B[34m`,`\x1B[39m`),magenta:t(`\x1B[35m`,`\x1B[39m`),cyan:t(`\x1B[36m`,`\x1B[39m`),white:t(`\x1B[37m`,`\x1B[39m`),gray:t(`\x1B[90m`,`\x1B[39m`),bgBlack:t(`\x1B[40m`,`\x1B[49m`),bgRed:t(`\x1B[41m`,`\x1B[49m`),bgGreen:t(`\x1B[42m`,`\x1B[49m`),bgYellow:t(`\x1B[43m`,`\x1B[49m`),bgBlue:t(`\x1B[44m`,`\x1B[49m`),bgMagenta:t(`\x1B[45m`,`\x1B[49m`),bgCyan:t(`\x1B[46m`,`\x1B[49m`),bgWhite:t(`\x1B[47m`,`\x1B[49m`),blackBright:t(`\x1B[90m`,`\x1B[39m`),redBright:t(`\x1B[91m`,`\x1B[39m`),greenBright:t(`\x1B[92m`,`\x1B[39m`),yellowBright:t(`\x1B[93m`,`\x1B[39m`),blueBright:t(`\x1B[94m`,`\x1B[39m`),magentaBright:t(`\x1B[95m`,`\x1B[39m`),cyanBright:t(`\x1B[96m`,`\x1B[39m`),whiteBright:t(`\x1B[97m`,`\x1B[39m`),bgBlackBright:t(`\x1B[100m`,`\x1B[49m`),bgRedBright:t(`\x1B[101m`,`\x1B[49m`),bgGreenBright:t(`\x1B[102m`,`\x1B[49m`),bgYellowBright:t(`\x1B[103m`,`\x1B[49m`),bgBlueBright:t(`\x1B[104m`,`\x1B[49m`),bgMagentaBright:t(`\x1B[105m`,`\x1B[49m`),bgCyanBright:t(`\x1B[106m`,`\x1B[49m`),bgWhiteBright:t(`\x1B[107m`,`\x1B[49m`)}};t.exports=c(),t.exports.createColors=c}));function Ye({onlyFirst:e=!1}={}){let t=[`[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?(?:\\u0007|\\u001B\\u005C|\\u009C))`,`(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-nq-uy=><~]))`].join(`|`);return new RegExp(t,e?void 0:`g`)}function Xe(e){if(typeof e!=`string`)throw TypeError(`Expected a \`string\`, got \`${typeof e}\``);return e.replace(at,``)}function Ze(e){return e&&e.__esModule&&Object.prototype.hasOwnProperty.call(e,`default`)?e.default:e}function Qe(e,t={}){if(typeof e!=`string`||e.length===0||(t={ambiguousIsNarrow:!0,...t},e=Xe(e),e.length===0))return 0;e=e.replace(ut(),` `);let n=t.ambiguousIsNarrow?1:2,r=0;for(let t of e){let e=t.codePointAt(0);if(!(e<=31||e>=127&&e<=159||e>=768&&e<=879))switch(ct.eastAsianWidth(t)){case`F`:case`W`:r+=2;break;case`A`:r+=n;break;default:r+=1}}return r}function $e(){let e=new Map;for(let[t,n]of Object.entries(I)){for(let[t,r]of Object.entries(n))I[t]={open:`\x1B[${r[0]}m`,close:`\x1B[${r[1]}m`},n[t]=I[t],e.set(r[0],r[1]);Object.defineProperty(I,t,{value:n,enumerable:!1})}return Object.defineProperty(I,`codes`,{value:e,enumerable:!1}),I.color.close=`\x1B[39m`,I.bgColor.close=`\x1B[49m`,I.color.ansi=ft(),I.color.ansi256=pt(),I.color.ansi16m=mt(),I.bgColor.ansi=ft(dt),I.bgColor.ansi256=pt(dt),I.bgColor.ansi16m=mt(dt),Object.defineProperties(I,{rgbToAnsi256:{value:(e,t,n)=>e===t&&t===n?e<8?16:e>248?231:Math.round((e-8)/247*24)+232:16+36*Math.round(e/255*5)+6*Math.round(t/255*5)+Math.round(n/255*5),enumerable:!1},hexToRgb:{value:e=>{let t=/[a-f\d]{6}|[a-f\d]{3}/i.exec(e.toString(16));if(!t)return[0,0,0];let[n]=t;n.length===3&&(n=[...n].map(e=>e+e).join(``));let r=Number.parseInt(n,16);return[r>>16&255,r>>8&255,r&255]},enumerable:!1},hexToAnsi256:{value:e=>I.rgbToAnsi256(...I.hexToRgb(e)),enumerable:!1},ansi256ToAnsi:{value:e=>{if(e<8)return 30+e;if(e<16)return 90+(e-8);let t,n,r;if(e>=232)t=((e-232)*10+8)/255,n=t,r=t;else{e-=16;let i=e%36;t=Math.floor(e/36)/5,n=Math.floor(i/6)/5,r=i%6/5}let i=Math.max(t,n,r)*2;if(i===0)return 30;let a=30+(Math.round(r)<<2|Math.round(n)<<1|Math.round(t));return i===2&&(a+=60),a},enumerable:!1},rgbToAnsi:{value:(e,t,n)=>I.ansi256ToAnsi(I.rgbToAnsi256(e,t,n)),enumerable:!1},hexToAnsi:{value:e=>I.ansi256ToAnsi(I.hexToAnsi256(e)),enumerable:!1}}),I}function et(e,t,n){return String(e).normalize().replace(/\r\n/g,`
3
6
  `).split(`
4
- `).map((i)=>Ti(i,t,n)).join(`
5
- `)}function Hi(e,t){if(e===t)return;let n=e.split(`
6
- `),i=t.split(`
7
- `),$=[];for(let p=0;p<Math.max(n.length,i.length);p++)n[p]!==i[p]&&$.push(p);return $}function ve(e){return e===Kr}function Ee(e,t){e.isTTY&&e.setRawMode(t)}class he{constructor({render:e,input:t=Ar,output:n=ur,...i},$=!0){re(this,"input"),re(this,"output"),re(this,"rl"),re(this,"opts"),re(this,"_track",!1),re(this,"_render"),re(this,"_cursor",0),re(this,"state","initial"),re(this,"value"),re(this,"error",""),re(this,"subscribers",new Map),re(this,"_prevFrame",""),this.opts=i,this.onKeypress=this.onKeypress.bind(this),this.close=this.close.bind(this),this.render=this.render.bind(this),this._render=e.bind(this),this._track=$,this.input=t,this.output=n}prompt(){let e=new hi(0);return e._write=(t,n,i)=>{this._track&&(this.value=this.rl.line.replace(/\t/g,""),this._cursor=this.rl.cursor,this.emit("value",this.value)),i()},this.input.pipe(e),this.rl=tr.createInterface({input:this.input,output:e,tabSize:2,prompt:"",escapeCodeTimeout:50}),tr.emitKeypressEvents(this.input,this.rl),this.rl.prompt(),this.opts.initialValue!==void 0&&this._track&&this.rl.write(this.opts.initialValue),this.input.on("keypress",this.onKeypress),Ee(this.input,!0),this.output.on("resize",this.render),this.render(),new Promise((t,n)=>{this.once("submit",()=>{this.output.write(F.cursor.show),this.output.off("resize",this.render),Ee(this.input,!1),t(this.value)}),this.once("cancel",()=>{this.output.write(F.cursor.show),this.output.off("resize",this.render),Ee(this.input,!1),t(Kr)})})}on(e,t){let n=this.subscribers.get(e)??[];n.push({cb:t}),this.subscribers.set(e,n)}once(e,t){let n=this.subscribers.get(e)??[];n.push({cb:t,once:!0}),this.subscribers.set(e,n)}emit(e,...t){let n=this.subscribers.get(e)??[],i=[];for(let $ of n)$.cb(...t),$.once&&i.push(()=>n.splice(n.indexOf($),1));for(let $ of i)$()}unsubscribe(){this.subscribers.clear()}onKeypress(e,t){if(this.state==="error"&&(this.state="active"),t?.name&&!this._track&&_r.has(t.name)&&this.emit("cursor",_r.get(t.name)),t?.name&&Zi.has(t.name)&&this.emit("cursor",t.name),e&&(e.toLowerCase()==="y"||e.toLowerCase()==="n")&&this.emit("confirm",e.toLowerCase()==="y"),e==="\t"&&this.opts.placeholder&&(this.value||(this.rl.write(this.opts.placeholder),this.emit("value",this.opts.placeholder))),e&&this.emit("key",e.toLowerCase()),t?.name==="return"){if(this.opts.validate){let n=this.opts.validate(this.value);n&&(this.error=n,this.state="error",this.rl.write(this.value))}this.state!=="error"&&(this.state="submit")}e==="\x03"&&(this.state="cancel"),(this.state==="submit"||this.state==="cancel")&&this.emit("finalize"),this.render(),(this.state==="submit"||this.state==="cancel")&&this.close()}close(){this.input.unpipe(),this.input.removeListener("keypress",this.onKeypress),this.output.write(`
8
- `),Ee(this.input,!1),this.rl.close(),this.emit(`${this.state}`,this.value),this.unsubscribe()}restoreCursor(){let e=yr(this._prevFrame,process.stdout.columns,{hard:!0}).split(`
9
- `).length-1;this.output.write(F.cursor.move(-999,e*-1))}render(){let e=yr(this._render(this)??"",process.stdout.columns,{hard:!0});if(e!==this._prevFrame){if(this.state==="initial")this.output.write(F.cursor.hide);else{let t=Hi(this._prevFrame,e);if(this.restoreCursor(),t&&t?.length===1){let n=t[0];this.output.write(F.cursor.move(0,n)),this.output.write(F.erase.lines(1));let i=e.split(`
10
- `);this.output.write(i[n]),this._prevFrame=e,this.output.write(F.cursor.move(0,i.length-n-1));return}else if(t&&t?.length>1){let n=t[0];this.output.write(F.cursor.move(0,n)),this.output.write(F.erase.down());let i=e.split(`
11
- `).slice(n);this.output.write(i.join(`
12
- `)),this._prevFrame=e;return}this.output.write(F.erase.down())}this.output.write(e),this.state==="initial"&&(this.state="active"),this._prevFrame=e}}}function jr({input:e=Ar,output:t=ur,overwrite:n=!0,hideCursor:i=!0}={}){let $=we.createInterface({input:e,output:t,prompt:"",tabSize:1});we.emitKeypressEvents(e,$),e.isTTY&&e.setRawMode(!0);let p=(r,{name:y})=>{if(String(r)==="\x03"){i&&t.write(F.cursor.show),process.exit(0);return}if(!n)return;we.moveCursor(t,y==="return"?0:-1,y==="return"?-1:0,()=>{we.clearLine(t,1,()=>{e.once("keypress",p)})})};return i&&t.write(F.cursor.hide),e.once("keypress",p),()=>{e.off("keypress",p),i&&t.write(F.cursor.show),e.isTTY&&!di&&e.setRawMode(!1),$.terminal=!1,$.close()}}var F,qe,ui,qr,Si,ki,qi=function(){return/\uD83C\uDFF4\uDB40\uDC67\uDB40\uDC62(?:\uDB40\uDC77\uDB40\uDC6C\uDB40\uDC73|\uDB40\uDC73\uDB40\uDC63\uDB40\uDC74|\uDB40\uDC65\uDB40\uDC6E\uDB40\uDC67)\uDB40\uDC7F|(?:\uD83E\uDDD1\uD83C\uDFFF\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFF\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB-\uDFFE])|(?:\uD83E\uDDD1\uD83C\uDFFE\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFE\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB-\uDFFD\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFD\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFD\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFC\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFC\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB\uDFFD-\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFB\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFB\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFC-\uDFFF])|\uD83D\uDC68(?:\uD83C\uDFFB(?:\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF]))|\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFC-\uDFFF])|[\u2695\u2696\u2708]\uFE0F|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))?|(?:\uD83C[\uDFFC-\uDFFF])\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF]))|\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83D\uDC68|(?:\uD83D[\uDC68\uDC69])\u200D(?:\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67]))|\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFE])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFD\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB\uDFFD-\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])\uFE0F|\u200D(?:(?:\uD83D[\uDC68\uDC69])\u200D(?:\uD83D[\uDC66\uDC67])|\uD83D[\uDC66\uDC67])|\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC)?|(?:\uD83D\uDC69(?:\uD83C\uDFFB\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69])|(?:\uD83C[\uDFFC-\uDFFF])\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69]))|\uD83E\uDDD1(?:\uD83C[\uDFFB-\uDFFF])\u200D\uD83E\uDD1D\u200D\uD83E\uDDD1)(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC69\u200D\uD83D\uDC69\u200D(?:\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67]))|\uD83D\uDC69(?:\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFB\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))|\uD83E\uDDD1(?:\u200D(?:\uD83E\uDD1D\u200D\uD83E\uDDD1|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFB\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))|\uD83D\uDC69\u200D\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC69\u200D\uD83D\uDC69\u200D(?:\uD83D[\uDC66\uDC67])|\uD83D\uDC69\u200D\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67])|(?:\uD83D\uDC41\uFE0F\u200D\uD83D\uDDE8|\uD83E\uDDD1(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\uD83C\uDFFB\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])|\uD83D\uDC69(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\uD83C\uDFFB\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])|\uD83D\uDE36\u200D\uD83C\uDF2B|\uD83C\uDFF3\uFE0F\u200D\u26A7|\uD83D\uDC3B\u200D\u2744|(?:(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC6F|\uD83E[\uDD3C\uDDDE\uDDDF])\u200D[\u2640\u2642]|(?:\u26F9|\uD83C[\uDFCB\uDFCC]|\uD83D\uDD75)(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])\u200D[\u2640\u2642]|\uD83C\uDFF4\u200D\u2620|(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])\u200D[\u2640\u2642]|[\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u2328\u23CF\u23ED-\u23EF\u23F1\u23F2\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB\u25FC\u2600-\u2604\u260E\u2611\u2618\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u265F\u2660\u2663\u2665\u2666\u2668\u267B\u267E\u2692\u2694-\u2697\u2699\u269B\u269C\u26A0\u26A7\u26B0\u26B1\u26C8\u26CF\u26D1\u26D3\u26E9\u26F0\u26F1\u26F4\u26F7\u26F8\u2702\u2708\u2709\u270F\u2712\u2714\u2716\u271D\u2721\u2733\u2734\u2744\u2747\u2763\u27A1\u2934\u2935\u2B05-\u2B07\u3030\u303D\u3297\u3299]|\uD83C[\uDD70\uDD71\uDD7E\uDD7F\uDE02\uDE37\uDF21\uDF24-\uDF2C\uDF36\uDF7D\uDF96\uDF97\uDF99-\uDF9B\uDF9E\uDF9F\uDFCD\uDFCE\uDFD4-\uDFDF\uDFF5\uDFF7]|\uD83D[\uDC3F\uDCFD\uDD49\uDD4A\uDD6F\uDD70\uDD73\uDD76-\uDD79\uDD87\uDD8A-\uDD8D\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA\uDECB\uDECD-\uDECF\uDEE0-\uDEE5\uDEE9\uDEF0\uDEF3])\uFE0F|\uD83C\uDFF3\uFE0F\u200D\uD83C\uDF08|\uD83D\uDC69\u200D\uD83D\uDC67|\uD83D\uDC69\u200D\uD83D\uDC66|\uD83D\uDE35\u200D\uD83D\uDCAB|\uD83D\uDE2E\u200D\uD83D\uDCA8|\uD83D\uDC15\u200D\uD83E\uDDBA|\uD83E\uDDD1(?:\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC|\uD83C\uDFFB)?|\uD83D\uDC69(?:\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC|\uD83C\uDFFB)?|\uD83C\uDDFD\uD83C\uDDF0|\uD83C\uDDF6\uD83C\uDDE6|\uD83C\uDDF4\uD83C\uDDF2|\uD83D\uDC08\u200D\u2B1B|\u2764\uFE0F\u200D(?:\uD83D\uDD25|\uD83E\uDE79)|\uD83D\uDC41\uFE0F|\uD83C\uDFF3\uFE0F|\uD83C\uDDFF(?:\uD83C[\uDDE6\uDDF2\uDDFC])|\uD83C\uDDFE(?:\uD83C[\uDDEA\uDDF9])|\uD83C\uDDFC(?:\uD83C[\uDDEB\uDDF8])|\uD83C\uDDFB(?:\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDEE\uDDF3\uDDFA])|\uD83C\uDDFA(?:\uD83C[\uDDE6\uDDEC\uDDF2\uDDF3\uDDF8\uDDFE\uDDFF])|\uD83C\uDDF9(?:\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDED\uDDEF-\uDDF4\uDDF7\uDDF9\uDDFB\uDDFC\uDDFF])|\uD83C\uDDF8(?:\uD83C[\uDDE6-\uDDEA\uDDEC-\uDDF4\uDDF7-\uDDF9\uDDFB\uDDFD-\uDDFF])|\uD83C\uDDF7(?:\uD83C[\uDDEA\uDDF4\uDDF8\uDDFA\uDDFC])|\uD83C\uDDF5(?:\uD83C[\uDDE6\uDDEA-\uDDED\uDDF0-\uDDF3\uDDF7-\uDDF9\uDDFC\uDDFE])|\uD83C\uDDF3(?:\uD83C[\uDDE6\uDDE8\uDDEA-\uDDEC\uDDEE\uDDF1\uDDF4\uDDF5\uDDF7\uDDFA\uDDFF])|\uD83C\uDDF2(?:\uD83C[\uDDE6\uDDE8-\uDDED\uDDF0-\uDDFF])|\uD83C\uDDF1(?:\uD83C[\uDDE6-\uDDE8\uDDEE\uDDF0\uDDF7-\uDDFB\uDDFE])|\uD83C\uDDF0(?:\uD83C[\uDDEA\uDDEC-\uDDEE\uDDF2\uDDF3\uDDF5\uDDF7\uDDFC\uDDFE\uDDFF])|\uD83C\uDDEF(?:\uD83C[\uDDEA\uDDF2\uDDF4\uDDF5])|\uD83C\uDDEE(?:\uD83C[\uDDE8-\uDDEA\uDDF1-\uDDF4\uDDF6-\uDDF9])|\uD83C\uDDED(?:\uD83C[\uDDF0\uDDF2\uDDF3\uDDF7\uDDF9\uDDFA])|\uD83C\uDDEC(?:\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEE\uDDF1-\uDDF3\uDDF5-\uDDFA\uDDFC\uDDFE])|\uD83C\uDDEB(?:\uD83C[\uDDEE-\uDDF0\uDDF2\uDDF4\uDDF7])|\uD83C\uDDEA(?:\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDED\uDDF7-\uDDFA])|\uD83C\uDDE9(?:\uD83C[\uDDEA\uDDEC\uDDEF\uDDF0\uDDF2\uDDF4\uDDFF])|\uD83C\uDDE8(?:\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDEE\uDDF0-\uDDF5\uDDF7\uDDFA-\uDDFF])|\uD83C\uDDE7(?:\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEF\uDDF1-\uDDF4\uDDF6-\uDDF9\uDDFB\uDDFC\uDDFE\uDDFF])|\uD83C\uDDE6(?:\uD83C[\uDDE8-\uDDEC\uDDEE\uDDF1\uDDF2\uDDF4\uDDF6-\uDDFA\uDDFC\uDDFD\uDDFF])|[#\*0-9]\uFE0F\u20E3|\u2764\uFE0F|(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])|(?:\u26F9|\uD83C[\uDFCB\uDFCC]|\uD83D\uDD75)(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])|\uD83C\uDFF4|(?:[\u270A\u270B]|\uD83C[\uDF85\uDFC2\uDFC7]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66\uDC67\uDC6B-\uDC6D\uDC72\uDC74-\uDC76\uDC78\uDC7C\uDC83\uDC85\uDC8F\uDC91\uDCAA\uDD7A\uDD95\uDD96\uDE4C\uDE4F\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1C\uDD1E\uDD1F\uDD30-\uDD34\uDD36\uDD77\uDDB5\uDDB6\uDDBB\uDDD2\uDDD3\uDDD5])(?:\uD83C[\uDFFB-\uDFFF])|(?:[\u261D\u270C\u270D]|\uD83D[\uDD74\uDD90])(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])|[\u270A\u270B]|\uD83C[\uDF85\uDFC2\uDFC7]|\uD83D[\uDC08\uDC15\uDC3B\uDC42\uDC43\uDC46-\uDC50\uDC66\uDC67\uDC6B-\uDC6D\uDC72\uDC74-\uDC76\uDC78\uDC7C\uDC83\uDC85\uDC8F\uDC91\uDCAA\uDD7A\uDD95\uDD96\uDE2E\uDE35\uDE36\uDE4C\uDE4F\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1C\uDD1E\uDD1F\uDD30-\uDD34\uDD36\uDD77\uDDB5\uDDB6\uDDBB\uDDD2\uDDD3\uDDD5]|\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD]|\uD83D\uDC6F|\uD83E[\uDD3C\uDDDE\uDDDF]|[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF84\uDF86-\uDF93\uDFA0-\uDFC1\uDFC5\uDFC6\uDFC8\uDFC9\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC07\uDC09-\uDC14\uDC16-\uDC3A\uDC3C-\uDC3E\uDC40\uDC44\uDC45\uDC51-\uDC65\uDC6A\uDC79-\uDC7B\uDC7D-\uDC80\uDC84\uDC88-\uDC8E\uDC90\uDC92-\uDCA9\uDCAB-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDDA4\uDDFB-\uDE2D\uDE2F-\uDE34\uDE37-\uDE44\uDE48-\uDE4A\uDE80-\uDEA2\uDEA4-\uDEB3\uDEB7-\uDEBF\uDEC1-\uDEC5\uDED0-\uDED2\uDED5-\uDED7\uDEEB\uDEEC\uDEF4-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0D\uDD0E\uDD10-\uDD17\uDD1D\uDD20-\uDD25\uDD27-\uDD2F\uDD3A\uDD3F-\uDD45\uDD47-\uDD76\uDD78\uDD7A-\uDDB4\uDDB7\uDDBA\uDDBC-\uDDCB\uDDD0\uDDE0-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6]|(?:[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u270A\u270B\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF93\uDFA0-\uDFCA\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF4\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC3E\uDC40\uDC42-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDD7A\uDD95\uDD96\uDDA4\uDDFB-\uDE4F\uDE80-\uDEC5\uDECC\uDED0-\uDED2\uDED5-\uDED7\uDEEB\uDEEC\uDEF4-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDD78\uDD7A-\uDDCB\uDDCD-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6])|(?:[#\*0-9\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2604\u260E\u2611\u2614\u2615\u2618\u261D\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u2648-\u2653\u265F\u2660\u2663\u2665\u2666\u2668\u267B\u267E\u267F\u2692-\u2697\u2699\u269B\u269C\u26A0\u26A1\u26A7\u26AA\u26AB\u26B0\u26B1\u26BD\u26BE\u26C4\u26C5\u26C8\u26CE\u26CF\u26D1\u26D3\u26D4\u26E9\u26EA\u26F0-\u26F5\u26F7-\u26FA\u26FD\u2702\u2705\u2708-\u270D\u270F\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753-\u2755\u2757\u2763\u2764\u2795-\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]|\uD83C[\uDC04\uDCCF\uDD70\uDD71\uDD7E\uDD7F\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE02\uDE1A\uDE2F\uDE32-\uDE3A\uDE50\uDE51\uDF00-\uDF21\uDF24-\uDF93\uDF96\uDF97\uDF99-\uDF9B\uDF9E-\uDFF0\uDFF3-\uDFF5\uDFF7-\uDFFF]|\uD83D[\uDC00-\uDCFD\uDCFF-\uDD3D\uDD49-\uDD4E\uDD50-\uDD67\uDD6F\uDD70\uDD73-\uDD7A\uDD87\uDD8A-\uDD8D\uDD90\uDD95\uDD96\uDDA4\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA-\uDE4F\uDE80-\uDEC5\uDECB-\uDED2\uDED5-\uDED7\uDEE0-\uDEE5\uDEE9\uDEEB\uDEEC\uDEF0\uDEF3-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDD78\uDD7A-\uDDCB\uDDCD-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6])\uFE0F|(?:[\u261D\u26F9\u270A-\u270D]|\uD83C[\uDF85\uDFC2-\uDFC4\uDFC7\uDFCA-\uDFCC]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66-\uDC78\uDC7C\uDC81-\uDC83\uDC85-\uDC87\uDC8F\uDC91\uDCAA\uDD74\uDD75\uDD7A\uDD90\uDD95\uDD96\uDE45-\uDE47\uDE4B-\uDE4F\uDEA3\uDEB4-\uDEB6\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1F\uDD26\uDD30-\uDD39\uDD3C-\uDD3E\uDD77\uDDB5\uDDB6\uDDB8\uDDB9\uDDBB\uDDCD-\uDDCF\uDDD1-\uDDDD])/g},oi,At=10,rr=(e=0)=>(t)=>`\x1B[${t+e}m`,nr=(e=0)=>(t)=>`\x1B[${38+e};5;${t}m`,ir=(e=0)=>(t,n,i)=>`\x1B[${38+e};2;${t};${n};${i}m`,C,Gi,Ki,Bi,Ie,ji=39,St="\x07",or="[",Ri="]",Gr="m",kt,$r=(e)=>`${Ie.values().next().value}${or}${e}${Gr}`,pr=(e)=>`${Ie.values().next().value}${kt}${e}${St}`,Ji=(e)=>e.split(" ").map((t)=>ze(t)),ut=(e,t,n)=>{let i=[...t],$=!1,p=!1,r=ze(Sr(e[e.length-1]));for(let[y,m]of i.entries()){let x=ze(m);if(r+x<=n?e[e.length-1]+=m:(e.push(m),r=0),Ie.has(m)&&($=!0,p=i.slice(y+1).join("").startsWith(kt)),$){p?m===St&&($=!1,p=!1):m===Gr&&($=!1);continue}r+=x,r===n&&y<i.length-1&&(e.push(""),r=0)}!r&&e[e.length-1].length>0&&e.length>1&&(e[e.length-2]+=e.pop())},Wi=(e)=>{let t=e.split(" "),n=t.length;for(;n>0&&!(ze(t[n-1])>0);)n--;return n===t.length?e:t.slice(0,n).join(" ")+t.slice(n).join("")},Ti=(e,t,n={})=>{if(n.trim!==!1&&e.trim()==="")return"";let i="",$,p,r=Ji(e),y=[""];for(let[x,b]of e.split(" ").entries()){n.trim!==!1&&(y[y.length-1]=y[y.length-1].trimStart());let w=ze(y[y.length-1]);if(x!==0&&(w>=t&&(n.wordWrap===!1||n.trim===!1)&&(y.push(""),w=0),(w>0||n.trim===!1)&&(y[y.length-1]+=" ",w++)),n.hard&&r[x]>t){let S=t-w,q=1+Math.floor((r[x]-S-1)/t);Math.floor((r[x]-1)/t)<q&&y.push(""),ut(y,b,t);continue}if(w+r[x]>t&&w>0&&r[x]>0){if(n.wordWrap===!1&&w<t){ut(y,b,t);continue}y.push("")}if(w+r[x]>t&&n.wordWrap===!1){ut(y,b,t);continue}y[y.length-1]+=b}n.trim!==!1&&(y=y.map((x)=>Wi(x)));let m=[...y.join(`
13
- `)];for(let[x,b]of m.entries()){if(i+=b,Ie.has(b)){let{groups:S}=new RegExp(`(?:\\${or}(?<code>\\d+)m|\\${kt}(?<uri>.*)${St})`).exec(m.slice(x).join(""))||{groups:{}};if(S.code!==void 0){let q=Number.parseFloat(S.code);$=q===ji?void 0:q}else S.uri!==void 0&&(p=S.uri.length===0?void 0:S.uri)}let w=Bi.codes.get(Number($));m[x+1]===`
14
- `?(p&&(i+=pr("")),$&&w&&(i+=$r(w))):b===`
15
- `&&($&&w&&(i+=$r($)),p&&(i+=pr(p)))}return i},Mi,Qi=(e,t,n)=>(t in e)?Mi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,re=(e,t,n)=>(Qi(e,typeof t!="symbol"?t+"":t,n),n),Kr,_r,Zi,qt,zi,Xi=(e,t,n)=>(t in e)?zi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,mr=(e,t,n)=>(Xi(e,typeof t!="symbol"?t+"":t,n),n),ot,Pi,Yi=(e,t,n)=>(t in e)?Pi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,xr=(e,t,n)=>(Yi(e,typeof t!="symbol"?t+"":t,n),n),Nr,Oi,ci=(e,t,n)=>(t in e)?Oi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,br=(e,t,n)=>(ci(e,typeof t!="symbol"?t+"":t,n),n),Gt,Ci,Li=(e,t,n)=>(t in e)?Ci(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,wr=(e,t,n)=>(Li(e,typeof t!="symbol"?t+"":t,n),n),Br,Vi,Ei=(e,t,n)=>(t in e)?Vi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,hr=(e,t,n)=>(Ei(e,typeof t!="symbol"?t+"":t,n),n),Kt,Ii,vi=(e,t,n)=>(t in e)?Ii(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,Ui=(e,t,n)=>(vi(e,typeof t!="symbol"?t+"":t,n),n),Nt,di;var Bt=Ot(()=>{F=ne(bt(),1),qe=ne(ht(),1);ui=Ai();qr={exports:{}};(function(e){var t={};e.exports=t,t.eastAsianWidth=function(i){var $=i.charCodeAt(0),p=i.length==2?i.charCodeAt(1):0,r=$;return 55296<=$&&$<=56319&&56320<=p&&p<=57343&&($&=1023,p&=1023,r=$<<10|p,r+=65536),r==12288||65281<=r&&r<=65376||65504<=r&&r<=65510?"F":r==8361||65377<=r&&r<=65470||65474<=r&&r<=65479||65482<=r&&r<=65487||65490<=r&&r<=65495||65498<=r&&r<=65500||65512<=r&&r<=65518?"H":4352<=r&&r<=4447||4515<=r&&r<=4519||4602<=r&&r<=4607||9001<=r&&r<=9002||11904<=r&&r<=11929||11931<=r&&r<=12019||12032<=r&&r<=12245||12272<=r&&r<=12283||12289<=r&&r<=12350||12353<=r&&r<=12438||12441<=r&&r<=12543||12549<=r&&r<=12589||12593<=r&&r<=12686||12688<=r&&r<=12730||12736<=r&&r<=12771||12784<=r&&r<=12830||12832<=r&&r<=12871||12880<=r&&r<=13054||13056<=r&&r<=19903||19968<=r&&r<=42124||42128<=r&&r<=42182||43360<=r&&r<=43388||44032<=r&&r<=55203||55216<=r&&r<=55238||55243<=r&&r<=55291||63744<=r&&r<=64255||65040<=r&&r<=65049||65072<=r&&r<=65106||65108<=r&&r<=65126||65128<=r&&r<=65131||110592<=r&&r<=110593||127488<=r&&r<=127490||127504<=r&&r<=127546||127552<=r&&r<=127560||127568<=r&&r<=127569||131072<=r&&r<=194367||177984<=r&&r<=196605||196608<=r&&r<=262141?"W":32<=r&&r<=126||162<=r&&r<=163||165<=r&&r<=166||r==172||r==175||10214<=r&&r<=10221||10629<=r&&r<=10630?"Na":r==161||r==164||167<=r&&r<=168||r==170||173<=r&&r<=174||176<=r&&r<=180||182<=r&&r<=186||188<=r&&r<=191||r==198||r==208||215<=r&&r<=216||222<=r&&r<=225||r==230||232<=r&&r<=234||236<=r&&r<=237||r==240||242<=r&&r<=243||247<=r&&r<=250||r==252||r==254||r==257||r==273||r==275||r==283||294<=r&&r<=295||r==299||305<=r&&r<=307||r==312||319<=r&&r<=322||r==324||328<=r&&r<=331||r==333||338<=r&&r<=339||358<=r&&r<=359||r==363||r==462||r==464||r==466||r==468||r==470||r==472||r==474||r==476||r==593||r==609||r==708||r==711||713<=r&&r<=715||r==717||r==720||728<=r&&r<=731||r==733||r==735||768<=r&&r<=879||913<=r&&r<=929||931<=r&&r<=937||945<=r&&r<=961||963<=r&&r<=969||r==1025||1040<=r&&r<=1103||r==1105||r==8208||8211<=r&&r<=8214||8216<=r&&r<=8217||8220<=r&&r<=8221||8224<=r&&r<=8226||8228<=r&&r<=8231||r==8240||8242<=r&&r<=8243||r==8245||r==8251||r==8254||r==8308||r==8319||8321<=r&&r<=8324||r==8364||r==8451||r==8453||r==8457||r==8467||r==8470||8481<=r&&r<=8482||r==8486||r==8491||8531<=r&&r<=8532||8539<=r&&r<=8542||8544<=r&&r<=8555||8560<=r&&r<=8569||r==8585||8592<=r&&r<=8601||8632<=r&&r<=8633||r==8658||r==8660||r==8679||r==8704||8706<=r&&r<=8707||8711<=r&&r<=8712||r==8715||r==8719||r==8721||r==8725||r==8730||8733<=r&&r<=8736||r==8739||r==8741||8743<=r&&r<=8748||r==8750||8756<=r&&r<=8759||8764<=r&&r<=8765||r==8776||r==8780||r==8786||8800<=r&&r<=8801||8804<=r&&r<=8807||8810<=r&&r<=8811||8814<=r&&r<=8815||8834<=r&&r<=8835||8838<=r&&r<=8839||r==8853||r==8857||r==8869||r==8895||r==8978||9312<=r&&r<=9449||9451<=r&&r<=9547||9552<=r&&r<=9587||9600<=r&&r<=9615||9618<=r&&r<=9621||9632<=r&&r<=9633||9635<=r&&r<=9641||9650<=r&&r<=9651||9654<=r&&r<=9655||9660<=r&&r<=9661||9664<=r&&r<=9665||9670<=r&&r<=9672||r==9675||9678<=r&&r<=9681||9698<=r&&r<=9701||r==9711||9733<=r&&r<=9734||r==9737||9742<=r&&r<=9743||9748<=r&&r<=9749||r==9756||r==9758||r==9792||r==9794||9824<=r&&r<=9825||9827<=r&&r<=9829||9831<=r&&r<=9834||9836<=r&&r<=9837||r==9839||9886<=r&&r<=9887||9918<=r&&r<=9919||9924<=r&&r<=9933||9935<=r&&r<=9953||r==9955||9960<=r&&r<=9983||r==10045||r==10071||10102<=r&&r<=10111||11093<=r&&r<=11097||12872<=r&&r<=12879||57344<=r&&r<=63743||65024<=r&&r<=65039||r==65533||127232<=r&&r<=127242||127248<=r&&r<=127277||127280<=r&&r<=127337||127344<=r&&r<=127386||917760<=r&&r<=917999||983040<=r&&r<=1048573||1048576<=r&&r<=1114109?"A":"N"},t.characterLength=function(i){var $=this.eastAsianWidth(i);return $=="F"||$=="W"||$=="A"?2:1};function n(i){return i.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]|[^\uD800-\uDFFF]/g)||[]}t.length=function(i){for(var $=n(i),p=0,r=0;r<$.length;r++)p=p+this.characterLength($[r]);return p},t.slice=function(i,$,p){textLen=t.length(i),$=$||0,p=p||1,$<0&&($=textLen+$),p<0&&(p=textLen+p);for(var r="",y=0,m=n(i),x=0;x<m.length;x++){var b=m[x],w=t.length(b);if(y>=$-(w==2?1:0))if(y+w<=p)r+=b;else break;y+=w}return r}})(qr);Si=qr.exports,ki=kr(Si),oi=kr(qi);C={modifier:{reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],overline:[53,55],inverse:[7,27],hidden:[8,28],strikethrough:[9,29]},color:{black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],blackBright:[90,39],gray:[90,39],grey:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39]},bgColor:{bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgBlackBright:[100,49],bgGray:[100,49],bgGrey:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]}};Object.keys(C.modifier);Gi=Object.keys(C.color),Ki=Object.keys(C.bgColor);[...Gi,...Ki];Bi=Ni(),Ie=new Set(["\x1B","›"]),kt=`${Ri}8;;`;Mi=Object.defineProperty;Kr=Symbol("clack:cancel");_r=new Map([["k","up"],["j","down"],["h","left"],["l","right"]]),Zi=new Set(["up","down","left","right","space","enter"]);qt=class qt extends he{get cursor(){return this.value?0:1}get _value(){return this.cursor===0}constructor(e){super(e,!1),this.value=!!e.initialValue,this.on("value",()=>{this.value=this._value}),this.on("confirm",(t)=>{this.output.write(F.cursor.move(0,-1)),this.value=t,this.state="submit",this.close()}),this.on("cursor",()=>{this.value=!this.value})}};zi=Object.defineProperty;ot=class ot extends he{constructor(e){super(e,!1),mr(this,"options"),mr(this,"cursor",0);let{options:t}=e;this.options=Object.entries(t).flatMap(([n,i])=>[{value:n,group:!0,label:n},...i.map(($)=>({...$,group:n}))]),this.value=[...e.initialValues??[]],this.cursor=Math.max(this.options.findIndex(({value:n})=>n===e.cursorAt),0),this.on("cursor",(n)=>{switch(n){case"left":case"up":this.cursor=this.cursor===0?this.options.length-1:this.cursor-1;break;case"down":case"right":this.cursor=this.cursor===this.options.length-1?0:this.cursor+1;break;case"space":this.toggleValue();break}})}getGroupItems(e){return this.options.filter((t)=>t.group===e)}isGroupSelected(e){return this.getGroupItems(e).every((t)=>this.value.includes(t.value))}toggleValue(){let e=this.options[this.cursor];if(e.group===!0){let t=e.value,n=this.getGroupItems(t);this.isGroupSelected(t)?this.value=this.value.filter((i)=>n.findIndex(($)=>$.value===i)===-1):this.value=[...this.value,...n.map((i)=>i.value)],this.value=Array.from(new Set(this.value))}else{let t=this.value.includes(e.value);this.value=t?this.value.filter((n)=>n!==e.value):[...this.value,e.value]}}};Pi=Object.defineProperty,Nr=class extends he{constructor(e){super(e,!1),xr(this,"options"),xr(this,"cursor",0),this.options=e.options,this.value=[...e.initialValues??[]],this.cursor=Math.max(this.options.findIndex(({value:t})=>t===e.cursorAt),0),this.on("key",(t)=>{t==="a"&&this.toggleAll()}),this.on("cursor",(t)=>{switch(t){case"left":case"up":this.cursor=this.cursor===0?this.options.length-1:this.cursor-1;break;case"down":case"right":this.cursor=this.cursor===this.options.length-1?0:this.cursor+1;break;case"space":this.toggleValue();break}})}get _value(){return this.options[this.cursor].value}toggleAll(){let e=this.value.length===this.options.length;this.value=e?[]:this.options.map((t)=>t.value)}toggleValue(){let e=this.value.includes(this._value);this.value=e?this.value.filter((t)=>t!==this._value):[...this.value,this._value]}},Oi=Object.defineProperty;Gt=class Gt extends he{constructor({mask:e,...t}){super(t),br(this,"valueWithCursor",""),br(this,"_mask","•"),this._mask=e??"•",this.on("finalize",()=>{this.valueWithCursor=this.masked}),this.on("value",()=>{if(this.cursor>=this.value.length)this.valueWithCursor=`${this.masked}${qe.default.inverse(qe.default.hidden("_"))}`;else{let n=this.masked.slice(0,this.cursor),i=this.masked.slice(this.cursor);this.valueWithCursor=`${n}${qe.default.inverse(i[0])}${i.slice(1)}`}})}get cursor(){return this._cursor}get masked(){return this.value.replaceAll(/./g,this._mask)}};Ci=Object.defineProperty,Br=class extends he{constructor(e){super(e,!1),wr(this,"options"),wr(this,"cursor",0),this.options=e.options,this.cursor=this.options.findIndex(({value:t})=>t===e.initialValue),this.cursor===-1&&(this.cursor=0),this.changeValue(),this.on("cursor",(t)=>{switch(t){case"left":case"up":this.cursor=this.cursor===0?this.options.length-1:this.cursor-1;break;case"down":case"right":this.cursor=this.cursor===this.options.length-1?0:this.cursor+1;break}this.changeValue()})}get _value(){return this.options[this.cursor]}changeValue(){this.value=this._value.value}},Vi=Object.defineProperty;Kt=class Kt extends he{constructor(e){super(e,!1),hr(this,"options"),hr(this,"cursor",0),this.options=e.options;let t=this.options.map(({value:[n]})=>n?.toLowerCase());this.cursor=Math.max(t.indexOf(e.initialValue),0),this.on("key",(n)=>{if(!t.includes(n))return;let i=this.options.find(({value:[$]})=>$?.toLowerCase()===n);i&&(this.value=i.value,this.state="submit",this.emit("submit"))})}};Ii=Object.defineProperty;Nt=class Nt extends he{constructor(e){super(e),Ui(this,"valueWithCursor",""),this.on("finalize",()=>{this.value||(this.value=e.defaultValue),this.valueWithCursor=this.value}),this.on("value",()=>{if(this.cursor>=this.value.length)this.valueWithCursor=`${this.value}${qe.default.inverse(qe.default.hidden("_"))}`;else{let t=this.value.slice(0,this.cursor),n=this.value.slice(this.cursor);this.valueWithCursor=`${t}${qe.default.inverse(n[0])}${n.slice(1)}`}})}get cursor(){return this._cursor}};di=globalThis.process.platform.startsWith("win")});var Pe={};Vn(Pe,{text:()=>i$,spinner:()=>u$,selectKey:()=>_$,select:()=>y$,password:()=>$$,outro:()=>A$,note:()=>b$,multiselect:()=>m$,log:()=>oe,isCancel:()=>ve,intro:()=>h$,groupMultiselect:()=>x$,group:()=>k$,confirm:()=>p$,cancel:()=>w$});import $e from"node:process";function si(){return $e.platform!=="win32"?$e.env.TERM!=="linux":Boolean($e.env.CI)||Boolean($e.env.WT_SESSION)||Boolean($e.env.TERMINUS_SUBLIME)||$e.env.ConEmuTask==="{cmd::Cmder}"||$e.env.TERM_PROGRAM==="Terminus-Sublime"||$e.env.TERM_PROGRAM==="vscode"||$e.env.TERM==="xterm-256color"||$e.env.TERM==="alacritty"||$e.env.TERMINAL_EMULATOR==="JetBrains-JediTerm"}function S$(){let e=["[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)","(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-nq-uy=><~]))"].join("|");return new RegExp(e,"g")}var _,We,Rt,v=(e,t)=>Rt?e:t,Fi,Jr,Wr,Ue,ai,R,D,Jt,Wt,Tt,Xe,Tr,Di,Rr,li,fi,gi,e$,t$,r$,n$,Ge=(e)=>{switch(e){case"initial":case"active":return _.default.cyan(Fi);case"cancel":return _.default.red(Jr);case"error":return _.default.yellow(Wr);case"submit":return _.default.green(Ue)}},i$=(e)=>new Nt({validate:e.validate,placeholder:e.placeholder,defaultValue:e.defaultValue,initialValue:e.initialValue,render(){let t=`${_.default.gray(R)}
16
- ${Ge(this.state)} ${e.message}
17
- `,n=e.placeholder?_.default.inverse(e.placeholder[0])+_.default.dim(e.placeholder.slice(1)):_.default.inverse(_.default.hidden("_")),i=this.value?this.valueWithCursor:n;switch(this.state){case"error":return`${t.trim()}
18
- ${_.default.yellow(R)} ${i}
19
- ${_.default.yellow(D)} ${_.default.yellow(this.error)}
20
- `;case"submit":return`${t}${_.default.gray(R)} ${_.default.dim(this.value||e.placeholder)}`;case"cancel":return`${t}${_.default.gray(R)} ${_.default.strikethrough(_.default.dim(this.value??""))}${this.value?.trim()?`
21
- `+_.default.gray(R):""}`;default:return`${t}${_.default.cyan(R)} ${i}
22
- ${_.default.cyan(D)}
23
- `}}}).prompt(),$$=(e)=>new Gt({validate:e.validate,mask:e.mask??Di,render(){let t=`${_.default.gray(R)}
24
- ${Ge(this.state)} ${e.message}
25
- `,n=this.valueWithCursor,i=this.masked;switch(this.state){case"error":return`${t.trim()}
26
- ${_.default.yellow(R)} ${i}
27
- ${_.default.yellow(D)} ${_.default.yellow(this.error)}
28
- `;case"submit":return`${t}${_.default.gray(R)} ${_.default.dim(i)}`;case"cancel":return`${t}${_.default.gray(R)} ${_.default.strikethrough(_.default.dim(i??""))}${i?`
29
- `+_.default.gray(R):""}`;default:return`${t}${_.default.cyan(R)} ${n}
30
- ${_.default.cyan(D)}
31
- `}}}).prompt(),p$=(e)=>{let t=e.active??"Yes",n=e.inactive??"No";return new qt({active:t,inactive:n,initialValue:e.initialValue??!0,render(){let i=`${_.default.gray(R)}
32
- ${Ge(this.state)} ${e.message}
33
- `,$=this.value?t:n;switch(this.state){case"submit":return`${i}${_.default.gray(R)} ${_.default.dim($)}`;case"cancel":return`${i}${_.default.gray(R)} ${_.default.strikethrough(_.default.dim($))}
34
- ${_.default.gray(R)}`;default:return`${i}${_.default.cyan(R)} ${this.value?`${_.default.green(Jt)} ${t}`:`${_.default.dim(Wt)} ${_.default.dim(t)}`} ${_.default.dim("/")} ${this.value?`${_.default.dim(Wt)} ${_.default.dim(n)}`:`${_.default.green(Jt)} ${n}`}
35
- ${_.default.cyan(D)}
36
- `}}}).prompt()},y$=(e)=>{let t=(i,$)=>{let p=i.label??String(i.value);return $==="active"?`${_.default.green(Jt)} ${p} ${i.hint?_.default.dim(`(${i.hint})`):""}`:$==="selected"?`${_.default.dim(p)}`:$==="cancelled"?`${_.default.strikethrough(_.default.dim(p))}`:`${_.default.dim(Wt)} ${_.default.dim(p)}`},n=0;return new Br({options:e.options,initialValue:e.initialValue,render(){let i=`${_.default.gray(R)}
37
- ${Ge(this.state)} ${e.message}
38
- `;switch(this.state){case"submit":return`${i}${_.default.gray(R)} ${t(this.options[this.cursor],"selected")}`;case"cancel":return`${i}${_.default.gray(R)} ${t(this.options[this.cursor],"cancelled")}
39
- ${_.default.gray(R)}`;default:{let $=e.maxItems===void 0?1/0:Math.max(e.maxItems,5);this.cursor>=n+$-3?n=Math.max(Math.min(this.cursor-$+3,this.options.length-$),0):this.cursor<n+2&&(n=Math.max(this.cursor-2,0));let p=$<this.options.length&&n>0,r=$<this.options.length&&n+$<this.options.length;return`${i}${_.default.cyan(R)} ${this.options.slice(n,n+$).map((y,m,x)=>m===0&&p?_.default.dim("..."):m===x.length-1&&r?_.default.dim("..."):t(y,m+n===this.cursor?"active":"inactive")).join(`
40
- ${_.default.cyan(R)} `)}
41
- ${_.default.cyan(D)}
42
- `}}}}).prompt()},_$=(e)=>{let t=(n,i="inactive")=>{let $=n.label??String(n.value);return i==="selected"?`${_.default.dim($)}`:i==="cancelled"?`${_.default.strikethrough(_.default.dim($))}`:i==="active"?`${_.default.bgCyan(_.default.gray(` ${n.value} `))} ${$} ${n.hint?_.default.dim(`(${n.hint})`):""}`:`${_.default.gray(_.default.bgWhite(_.default.inverse(` ${n.value} `)))} ${$} ${n.hint?_.default.dim(`(${n.hint})`):""}`};return new Kt({options:e.options,initialValue:e.initialValue,render(){let n=`${_.default.gray(R)}
43
- ${Ge(this.state)} ${e.message}
44
- `;switch(this.state){case"submit":return`${n}${_.default.gray(R)} ${t(this.options.find((i)=>i.value===this.value),"selected")}`;case"cancel":return`${n}${_.default.gray(R)} ${t(this.options[0],"cancelled")}
45
- ${_.default.gray(R)}`;default:return`${n}${_.default.cyan(R)} ${this.options.map((i,$)=>t(i,$===this.cursor?"active":"inactive")).join(`
46
- ${_.default.cyan(R)} `)}
47
- ${_.default.cyan(D)}
48
- `}}}).prompt()},m$=(e)=>{let t=(n,i)=>{let $=n.label??String(n.value);return i==="active"?`${_.default.cyan(Tt)} ${$} ${n.hint?_.default.dim(`(${n.hint})`):""}`:i==="selected"?`${_.default.green(Xe)} ${_.default.dim($)}`:i==="cancelled"?`${_.default.strikethrough(_.default.dim($))}`:i==="active-selected"?`${_.default.green(Xe)} ${$} ${n.hint?_.default.dim(`(${n.hint})`):""}`:i==="submitted"?`${_.default.dim($)}`:`${_.default.dim(Tr)} ${_.default.dim($)}`};return new Nr({options:e.options,initialValues:e.initialValues,required:e.required??!0,cursorAt:e.cursorAt,validate(n){if(this.required&&n.length===0)return`Please select at least one option.
49
- ${_.default.reset(_.default.dim(`Press ${_.default.gray(_.default.bgWhite(_.default.inverse(" space ")))} to select, ${_.default.gray(_.default.bgWhite(_.default.inverse(" enter ")))} to submit`))}`},render(){let n=`${_.default.gray(R)}
50
- ${Ge(this.state)} ${e.message}
51
- `;switch(this.state){case"submit":return`${n}${_.default.gray(R)} ${this.options.filter(({value:i})=>this.value.includes(i)).map((i)=>t(i,"submitted")).join(_.default.dim(", "))||_.default.dim("none")}`;case"cancel":{let i=this.options.filter(({value:$})=>this.value.includes($)).map(($)=>t($,"cancelled")).join(_.default.dim(", "));return`${n}${_.default.gray(R)} ${i.trim()?`${i}
52
- ${_.default.gray(R)}`:""}`}case"error":{let i=this.error.split(`
53
- `).map(($,p)=>p===0?`${_.default.yellow(D)} ${_.default.yellow($)}`:` ${$}`).join(`
54
- `);return n+_.default.yellow(R)+" "+this.options.map(($,p)=>{let r=this.value.includes($.value),y=p===this.cursor;return y&&r?t($,"active-selected"):r?t($,"selected"):t($,y?"active":"inactive")}).join(`
55
- ${_.default.yellow(R)} `)+`
56
- `+i+`
57
- `}default:return`${n}${_.default.cyan(R)} ${this.options.map((i,$)=>{let p=this.value.includes(i.value),r=$===this.cursor;return r&&p?t(i,"active-selected"):p?t(i,"selected"):t(i,r?"active":"inactive")}).join(`
58
- ${_.default.cyan(R)} `)}
59
- ${_.default.cyan(D)}
60
- `}}}).prompt()},x$=(e)=>{let t=(n,i,$=[])=>{let p=n.label??String(n.value),r=typeof n.group=="string",y=r&&($[$.indexOf(n)+1]??{group:!0}),m=r&&y.group===!0,x=r?`${m?D:R} `:"";return i==="active"?`${_.default.dim(x)}${_.default.cyan(Tt)} ${p} ${n.hint?_.default.dim(`(${n.hint})`):""}`:i==="group-active"?`${x}${_.default.cyan(Tt)} ${_.default.dim(p)}`:i==="group-active-selected"?`${x}${_.default.green(Xe)} ${_.default.dim(p)}`:i==="selected"?`${_.default.dim(x)}${_.default.green(Xe)} ${_.default.dim(p)}`:i==="cancelled"?`${_.default.strikethrough(_.default.dim(p))}`:i==="active-selected"?`${_.default.dim(x)}${_.default.green(Xe)} ${p} ${n.hint?_.default.dim(`(${n.hint})`):""}`:i==="submitted"?`${_.default.dim(p)}`:`${_.default.dim(x)}${_.default.dim(Tr)} ${_.default.dim(p)}`};return new ot({options:e.options,initialValues:e.initialValues,required:e.required??!0,cursorAt:e.cursorAt,validate(n){if(this.required&&n.length===0)return`Please select at least one option.
61
- ${_.default.reset(_.default.dim(`Press ${_.default.gray(_.default.bgWhite(_.default.inverse(" space ")))} to select, ${_.default.gray(_.default.bgWhite(_.default.inverse(" enter ")))} to submit`))}`},render(){let n=`${_.default.gray(R)}
62
- ${Ge(this.state)} ${e.message}
63
- `;switch(this.state){case"submit":return`${n}${_.default.gray(R)} ${this.options.filter(({value:i})=>this.value.includes(i)).map((i)=>t(i,"submitted")).join(_.default.dim(", "))}`;case"cancel":{let i=this.options.filter(({value:$})=>this.value.includes($)).map(($)=>t($,"cancelled")).join(_.default.dim(", "));return`${n}${_.default.gray(R)} ${i.trim()?`${i}
64
- ${_.default.gray(R)}`:""}`}case"error":{let i=this.error.split(`
65
- `).map(($,p)=>p===0?`${_.default.yellow(D)} ${_.default.yellow($)}`:` ${$}`).join(`
66
- `);return`${n}${_.default.yellow(R)} ${this.options.map(($,p,r)=>{let y=this.value.includes($.value)||$.group===!0&&this.isGroupSelected(`${$.value}`),m=p===this.cursor;return!m&&typeof $.group=="string"&&this.options[this.cursor].value===$.group?t($,y?"group-active-selected":"group-active",r):m&&y?t($,"active-selected",r):y?t($,"selected",r):t($,m?"active":"inactive",r)}).join(`
67
- ${_.default.yellow(R)} `)}
68
- ${i}
69
- `}default:return`${n}${_.default.cyan(R)} ${this.options.map((i,$,p)=>{let r=this.value.includes(i.value)||i.group===!0&&this.isGroupSelected(`${i.value}`),y=$===this.cursor;return!y&&typeof i.group=="string"&&this.options[this.cursor].value===i.group?t(i,r?"group-active-selected":"group-active",p):y&&r?t(i,"active-selected",p):r?t(i,"selected",p):t(i,y?"active":"inactive",p)}).join(`
70
- ${_.default.cyan(R)} `)}
71
- ${_.default.cyan(D)}
72
- `}}}).prompt()},jt=(e)=>e.replace(S$(),""),b$=(e="",t="")=>{let n=`
7
+ `).map(e=>At(e,t,n)).join(`
8
+ `)}function tt(e,t){if(e===t)return;let n=e.split(`
9
+ `),r=t.split(`
10
+ `),i=[];for(let e=0;e<Math.max(n.length,r.length);e++)n[e]!==r[e]&&i.push(e);return i}function nt(e){return e===Nt}function rt(e,t){e.isTTY&&e.setRawMode(t)}function it({input:e=he,output:t=ge,overwrite:n=!0,hideCursor:r=!0}={}){let i=_e.createInterface({input:e,output:t,prompt:``,tabSize:1});_e.emitKeypressEvents(e,i),e.isTTY&&e.setRawMode(!0);let a=(i,{name:o})=>{if(String(i)===``){r&&t.write(P.cursor.show),process.exit(0);return}if(!n)return;let s=o===`return`?0:-1,c=o===`return`?-1:0;_e.moveCursor(t,s,c,()=>{_e.clearLine(t,1,()=>{e.once(`keypress`,a)})})};return r&&t.write(P.cursor.hide),e.once(`keypress`,a),()=>{e.off(`keypress`,a),r&&t.write(P.cursor.show),e.isTTY&&!cn&&e.setRawMode(!1),i.terminal=!1,i.close()}}var P,F,at,ot,st,ct,lt,ut,dt,ft,pt,mt,I,ht,gt,_t,vt,yt,bt,xt,St,Ct,wt,Tt,Et,Dt,Ot,kt,At,jt,Mt,L,Nt,Pt,Ft,R,It,Lt,Rt,zt,Bt,Vt,Ht,Ut,Wt,Gt,Kt,qt,Jt,Yt,Xt,Zt,Qt,$t,en,tn,nn,rn,an,on,sn,cn,ln=Ie((()=>{P=qe(),F=Be(Je(),1),at=Ye(),ot={exports:{}},(function(e){var t={};e.exports=t,t.eastAsianWidth=function(e){var t=e.charCodeAt(0),n=e.length==2?e.charCodeAt(1):0,r=t;return 55296<=t&&t<=56319&&56320<=n&&n<=57343&&(t&=1023,n&=1023,r=t<<10|n,r+=65536),r==12288||65281<=r&&r<=65376||65504<=r&&r<=65510?`F`:r==8361||65377<=r&&r<=65470||65474<=r&&r<=65479||65482<=r&&r<=65487||65490<=r&&r<=65495||65498<=r&&r<=65500||65512<=r&&r<=65518?`H`:4352<=r&&r<=4447||4515<=r&&r<=4519||4602<=r&&r<=4607||9001<=r&&r<=9002||11904<=r&&r<=11929||11931<=r&&r<=12019||12032<=r&&r<=12245||12272<=r&&r<=12283||12289<=r&&r<=12350||12353<=r&&r<=12438||12441<=r&&r<=12543||12549<=r&&r<=12589||12593<=r&&r<=12686||12688<=r&&r<=12730||12736<=r&&r<=12771||12784<=r&&r<=12830||12832<=r&&r<=12871||12880<=r&&r<=13054||13056<=r&&r<=19903||19968<=r&&r<=42124||42128<=r&&r<=42182||43360<=r&&r<=43388||44032<=r&&r<=55203||55216<=r&&r<=55238||55243<=r&&r<=55291||63744<=r&&r<=64255||65040<=r&&r<=65049||65072<=r&&r<=65106||65108<=r&&r<=65126||65128<=r&&r<=65131||110592<=r&&r<=110593||127488<=r&&r<=127490||127504<=r&&r<=127546||127552<=r&&r<=127560||127568<=r&&r<=127569||131072<=r&&r<=194367||177984<=r&&r<=196605||196608<=r&&r<=262141?`W`:32<=r&&r<=126||162<=r&&r<=163||165<=r&&r<=166||r==172||r==175||10214<=r&&r<=10221||10629<=r&&r<=10630?`Na`:r==161||r==164||167<=r&&r<=168||r==170||173<=r&&r<=174||176<=r&&r<=180||182<=r&&r<=186||188<=r&&r<=191||r==198||r==208||215<=r&&r<=216||222<=r&&r<=225||r==230||232<=r&&r<=234||236<=r&&r<=237||r==240||242<=r&&r<=243||247<=r&&r<=250||r==252||r==254||r==257||r==273||r==275||r==283||294<=r&&r<=295||r==299||305<=r&&r<=307||r==312||319<=r&&r<=322||r==324||328<=r&&r<=331||r==333||338<=r&&r<=339||358<=r&&r<=359||r==363||r==462||r==464||r==466||r==468||r==470||r==472||r==474||r==476||r==593||r==609||r==708||r==711||713<=r&&r<=715||r==717||r==720||728<=r&&r<=731||r==733||r==735||768<=r&&r<=879||913<=r&&r<=929||931<=r&&r<=937||945<=r&&r<=961||963<=r&&r<=969||r==1025||1040<=r&&r<=1103||r==1105||r==8208||8211<=r&&r<=8214||8216<=r&&r<=8217||8220<=r&&r<=8221||8224<=r&&r<=8226||8228<=r&&r<=8231||r==8240||8242<=r&&r<=8243||r==8245||r==8251||r==8254||r==8308||r==8319||8321<=r&&r<=8324||r==8364||r==8451||r==8453||r==8457||r==8467||r==8470||8481<=r&&r<=8482||r==8486||r==8491||8531<=r&&r<=8532||8539<=r&&r<=8542||8544<=r&&r<=8555||8560<=r&&r<=8569||r==8585||8592<=r&&r<=8601||8632<=r&&r<=8633||r==8658||r==8660||r==8679||r==8704||8706<=r&&r<=8707||8711<=r&&r<=8712||r==8715||r==8719||r==8721||r==8725||r==8730||8733<=r&&r<=8736||r==8739||r==8741||8743<=r&&r<=8748||r==8750||8756<=r&&r<=8759||8764<=r&&r<=8765||r==8776||r==8780||r==8786||8800<=r&&r<=8801||8804<=r&&r<=8807||8810<=r&&r<=8811||8814<=r&&r<=8815||8834<=r&&r<=8835||8838<=r&&r<=8839||r==8853||r==8857||r==8869||r==8895||r==8978||9312<=r&&r<=9449||9451<=r&&r<=9547||9552<=r&&r<=9587||9600<=r&&r<=9615||9618<=r&&r<=9621||9632<=r&&r<=9633||9635<=r&&r<=9641||9650<=r&&r<=9651||9654<=r&&r<=9655||9660<=r&&r<=9661||9664<=r&&r<=9665||9670<=r&&r<=9672||r==9675||9678<=r&&r<=9681||9698<=r&&r<=9701||r==9711||9733<=r&&r<=9734||r==9737||9742<=r&&r<=9743||9748<=r&&r<=9749||r==9756||r==9758||r==9792||r==9794||9824<=r&&r<=9825||9827<=r&&r<=9829||9831<=r&&r<=9834||9836<=r&&r<=9837||r==9839||9886<=r&&r<=9887||9918<=r&&r<=9919||9924<=r&&r<=9933||9935<=r&&r<=9953||r==9955||9960<=r&&r<=9983||r==10045||r==10071||10102<=r&&r<=10111||11093<=r&&r<=11097||12872<=r&&r<=12879||57344<=r&&r<=63743||65024<=r&&r<=65039||r==65533||127232<=r&&r<=127242||127248<=r&&r<=127277||127280<=r&&r<=127337||127344<=r&&r<=127386||917760<=r&&r<=917999||983040<=r&&r<=1048573||1048576<=r&&r<=1114109?`A`:`N`},t.characterLength=function(e){var t=this.eastAsianWidth(e);return t==`F`||t==`W`||t==`A`?2:1};function n(e){return e.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]|[^\uD800-\uDFFF]/g)||[]}t.length=function(e){for(var t=n(e),r=0,i=0;i<t.length;i++)r+=this.characterLength(t[i]);return r},t.slice=function(e,r,i){textLen=t.length(e),r||=0,i||=1,r<0&&(r=textLen+r),i<0&&(i=textLen+i);for(var a=``,o=0,s=n(e),c=0;c<s.length;c++){var l=s[c],u=t.length(l);if(o>=r-+(u==2))if(o+u<=i)a+=l;else break;o+=u}return a}})(ot),st=ot.exports,ct=Ze(st),lt=function(){return/\uD83C\uDFF4\uDB40\uDC67\uDB40\uDC62(?:\uDB40\uDC77\uDB40\uDC6C\uDB40\uDC73|\uDB40\uDC73\uDB40\uDC63\uDB40\uDC74|\uDB40\uDC65\uDB40\uDC6E\uDB40\uDC67)\uDB40\uDC7F|(?:\uD83E\uDDD1\uD83C\uDFFF\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFF\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB-\uDFFE])|(?:\uD83E\uDDD1\uD83C\uDFFE\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFE\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB-\uDFFD\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFD\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFD\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFC\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFC\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFB\uDFFD-\uDFFF])|(?:\uD83E\uDDD1\uD83C\uDFFB\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83E\uDDD1|\uD83D\uDC69\uD83C\uDFFB\u200D\uD83E\uDD1D\u200D(?:\uD83D[\uDC68\uDC69]))(?:\uD83C[\uDFFC-\uDFFF])|\uD83D\uDC68(?:\uD83C\uDFFB(?:\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF]))|\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFC-\uDFFF])|[\u2695\u2696\u2708]\uFE0F|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))?|(?:\uD83C[\uDFFC-\uDFFF])\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFF]))|\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D)?\uD83D\uDC68|(?:\uD83D[\uDC68\uDC69])\u200D(?:\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67]))|\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFE])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB-\uDFFD\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB\uDFFC\uDFFE\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83E\uDD1D\u200D\uD83D\uDC68(?:\uD83C[\uDFFB\uDFFD-\uDFFF])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])\uFE0F|\u200D(?:(?:\uD83D[\uDC68\uDC69])\u200D(?:\uD83D[\uDC66\uDC67])|\uD83D[\uDC66\uDC67])|\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC)?|(?:\uD83D\uDC69(?:\uD83C\uDFFB\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69])|(?:\uD83C[\uDFFC-\uDFFF])\u200D\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69]))|\uD83E\uDDD1(?:\uD83C[\uDFFB-\uDFFF])\u200D\uD83E\uDD1D\u200D\uD83E\uDDD1)(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC69\u200D\uD83D\uDC69\u200D(?:\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67]))|\uD83D\uDC69(?:\u200D(?:\u2764\uFE0F\u200D(?:\uD83D\uDC8B\u200D(?:\uD83D[\uDC68\uDC69])|\uD83D[\uDC68\uDC69])|\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFB\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))|\uD83E\uDDD1(?:\u200D(?:\uD83E\uDD1D\u200D\uD83E\uDDD1|\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFF\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFE\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFD\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFC\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD])|\uD83C\uDFFB\u200D(?:\uD83C[\uDF3E\uDF73\uDF7C\uDF84\uDF93\uDFA4\uDFA8\uDFEB\uDFED]|\uD83D[\uDCBB\uDCBC\uDD27\uDD2C\uDE80\uDE92]|\uD83E[\uDDAF-\uDDB3\uDDBC\uDDBD]))|\uD83D\uDC69\u200D\uD83D\uDC66\u200D\uD83D\uDC66|\uD83D\uDC69\u200D\uD83D\uDC69\u200D(?:\uD83D[\uDC66\uDC67])|\uD83D\uDC69\u200D\uD83D\uDC67\u200D(?:\uD83D[\uDC66\uDC67])|(?:\uD83D\uDC41\uFE0F\u200D\uD83D\uDDE8|\uD83E\uDDD1(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\uD83C\uDFFB\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])|\uD83D\uDC69(?:\uD83C\uDFFF\u200D[\u2695\u2696\u2708]|\uD83C\uDFFE\u200D[\u2695\u2696\u2708]|\uD83C\uDFFD\u200D[\u2695\u2696\u2708]|\uD83C\uDFFC\u200D[\u2695\u2696\u2708]|\uD83C\uDFFB\u200D[\u2695\u2696\u2708]|\u200D[\u2695\u2696\u2708])|\uD83D\uDE36\u200D\uD83C\uDF2B|\uD83C\uDFF3\uFE0F\u200D\u26A7|\uD83D\uDC3B\u200D\u2744|(?:(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])|\uD83D\uDC6F|\uD83E[\uDD3C\uDDDE\uDDDF])\u200D[\u2640\u2642]|(?:\u26F9|\uD83C[\uDFCB\uDFCC]|\uD83D\uDD75)(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])\u200D[\u2640\u2642]|\uD83C\uDFF4\u200D\u2620|(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])\u200D[\u2640\u2642]|[\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u2328\u23CF\u23ED-\u23EF\u23F1\u23F2\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB\u25FC\u2600-\u2604\u260E\u2611\u2618\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u265F\u2660\u2663\u2665\u2666\u2668\u267B\u267E\u2692\u2694-\u2697\u2699\u269B\u269C\u26A0\u26A7\u26B0\u26B1\u26C8\u26CF\u26D1\u26D3\u26E9\u26F0\u26F1\u26F4\u26F7\u26F8\u2702\u2708\u2709\u270F\u2712\u2714\u2716\u271D\u2721\u2733\u2734\u2744\u2747\u2763\u27A1\u2934\u2935\u2B05-\u2B07\u3030\u303D\u3297\u3299]|\uD83C[\uDD70\uDD71\uDD7E\uDD7F\uDE02\uDE37\uDF21\uDF24-\uDF2C\uDF36\uDF7D\uDF96\uDF97\uDF99-\uDF9B\uDF9E\uDF9F\uDFCD\uDFCE\uDFD4-\uDFDF\uDFF5\uDFF7]|\uD83D[\uDC3F\uDCFD\uDD49\uDD4A\uDD6F\uDD70\uDD73\uDD76-\uDD79\uDD87\uDD8A-\uDD8D\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA\uDECB\uDECD-\uDECF\uDEE0-\uDEE5\uDEE9\uDEF0\uDEF3])\uFE0F|\uD83C\uDFF3\uFE0F\u200D\uD83C\uDF08|\uD83D\uDC69\u200D\uD83D\uDC67|\uD83D\uDC69\u200D\uD83D\uDC66|\uD83D\uDE35\u200D\uD83D\uDCAB|\uD83D\uDE2E\u200D\uD83D\uDCA8|\uD83D\uDC15\u200D\uD83E\uDDBA|\uD83E\uDDD1(?:\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC|\uD83C\uDFFB)?|\uD83D\uDC69(?:\uD83C\uDFFF|\uD83C\uDFFE|\uD83C\uDFFD|\uD83C\uDFFC|\uD83C\uDFFB)?|\uD83C\uDDFD\uD83C\uDDF0|\uD83C\uDDF6\uD83C\uDDE6|\uD83C\uDDF4\uD83C\uDDF2|\uD83D\uDC08\u200D\u2B1B|\u2764\uFE0F\u200D(?:\uD83D\uDD25|\uD83E\uDE79)|\uD83D\uDC41\uFE0F|\uD83C\uDFF3\uFE0F|\uD83C\uDDFF(?:\uD83C[\uDDE6\uDDF2\uDDFC])|\uD83C\uDDFE(?:\uD83C[\uDDEA\uDDF9])|\uD83C\uDDFC(?:\uD83C[\uDDEB\uDDF8])|\uD83C\uDDFB(?:\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDEE\uDDF3\uDDFA])|\uD83C\uDDFA(?:\uD83C[\uDDE6\uDDEC\uDDF2\uDDF3\uDDF8\uDDFE\uDDFF])|\uD83C\uDDF9(?:\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDED\uDDEF-\uDDF4\uDDF7\uDDF9\uDDFB\uDDFC\uDDFF])|\uD83C\uDDF8(?:\uD83C[\uDDE6-\uDDEA\uDDEC-\uDDF4\uDDF7-\uDDF9\uDDFB\uDDFD-\uDDFF])|\uD83C\uDDF7(?:\uD83C[\uDDEA\uDDF4\uDDF8\uDDFA\uDDFC])|\uD83C\uDDF5(?:\uD83C[\uDDE6\uDDEA-\uDDED\uDDF0-\uDDF3\uDDF7-\uDDF9\uDDFC\uDDFE])|\uD83C\uDDF3(?:\uD83C[\uDDE6\uDDE8\uDDEA-\uDDEC\uDDEE\uDDF1\uDDF4\uDDF5\uDDF7\uDDFA\uDDFF])|\uD83C\uDDF2(?:\uD83C[\uDDE6\uDDE8-\uDDED\uDDF0-\uDDFF])|\uD83C\uDDF1(?:\uD83C[\uDDE6-\uDDE8\uDDEE\uDDF0\uDDF7-\uDDFB\uDDFE])|\uD83C\uDDF0(?:\uD83C[\uDDEA\uDDEC-\uDDEE\uDDF2\uDDF3\uDDF5\uDDF7\uDDFC\uDDFE\uDDFF])|\uD83C\uDDEF(?:\uD83C[\uDDEA\uDDF2\uDDF4\uDDF5])|\uD83C\uDDEE(?:\uD83C[\uDDE8-\uDDEA\uDDF1-\uDDF4\uDDF6-\uDDF9])|\uD83C\uDDED(?:\uD83C[\uDDF0\uDDF2\uDDF3\uDDF7\uDDF9\uDDFA])|\uD83C\uDDEC(?:\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEE\uDDF1-\uDDF3\uDDF5-\uDDFA\uDDFC\uDDFE])|\uD83C\uDDEB(?:\uD83C[\uDDEE-\uDDF0\uDDF2\uDDF4\uDDF7])|\uD83C\uDDEA(?:\uD83C[\uDDE6\uDDE8\uDDEA\uDDEC\uDDED\uDDF7-\uDDFA])|\uD83C\uDDE9(?:\uD83C[\uDDEA\uDDEC\uDDEF\uDDF0\uDDF2\uDDF4\uDDFF])|\uD83C\uDDE8(?:\uD83C[\uDDE6\uDDE8\uDDE9\uDDEB-\uDDEE\uDDF0-\uDDF5\uDDF7\uDDFA-\uDDFF])|\uD83C\uDDE7(?:\uD83C[\uDDE6\uDDE7\uDDE9-\uDDEF\uDDF1-\uDDF4\uDDF6-\uDDF9\uDDFB\uDDFC\uDDFE\uDDFF])|\uD83C\uDDE6(?:\uD83C[\uDDE8-\uDDEC\uDDEE\uDDF1\uDDF2\uDDF4\uDDF6-\uDDFA\uDDFC\uDDFD\uDDFF])|[#\*0-9]\uFE0F\u20E3|\u2764\uFE0F|(?:\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])|(?:\u26F9|\uD83C[\uDFCB\uDFCC]|\uD83D\uDD75)(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])|\uD83C\uDFF4|(?:[\u270A\u270B]|\uD83C[\uDF85\uDFC2\uDFC7]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66\uDC67\uDC6B-\uDC6D\uDC72\uDC74-\uDC76\uDC78\uDC7C\uDC83\uDC85\uDC8F\uDC91\uDCAA\uDD7A\uDD95\uDD96\uDE4C\uDE4F\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1C\uDD1E\uDD1F\uDD30-\uDD34\uDD36\uDD77\uDDB5\uDDB6\uDDBB\uDDD2\uDDD3\uDDD5])(?:\uD83C[\uDFFB-\uDFFF])|(?:[\u261D\u270C\u270D]|\uD83D[\uDD74\uDD90])(?:\uFE0F|\uD83C[\uDFFB-\uDFFF])|[\u270A\u270B]|\uD83C[\uDF85\uDFC2\uDFC7]|\uD83D[\uDC08\uDC15\uDC3B\uDC42\uDC43\uDC46-\uDC50\uDC66\uDC67\uDC6B-\uDC6D\uDC72\uDC74-\uDC76\uDC78\uDC7C\uDC83\uDC85\uDC8F\uDC91\uDCAA\uDD7A\uDD95\uDD96\uDE2E\uDE35\uDE36\uDE4C\uDE4F\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1C\uDD1E\uDD1F\uDD30-\uDD34\uDD36\uDD77\uDDB5\uDDB6\uDDBB\uDDD2\uDDD3\uDDD5]|\uD83C[\uDFC3\uDFC4\uDFCA]|\uD83D[\uDC6E\uDC70\uDC71\uDC73\uDC77\uDC81\uDC82\uDC86\uDC87\uDE45-\uDE47\uDE4B\uDE4D\uDE4E\uDEA3\uDEB4-\uDEB6]|\uD83E[\uDD26\uDD35\uDD37-\uDD39\uDD3D\uDD3E\uDDB8\uDDB9\uDDCD-\uDDCF\uDDD4\uDDD6-\uDDDD]|\uD83D\uDC6F|\uD83E[\uDD3C\uDDDE\uDDDF]|[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF84\uDF86-\uDF93\uDFA0-\uDFC1\uDFC5\uDFC6\uDFC8\uDFC9\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC07\uDC09-\uDC14\uDC16-\uDC3A\uDC3C-\uDC3E\uDC40\uDC44\uDC45\uDC51-\uDC65\uDC6A\uDC79-\uDC7B\uDC7D-\uDC80\uDC84\uDC88-\uDC8E\uDC90\uDC92-\uDCA9\uDCAB-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDDA4\uDDFB-\uDE2D\uDE2F-\uDE34\uDE37-\uDE44\uDE48-\uDE4A\uDE80-\uDEA2\uDEA4-\uDEB3\uDEB7-\uDEBF\uDEC1-\uDEC5\uDED0-\uDED2\uDED5-\uDED7\uDEEB\uDEEC\uDEF4-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0D\uDD0E\uDD10-\uDD17\uDD1D\uDD20-\uDD25\uDD27-\uDD2F\uDD3A\uDD3F-\uDD45\uDD47-\uDD76\uDD78\uDD7A-\uDDB4\uDDB7\uDDBA\uDDBC-\uDDCB\uDDD0\uDDE0-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6]|(?:[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u270A\u270B\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF93\uDFA0-\uDFCA\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF4\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC3E\uDC40\uDC42-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDD7A\uDD95\uDD96\uDDA4\uDDFB-\uDE4F\uDE80-\uDEC5\uDECC\uDED0-\uDED2\uDED5-\uDED7\uDEEB\uDEEC\uDEF4-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDD78\uDD7A-\uDDCB\uDDCD-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6])|(?:[#\*0-9\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2604\u260E\u2611\u2614\u2615\u2618\u261D\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u2648-\u2653\u265F\u2660\u2663\u2665\u2666\u2668\u267B\u267E\u267F\u2692-\u2697\u2699\u269B\u269C\u26A0\u26A1\u26A7\u26AA\u26AB\u26B0\u26B1\u26BD\u26BE\u26C4\u26C5\u26C8\u26CE\u26CF\u26D1\u26D3\u26D4\u26E9\u26EA\u26F0-\u26F5\u26F7-\u26FA\u26FD\u2702\u2705\u2708-\u270D\u270F\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753-\u2755\u2757\u2763\u2764\u2795-\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]|\uD83C[\uDC04\uDCCF\uDD70\uDD71\uDD7E\uDD7F\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE02\uDE1A\uDE2F\uDE32-\uDE3A\uDE50\uDE51\uDF00-\uDF21\uDF24-\uDF93\uDF96\uDF97\uDF99-\uDF9B\uDF9E-\uDFF0\uDFF3-\uDFF5\uDFF7-\uDFFF]|\uD83D[\uDC00-\uDCFD\uDCFF-\uDD3D\uDD49-\uDD4E\uDD50-\uDD67\uDD6F\uDD70\uDD73-\uDD7A\uDD87\uDD8A-\uDD8D\uDD90\uDD95\uDD96\uDDA4\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA-\uDE4F\uDE80-\uDEC5\uDECB-\uDED2\uDED5-\uDED7\uDEE0-\uDEE5\uDEE9\uDEEB\uDEEC\uDEF0\uDEF3-\uDEFC\uDFE0-\uDFEB]|\uD83E[\uDD0C-\uDD3A\uDD3C-\uDD45\uDD47-\uDD78\uDD7A-\uDDCB\uDDCD-\uDDFF\uDE70-\uDE74\uDE78-\uDE7A\uDE80-\uDE86\uDE90-\uDEA8\uDEB0-\uDEB6\uDEC0-\uDEC2\uDED0-\uDED6])\uFE0F|(?:[\u261D\u26F9\u270A-\u270D]|\uD83C[\uDF85\uDFC2-\uDFC4\uDFC7\uDFCA-\uDFCC]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66-\uDC78\uDC7C\uDC81-\uDC83\uDC85-\uDC87\uDC8F\uDC91\uDCAA\uDD74\uDD75\uDD7A\uDD90\uDD95\uDD96\uDE45-\uDE47\uDE4B-\uDE4F\uDEA3\uDEB4-\uDEB6\uDEC0\uDECC]|\uD83E[\uDD0C\uDD0F\uDD18-\uDD1F\uDD26\uDD30-\uDD39\uDD3C-\uDD3E\uDD77\uDDB5\uDDB6\uDDB8\uDDB9\uDDBB\uDDCD-\uDDCF\uDDD1-\uDDDD])/g},ut=Ze(lt),dt=10,ft=(e=0)=>t=>`\x1B[${t+e}m`,pt=(e=0)=>t=>`\x1B[${38+e};5;${t}m`,mt=(e=0)=>(t,n,r)=>`\x1B[${38+e};2;${t};${n};${r}m`,I={modifier:{reset:[0,0],bold:[1,22],dim:[2,22],italic:[3,23],underline:[4,24],overline:[53,55],inverse:[7,27],hidden:[8,28],strikethrough:[9,29]},color:{black:[30,39],red:[31,39],green:[32,39],yellow:[33,39],blue:[34,39],magenta:[35,39],cyan:[36,39],white:[37,39],blackBright:[90,39],gray:[90,39],grey:[90,39],redBright:[91,39],greenBright:[92,39],yellowBright:[93,39],blueBright:[94,39],magentaBright:[95,39],cyanBright:[96,39],whiteBright:[97,39]},bgColor:{bgBlack:[40,49],bgRed:[41,49],bgGreen:[42,49],bgYellow:[43,49],bgBlue:[44,49],bgMagenta:[45,49],bgCyan:[46,49],bgWhite:[47,49],bgBlackBright:[100,49],bgGray:[100,49],bgGrey:[100,49],bgRedBright:[101,49],bgGreenBright:[102,49],bgYellowBright:[103,49],bgBlueBright:[104,49],bgMagentaBright:[105,49],bgCyanBright:[106,49],bgWhiteBright:[107,49]}},Object.keys(I.modifier),ht=Object.keys(I.color),gt=Object.keys(I.bgColor),[...ht,...gt],_t=$e(),vt=new Set([`\x1B`,`›`]),yt=39,bt=`\x07`,xt=`[`,St=`]`,Ct=`m`,wt=`${St}8;;`,Tt=e=>`${vt.values().next().value}${xt}${e}${Ct}`,Et=e=>`${vt.values().next().value}${wt}${e}${bt}`,Dt=e=>e.split(` `).map(e=>Qe(e)),Ot=(e,t,n)=>{let r=[...t],i=!1,a=!1,o=Qe(Xe(e[e.length-1]));for(let[t,s]of r.entries()){let c=Qe(s);if(o+c<=n?e[e.length-1]+=s:(e.push(s),o=0),vt.has(s)&&(i=!0,a=r.slice(t+1).join(``).startsWith(wt)),i){a?s===bt&&(i=!1,a=!1):s===Ct&&(i=!1);continue}o+=c,o===n&&t<r.length-1&&(e.push(``),o=0)}!o&&e[e.length-1].length>0&&e.length>1&&(e[e.length-2]+=e.pop())},kt=e=>{let t=e.split(` `),n=t.length;for(;n>0&&!(Qe(t[n-1])>0);)n--;return n===t.length?e:t.slice(0,n).join(` `)+t.slice(n).join(``)},At=(e,t,n={})=>{if(n.trim!==!1&&e.trim()===``)return``;let r=``,i,a,o=Dt(e),s=[``];for(let[r,i]of e.split(` `).entries()){n.trim!==!1&&(s[s.length-1]=s[s.length-1].trimStart());let e=Qe(s[s.length-1]);if(r!==0&&(e>=t&&(n.wordWrap===!1||n.trim===!1)&&(s.push(``),e=0),(e>0||n.trim===!1)&&(s[s.length-1]+=` `,e++)),n.hard&&o[r]>t){let n=t-e,a=1+Math.floor((o[r]-n-1)/t);Math.floor((o[r]-1)/t)<a&&s.push(``),Ot(s,i,t);continue}if(e+o[r]>t&&e>0&&o[r]>0){if(n.wordWrap===!1&&e<t){Ot(s,i,t);continue}s.push(``)}if(e+o[r]>t&&n.wordWrap===!1){Ot(s,i,t);continue}s[s.length-1]+=i}n.trim!==!1&&(s=s.map(e=>kt(e)));let c=[...s.join(`
11
+ `)];for(let[e,t]of c.entries()){if(r+=t,vt.has(t)){let{groups:t}=RegExp(`(?:\\${xt}(?<code>\\d+)m|\\${wt}(?<uri>.*)${bt})`).exec(c.slice(e).join(``))||{groups:{}};if(t.code!==void 0){let e=Number.parseFloat(t.code);i=e===yt?void 0:e}else t.uri!==void 0&&(a=t.uri.length===0?void 0:t.uri)}let n=_t.codes.get(Number(i));c[e+1]===`
12
+ `?(a&&(r+=Et(``)),i&&n&&(r+=Tt(n))):t===`
13
+ `&&(i&&n&&(r+=Tt(i)),a&&(r+=Et(a)))}return r},jt=Object.defineProperty,Mt=(e,t,n)=>t in e?jt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,L=(e,t,n)=>(Mt(e,typeof t==`symbol`?t:t+``,n),n),Nt=Symbol(`clack:cancel`),Pt=new Map([[`k`,`up`],[`j`,`down`],[`h`,`left`],[`l`,`right`]]),Ft=new Set([`up`,`down`,`left`,`right`,`space`,`enter`]),R=class{constructor({render:e,input:t=he,output:n=ge,...r},i=!0){L(this,`input`),L(this,`output`),L(this,`rl`),L(this,`opts`),L(this,`_track`,!1),L(this,`_render`),L(this,`_cursor`,0),L(this,`state`,`initial`),L(this,`value`),L(this,`error`,``),L(this,`subscribers`,new Map),L(this,`_prevFrame`,``),this.opts=r,this.onKeypress=this.onKeypress.bind(this),this.close=this.close.bind(this),this.render=this.render.bind(this),this._render=e.bind(this),this._track=i,this.input=t,this.output=n}prompt(){let e=new ye(0);return e._write=(e,t,n)=>{this._track&&(this.value=this.rl.line.replace(/\t/g,``),this._cursor=this.rl.cursor,this.emit(`value`,this.value)),n()},this.input.pipe(e),this.rl=ve.createInterface({input:this.input,output:e,tabSize:2,prompt:``,escapeCodeTimeout:50}),ve.emitKeypressEvents(this.input,this.rl),this.rl.prompt(),this.opts.initialValue!==void 0&&this._track&&this.rl.write(this.opts.initialValue),this.input.on(`keypress`,this.onKeypress),rt(this.input,!0),this.output.on(`resize`,this.render),this.render(),new Promise((e,t)=>{this.once(`submit`,()=>{this.output.write(P.cursor.show),this.output.off(`resize`,this.render),rt(this.input,!1),e(this.value)}),this.once(`cancel`,()=>{this.output.write(P.cursor.show),this.output.off(`resize`,this.render),rt(this.input,!1),e(Nt)})})}on(e,t){let n=this.subscribers.get(e)??[];n.push({cb:t}),this.subscribers.set(e,n)}once(e,t){let n=this.subscribers.get(e)??[];n.push({cb:t,once:!0}),this.subscribers.set(e,n)}emit(e,...t){let n=this.subscribers.get(e)??[],r=[];for(let e of n)e.cb(...t),e.once&&r.push(()=>n.splice(n.indexOf(e),1));for(let e of r)e()}unsubscribe(){this.subscribers.clear()}onKeypress(e,t){if(this.state===`error`&&(this.state=`active`),t?.name&&!this._track&&Pt.has(t.name)&&this.emit(`cursor`,Pt.get(t.name)),t?.name&&Ft.has(t.name)&&this.emit(`cursor`,t.name),e&&(e.toLowerCase()===`y`||e.toLowerCase()===`n`)&&this.emit(`confirm`,e.toLowerCase()===`y`),e===` `&&this.opts.placeholder&&(this.value||(this.rl.write(this.opts.placeholder),this.emit(`value`,this.opts.placeholder))),e&&this.emit(`key`,e.toLowerCase()),t?.name===`return`){if(this.opts.validate){let e=this.opts.validate(this.value);e&&(this.error=e,this.state=`error`,this.rl.write(this.value))}this.state!==`error`&&(this.state=`submit`)}e===``&&(this.state=`cancel`),(this.state===`submit`||this.state===`cancel`)&&this.emit(`finalize`),this.render(),(this.state===`submit`||this.state===`cancel`)&&this.close()}close(){this.input.unpipe(),this.input.removeListener(`keypress`,this.onKeypress),this.output.write(`
14
+ `),rt(this.input,!1),this.rl.close(),this.emit(`${this.state}`,this.value),this.unsubscribe()}restoreCursor(){let e=et(this._prevFrame,process.stdout.columns,{hard:!0}).split(`
15
+ `).length-1;this.output.write(P.cursor.move(-999,e*-1))}render(){let e=et(this._render(this)??``,process.stdout.columns,{hard:!0});if(e!==this._prevFrame){if(this.state===`initial`)this.output.write(P.cursor.hide);else{let t=tt(this._prevFrame,e);if(this.restoreCursor(),t&&t?.length===1){let n=t[0];this.output.write(P.cursor.move(0,n)),this.output.write(P.erase.lines(1));let r=e.split(`
16
+ `);this.output.write(r[n]),this._prevFrame=e,this.output.write(P.cursor.move(0,r.length-n-1));return}else if(t&&t?.length>1){let n=t[0];this.output.write(P.cursor.move(0,n)),this.output.write(P.erase.down());let r=e.split(`
17
+ `).slice(n);this.output.write(r.join(`
18
+ `)),this._prevFrame=e;return}this.output.write(P.erase.down())}this.output.write(e),this.state===`initial`&&(this.state=`active`),this._prevFrame=e}}},It=class extends R{get cursor(){return+!this.value}get _value(){return this.cursor===0}constructor(e){super(e,!1),this.value=!!e.initialValue,this.on(`value`,()=>{this.value=this._value}),this.on(`confirm`,e=>{this.output.write(P.cursor.move(0,-1)),this.value=e,this.state=`submit`,this.close()}),this.on(`cursor`,()=>{this.value=!this.value})}},Lt=Object.defineProperty,Rt=(e,t,n)=>t in e?Lt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,zt=(e,t,n)=>(Rt(e,typeof t==`symbol`?t:t+``,n),n),Bt=class extends R{constructor(e){super(e,!1),zt(this,`options`),zt(this,`cursor`,0);let{options:t}=e;this.options=Object.entries(t).flatMap(([e,t])=>[{value:e,group:!0,label:e},...t.map(t=>({...t,group:e}))]),this.value=[...e.initialValues??[]],this.cursor=Math.max(this.options.findIndex(({value:t})=>t===e.cursorAt),0),this.on(`cursor`,e=>{switch(e){case`left`:case`up`:this.cursor=this.cursor===0?this.options.length-1:this.cursor-1;break;case`down`:case`right`:this.cursor=this.cursor===this.options.length-1?0:this.cursor+1;break;case`space`:this.toggleValue();break}})}getGroupItems(e){return this.options.filter(t=>t.group===e)}isGroupSelected(e){return this.getGroupItems(e).every(e=>this.value.includes(e.value))}toggleValue(){let e=this.options[this.cursor];if(e.group===!0){let t=e.value,n=this.getGroupItems(t);this.isGroupSelected(t)?this.value=this.value.filter(e=>n.findIndex(t=>t.value===e)===-1):this.value=[...this.value,...n.map(e=>e.value)],this.value=Array.from(new Set(this.value))}else{let t=this.value.includes(e.value);this.value=t?this.value.filter(t=>t!==e.value):[...this.value,e.value]}}},Vt=Object.defineProperty,Ht=(e,t,n)=>t in e?Vt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,Ut=(e,t,n)=>(Ht(e,typeof t==`symbol`?t:t+``,n),n),Wt=class extends R{constructor(e){super(e,!1),Ut(this,`options`),Ut(this,`cursor`,0),this.options=e.options,this.value=[...e.initialValues??[]],this.cursor=Math.max(this.options.findIndex(({value:t})=>t===e.cursorAt),0),this.on(`key`,e=>{e===`a`&&this.toggleAll()}),this.on(`cursor`,e=>{switch(e){case`left`:case`up`:this.cursor=this.cursor===0?this.options.length-1:this.cursor-1;break;case`down`:case`right`:this.cursor=this.cursor===this.options.length-1?0:this.cursor+1;break;case`space`:this.toggleValue();break}})}get _value(){return this.options[this.cursor].value}toggleAll(){let e=this.value.length===this.options.length;this.value=e?[]:this.options.map(e=>e.value)}toggleValue(){let e=this.value.includes(this._value);this.value=e?this.value.filter(e=>e!==this._value):[...this.value,this._value]}},Gt=Object.defineProperty,Kt=(e,t,n)=>t in e?Gt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,qt=(e,t,n)=>(Kt(e,typeof t==`symbol`?t:t+``,n),n),Jt=class extends R{constructor({mask:e,...t}){super(t),qt(this,`valueWithCursor`,``),qt(this,`_mask`,`•`),this._mask=e??`•`,this.on(`finalize`,()=>{this.valueWithCursor=this.masked}),this.on(`value`,()=>{if(this.cursor>=this.value.length)this.valueWithCursor=`${this.masked}${F.default.inverse(F.default.hidden(`_`))}`;else{let e=this.masked.slice(0,this.cursor),t=this.masked.slice(this.cursor);this.valueWithCursor=`${e}${F.default.inverse(t[0])}${t.slice(1)}`}})}get cursor(){return this._cursor}get masked(){return this.value.replaceAll(/./g,this._mask)}},Yt=Object.defineProperty,Xt=(e,t,n)=>t in e?Yt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,Zt=(e,t,n)=>(Xt(e,typeof t==`symbol`?t:t+``,n),n),Qt=class extends R{constructor(e){super(e,!1),Zt(this,`options`),Zt(this,`cursor`,0),this.options=e.options,this.cursor=this.options.findIndex(({value:t})=>t===e.initialValue),this.cursor===-1&&(this.cursor=0),this.changeValue(),this.on(`cursor`,e=>{switch(e){case`left`:case`up`:this.cursor=this.cursor===0?this.options.length-1:this.cursor-1;break;case`down`:case`right`:this.cursor=this.cursor===this.options.length-1?0:this.cursor+1;break}this.changeValue()})}get _value(){return this.options[this.cursor]}changeValue(){this.value=this._value.value}},$t=Object.defineProperty,en=(e,t,n)=>t in e?$t(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,tn=(e,t,n)=>(en(e,typeof t==`symbol`?t:t+``,n),n),nn=class extends R{constructor(e){super(e,!1),tn(this,`options`),tn(this,`cursor`,0),this.options=e.options;let t=this.options.map(({value:[e]})=>e?.toLowerCase());this.cursor=Math.max(t.indexOf(e.initialValue),0),this.on(`key`,e=>{if(!t.includes(e))return;let n=this.options.find(({value:[t]})=>t?.toLowerCase()===e);n&&(this.value=n.value,this.state=`submit`,this.emit(`submit`))})}},rn=Object.defineProperty,an=(e,t,n)=>t in e?rn(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,on=(e,t,n)=>(an(e,typeof t==`symbol`?t:t+``,n),n),sn=class extends R{constructor(e){super(e),on(this,`valueWithCursor`,``),this.on(`finalize`,()=>{this.value||=e.defaultValue,this.valueWithCursor=this.value}),this.on(`value`,()=>{if(this.cursor>=this.value.length)this.valueWithCursor=`${this.value}${F.default.inverse(F.default.hidden(`_`))}`;else{let e=this.value.slice(0,this.cursor),t=this.value.slice(this.cursor);this.valueWithCursor=`${e}${F.default.inverse(t[0])}${t.slice(1)}`}})}get cursor(){return this._cursor}},cn=globalThis.process.platform.startsWith(`win`)})),un=Re({cancel:()=>Hn,confirm:()=>Fn,group:()=>Kn,groupMultiselect:()=>zn,intro:()=>Un,isCancel:()=>nt,log:()=>G,multiselect:()=>Rn,note:()=>Vn,outro:()=>Wn,password:()=>Pn,select:()=>In,selectKey:()=>Ln,spinner:()=>Gn,text:()=>Nn});function dn(){return A.platform===`win32`?!!A.env.CI||!!A.env.WT_SESSION||!!A.env.TERMINUS_SUBLIME||A.env.ConEmuTask===`{cmd::Cmder}`||A.env.TERM_PROGRAM===`Terminus-Sublime`||A.env.TERM_PROGRAM===`vscode`||A.env.TERM===`xterm-256color`||A.env.TERM===`alacritty`||A.env.TERMINAL_EMULATOR===`JetBrains-JediTerm`:A.env.TERM!==`linux`}function fn(){let e=[`[\\u001B\\u009B][[\\]()#;?]*(?:(?:(?:(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]+)*|[a-zA-Z\\d]+(?:;[-a-zA-Z\\d\\/#&.:=?%@~_]*)*)?\\u0007)`,`(?:(?:\\d{1,4}(?:;\\d{0,4})*)?[\\dA-PR-TZcf-nq-uy=><~]))`].join(`|`);return new RegExp(e,`g`)}var z,pn,mn,B,hn,gn,_n,vn,yn,V,H,bn,xn,Sn,U,Cn,wn,Tn,En,Dn,On,kn,An,jn,Mn,W,Nn,Pn,Fn,In,Ln,Rn,zn,Bn,Vn,Hn,Un,Wn,G,Gn,Kn,qn=Ie((()=>{ln(),z=Be(Je(),1),pn=qe(),mn=dn(),B=(e,t)=>mn?e:t,hn=B(`◆`,`*`),gn=B(`■`,`x`),_n=B(`▲`,`x`),vn=B(`◇`,`o`),yn=B(`┌`,`T`),V=B(`│`,`|`),H=B(`└`,`—`),bn=B(`●`,`>`),xn=B(`○`,` `),Sn=B(`◻`,`[•]`),U=B(`◼`,`[+]`),Cn=B(`◻`,`[ ]`),wn=B(`▪`,`•`),Tn=B(`─`,`-`),En=B(`╮`,`+`),Dn=B(`├`,`+`),On=B(`╯`,`+`),kn=B(`●`,`•`),An=B(`◆`,`*`),jn=B(`▲`,`!`),Mn=B(`■`,`x`),W=e=>{switch(e){case`initial`:case`active`:return z.default.cyan(hn);case`cancel`:return z.default.red(gn);case`error`:return z.default.yellow(_n);case`submit`:return z.default.green(vn)}},Nn=e=>new sn({validate:e.validate,placeholder:e.placeholder,defaultValue:e.defaultValue,initialValue:e.initialValue,render(){let t=`${z.default.gray(V)}
19
+ ${W(this.state)} ${e.message}
20
+ `,n=e.placeholder?z.default.inverse(e.placeholder[0])+z.default.dim(e.placeholder.slice(1)):z.default.inverse(z.default.hidden(`_`)),r=this.value?this.valueWithCursor:n;switch(this.state){case`error`:return`${t.trim()}
21
+ ${z.default.yellow(V)} ${r}
22
+ ${z.default.yellow(H)} ${z.default.yellow(this.error)}
23
+ `;case`submit`:return`${t}${z.default.gray(V)} ${z.default.dim(this.value||e.placeholder)}`;case`cancel`:return`${t}${z.default.gray(V)} ${z.default.strikethrough(z.default.dim(this.value??``))}${this.value?.trim()?`
24
+ `+z.default.gray(V):``}`;default:return`${t}${z.default.cyan(V)} ${r}
25
+ ${z.default.cyan(H)}
26
+ `}}}).prompt(),Pn=e=>new Jt({validate:e.validate,mask:e.mask??wn,render(){let t=`${z.default.gray(V)}
27
+ ${W(this.state)} ${e.message}
28
+ `,n=this.valueWithCursor,r=this.masked;switch(this.state){case`error`:return`${t.trim()}
29
+ ${z.default.yellow(V)} ${r}
30
+ ${z.default.yellow(H)} ${z.default.yellow(this.error)}
31
+ `;case`submit`:return`${t}${z.default.gray(V)} ${z.default.dim(r)}`;case`cancel`:return`${t}${z.default.gray(V)} ${z.default.strikethrough(z.default.dim(r??``))}${r?`
32
+ `+z.default.gray(V):``}`;default:return`${t}${z.default.cyan(V)} ${n}
33
+ ${z.default.cyan(H)}
34
+ `}}}).prompt(),Fn=e=>{let t=e.active??`Yes`,n=e.inactive??`No`;return new It({active:t,inactive:n,initialValue:e.initialValue??!0,render(){let r=`${z.default.gray(V)}
35
+ ${W(this.state)} ${e.message}
36
+ `,i=this.value?t:n;switch(this.state){case`submit`:return`${r}${z.default.gray(V)} ${z.default.dim(i)}`;case`cancel`:return`${r}${z.default.gray(V)} ${z.default.strikethrough(z.default.dim(i))}
37
+ ${z.default.gray(V)}`;default:return`${r}${z.default.cyan(V)} ${this.value?`${z.default.green(bn)} ${t}`:`${z.default.dim(xn)} ${z.default.dim(t)}`} ${z.default.dim(`/`)} ${this.value?`${z.default.dim(xn)} ${z.default.dim(n)}`:`${z.default.green(bn)} ${n}`}
38
+ ${z.default.cyan(H)}
39
+ `}}}).prompt()},In=e=>{let t=(e,t)=>{let n=e.label??String(e.value);return t===`active`?`${z.default.green(bn)} ${n} ${e.hint?z.default.dim(`(${e.hint})`):``}`:t===`selected`?`${z.default.dim(n)}`:t===`cancelled`?`${z.default.strikethrough(z.default.dim(n))}`:`${z.default.dim(xn)} ${z.default.dim(n)}`},n=0;return new Qt({options:e.options,initialValue:e.initialValue,render(){let r=`${z.default.gray(V)}
40
+ ${W(this.state)} ${e.message}
41
+ `;switch(this.state){case`submit`:return`${r}${z.default.gray(V)} ${t(this.options[this.cursor],`selected`)}`;case`cancel`:return`${r}${z.default.gray(V)} ${t(this.options[this.cursor],`cancelled`)}
42
+ ${z.default.gray(V)}`;default:{let i=e.maxItems===void 0?1/0:Math.max(e.maxItems,5);this.cursor>=n+i-3?n=Math.max(Math.min(this.cursor-i+3,this.options.length-i),0):this.cursor<n+2&&(n=Math.max(this.cursor-2,0));let a=i<this.options.length&&n>0,o=i<this.options.length&&n+i<this.options.length;return`${r}${z.default.cyan(V)} ${this.options.slice(n,n+i).map((e,r,i)=>r===0&&a||r===i.length-1&&o?z.default.dim(`...`):t(e,r+n===this.cursor?`active`:`inactive`)).join(`
43
+ ${z.default.cyan(V)} `)}
44
+ ${z.default.cyan(H)}
45
+ `}}}}).prompt()},Ln=e=>{let t=(e,t=`inactive`)=>{let n=e.label??String(e.value);return t===`selected`?`${z.default.dim(n)}`:t===`cancelled`?`${z.default.strikethrough(z.default.dim(n))}`:t===`active`?`${z.default.bgCyan(z.default.gray(` ${e.value} `))} ${n} ${e.hint?z.default.dim(`(${e.hint})`):``}`:`${z.default.gray(z.default.bgWhite(z.default.inverse(` ${e.value} `)))} ${n} ${e.hint?z.default.dim(`(${e.hint})`):``}`};return new nn({options:e.options,initialValue:e.initialValue,render(){let n=`${z.default.gray(V)}
46
+ ${W(this.state)} ${e.message}
47
+ `;switch(this.state){case`submit`:return`${n}${z.default.gray(V)} ${t(this.options.find(e=>e.value===this.value),`selected`)}`;case`cancel`:return`${n}${z.default.gray(V)} ${t(this.options[0],`cancelled`)}
48
+ ${z.default.gray(V)}`;default:return`${n}${z.default.cyan(V)} ${this.options.map((e,n)=>t(e,n===this.cursor?`active`:`inactive`)).join(`
49
+ ${z.default.cyan(V)} `)}
50
+ ${z.default.cyan(H)}
51
+ `}}}).prompt()},Rn=e=>{let t=(e,t)=>{let n=e.label??String(e.value);return t===`active`?`${z.default.cyan(Sn)} ${n} ${e.hint?z.default.dim(`(${e.hint})`):``}`:t===`selected`?`${z.default.green(U)} ${z.default.dim(n)}`:t===`cancelled`?`${z.default.strikethrough(z.default.dim(n))}`:t===`active-selected`?`${z.default.green(U)} ${n} ${e.hint?z.default.dim(`(${e.hint})`):``}`:t===`submitted`?`${z.default.dim(n)}`:`${z.default.dim(Cn)} ${z.default.dim(n)}`};return new Wt({options:e.options,initialValues:e.initialValues,required:e.required??!0,cursorAt:e.cursorAt,validate(e){if(this.required&&e.length===0)return`Please select at least one option.
52
+ ${z.default.reset(z.default.dim(`Press ${z.default.gray(z.default.bgWhite(z.default.inverse(` space `)))} to select, ${z.default.gray(z.default.bgWhite(z.default.inverse(` enter `)))} to submit`))}`},render(){let n=`${z.default.gray(V)}
53
+ ${W(this.state)} ${e.message}
54
+ `;switch(this.state){case`submit`:return`${n}${z.default.gray(V)} ${this.options.filter(({value:e})=>this.value.includes(e)).map(e=>t(e,`submitted`)).join(z.default.dim(`, `))||z.default.dim(`none`)}`;case`cancel`:{let e=this.options.filter(({value:e})=>this.value.includes(e)).map(e=>t(e,`cancelled`)).join(z.default.dim(`, `));return`${n}${z.default.gray(V)} ${e.trim()?`${e}
55
+ ${z.default.gray(V)}`:``}`}case`error`:{let e=this.error.split(`
56
+ `).map((e,t)=>t===0?`${z.default.yellow(H)} ${z.default.yellow(e)}`:` ${e}`).join(`
57
+ `);return n+z.default.yellow(V)+` `+this.options.map((e,n)=>{let r=this.value.includes(e.value),i=n===this.cursor;return i&&r?t(e,`active-selected`):r?t(e,`selected`):t(e,i?`active`:`inactive`)}).join(`
58
+ ${z.default.yellow(V)} `)+`
59
+ `+e+`
60
+ `}default:return`${n}${z.default.cyan(V)} ${this.options.map((e,n)=>{let r=this.value.includes(e.value),i=n===this.cursor;return i&&r?t(e,`active-selected`):r?t(e,`selected`):t(e,i?`active`:`inactive`)}).join(`
61
+ ${z.default.cyan(V)} `)}
62
+ ${z.default.cyan(H)}
63
+ `}}}).prompt()},zn=e=>{let t=(e,t,n=[])=>{let r=e.label??String(e.value),i=typeof e.group==`string`,a=i&&(n[n.indexOf(e)+1]??{group:!0}),o=i&&a.group===!0,s=i?`${o?H:V} `:``;return t===`active`?`${z.default.dim(s)}${z.default.cyan(Sn)} ${r} ${e.hint?z.default.dim(`(${e.hint})`):``}`:t===`group-active`?`${s}${z.default.cyan(Sn)} ${z.default.dim(r)}`:t===`group-active-selected`?`${s}${z.default.green(U)} ${z.default.dim(r)}`:t===`selected`?`${z.default.dim(s)}${z.default.green(U)} ${z.default.dim(r)}`:t===`cancelled`?`${z.default.strikethrough(z.default.dim(r))}`:t===`active-selected`?`${z.default.dim(s)}${z.default.green(U)} ${r} ${e.hint?z.default.dim(`(${e.hint})`):``}`:t===`submitted`?`${z.default.dim(r)}`:`${z.default.dim(s)}${z.default.dim(Cn)} ${z.default.dim(r)}`};return new Bt({options:e.options,initialValues:e.initialValues,required:e.required??!0,cursorAt:e.cursorAt,validate(e){if(this.required&&e.length===0)return`Please select at least one option.
64
+ ${z.default.reset(z.default.dim(`Press ${z.default.gray(z.default.bgWhite(z.default.inverse(` space `)))} to select, ${z.default.gray(z.default.bgWhite(z.default.inverse(` enter `)))} to submit`))}`},render(){let n=`${z.default.gray(V)}
65
+ ${W(this.state)} ${e.message}
66
+ `;switch(this.state){case`submit`:return`${n}${z.default.gray(V)} ${this.options.filter(({value:e})=>this.value.includes(e)).map(e=>t(e,`submitted`)).join(z.default.dim(`, `))}`;case`cancel`:{let e=this.options.filter(({value:e})=>this.value.includes(e)).map(e=>t(e,`cancelled`)).join(z.default.dim(`, `));return`${n}${z.default.gray(V)} ${e.trim()?`${e}
67
+ ${z.default.gray(V)}`:``}`}case`error`:{let e=this.error.split(`
68
+ `).map((e,t)=>t===0?`${z.default.yellow(H)} ${z.default.yellow(e)}`:` ${e}`).join(`
69
+ `);return`${n}${z.default.yellow(V)} ${this.options.map((e,n,r)=>{let i=this.value.includes(e.value)||e.group===!0&&this.isGroupSelected(`${e.value}`),a=n===this.cursor;return!a&&typeof e.group==`string`&&this.options[this.cursor].value===e.group?t(e,i?`group-active-selected`:`group-active`,r):a&&i?t(e,`active-selected`,r):i?t(e,`selected`,r):t(e,a?`active`:`inactive`,r)}).join(`
70
+ ${z.default.yellow(V)} `)}
71
+ ${e}
72
+ `}default:return`${n}${z.default.cyan(V)} ${this.options.map((e,n,r)=>{let i=this.value.includes(e.value)||e.group===!0&&this.isGroupSelected(`${e.value}`),a=n===this.cursor;return!a&&typeof e.group==`string`&&this.options[this.cursor].value===e.group?t(e,i?`group-active-selected`:`group-active`,r):a&&i?t(e,`active-selected`,r):i?t(e,`selected`,r):t(e,a?`active`:`inactive`,r)}).join(`
73
+ ${z.default.cyan(V)} `)}
74
+ ${z.default.cyan(H)}
75
+ `}}}).prompt()},Bn=e=>e.replace(fn(),``),Vn=(e=``,t=``)=>{let n=`
73
76
  ${e}
74
77
  `.split(`
75
- `),i=jt(t).length,$=Math.max(n.reduce((r,y)=>(y=jt(y),y.length>r?y.length:r),0),i)+2,p=n.map((r)=>`${_.default.gray(R)} ${_.default.dim(r)}${" ".repeat($-jt(r).length)}${_.default.gray(R)}`).join(`
76
- `);process.stdout.write(`${_.default.gray(R)}
77
- ${_.default.green(Ue)} ${_.default.reset(t)} ${_.default.gray(Rr.repeat(Math.max($-i-1,1))+li)}
78
- ${p}
79
- ${_.default.gray(fi+Rr.repeat($+2)+gi)}
80
- `)},w$=(e="")=>{process.stdout.write(`${_.default.gray(D)} ${_.default.red(e)}
81
-
82
- `)},h$=(e="")=>{process.stdout.write(`${_.default.gray(ai)} ${e}
83
- `)},A$=(e="")=>{process.stdout.write(`${_.default.gray(R)}
84
- ${_.default.gray(D)} ${e}
85
-
86
- `)},oe,u$=()=>{let e=Rt?["◒","◐","◓","◑"]:["•","o","O","0"],t=Rt?80:120,n,i,$=!1,p="",r=(b="")=>{$=!0,n=jr(),p=b.replace(/\.+$/,""),process.stdout.write(`${_.default.gray(R)}
87
- `);let w=0,S=0;i=setInterval(()=>{let q=_.default.magenta(e[w]),o=".".repeat(Math.floor(S)).slice(0,3);process.stdout.write(We.cursor.move(-999,0)),process.stdout.write(We.erase.down(1)),process.stdout.write(`${q} ${p}${o}`),w=w+1<e.length?w+1:0,S=S<e.length?S+0.125:0},t)},y=(b="",w=0)=>{p=b??p,$=!1,clearInterval(i);let S=w===0?_.default.green(Ue):w===1?_.default.red(Jr):_.default.red(Wr);process.stdout.write(We.cursor.move(-999,0)),process.stdout.write(We.erase.down(1)),process.stdout.write(`${S} ${p}
88
- `),n()},m=(b="")=>{p=b??p},x=(b)=>{let w=b>1?"Something went wrong":"Canceled";$&&y(w,b)};return process.on("uncaughtExceptionMonitor",()=>x(2)),process.on("unhandledRejection",()=>x(2)),process.on("SIGINT",()=>x(1)),process.on("SIGTERM",()=>x(1)),process.on("exit",x),{start:r,stop:y,message:m}},k$=async(e,t)=>{let n={},i=Object.keys(e);for(let $ of i){let p=e[$],r=await p({results:n})?.catch((y)=>{throw y});if(typeof t?.onCancel=="function"&&ve(r)){n[$]="canceled",t.onCancel({results:n});continue}n[$]=r}return n};var Ye=Ot(()=>{Bt();Bt();_=ne(ht(),1),We=ne(bt(),1);Rt=si(),Fi=v("◆","*"),Jr=v("■","x"),Wr=v("▲","x"),Ue=v("◇","o"),ai=v("┌","T"),R=v("│","|"),D=v("└","—"),Jt=v("●",">"),Wt=v("○"," "),Tt=v("◻","[•]"),Xe=v("◼","[+]"),Tr=v("◻","[ ]"),Di=v("▪","•"),Rr=v("─","-"),li=v("╮","+"),fi=v("├","+"),gi=v("╯","+"),e$=v("●","•"),t$=v("◆","*"),r$=v("▲","!"),n$=v("■","x"),oe={message:(e="",{symbol:t=_.default.gray(R)}={})=>{let n=[`${_.default.gray(R)}`];if(e){let[i,...$]=e.split(`
89
- `);n.push(`${t} ${i}`,...$.map((p)=>`${_.default.gray(R)} ${p}`))}process.stdout.write(`${n.join(`
78
+ `),r=Bn(t).length,i=Math.max(n.reduce((e,t)=>(t=Bn(t),t.length>e?t.length:e),0),r)+2,a=n.map(e=>`${z.default.gray(V)} ${z.default.dim(e)}${` `.repeat(i-Bn(e).length)}${z.default.gray(V)}`).join(`
79
+ `);process.stdout.write(`${z.default.gray(V)}
80
+ ${z.default.green(vn)} ${z.default.reset(t)} ${z.default.gray(Tn.repeat(Math.max(i-r-1,1))+En)}
81
+ ${a}
82
+ ${z.default.gray(Dn+Tn.repeat(i+2)+On)}
83
+ `)},Hn=(e=``)=>{process.stdout.write(`${z.default.gray(H)} ${z.default.red(e)}
84
+
85
+ `)},Un=(e=``)=>{process.stdout.write(`${z.default.gray(yn)} ${e}
86
+ `)},Wn=(e=``)=>{process.stdout.write(`${z.default.gray(V)}
87
+ ${z.default.gray(H)} ${e}
88
+
89
+ `)},G={message:(e=``,{symbol:t=z.default.gray(V)}={})=>{let n=[`${z.default.gray(V)}`];if(e){let[r,...i]=e.split(`
90
+ `);n.push(`${t} ${r}`,...i.map(e=>`${z.default.gray(V)} ${e}`))}process.stdout.write(`${n.join(`
90
91
  `)}
91
- `)},info:(e)=>{oe.message(e,{symbol:_.default.blue(e$)})},success:(e)=>{oe.message(e,{symbol:_.default.green(t$)})},step:(e)=>{oe.message(e,{symbol:_.default.green(Ue)})},warn:(e)=>{oe.message(e,{symbol:_.default.yellow(r$)})},warning:(e)=>{oe.warn(e)},error:(e)=>{oe.message(e,{symbol:_.default.red(n$)})}}});var h={SUCCESS:0,GENERAL:1,USAGE:2,AUTH:3,QUOTA:4,TIMEOUT:5,NETWORK:6,CONTENT_FILTER:10};class u extends Error{exitCode;hint;constructor(e,t=h.GENERAL,n){super(e);this.name="CLIError",this.exitCode=t,this.hint=n}toJSON(){return{error:{code:this.exitCode,message:this.message,...this.hint?{hint:this.hint}:{}}}}}function fe(e){return e.replace(/-([a-z])/g,(t,n)=>n.toUpperCase())}function In(e){let t=e.flag.match(/^--([a-z][a-z0-9-]*)/i);return t?fe(t[1]):null}function vn(e){if(e.type==="boolean")return!0;if(e.type==="string"||e.type==="number"||e.type==="array")return!1;return!e.flag.includes("<")&&!e.flag.includes("[")}function ct(e){let t=new Set,n=new Set,i=new Set;for(let $ of e){let p=In($);if(!p)continue;if(vn($))t.add(p);else if($.type==="number")n.add(p);else if($.type==="array")i.add(p)}return{booleans:t,numbers:n,arrays:i}}function Ct(e,t=[]){let n=ct(t),i=[],$=0;while($<e.length){let p=e[$];if(p==="--")break;if(p.startsWith("--")){let r=p.indexOf("="),y=r!==-1?p.slice(2,r):p.slice(2),m=fe(y);if(!n.booleans.has(m)&&r===-1)$+=2;else $+=1;continue}if(p.startsWith("-")){$++;continue}i.push(p),$++}return i}function ge(e,t){let n=ct(t),i={quiet:!1,verbose:!1,noColor:!1,yes:!1,dryRun:!1,help:!1,nonInteractive:!1,async:!1},$=0;while($<e.length){let p=e[$];if(p==="--help"||p==="-h"){i.help=!0,$++;continue}if(p==="--")break;if(p.startsWith("--")){let r=p.indexOf("="),y,m;if(r!==-1)y=p.slice(2,r),m=p.slice(r+1);else y=p.slice(2);let x=fe(y);if(n.booleans.has(x)){i[x]=!0,$++;continue}if(m===void 0)$++,m=e[$];if(m===void 0)throw new u(`Flag --${y} requires a value.`,h.USAGE);if(n.arrays.has(x)){let b=i[x];if(b)b.push(m);else i[x]=[m]}else if(n.numbers.has(x)){let b=Number(m);if(!Number.isFinite(b))throw new u(`Flag --${y} requires a finite number.`,h.USAGE);i[x]=b}else i[x]=m}$++}return i}var et={cn:"https://dashscope.aliyuncs.com",us:"https://dashscope-us.aliyuncs.com",intl:"https://dashscope-intl.aliyuncs.com"},Qe={cn:"https://help.aliyun.com/zh/model-studio",us:"https://help.aliyun.com/zh/model-studio",intl:"https://help.aliyun.com/zh/model-studio"},Un=new Set(["cn","us","intl"]),dn=new Set(["text","json"]);function Lt(e){if(!e||typeof e!=="object"||Array.isArray(e))return{};let t=e,n={};if(typeof t.api_key==="string")n.api_key=t.api_key;if(typeof t.region==="string"&&Un.has(t.region))n.region=t.region;if(typeof t.base_url==="string"&&t.base_url.startsWith("http"))n.base_url=t.base_url;if(typeof t.output==="string"&&dn.has(t.output))n.output=t.output;if(typeof t.output_dir==="string"&&t.output_dir.length>0)n.output_dir=t.output_dir;if(typeof t.timeout==="number"&&t.timeout>0)n.timeout=t.timeout;if(typeof t.default_text_model==="string"&&t.default_text_model.length>0)n.default_text_model=t.default_text_model;if(typeof t.default_video_model==="string"&&t.default_video_model.length>0)n.default_video_model=t.default_video_model;if(typeof t.default_image_model==="string"&&t.default_image_model.length>0)n.default_image_model=t.default_image_model;if(typeof t.default_speech_model==="string"&&t.default_speech_model.length>0)n.default_speech_model=t.default_speech_model;if(typeof t.default_omni_model==="string"&&t.default_omni_model.length>0)n.default_omni_model=t.default_omni_model;if(typeof t.access_key_id==="string"&&t.access_key_id.length>0)n.access_key_id=t.access_key_id;if(typeof t.access_key_secret==="string"&&t.access_key_secret.length>0)n.access_key_secret=t.access_key_secret;if(typeof t.workspace_id==="string"&&t.workspace_id.length>0)n.workspace_id=t.workspace_id;return n}function K(e){return{name:e.name,description:e.description,usage:e.usage,options:e.options,examples:e.examples,apiDocs:e.apiDocs,execute:e.run}}var Oe=[{flag:"--api-key <key>",description:"API key"},{flag:"--region <region>",description:"API region: cn (default), us, intl"},{flag:"--base-url <url>",description:"API base URL"},{flag:"--output <format>",description:"Output format: text, json"},{flag:"--timeout <seconds>",description:"Request timeout",type:"number"},{flag:"--quiet",description:"Suppress non-essential output"},{flag:"--verbose",description:"Print HTTP request/response details"},{flag:"--no-color",description:"Disable ANSI colors"},{flag:"--dry-run",description:"Dry run mode"},{flag:"--non-interactive",description:"Disable interactive prompts"},{flag:"--concurrent <n>",description:"Run N parallel requests (default: 1)",type:"number"},{flag:"--help",description:"Show help"},{flag:"--version",description:"Print version"}];async function V(e){if(e.apiKey)return{token:e.apiKey,method:"api-key",source:"flag"};if(e.fileApiKey)return{token:e.fileApiKey,method:"api-key",source:"config.json"};if(process.env.DASHSCOPE_API_KEY)return{token:process.env.DASHSCOPE_API_KEY,method:"api-key",source:"DASHSCOPE_API_KEY"};throw new u("No credentials found.",h.AUTH,`Log in: bl auth login --api-key sk-xxxxx
92
- Pass directly: --api-key sk-xxxxx
93
- Set env var: export DASHSCOPE_API_KEY=sk-xxxxx
94
- Get API Key: https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key`)}function tt(e,t,n){let i=t.error?.message||t.message||`HTTP ${e}`,$=t.error?.type||t.code;if(e===401||e===403||$==="InvalidApiKey"||$==="Unauthorized")return new u(`API key rejected (HTTP ${e}). ${i}`,h.AUTH,`Check status: bailian auth status
95
- Re-authenticate: bailian auth login --api-key sk-xxxxx
96
- Get API Key: https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key`);if(e===429||$==="Throttling"||$==="Throttling.RateQuota"||$==="Throttling.AllocationQuota")return new u(`Rate limit or quota exceeded. ${i}`,h.QUOTA,`Please wait and retry, or check your DashScope quota at
97
- https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key`);if(e===408||e===504)return new u(`Request timed out (HTTP ${e}).`,h.TIMEOUT,"Try increasing --timeout or retry later.");if($==="InvalidParameter"||$==="BadRequest")return new u(`Invalid parameter: ${i}`,h.USAGE);if($==="ModelNotFound"||$==="AccessDenied")return new u(`Model access denied or not found: ${i}`,h.AUTH,"Check model availability at https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key");if($==="DataInspectionFailed")return new u(`Content flagged by safety filter: ${i}`,h.CONTENT_FILTER);return new u(`API error: ${i} (HTTP ${e}${$?`, code: ${$}`:""})`,h.GENERAL)}import{homedir as Vt}from"os";function g(e){return e.length>8?`${e.slice(0,4)}...${e.slice(-4)}`:"***"}var Et=!1;var ee="\x1B[0m",xe="\x1B[2m",sn="\x1B[1m",Fn="\x1B[38;2;43;82;255m",an="\x1B[38;2;147;51;234m",Dn="\x1B[38;2;6;184;212m",ln="\x1B[38;2;236;72;153m";function fn(e){return e.startsWith(Vt())?e.replace(Vt(),"~"):e}function ce(e,t,n){if(e.quiet||Et||!process.stderr.isTTY)return;Et=!0;let i=e.configPath?fn(e.configPath):"~/.bailian/config.json",$=e.fileRegion?`${e.fileRegion} (file)`:"cn (default)",p=e.apiKey?"(flag)":"(file)",r=g(t),y=n?` ${xe}|${ee} ${xe}Model:${ee} ${an}${n}${ee}`:"";process.stderr.write(`${sn}${Fn}BAILIAN${ee} ${xe}${i}${ee} ${xe}|${ee} ${xe}Region:${ee} ${Dn}${$}${ee} ${xe}|${ee} ${xe}Key:${ee} ${ln}${r}${ee} ${xe}${p}${ee}${y}
98
- `)}var gn={t1:"public",t2:""},rt=JSON.stringify({channel:"bailian-cli",tags:gn});function d(){return{"x-dashscope-source-config":rt}}async function ye(e,t){let n=typeof FormData<"u"&&t.body instanceof FormData,i="0.1.2-beta.0",$={"User-Agent":"bailian-cli/0.1.2-beta.0",...d(),...t.headers};if(!n&&!$["Content-Type"])$["Content-Type"]="application/json";if(t.async)$["X-DashScope-Async"]="enable";if(t.ossResolve)$["X-DashScope-OssResourceResolve"]="enable";if(!t.noAuth){let m=await V(e);if($.Authorization=`Bearer ${m.token}`,e.verbose)process.stderr.write(`> ${t.method??"GET"} ${t.url}
99
- `),process.stderr.write(`> Auth: ${m.token.slice(0,8)}...
100
- `),process.stderr.write(`> x-dashscope-source-config: ${rt}
101
- `);let x=t.body&&typeof t.body==="object"&&"model"in t.body?String(t.body.model):void 0;ce(e,m.token,x)}let p=(t.timeout??e.timeout)*1000,r=await fetch(t.url,{method:t.method??"GET",headers:$,body:t.body?n?t.body:JSON.stringify(t.body):void 0,signal:AbortSignal.timeout(p)}),y=r.headers.get("x-request-id");if(e.verbose)process.stderr.write(`< ${r.status} ${r.statusText}
102
- `);if(y&&!e.quiet)process.stderr.write(`request_id: ${y}
103
- `);if(!r.ok){let m={};try{m=await r.json()}catch{}throw tt(r.status,m,t.url)}return r}async function Q(e,t){let n=await ye(e,t),i;try{i=await n.json()}catch{let $=n.headers.get("content-type")||"";throw new u(`API returned non-JSON response (${$||"unknown type"}). Server may be experiencing issues.`,h.GENERAL)}if(i.code&&typeof i.code==="string"&&i.code!=="200"&&i.code!=="Success")throw tt(200,{error:{message:i.message,type:i.code}},t.url);return i}var He="https://registry.npmjs.org",Be="bailian-cli";function be(e){return`${e}/compatible-mode/v1/chat/completions`}function It(e){return`${e}/api/v1/services/aigc/image-generation/generation`}function Ce(e){return`${e}/api/v1/services/aigc/multimodal-generation/generation`}function je(e){return`${e}/api/v1/services/aigc/video-generation/video-synthesis`}function a(e,t){return`${e}/api/v1/tasks/${t}`}function nt(e,t){return`${e}/api/v1/apps/${t}/completion`}function it(e){return`${e}/api/v2/apps/memory/add`}function $t(e){return`${e}/api/v2/apps/memory/memory_nodes/search`}function vt(e){return`${e}/api/v2/apps/memory/memory_nodes`}function Ze(e,t){return`${e}/api/v2/apps/memory/memory_nodes/${t}`}function Ut(e){return`${e}/api/v1/services/audio/tts/SpeechSynthesizer`}function dt(e){return`${e}/api/v1/services/audio/asr/transcription`}function pt(e){return`${e}/api/v2/apps/memory/profile_schemas`}function st(e,t){return`${e}/api/v2/apps/memory/profile_schemas/${t}/profiles`}function Ft(e){return`${e}/api/v1/mcps/WebSearch/mcp`}function at(e){if(e===null||e===void 0)return"";if(typeof e==="string")return e;if(typeof e==="number"||typeof e==="boolean")return String(e);if(Array.isArray(e)){if(e.length===0)return"(empty)";if(typeof e[0]==="object"&&e[0]!==null)return ei(e);return e.map(String).join(`
104
- `)}if(typeof e==="object")return yt(e);return String(e)}function yt(e,t=0){let n=" ".repeat(t),i=[];for(let[$,p]of Object.entries(e)){if(p===null||p===void 0)continue;if(Array.isArray(p)){i.push(`${n}${$}:`);for(let r of p)if(typeof r==="object"&&r!==null)i.push(`${n} - ${yt(r,t+4).trimStart()}`);else i.push(`${n} - ${String(r)}`)}else if(typeof p==="object")i.push(`${n}${$}:`),i.push(yt(p,t+2));else i.push(`${n}${$}: ${String(p)}`)}return i.join(`
105
- `)}function ei(e){if(e.length===0)return"(empty)";let t=Object.keys(e[0]),n=t.map((r)=>Math.max(r.length,...e.map((y)=>String(y[r]??"").length))),i=t.map((r,y)=>r.toUpperCase().padEnd(n[y])).join(" "),$=n.map((r)=>"-".repeat(r)).join(" "),p=e.map((r)=>t.map((y,m)=>String(r[y]??"").padEnd(n[m])).join(" "));return[i,$,...p].join(`
106
- `)}function Dt(e){return JSON.stringify(e,null,2)}function B(e){if(e==="json"||e==="text")return e;if(!process.stdout.isTTY)return"json";return"text"}function ti(e,t){switch(t){case"json":return Dt(e);case"text":return at(e)}}function A(e,t){process.stdout.write(ti(e,t)+`
107
- `)}function N(e){process.stdout.write(e+`
108
- `)}import{homedir as ri}from"os";import{join as lt}from"path";var ni=".bailian";function Re(){if(process.env.BAILIAN_CONFIG_DIR)return process.env.BAILIAN_CONFIG_DIR;return lt(ri(),ni)}function ie(){return lt(Re(),"config.json")}async function _t(){let e=Re();await(await import("fs/promises")).mkdir(e,{recursive:!0,mode:448})}import{readFileSync as ii,writeFileSync as $i,renameSync as pi,existsSync as yi}from"fs";function te(){let e=ie();if(!yi(e))return{};try{return Lt(JSON.parse(ii(e,"utf-8")))}catch(t){let n=t;if(n instanceof SyntaxError||n.message.includes("JSON"))process.stderr.write(`Warning: config file is corrupted. Run 'bl config set' to reset.
109
- `);return{}}}async function Je(e){await _t();let t=ie(),n=t+".tmp";$i(n,JSON.stringify(e,null,2)+`
110
- `,{mode:384}),pi(n,t)}function mt(e){let t=te(),n=e.apiKey||void 0,i=t.api_key,$=e.region||process.env.DASHSCOPE_REGION||void 0,p=t.region,r=$||p||"cn",y=e.baseUrl||process.env.DASHSCOPE_BASE_URL||t.base_url||et[r]||et.cn,m=B(e.output||process.env.DASHSCOPE_OUTPUT||t.output),x=process.env.DASHSCOPE_TIMEOUT?Number(process.env.DASHSCOPE_TIMEOUT):void 0,b=x!==void 0&&Number.isFinite(x)&&x>0?x:void 0,w=e.timeout??b??t.timeout??300;if(!Number.isFinite(w)||w<=0)throw new u("Timeout must be a positive finite number.",h.USAGE);return{apiKey:n,fileApiKey:i,fileRegion:t.region,configPath:ie(),region:r,baseUrl:y,output:m,outputDir:t.output_dir||void 0,timeout:w,defaultTextModel:t.default_text_model,defaultVideoModel:t.default_video_model,defaultImageModel:t.default_image_model,defaultSpeechModel:t.default_speech_model,defaultOmniModel:t.default_omni_model,accessKeyId:process.env.ALIBABA_CLOUD_ACCESS_KEY_ID||t.access_key_id||void 0,accessKeySecret:process.env.ALIBABA_CLOUD_ACCESS_KEY_SECRET||t.access_key_secret||void 0,workspaceId:process.env.BAILIAN_WORKSPACE_ID||t.workspace_id||void 0,verbose:e.verbose||process.env.DASHSCOPE_VERBOSE==="1",quiet:e.quiet||!1,noColor:e.noColor||process.env.NO_COLOR!==void 0||!process.stdout.isTTY,yes:e.yes||!1,dryRun:e.dryRun||!1,nonInteractive:e.nonInteractive||!1,async:e.async||!1}}function Y(e){if(e?.nonInteractive===!0)return!1;if(process.env.CI)return!1;return process.stdout.isTTY===!0&&process.stdin.isTTY===!0}var Mr=K({name:"auth login",description:"Authenticate with API key",usage:"bl auth login --api-key <key>",options:[{flag:"--api-key <key>",description:"DashScope API key to store"}],examples:["bl auth login --api-key sk-xxxxx"],async run(e,t){let n=process.env.DASHSCOPE_API_KEY;if(n&&!t.apiKey){let $=g(n);if(Y({nonInteractive:e.nonInteractive})){let{confirm:p}=await Promise.resolve().then(() => (Ye(),Pe));if(!await p({message:`Detected DASHSCOPE_API_KEY in environment (${$}).
111
- You are already authenticated via env.
112
- Do you still want to configure local persistent credentials?`,initialValue:!1}))process.stdout.write(`Login skipped. Using environment variables.
113
- `),process.exit(0)}else process.stderr.write(`Warning: DASHSCOPE_API_KEY is already set in environment.
114
- `)}let i=t.apiKey||e.apiKey;if(!i)throw new u("--api-key is required.",h.USAGE,"bl auth login --api-key sk-xxxxx");if(!e.dryRun){process.stderr.write("Testing key... ");try{let w={...e,apiKey:i};await Q(w,{url:be(w.baseUrl),method:"POST",body:{model:"qwen3.6-plus",messages:[{role:"user",content:"hi"}],max_tokens:1}}),process.stderr.write(`Valid
115
- `)}catch{throw new u("API key validation failed.",h.AUTH,`Check that your key is valid.
116
- Get API Key: https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key`)}let $=te();$.api_key=i,await Je($),process.stderr.write(`API key saved to ${ie()}
117
-
118
- `);let p=g(i);process.stderr.write(`To make the key available to all tools in this shell, run:
92
+ `)},info:e=>{G.message(e,{symbol:z.default.blue(kn)})},success:e=>{G.message(e,{symbol:z.default.green(An)})},step:e=>{G.message(e,{symbol:z.default.green(vn)})},warn:e=>{G.message(e,{symbol:z.default.yellow(jn)})},warning:e=>{G.warn(e)},error:e=>{G.message(e,{symbol:z.default.red(Mn)})}},Gn=()=>{let e=mn?[`◒`,`◐`,`◓`,`◑`]:[`•`,`o`,`O`,`0`],t=mn?80:120,n,r,i=!1,a=``,o=(o=``)=>{i=!0,n=it(),a=o.replace(/\.+$/,``),process.stdout.write(`${z.default.gray(V)}
93
+ `);let s=0,c=0;r=setInterval(()=>{let t=z.default.magenta(e[s]),n=`.`.repeat(Math.floor(c)).slice(0,3);process.stdout.write(pn.cursor.move(-999,0)),process.stdout.write(pn.erase.down(1)),process.stdout.write(`${t} ${a}${n}`),s=s+1<e.length?s+1:0,c=c<e.length?c+.125:0},t)},s=(e=``,t=0)=>{a=e??a,i=!1,clearInterval(r);let o=t===0?z.default.green(vn):t===1?z.default.red(gn):z.default.red(_n);process.stdout.write(pn.cursor.move(-999,0)),process.stdout.write(pn.erase.down(1)),process.stdout.write(`${o} ${a}
94
+ `),n()},c=(e=``)=>{a=e??a},l=e=>{i&&s(e>1?`Something went wrong`:`Canceled`,e)};return process.on(`uncaughtExceptionMonitor`,()=>l(2)),process.on(`unhandledRejection`,()=>l(2)),process.on(`SIGINT`,()=>l(1)),process.on(`SIGTERM`,()=>l(1)),process.on(`exit`,l),{start:o,stop:s,message:c}},Kn=async(e,t)=>{let n={},r=Object.keys(e);for(let i of r){let r=e[i],a=await r({results:n})?.catch(e=>{throw e});if(typeof t?.onCancel==`function`&&nt(a)){n[i]=`canceled`,t.onCancel({results:n});continue}n[i]=a}return n}}));async function K(e){if(!_())return;let{defaultValue:t,message:n}=e,r=await(await Promise.resolve().then(()=>(qn(),un))).text({message:n,default:t,placeholder:t});if(typeof r!=`symbol`)return r}async function Jn(e){if(!_())return;let{message:t,initialValue:n}=e,r=await(await Promise.resolve().then(()=>(qn(),un))).confirm({message:t,initialValue:n});if(typeof r!=`symbol`)return r}async function Yn(e){if(!_())return;let{message:t,choices:n,defaultValue:r}=e,i=await(await Promise.resolve().then(()=>(qn(),un))).select({message:t,initialValue:r,options:n});if(typeof i!=`symbol`)return i}function q(t,r){throw new e(`Missing required argument: --${t}\nHint: In non-interactive (CI / agent) environments all required flags must be provided.\n In an interactive terminal, run without --${t} and the CLI will prompt for it.`,n.USAGE,r)}const Xn=`https://bailian.console.aliyun.com`,J=`${`${Xn}/cn-beijing`}/?tab=app#/api-key`;var Zn=c({name:`auth login`,description:`Authenticate with API key`,usage:`bl auth login --api-key <key>`,options:[{flag:`--api-key <key>`,description:`DashScope API key to store`}],examples:[`bl auth login --api-key sk-xxxxx`],async run(t,r){let i=process.env.DASHSCOPE_API_KEY;if(i&&!r.apiKey){let e=x(i);_({nonInteractive:t.nonInteractive})?await Jn({message:`Detected DASHSCOPE_API_KEY in environment (${e}).\nYou are already authenticated via env.\nDo you still want to configure local persistent credentials?`,initialValue:!1})||(process.stdout.write(`Login skipped. Using environment variables.
95
+ `),process.exit(0)):process.stderr.write(`Warning: DASHSCOPE_API_KEY is already set in environment.
96
+ `)}let a=r.apiKey||t.apiKey;if(!a)throw new e(`--api-key is required.`,n.USAGE,`bl auth login --api-key sk-xxxxx`);if(t.dryRun)N(`Would validate and save API key.`);else{process.stderr.write(`Testing key... `);try{let e={...t,apiKey:a};await T(e,{url:o(e.baseUrl),method:`POST`,body:{model:`qwen3.6-plus`,messages:[{role:`user`,content:`hi`}],max_tokens:1}}),process.stderr.write(`Valid
97
+ `)}catch{throw new e(`API key validation failed.`,n.AUTH,`Check that your key is valid.\nGet API Key: ${J}`)}let r=w();r.api_key=a,await me(r),process.stderr.write(`API key saved to ${m()}\n\n`);let i=x(a);process.stderr.write(`To make the key available to all tools in this shell, run:
119
98
 
120
- `),process.stderr.write(` export DASHSCOPE_API_KEY=${i}
99
+ `),process.stderr.write(` export DASHSCOPE_API_KEY=${a}\n\n`),process.stderr.write(`Or add it to your shell profile (~/.zshrc / ~/.bashrc) for persistence:
121
100
 
122
- `),process.stderr.write(`Or add it to your shell profile (~/.zshrc / ~/.bashrc) for persistence:
123
-
124
- `),process.stderr.write(` echo 'export DASHSCOPE_API_KEY=${p}' >> ~/.zshrc
125
-
126
- `);let r=process.stderr.isTTY,y=r?"\x1B[38;2;147;51;234m":"",m=r?"\x1B[36m":"",x=r?"\x1B[2m":"",b=r?"\x1B[0m":"";process.stderr.write(`${y}You're all set!${b} Here are some things to try:
127
-
128
- `),process.stderr.write(`${m}▸ Direct CLI usage:${b}
129
- `),process.stderr.write(` bl text chat --message "用中文写一首关于春天的诗"
101
+ `),process.stderr.write(` echo 'export DASHSCOPE_API_KEY=${i}' >> ~/.zshrc\n\n`);let s=process.stderr.isTTY,c=s?`\x1B[38;2;147;51;234m`:``,l=s?`\x1B[36m`:``,u=s?`\x1B[2m`:``,d=s?`\x1B[0m`:``;process.stderr.write(`${c}You're all set!${d} Here are some things to try:\n\n`),process.stderr.write(`${l}▸ Direct CLI usage:${d}\n`),process.stderr.write(` bl text chat --message "用中文写一首关于春天的诗"
130
102
  `),process.stderr.write(` bl image generate --prompt "A cat in space suit, digital art"
131
103
  `),process.stderr.write(` bl speech synthesize --text "你好世界" --voice zhiyan
132
104
 
133
- `),process.stderr.write(`${m}▸ In AI coding assistant ${x}(Qoder / Cursor / Claude Code / ...)${b}${m}, just say:${b}
134
- `),process.stderr.write(` 帮我生成一套鸭舌帽的亚马逊电商主图(白底 + 场景图 + 模特上身图)
105
+ `),process.stderr.write(`${l}▸ In AI coding assistant ${u}(Qoder / Cursor / Claude Code / ...)${d}${l}, just say:${d}\n`),process.stderr.write(` 帮我生成一套鸭舌帽的亚马逊电商主图(白底 + 场景图 + 模特上身图)
135
106
  `),process.stderr.write(` 帮我生成一段 3 分钟的幽默相声音频
136
107
  `),process.stderr.write(` 帮我生成一套小红帽故事绘本 PDF(含插图)
137
108
  `),process.stderr.write(` 帮我分析这个视频的内容并写一篇小红书文案
138
109
 
139
- `)}else N("Would validate and save API key.")}});var Qr=K({name:"auth status",description:"Show current authentication state",usage:"bl auth status",examples:["bl auth status","bl auth status --output json"],async run(e,t){try{let n=await V(e),i=B(e.output);if(i!=="text"){let $={method:n.method,source:n.source,key:g(n.token)};A($,i);return}N("Authentication Status:"),N(` Method: ${n.method}`),N(` Source: ${n.source}`),N(` Key: ${g(n.token)}`)}catch{let n=B(e.output);A({authenticated:!1,message:"Not authenticated.",hint:`Run: bailian auth login --api-key sk-xxxxx
140
- Or set $DASHSCOPE_API_KEY
141
- Get API Key: https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key`},n)}}});import{readFileSync as Hr,writeFileSync as q$,renameSync as o$,existsSync as Zr}from"fs";function zr(){let e=ie();if(!Zr(e))return null;try{let t=Hr(e,"utf-8"),n=JSON.parse(t);if(typeof n.api_key==="string"&&n.api_key.length>0)return n.api_key;return null}catch{return null}}async function Xr(){let e=ie();if(!Zr(e))return;try{let t=JSON.parse(Hr(e,"utf-8"));delete t.api_key;let n=e+".tmp";q$(n,JSON.stringify(t,null,2)+`
142
- `,{mode:384}),o$(n,e)}catch{}}var Pr=K({name:"auth logout",description:"Clear stored credentials",usage:"bl auth logout [--yes] [--dry-run]",options:[{flag:"--yes",description:"Skip confirmation prompt"}],examples:["bl auth logout","bl auth logout --dry-run","bl auth logout --yes"],async run(e,t){let n=!!zr();if(e.dryRun){if(n)N("Would clear api_key from ~/.bailian/config.json");else N("No credentials to clear.");N("No changes made.");return}if(n)await Xr(),process.stderr.write(`Cleared api_key from ~/.bailian/config.json
143
- `);else process.stderr.write(`No credentials to clear.
144
- `)}});async function*Ae(e){let t=e.body?.getReader();if(!t)return;let n=new TextDecoder,i="";try{while(!0){let{done:$,value:p}=await t.read();if($)break;i+=n.decode(p,{stream:!0});let r=i.split(`
145
- `);i=r.pop()||"";let y={};for(let m of r){if(m===""){if(y.data!==void 0)yield{data:y.data,event:y.event,id:y.id};y={};continue}if(m.startsWith(":"))continue;let x=m.indexOf(":");if(x===-1)continue;let b=m.slice(0,x),w=m.slice(x+1).trimStart();switch(b){case"data":y.data=y.data!==void 0?`${y.data}
146
- ${w}`:w;break;case"event":y.event=w;break;case"id":y.id=w;break}}}if(i.trim()&&i.includes("data:")){let $=i.indexOf(":");if($!==-1)yield{data:i.slice($+1).trimStart()}}}finally{t.releaseLock()}}import{readFileSync as Mt}from"fs";async function L(e){if(!Y())return;let{defaultValue:t,message:n}=e,$=await(await Promise.resolve().then(() => (Ye(),Pe))).text({message:n,default:t,placeholder:t});if(typeof $==="symbol")return;return $}async function Yr(e){if(!Y())return;let{message:t}=e,i=await(await Promise.resolve().then(() => (Ye(),Pe))).confirm({message:t});if(typeof i==="symbol")return;return i}async function Or(e){if(!Y())return;let{message:t,choices:n,defaultValue:i}=e,p=await(await Promise.resolve().then(() => (Ye(),Pe))).select({message:t,initialValue:i,options:n});if(typeof p==="symbol")return;return p}function W(e,t){throw new u(`Missing required argument: --${e}
147
- Hint: In non-interactive (CI / agent) environments all required flags must be provided.
148
- In an interactive terminal, run without --${e} and the CLI will prompt for it.`,h.USAGE,t)}function G$(e){let t=[],n;if(e.system)n=e.system;if(e.messagesFile){let i=e.messagesFile,$=i==="-"?Mt("/dev/stdin","utf-8"):Mt(i,"utf-8"),p=JSON.parse($);for(let r of p)if(r.role==="system")n=typeof r.content==="string"?r.content:"";else t.push(r)}if(e.message){let i=new Set(["system","user","assistant"]),$=e.message;for(let p of $){let r=p.indexOf(":"),y=r!==-1?p.slice(0,r):"";if(i.has(y)){let m=p.slice(r+1);if(y==="system")n=m;else t.push({role:y,content:m})}else t.push({role:"user",content:p})}}return{system:n,messages:t}}var cr=K({name:"text chat",description:"Send a chat completion (OpenAI compatible, DashScope)",apiDocs:"/compatibility-of-openai-with-dashscope",usage:"bl text chat --message <text> [flags]",options:[{flag:"--model <model>",description:"Model ID (default: qwen3.6-plus)"},{flag:"--message <text>",description:"Message text (repeatable, prefix role: to set role)",required:!0,type:"array"},{flag:"--messages-file <path>",description:"JSON file with messages array (use - for stdin)"},{flag:"--system <text>",description:"System prompt"},{flag:"--max-tokens <n>",description:"Maximum tokens to generate (default: 4096)",type:"number"},{flag:"--temperature <n>",description:"Sampling temperature (0.0, 2.0]",type:"number"},{flag:"--top-p <n>",description:"Nucleus sampling threshold",type:"number"},{flag:"--stream",description:"Stream response tokens (default: on in TTY)"},{flag:"--tool <json-or-path>",description:"Tool definition as JSON or file path (repeatable)",type:"array"},{flag:"--enable-thinking",description:"Enable thinking/reasoning mode (for qwen3/qwq models)"},{flag:"--thinking-budget <n>",description:"Max tokens for thinking (default: 4096)",type:"number"}],examples:['bl text chat --message "What is Qwen?"','bl text chat --model qwen-max --system "You are a coding assistant." --message "Write fizzbuzz in Python"','bl text chat --message "Hello" --message "assistant:Hi!" --message "How are you?"',"cat conversation.json | bl text chat --messages-file - --stream",'bl text chat --message "Hello" --output json','bl text chat --model qwq-plus --message "Solve 1+1" --enable-thinking'],async run(e,t){let{system:n,messages:i}=G$(t),$=i;if($.length===0)if(Y({nonInteractive:e.nonInteractive})){let w=await L({message:"Enter your message:"});if(!w)process.stderr.write(`Chat cancelled.
149
- `),process.exit(1);$=[{role:"user",content:w}]}else W("message","bl text chat --message <text>");let p=t.model||e.defaultTextModel||"qwen3.6-plus",r=t.stream===!0||t.stream===void 0&&process.stdout.isTTY,y=B(e.output),m=[];if(n)m.push({role:"system",content:n});m.push(...$);let x={model:p,messages:m,max_tokens:t.maxTokens??4096,stream:r};if(t.temperature!==void 0)x.temperature=t.temperature;if(t.topP!==void 0)x.top_p=t.topP;if(t.enableThinking){if(x.enable_thinking=!0,t.thinkingBudget!==void 0)x.thinking_budget=t.thinkingBudget}if(t.tool){let w=t.tool.map((S)=>{try{return JSON.parse(S)}catch{let q=Mt(S,"utf-8");return JSON.parse(q)}});x.tools=w}if(e.dryRun){A({request:x},y);return}let b=be(e.baseUrl);if(r){let w=await ye(e,{url:b,method:"POST",body:x,stream:!0}),S="",q=!1,o=y==="text",k=e.noColor?"":"\x1B[2m",G=e.noColor?"":"\x1B[0m",z=process.stdout.isTTY,J=y==="json"?process.stderr:z?process.stdout:process.stderr,Z=process.stdout;for await(let j of Ae(w)){if(j.data==="[DONE]")break;try{let T=JSON.parse(j.data);for(let X of T.choices){let U=X.delta;if(U.reasoning_content){if(o&&!q)q=!0,J.write(`${k}Thinking:
150
- `);if(o)J.write(U.reasoning_content)}if(U.content){if(o&&q)J.write(`${G}
151
-
152
- Response:
153
- `),q=!1;if(S+=U.content,o)Z.write(U.content)}}}catch{}}if(q)J.write(G);if(y==="json")A({content:S},y);else Z.write(`
154
- `)}else{let w=await Q(e,{url:b,method:"POST",body:x}),S=w.choices?.[0]?.message?.content??"";if(e.quiet||y==="text")N(S);else A(w,y)}}});import{writeFileSync as Q$}from"fs";import{existsSync as K$,mkdirSync as N$}from"fs";import{join as Cr}from"path";import{homedir as B$}from"os";var j$=()=>Cr(B$(),"bailian-output");function l(e,t){let n=t?.flagDir||e.outputDir||j$(),i=t?.subDir?Cr(n,t.subDir):n;if(!K$(i))N$(i,{recursive:!0});return i}import{existsSync as Lr,readFileSync as R$,statSync as J$}from"fs";import{basename as Vr}from"path";var W$="https://dashscope.aliyuncs.com/api/v1/uploads";async function T$(e,t){let n=`${W$}?action=getPolicy&model=${encodeURIComponent(t)}`,i=await fetch(n,{headers:{Authorization:`Bearer ${e}`,"Content-Type":"application/json",...d()},signal:AbortSignal.timeout(15000)});if(!i.ok){let p=await i.text().catch(()=>"");throw new u(`Failed to get upload policy (HTTP ${i.status}): ${p}`,h.GENERAL)}return(await i.json()).data}async function M$(e,t,n){let i=Vr(t),$=`${e.upload_dir}/${i}`,p=R$(t),r=new FormData;r.append("OSSAccessKeyId",e.oss_access_key_id),r.append("Signature",e.signature),r.append("policy",e.policy),r.append("x-oss-object-acl",e.x_oss_object_acl),r.append("x-oss-forbid-overwrite",e.x_oss_forbid_overwrite),r.append("key",$),r.append("success_action_status","200"),r.append("file",new Blob([p]),i);let y=await fetch(e.upload_host,{method:"POST",headers:{...d()},body:r,signal:AbortSignal.timeout(120000)});if(!y.ok){let m=await y.text().catch(()=>"");throw new u(`Failed to upload file to OSS (HTTP ${y.status}): ${m}`,h.GENERAL)}return`oss://${$}`}async function Qt(e){let{apiKey:t,model:n,filePath:i,quiet:$=!1}=e;if(!Lr(i))throw new u(`File not found: ${i}`,h.USAGE);let p=J$(i);if(!p.isFile())throw new u(`Not a file: ${i}`,h.USAGE);if(!$){let m=(p.size/1048576).toFixed(1);process.stderr.write(`Uploading ${Vr(i)} (${m} MB) for model ${n}...
155
- `)}let r=await T$(t,n),y=await M$(r,i,$);if(!$)process.stderr.write(`Upload complete: ${y}
156
- `);return y}function de(e){if(e.startsWith("http://")||e.startsWith("https://"))return!1;if(e.startsWith("oss://"))return!1;if(e.startsWith("data:"))return!1;return Lr(e)}async function E(e,t,n,i){if(!de(e))return e;return Qt({apiKey:t,model:n,filePath:e,quiet:i})}var H$=["Chelsie","Cherry","Ethan","Serena","Tina"];function Z$(e){let t=Buffer.alloc(44);return t.write("RIFF",0),t.writeUInt32LE(36+e,4),t.write("WAVE",8),t.write("fmt ",12),t.writeUInt32LE(16,16),t.writeUInt16LE(1,20),t.writeUInt16LE(1,22),t.writeUInt32LE(24000,24),t.writeUInt32LE(48000,28),t.writeUInt16LE(2,32),t.writeUInt16LE(16,34),t.write("data",36),t.writeUInt32LE(e,40),t}var Er=K({name:"omni",description:"Multimodal chat with text + audio output (Qwen-Omni)",apiDocs:"/model-studio/qwen-omni",usage:"bl omni --message <text> [flags]",options:[{flag:"--message <text>",description:"Message text (repeatable, prefix role: to set role)",required:!0,type:"array"},{flag:"--model <model>",description:"Model ID (default: qwen3.5-omni-plus)"},{flag:"--system <text>",description:"System prompt"},{flag:"--image <url>",description:"Image URL or local file (repeatable)",type:"array"},{flag:"--audio <url>",description:"Audio URL or local file (repeatable)",type:"array"},{flag:"--video <url>",description:"Video file URL / local path, or comma-separated frame URLs",type:"array"},{flag:"--voice <voice>",description:`Output voice (default: Cherry). Options: ${H$.join(", ")}`},{flag:"--audio-format <fmt>",description:"Audio output format (default: wav)"},{flag:"--audio-out <path>",description:"Save audio to file (default: auto-generate)"},{flag:"--text-only",description:"Output text only, no audio generation"},{flag:"--max-tokens <n>",description:"Maximum tokens to generate",type:"number"},{flag:"--temperature <n>",description:"Sampling temperature (0.0, 2.0]",type:"number"}],examples:['bl omni --message "你好,你是谁?"','bl omni --message "描述这张图片" --image ./photo.jpg','bl omni --message "这段音频在说什么?" --audio https://example.com/audio.wav','bl omni --message "总结这个视频" --video https://example.com/video.mp4','bl omni --message "这个视频讲了什么" --video ./local-video.mp4 --text-only','bl omni --message "用四川话回答:今天天气怎么样" --voice Serena','bl omni --message "Hello" --text-only --output json','bl omni --message "朗读这段话" --audio-out greeting.wav'],async run(e,t){let n=[];if(t.message)n=t.message;if(n.length===0)if(Y({nonInteractive:e.nonInteractive})){let M=await L({message:"Enter your message:"});if(!M)process.stderr.write(`Omni chat cancelled.
157
- `),process.exit(1);n=[M]}else W("message","bl text omni --message <text>");let i=t.model||e.defaultOmniModel||"qwen3.5-omni-plus",$=t.voice||"Cherry",p=t.audioFormat||"wav",r=t.textOnly===!0,y=B(e.output),m=[];if(t.system)m.push({role:"system",content:t.system});let x=new Set(["system","user","assistant"]);for(let M of n){let O=M.indexOf(":"),P=O!==-1?M.slice(0,O):"";if(x.has(P)){let I=M.slice(O+1);if(P==="system")m.push({role:"system",content:I});else m.push({role:P,content:I})}else m.push({role:"user",content:M})}let b=t.image||[],w=t.audio||[],S=t.video||[],q=!1,o=[],k=[],G=[];if(b.length>0||w.length>0||S.length>0){let M=await V(e);for(let O of b){let P=await E(O,M.token,i,e.quiet);if(P.startsWith("oss://"))q=!0;o.push(P)}for(let O of w){let P=await E(O,M.token,i,e.quiet);if(P.startsWith("oss://"))q=!0;k.push(P)}for(let O of S)if(O.includes(",")){let P=O.split(",").map((I)=>I.trim()).filter(Boolean);for(let I of P){let Ne=await E(I,M.token,i,e.quiet);if(Ne.startsWith("oss://"))q=!0;G.push(`frame:${Ne}`)}}else{let P=await E(O,M.token,i,e.quiet);if(P.startsWith("oss://"))q=!0;G.push(P)}}if(o.length>0||k.length>0||G.length>0){for(let M=m.length-1;M>=0;M--)if(m[M].role==="user"){let O=m[M].content,P=[];if(typeof O==="string")P.push({type:"text",text:O});else if(Array.isArray(O))P.push(...O);for(let f of o)P.push({type:"image_url",image_url:{url:f}});for(let f of k)P.push({type:"audio_url",audio_url:{url:f}});let I=G.filter((f)=>f.startsWith("frame:")).map((f)=>f.slice(6)),Ne=G.filter((f)=>!f.startsWith("frame:"));if(I.length>0)P.push({type:"video",video:I});for(let f of Ne)P.push({type:"video_url",video_url:{url:f}});m[M]={role:"user",content:P};break}}let J={model:i,messages:m,stream:!0,stream_options:{include_usage:!0}};if(!r)J.modalities=["text","audio"],J.audio={voice:$,format:p};if(t.maxTokens!==void 0)J.max_tokens=t.maxTokens;if(t.temperature!==void 0)J.temperature=t.temperature;if(e.dryRun){A({request:J},y);return}if(!e.quiet){let M=r?"text-only":`text+audio, voice: ${$}`;process.stderr.write(`[Model: ${i}] [${M}]
158
- `)}let Z=be(e.baseUrl),j=await ye(e,{url:Z,method:"POST",body:J,stream:!0,ossResolve:q}),T="",X="",U=process.stdout.isTTY,c=process.stdout;for await(let M of Ae(j)){if(M.data==="[DONE]")break;try{let O=JSON.parse(M.data);for(let P of O.choices){let I=P.delta;if(I.content){if(T+=I.content,U)c.write(I.content)}if(I.audio?.data)X+=I.audio.data}}catch{}}if(U&&T)c.write(`
159
- `);let H;if(X&&!r){let M=Buffer.from(X,"base64"),O=Z$(M.length),P=Buffer.concat([O,M]),I=t.audioOut;if(!I){let{join:Ne}=await import("path"),f=l(e,{subDir:"omni"}),Yn=Date.now();I=Ne(f,`omni_${Yn}.wav`)}if(Q$(I,P),H=I,!e.quiet)process.stderr.write(`Audio saved: ${I}
160
- `)}if(!U||y==="json"){let M={content:T};if(H)M.audio_saved=H,M.voice=$;A(M,y)}}});var Ir=["⠋","⠙","⠹","⠸","⠼","⠴","⠦","⠧","⠇","⠏"];function se(e){let t=process.stderr.isTTY,n=0,i=null,$=e;return{start(){if(!t)return;i=setInterval(()=>{process.stderr.write(`\r${Ir[n%Ir.length]} ${$}`),n++},80)},update(p){$=p},stop(p){if(i)clearInterval(i),i=null;if(t){if(process.stderr.write("\r\x1B[K"),p)process.stderr.write(`${p}
161
- `)}}}}function vr(e,t=""){let n=process.stderr.isTTY,i=30;return{update($){if(!n)return;let p=Math.min(1,$/e),r=Math.round(30*p),y=30-r,m="█".repeat(r)+"░".repeat(y),x=`${Math.round(p*100)}%`;process.stderr.write(`\r${t} ${m} ${x}`)},finish(){if(n)process.stderr.write(`
162
- `)}}}async function pe(e,t){let n=Date.now()+t.timeoutSec*1000,i=se("Polling...");if(!e.quiet)i.start();try{while(Date.now()<n){let $=await Q(e,{url:t.url});if(t.getStatus&&!e.quiet)i.update(`Status: ${t.getStatus($)}`);if(t.isComplete($))return i.stop("Done."),$;if(t.isFailed($)){if(i.stop("Failed."),e.verbose)process.stderr.write(`[verbose] Task response: ${JSON.stringify($,null,2)}
163
- `);let p=t.getErrorMessage?.($);throw new u(p?`Task failed: ${p}`:"Task failed.",h.GENERAL,p?void 0:"Use --verbose to see full API response details.")}await new Promise((p)=>setTimeout(p,t.intervalSec*1000))}}finally{i.stop()}throw new u("Polling timed out.",h.TIMEOUT,"Try increasing --timeout or check task status manually.")}import{createWriteStream as z$,mkdirSync as X$,unlinkSync as P$}from"fs";import{dirname as Y$}from"path";async function s(e,t,n){let i=await fetch(e,{headers:d()});if(!i.ok)throw new u(`Download failed: HTTP ${i.status}`,h.GENERAL);let $=Number(i.headers.get("content-length")||0),p=i.body?.getReader();if(!p)throw new u("No response body",h.GENERAL);X$(Y$(t),{recursive:!0});let r=z$(t),y=$>0&&!n?.quiet?vr($,"Downloading"):null,m=0,x=!1;try{let b=new Promise((w,S)=>{r.on("error",S)});while(!0){let{done:w,value:S}=await Promise.race([p.read(),b]);if(w)break;if(!r.write(S))await new Promise((o)=>r.once("drain",o));m+=S.byteLength,y?.update(m)}x=!0}finally{if(p.releaseLock(),y?.finish(),await new Promise((b,w)=>{r.on("finish",b),r.on("error",w),r.end()}),!x)try{P$(t)}catch{}}return{size:m}}function ue(e){if(e<1024)return`${e} B`;if(e<1048576)return`${(e/1024).toFixed(1)} KB`;if(e<1073741824)return`${(e/1048576).toFixed(1)} MB`;return`${(e/1073741824).toFixed(1)} GB`}import{join as dr}from"path";function Se(e){let t=e.concurrent;return Math.max(1,t??1)}async function _e(e,t,n,i="requests"){if(e<=1)return[await n(0)];if(!t.quiet)process.stderr.write(`[Concurrent: ${e} ${i}]
164
- `);let $=Array.from({length:e},(p,r)=>n(r));return Promise.all($)}async function Te(e,t,n){return Promise.all(e.map(({url:i,destPath:$})=>t(i,$,n).then(()=>$)))}function Ur(e,t){return e.normalize("NFKC").replace(/[\\/:*?"<>|]/g,"_").replace(/\s+/g,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"")||t}function Fe(e,t){let n=Ur(e||"image","image"),i=Ur((t||"").substring(0,20),"untitled");return`${n}_${i}_${Date.now()}`}var O$=["qwen-image-2.0","qwen-image-max"];function c$(e){return O$.some((t)=>e.startsWith(t))}var C$={"16:9":"2688*1536","9:16":"1536*2688","1:1":"2048*2048","4:3":"2368*1728","3:4":"1728*2368"},L$={"16:9":"1664*928","4:3":"1472*1104","1:1":"1328*1328","3:4":"1104*1472","9:16":"928*1664"};function V$(e,t){let i=(t?C$:L$)[e];if(i)return i;return e}var sr=K({name:"image generate",description:"Generate images (Qwen-Image / wan2.x)",apiDocs:"/best-practice/wanx/text-to-image",usage:"bl image generate --prompt <text> [flags]",options:[{flag:"--prompt <text>",description:"Image description",required:!0},{flag:"--model <model>",description:"Model ID (default: qwen-image-2.0)"},{flag:"--size <W*H>",description:"Image size: ratio (3:4, 16:9, 1:1) or pixels (2048*2048)"},{flag:"--n <count>",description:"Number of images per request (default: 1, max: 6)",type:"number"},{flag:"--seed <n>",description:"Random seed for reproducible generation",type:"number"},{flag:"--negative-prompt <text>",description:"Negative prompt to exclude unwanted content"},{flag:"--prompt-extend",description:"Automatically extend prompt for better results (default: true for qwen-image)"},{flag:"--no-prompt-extend",description:"Disable prompt extend"},{flag:"--watermark",description:"Add watermark to generated images"},{flag:"--no-wait",description:"Return task ID immediately without waiting (async models only)"},{flag:"--out-dir <dir>",description:"Download images to directory"},{flag:"--out-prefix <prefix>",description:"Filename prefix (default: image)"},{flag:"--poll-interval <seconds>",description:"Polling interval when waiting (default: 3)",type:"number"}],examples:['bl image generate --prompt "一只穿太空服的猫在火星上"','bl image generate --prompt "Logo design" --n 3 --out-dir ./generated/','bl image generate --prompt "Mountain landscape" --size 2688*1536','bl image generate --prompt "A castle" --seed 42 --no-prompt-extend','bl image generate --prompt "sunset" --model wan2.6-t2i --no-wait --quiet','bl image generate --prompt "Pro quality" --model qwen-image-2.0-pro','bl image generate --prompt "Product shots" --n 2 --concurrent 3 # 6 images in parallel'],async run(e,t){let n=t.prompt??t._positional?.[0];if(!n)if(Y({nonInteractive:e.nonInteractive})){let q=await L({message:"Enter your image prompt:"});if(!q)process.stderr.write(`Image generation cancelled.
165
- `),process.exit(1);n=q}else W("prompt","bl image generate --prompt <text>");let i=t.model||e.defaultImageModel||"qwen-image-2.0",$=c$(i),p=$?"1:1":"1:1",r=t.size||p,y=V$(r,$),m=t.n??1,x=Se(t),b;if(t.noPromptExtend===!0)b=!1;else if(t.promptExtend===!0)b=!0;else if($)b=!0;let w={model:i,input:{messages:[{role:"user",content:[{text:n}]}]},parameters:{size:y,n:m,seed:t.seed,prompt_extend:b,watermark:t.watermark===!0?!0:void 0,negative_prompt:t.negativePrompt||void 0}},S=B(e.output);if(e.dryRun){A({request:w,mode:$?"sync":"async"},S);return}if(!e.quiet)process.stderr.write(`[Model: ${i}] [Mode: ${$?"sync":"async"}]
166
- `);if($)await E$(e,i,w,t,S,x);else await I$(e,i,w,t,S,x)}});async function E$(e,t,n,i,$,p){let r=Ce(e.baseUrl),m=(await _e(p,e,()=>Q(e,{url:r,method:"POST",body:n}))).flatMap((x)=>x.output.choices||[]).flatMap((x)=>x.message?.content||[]).map((x)=>x.image).filter(Boolean);if(m.length===0)throw new u("Generation completed but no images returned.",h.GENERAL);await Fr(m,i,e,$)}async function I$(e,t,n,i,$,p){let r=It(e.baseUrl),m=(await _e(p,e,()=>Q(e,{url:r,method:"POST",body:n,async:!0}),"tasks")).map((q)=>q.output.task_id);if(i.noWait||e.async){A({task_ids:m},$);return}let x=i.pollInterval??3,b=m.map((q)=>{let o=a(e.baseUrl,q);return pe(e,{url:o,intervalSec:x,timeoutSec:e.timeout,isComplete:(k)=>k.output.task_status==="SUCCEEDED",isFailed:(k)=>k.output.task_status==="FAILED",getStatus:(k)=>k.output.task_status,getErrorMessage:(k)=>{let G=k.output;return G.message||G.code||void 0}})}),w=await Promise.all(b),S=[];for(let q of w){if(q.output.choices){let o=q.output.choices.flatMap((k)=>k.message?.content||[]).map((k)=>k.image).filter(Boolean);S.push(...o)}if(q.output.results){let o=q.output.results.map((k)=>k.url).filter(Boolean);if(o.length>0&&S.length===0)S.push(...o)}}if(S.length===0)throw new u("All tasks completed but no images returned.",h.GENERAL);await Fr(S,i,e,$,m.length===1?m[0]:void 0,m)}async function Fr(e,t,n,i,$,p){let r=l(n,{flagDir:t.outDir,subDir:t.outDir?void 0:"images"}),y=t.prompt||t._positional?.[0]||"",m=t.outPrefix||Fe("image",y),x=e.length>1?e.map((w,S)=>{let q=`${m}_${String(S+1).padStart(3,"0")}.png`;return{url:w,destPath:dr(r,q)}}):[{url:e[0],destPath:dr(r,`${m}.png`)}],b=await Te(x,s,{quiet:n.quiet});if(n.quiet)N(b.join(`
167
- `));else{let w={urls:e,saved:b,total:e.length};if($)w.task_id=$;if(p&&p.length>1)w.task_ids=p;A(w,i)}}import{join as ar}from"path";function Me(e){for(let t of Object.keys(e))if(e[t]===void 0)delete e[t];return e}var v$={"16:9":"2688*1536","9:16":"1536*2688","1:1":"2048*2048","4:3":"2368*1728","3:4":"1728*2368"};function U$(e){if(!e)return;return v$[e]??e}var Dr=K({name:"image edit",description:"Edit an existing image with text instructions (Qwen-Image)",apiDocs:"/developer-reference/qwen-image-edit-api",usage:"bl image edit --image <url> --prompt <text> [flags]",options:[{flag:"--image <url>",description:"Source image URL or local file path (repeatable for multi-image merge)",required:!0,type:"array"},{flag:"--prompt <text>",description:"Edit instruction text",required:!0},{flag:"--model <model>",description:"Model ID (default: qwen-image-2.0)"},{flag:"--size <W*H>",description:"Output image size: ratio (3:4, 16:9) or pixels (2048*2048)"},{flag:"--n <count>",description:"Number of images (default: 1, max: 6)",type:"number"},{flag:"--seed <n>",description:"Random seed for reproducible results",type:"number"},{flag:"--negative-prompt <text>",description:"Negative prompt to exclude unwanted content"},{flag:"--prompt-extend",description:"Enable prompt smart rewrite (default: true)"},{flag:"--no-prompt-extend",description:"Disable prompt extend"},{flag:"--watermark",description:"Add watermark to output images"},{flag:"--out-dir <dir>",description:"Download images to directory"},{flag:"--out-prefix <prefix>",description:"Filename prefix (default: edited)"}],examples:['bl image edit --image ./photo.png --prompt "把背景换成海滩"','bl image edit --image https://example.com/logo.png --prompt "Change color to blue" --n 3','bl image edit --image ./a.png --image ./b.png --prompt "把两张图合并成一张拼图"','bl image edit --image https://example.com/photo.png --prompt "Remove the person" --model qwen-image-2.0-pro'],async run(e,t){let n=[];if(Array.isArray(t.image))n=t.image;else if(typeof t.image==="string")n=[t.image];if(n.length===0)W("image","bl image edit --image <url> --prompt <text>");let i=t.prompt;if(!i)if(Y({nonInteractive:e.nonInteractive})){let T=await L({message:"Enter your edit instruction:"});if(!T)process.stderr.write(`Image editing cancelled.
168
- `),process.exit(1);i=T}else W("prompt","bl image edit --image <url> --prompt <text>");let $=t.model||e.defaultImageModel||"qwen-image-2.0",p=await V(e),r=await Promise.all(n.map((T)=>E(T,p.token,$,e.quiet))),y=r.some((T)=>T.startsWith("oss://")),m=t.n??1,x;if(t.noPromptExtend===!0)x=!1;else if(t.promptExtend===!0)x=!0;else x=!0;let b=r.map((T)=>({image:T}));b.push({text:i});let w={model:$,input:{messages:[{role:"user",content:b}]},parameters:{size:U$(t.size)||void 0,n:m,seed:t.seed,prompt_extend:x,watermark:t.watermark===!0?!0:void 0,negative_prompt:t.negativePrompt||void 0}};Me(w.parameters);let S=B(e.output);if(e.dryRun){A({request:w},S);return}if(!e.quiet)process.stderr.write(`[Model: ${$}] [Mode: sync] [Images: ${r.length}]
169
- `);let q=Ce(e.baseUrl),o=Se(t),G=(await _e(o,e,()=>Q(e,{url:q,method:"POST",body:w,ossResolve:y}))).flatMap((T)=>T.output.choices||[]).flatMap((T)=>T.message?.content||[]).map((T)=>T.image).filter(Boolean);if(G.length===0)throw new u("Edit completed but no images returned.",h.GENERAL);let z=l(e,{flagDir:t.outDir,subDir:t.outDir?void 0:"images"}),J=t.outPrefix||Fe("edited",t?.prompt),Z=G.length>1?G.map((T,X)=>{let U=`${J}_${String(X+1).padStart(3,"0")}.png`;return{url:T,destPath:ar(z,U)}}):[{url:G[0],destPath:ar(z,`${J}.png`)}],j=await Te(Z,s,{quiet:e.quiet});if(e.quiet)N(j.join(`
170
- `));else A({urls:G,saved:j,total:G.length},S)}});var lr=K({name:"video generate",description:"Generate a video from text or image (happyhorse-1.0-t2v / happyhorse-1.0-i2v)",apiDocs:"/best-practice/wanx/text-to-video",usage:"bl video generate --prompt <text> [--image <url>] [flags]",options:[{flag:"--model <model>",description:"Model ID (default: happyhorse-1.0-t2v, or happyhorse-1.0-i2v with --image)"},{flag:"--prompt <text>",description:"Video description",required:!0},{flag:"--image <url>",description:"Input image URL for image-to-video generation"},{flag:"--negative-prompt <text>",description:"Negative prompt to exclude unwanted content"},{flag:"--resolution <res>",description:"Resolution (e.g. 720P, 1080P)"},{flag:"--ratio <ratio>",description:"Aspect ratio (e.g. 16:9, 1:1)"},{flag:"--duration <seconds>",description:"Video duration in seconds (default: 5)",type:"number"},{flag:"--prompt-extend",description:"Automatically extend prompt for better results"},{flag:"--watermark",description:"Add watermark to generated video"},{flag:"--seed <n>",description:"Random seed for reproducible generation",type:"number"},{flag:"--download <path>",description:"Save video to file on completion"},{flag:"--no-wait",description:"Return task ID immediately without waiting"},{flag:"--async",description:"Return task ID immediately (agent/CI mode, same as --no-wait)"},{flag:"--poll-interval <seconds>",description:"Polling interval when waiting (default: 5)",type:"number"}],examples:['bl video generate --prompt "一个人在读书,静态镜头"','bl video generate --prompt "Ocean waves at sunset." --download sunset.mp4','bl video generate --image https://example.com/cat.png --prompt "让画面中的猫动起来"','bl video generate --prompt "Mountain landscape" --resolution 720P --duration 5'],async run(e,t){let n=t.prompt;if(!n)if(Y({nonInteractive:e.nonInteractive})){let j=await L({message:"Enter your video prompt:"});if(!j)process.stderr.write(`Video generation cancelled.
171
- `),process.exit(1);n=j}else W("prompt","bl video generate --prompt <text>");let i=t.model||e.defaultVideoModel||(t.image?"happyhorse-1.0-i2v":"happyhorse-1.0-t2v"),$=B(e.output),p=t.image,r,y=!1;if(p){let j=await V(e);r=await E(p,j.token,i,e.quiet),y=r.startsWith("oss://")}let m={model:i,input:{prompt:n,negative_prompt:t.negativePrompt||void 0,...r?{media:[{type:"first_frame",url:r}]}:{}},parameters:{resolution:t.resolution?.toUpperCase()||void 0,ratio:t.ratio||void 0,duration:t.duration||void 0,prompt_extend:t.promptExtend===!0?!0:void 0,watermark:t.watermark===!0?!0:void 0,seed:t.seed}};if(e.dryRun){A({request:m},$);return}let x=Se(t),b=je(e.baseUrl),S=(await _e(x,e,()=>Q(e,{url:b,method:"POST",body:m,async:!0,ossResolve:y}),"tasks")).map((j)=>j.output.task_id);if(!e.quiet)process.stderr.write(`[Model: ${i}]
172
- `);if(t.noWait||e.async){A(S.length===1?{task_id:S[0]}:{task_ids:S},$);return}let q=t.pollInterval??5,o=S.map((j)=>{let T=a(e.baseUrl,j);return pe(e,{url:T,intervalSec:q,timeoutSec:e.timeout,isComplete:(X)=>X.output.task_status==="SUCCEEDED",isFailed:(X)=>X.output.task_status==="FAILED",getStatus:(X)=>X.output.task_status,getErrorMessage:(X)=>{let U=X.output;return U.message||U.code||void 0}})}),k=await Promise.all(o),G=[];for(let j=0;j<k.length;j++){let T=k[j],X=T.output.video_url||T.output.results&&T.output.results[0]?.url;if(X)G.push({taskId:S[j],videoUrl:X})}if(G.length===0)throw new u("All tasks completed but no video URLs returned.",h.GENERAL);if(t.download){let j=t.download,{size:T}=await s(G[0].videoUrl,j,{quiet:e.quiet});if(e.quiet)N(j);else A({task_id:G[0].taskId,video_url:G[0].videoUrl,status:"SUCCEEDED",saved:j,size:ue(T)},$);return}let z=l(e,{subDir:"videos"}),{join:J}=await import("path"),Z=[];if(await Promise.all(G.map(async({taskId:j,videoUrl:T})=>{let X=J(z,`${j}.mp4`);await s(T,X,{quiet:e.quiet}),Z.push({task_id:j,video_url:T,saved:X})})),Z.length===1)A(Z[0],$);else A({videos:Z,total:Z.length},$)}});var fr=K({name:"video edit",description:"Edit a video with happyhorse-1.0-video-edit (style transfer, object replacement, etc.)",apiDocs:"/best-practice/wanx/video-edit",usage:"bl video edit --video <url> --prompt <text> [flags]",options:[{flag:"--model <model>",description:"Model ID (default: happyhorse-1.0-video-edit)"},{flag:"--video <url>",description:"Input video URL or local file (mp4/mov, 2-10s)",required:!0},{flag:"--prompt <text>",description:'Edit instruction (e.g. "将画面转换为黏土风格")'},{flag:"--ref-image <url>",description:"Reference image URL (up to 4, comma-separated)"},{flag:"--negative-prompt <text>",description:"Negative prompt to exclude unwanted content"},{flag:"--resolution <res>",description:"Resolution: 720P or 1080P (default: 1080P)"},{flag:"--ratio <ratio>",description:"Aspect ratio (16:9, 9:16, 1:1, 4:3, 3:4)"},{flag:"--duration <seconds>",description:"Output video duration in seconds (2-10)",type:"number"},{flag:"--audio-setting <mode>",description:"Audio: auto (default) or origin (keep original)"},{flag:"--prompt-extend",description:"Enable prompt intelligent rewriting (default: true)"},{flag:"--no-prompt-extend",description:"Disable prompt intelligent rewriting"},{flag:"--watermark",description:'Add "AI生成" watermark'},{flag:"--seed <n>",description:"Random seed for reproducible generation",type:"number"},{flag:"--download <path>",description:"Save video to file on completion"},{flag:"--no-wait",description:"Return task ID immediately without waiting"},{flag:"--async",description:"Return task ID immediately (agent/CI mode, same as --no-wait)"},{flag:"--poll-interval <seconds>",description:"Polling interval when waiting (default: 15)",type:"number"}],examples:['bl video edit --video https://example.com/input.mp4 --prompt "将整个画面转换为黏土风格"','bl video edit --video https://example.com/input.mp4 --prompt "替换衣服为图片中的款式" --ref-image https://example.com/clothes.png','bl video edit --video https://example.com/input.mp4 --prompt "Convert to anime style" --resolution 720P --download output.mp4'],async run(e,t){let n=t.video;if(!n)if(Y({nonInteractive:e.nonInteractive})){let c=await L({message:"Enter the video URL to edit:"});if(!c)process.stderr.write(`Video editing cancelled.
173
- `),process.exit(1);n=c}else W("video","bl video edit --video <url> --prompt <text>");let i=t.prompt;if(!i){if(Y({nonInteractive:e.nonInteractive})){let c=await L({message:"Enter your edit instruction:"});if(!c)process.stderr.write(`Video editing cancelled.
174
- `),process.exit(1);i=c}}let $=t.model||"happyhorse-1.0-video-edit",p=B(e.output),r=await V(e),y=await E(n,r.token,$,e.quiet),m=y.startsWith("oss://"),x=[{type:"video",url:y}],b=t.refImage;if(b){let c=b.split(",").map((H)=>H.trim()).filter(Boolean);for(let H of c){let M=await E(H,r.token,$,e.quiet);if(M.startsWith("oss://"))m=!0;x.push({type:"reference_image",url:M})}}let w=t.noPromptExtend===!0?!1:t.promptExtend===!0?!0:void 0,S={model:$,input:{prompt:i||void 0,negative_prompt:t.negativePrompt||void 0,media:x},parameters:{resolution:t.resolution?.toUpperCase()||void 0,ratio:t.ratio||void 0,duration:t.duration||void 0,audio_setting:t.audioSetting||void 0,prompt_extend:w,watermark:t.watermark===!0?!0:void 0,seed:t.seed}};if(e.dryRun){A({request:S},p);return}let q=je(e.baseUrl),k=(await Q(e,{url:q,method:"POST",body:S,async:!0,ossResolve:m})).output.task_id;if(!e.quiet)process.stderr.write(`[Model: ${$}]
175
- `),process.stderr.write(`Note: Video editing typically takes 5-8 minutes. Please be patient.
176
- `);if(t.noWait||e.async){A({task_id:k},p);return}let G=t.pollInterval??15,z=a(e.baseUrl,k),J=Math.max(e.timeout,600),Z=await pe(e,{url:z,intervalSec:G,timeoutSec:J,isComplete:(c)=>c.output.task_status==="SUCCEEDED",isFailed:(c)=>c.output.task_status==="FAILED",getStatus:(c)=>c.output.task_status,getErrorMessage:(c)=>{let H=c.output;return H.message||H.code||void 0}}),j=Z.output.video_url||Z.output.results&&Z.output.results[0]?.url;if(!j)throw new u("Task completed but no video URL returned.",h.GENERAL);if(t.download){let c=t.download,{size:H}=await s(j,c,{quiet:e.quiet});if(e.quiet)N(c);else A({task_id:k,video_url:j,status:"SUCCEEDED",saved:c,size:ue(H)},p);return}let{join:T}=await import("path"),X=l(e,{subDir:"videos"}),U=T(X,`${k}.mp4`);await s(j,U,{quiet:e.quiet}),A({task_id:k,video_url:j,saved:U},p)}});var gr=K({name:"video ref",description:"Reference-to-video generation (happyhorse-1.0-r2v / wan2.6-r2v): multi-subject, multi-shot with voice",apiDocs:"/best-practice/wanx/video-reference",usage:"bl video ref --prompt <text> --image <url>... [--ref-video <url>...] [flags]",options:[{flag:"--model <model>",description:"Model ID (default: happyhorse-1.0-r2v)"},{flag:"--prompt <text>",description:"Video description with reference markers (图1, 视频1, etc.)",required:!0},{flag:"--image <url>",description:"Reference image URL or local file (repeatable for multiple subjects)",type:"array"},{flag:"--ref-video <url>",description:"Reference video URL or local file (repeatable)",type:"array"},{flag:"--image-voice <url>",description:"Voice URL for corresponding image (pairs by position)",type:"array"},{flag:"--video-voice <url>",description:"Voice URL for corresponding ref-video (pairs by position)",type:"array"},{flag:"--resolution <res>",description:"Resolution: 720P or 1080P (default: 720P)"},{flag:"--ratio <ratio>",description:"Aspect ratio (16:9, 9:16, 1:1)"},{flag:"--duration <seconds>",description:"Video duration in seconds (2-10, default: 5)",type:"number"},{flag:"--prompt-extend",description:"Enable prompt intelligent rewriting"},{flag:"--no-prompt-extend",description:"Disable prompt intelligent rewriting"},{flag:"--watermark",description:"Add watermark to generated video"},{flag:"--seed <n>",description:"Random seed for reproducible generation",type:"number"},{flag:"--download <path>",description:"Save video to file on completion"},{flag:"--no-wait",description:"Return task ID immediately without waiting"},{flag:"--async",description:"Return task ID immediately (agent/CI mode, same as --no-wait)"},{flag:"--poll-interval <seconds>",description:"Polling interval when waiting (default: 15)",type:"number"}],examples:['bl video ref --prompt "图1在草地上奔跑" --image person.jpg','bl video ref --prompt "视频1在弹吉他,图1走过来" --ref-video scene.mp4 --image person.jpg','bl video ref --prompt "图1说话" --image person.jpg --image-voice voice.mp3 --resolution 1080P','bl video ref --prompt "图1和图2在对话" --image a.jpg --image b.jpg --image-voice va.mp3 --image-voice vb.mp3'],async run(e,t){let n=t.prompt;if(!n)if(Y({nonInteractive:e.nonInteractive})){let H=await L({message:"Enter your video prompt (use 图1, 视频1 to reference inputs):"});if(!H)process.stderr.write(`Video generation cancelled.
177
- `),process.exit(1);n=H}else W("prompt","bl video ref --prompt <text> --image <url>");let i=t.image||[],$=t.refVideo||[];if(i.length===0&&$.length===0)throw new u("At least one --image or --ref-video is required.",h.USAGE,'bl video ref --prompt "描述" --image person.jpg');let p=t.imageVoice||[],r=t.videoVoice||[],y=t.model||"happyhorse-1.0-r2v",m=B(e.output),x=await V(e),b=!1,w=[];for(let H=0;H<i.length;H++){let M=await E(i[H],x.token,y,e.quiet);if(M.startsWith("oss://"))b=!0;let O={type:"reference_image",url:M};if(p[H]){let P=await E(p[H],x.token,y,e.quiet);if(P.startsWith("oss://"))b=!0;O.reference_voice=P}w.push(O)}for(let H=0;H<$.length;H++){let M=await E($[H],x.token,y,e.quiet);if(M.startsWith("oss://"))b=!0;let O={type:"reference_video",url:M};if(r[H]){let P=await E(r[H],x.token,y,e.quiet);if(P.startsWith("oss://"))b=!0;O.reference_voice=P}w.push(O)}let S=t.noPromptExtend===!0?!1:t.promptExtend===!0?!0:void 0,q={model:y,input:{prompt:n,media:w},parameters:{resolution:t.resolution?.toUpperCase()||void 0,ratio:t.ratio||void 0,duration:t.duration||void 0,prompt_extend:S,watermark:t.watermark===!0?!0:void 0,seed:t.seed}};if(e.dryRun){A({request:q},m);return}let o=je(e.baseUrl),G=(await Q(e,{url:o,method:"POST",body:q,async:!0,ossResolve:b})).output.task_id;if(!e.quiet)process.stderr.write(`[Model: ${y}]
178
- `),process.stderr.write(`Note: Reference-to-video typically takes 5-10 minutes. Please be patient.
179
- `);if(t.noWait||e.async){A({task_id:G},m);return}let z=t.pollInterval??15,J=a(e.baseUrl,G),Z=Math.max(e.timeout,600),j=await pe(e,{url:J,intervalSec:z,timeoutSec:Z,isComplete:(H)=>H.output.task_status==="SUCCEEDED",isFailed:(H)=>H.output.task_status==="FAILED",getStatus:(H)=>H.output.task_status,getErrorMessage:(H)=>{let M=H.output;return M.message||M.code||void 0}}),T=j.output.video_url||j.output.results&&j.output.results[0]?.url;if(!T)throw new u("Task completed but no video URL returned.",h.GENERAL);if(t.download){let H=t.download,{size:M}=await s(T,H,{quiet:e.quiet});if(e.quiet)N(H);else A({task_id:G,video_url:T,status:"SUCCEEDED",saved:H,size:ue(M)},m);return}let{join:X}=await import("path"),U=l(e,{subDir:"videos"}),c=X(U,`${G}.mp4`);await s(T,c,{quiet:e.quiet}),A({task_id:G,video_url:T,saved:c},m)}});var en=K({name:"video task get",description:"Query async task status",usage:"bl video task get --task-id <id>",options:[{flag:"--task-id <id>",description:"Async task ID"}],examples:["bl video task get --task-id 3b256896-3e70-xxxx-xxxx-xxxxxxxxxxxx","bl video task get --task-id 3b256896-3e70-xxxx --output json"],async run(e,t){let n=t.taskId;if(!n)throw new u("--task-id is required.",h.USAGE,"bl video task get --task-id <id>");let i=B(e.output);if(e.dryRun){A({task_id:n},i);return}let $=a(e.baseUrl,n),p=await Q(e,{url:$});if(e.quiet){N(p.output.task_status);return}A({task_id:p.output.task_id,task_status:p.output.task_status,video_url:p.output.video_url,results:p.output.results,submit_time:p.output.submit_time,end_time:p.output.end_time},i)}});var tn=K({name:"video download",description:"Download a completed video by task ID",usage:"bl video download --task-id <id> --out <path>",options:[{flag:"--task-id <id>",description:"Task ID to download from"},{flag:"--out <path>",description:"Output file path"}],examples:["bl video download --task-id 3b256896-xxxx --out video.mp4","bl video download --task-id 3b256896-xxxx --out video.mp4 --quiet"],async run(e,t){let n=t.taskId;if(!n)throw new u("--task-id is required.",h.USAGE,"bl video download --task-id <id> --out <path>");let i=t.out;if(!i)throw new u("--out is required.",h.USAGE,`bl video download --task-id <id> --out video.mp4
180
- Or set output_dir: bl config set --key output_dir --value ~/my-output`);let $=B(e.output);if(e.dryRun){A({task_id:n,action:"download",out:i},$);return}let p=a(e.baseUrl,n),r=await Q(e,{url:p});if(r.output.task_status!=="SUCCEEDED")throw new u(`Task is not complete (status: ${r.output.task_status}).`,h.GENERAL,"Wait for the task to complete before downloading.");let y=r.output.video_url||r.output.results&&r.output.results[0]?.url;if(!y)throw new u("No download URL available for this task.",h.GENERAL);let{size:m}=await s(y,i,{quiet:e.quiet});if(e.quiet){N(i);return}A({saved:i,size:ue(m)},$)}});import{readFileSync as d$,existsSync as nn}from"fs";import{extname as $n}from"path";var s$={".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".webp":"image/webp"},F$=new Set([".mp4",".mov",".avi",".mkv",".webm",".flv",".wmv"]);function rn(e){let t=$n(e).toLowerCase().split("?")[0];if(F$.has(t))return!0;if(/\.(mp4|mov|avi|mkv|webm|flv|wmv)(\?|$)/i.test(e))return!0;return!1}async function a$(e){if(e.startsWith("data:"))return e;if(e.startsWith("http://")||e.startsWith("https://"))return e;if(e.startsWith("oss://"))return e;if(!nn(e))throw new u(`File not found: ${e}`,h.USAGE);let t=$n(e).toLowerCase(),n=s$[t];if(!n)throw new u(`Unsupported image format "${t}". Supported: jpg, jpeg, png, webp`,h.USAGE);let i=d$(e);return`data:${n};base64,${i.toString("base64")}`}var pn=K({name:"vision describe",description:"Describe an image or video using Qwen-VL",usage:"bl vision describe --image <path-or-url> [--video <url>] [--prompt <text>]",options:[{flag:"--image <path-or-url>",description:"Local image path or URL"},{flag:"--video <url>",description:"Video file URL or local path (mp4/mov/avi/mkv/webm)",type:"array"},{flag:"--prompt <text>",description:"Question about the content (default: auto-detected)"},{flag:"--model <model>",description:"Vision model (default: qwen-vl-max)"}],examples:["bl vision describe --image photo.jpg",'bl vision describe --image https://example.com/photo.jpg --prompt "这只狗是什么品种?"','bl vision describe --video https://example.com/video.mp4 --prompt "总结视频内容"',"bl vision describe --video ./local-video.mp4",'bl vision describe --image photo.png --prompt "Extract the text" --model qwen-vl-plus'],async run(e,t){let n=t.image??t._positional?.[0],i=t.video??[],$=t.model||"qwen-vl-max";if(n&&rn(n))i.push(n),n=void 0;let p=i.length>0,r=p?"Describe the video.":"Describe the image.",y=t.prompt||r;if(!n&&!p)if(Y({nonInteractive:e.nonInteractive})){let k=await L({message:"Enter image/video path or URL:"});if(!k)process.stderr.write(`Vision describe cancelled.
181
- `),process.exit(1);if(rn(k))i.push(k);else n=k}else throw new u("Missing required argument --image or --video.",h.USAGE,`bl vision describe --image <path-or-url>
182
- bl vision describe --video <url-or-path>`);let m=B(e.output);if(e.dryRun){A({request:{prompt:y,image:n,video:i.length?i:void 0,model:$}},m);return}let x=[],b=!1;if(i.length>0)for(let k of i){let G=k;if(de(k)){if(!nn(k))throw new u(`Video file not found: ${k}`,h.USAGE);let z=await V(e);if(G=await E(k,z.token,$,e.quiet),G.startsWith("oss://"))b=!0}x.push({type:"video_url",video_url:{url:G}})}if(n){let k=await a$(n),G=k;if(de(n)&&k.startsWith("data:")){let{statSync:z}=await import("fs");if(z(n).size>5242880){let Z=await V(e);if(G=await E(n,Z.token,$,e.quiet),G.startsWith("oss://"))b=!0}}x.push({type:"image_url",image_url:{url:G}})}x.push({type:"text",text:y});let w={model:$,messages:[{role:"user",content:x}]},S=be(e.baseUrl),q=await Q(e,{url:S,method:"POST",body:w,ossResolve:b}),o=q.choices?.[0]?.message?.content;if(m!=="text"){A(q,m);return}N(o||"")}});var yn=K({name:"config show",description:"Display current configuration",usage:"bl config show",examples:["bl config show","bl config show --output json"],async run(e,t){let n=te(),i=B(e.output),$={region:e.region,base_url:e.baseUrl,output:e.output,timeout:e.timeout,config_file:ie()};if(n.api_key)$.api_key=g(n.api_key);if(n.default_text_model)$.default_text_model=n.default_text_model;if(n.default_video_model)$.default_video_model=n.default_video_model;if(n.default_image_model)$.default_image_model=n.default_image_model;A($,i)}});var _n=["region","base_url","output","output_dir","timeout","api_key","default_text_model","default_video_model","default_image_model","default_speech_model","default_omni_model","access_key_id","access_key_secret","workspace_id"],D$={"base-url":"base_url","output-dir":"output_dir","api-key":"api_key","default-text-model":"default_text_model","default-video-model":"default_video_model","default-image-model":"default_image_model","default-speech-model":"default_speech_model","default-omni-model":"default_omni_model","access-key-id":"access_key_id","access-key-secret":"access_key_secret","workspace-id":"workspace_id"},mn=K({name:"config set",description:"Set a config value",usage:"bl config set --key <key> --value <value>",options:[{flag:"--key <key>",description:"Config key (region, base_url, output, output_dir, timeout, api_key, default_*_model, access_key_id, access_key_secret, workspace_id)"},{flag:"--value <value>",description:"Value to set"}],examples:["bl config set --key output --value json","bl config set --key timeout --value 600","bl config set --key base_url --value https://dashscope.aliyuncs.com"],async run(e,t){let{key:n,value:i}=t;if(!n||i===void 0)throw new u("--key and --value are required.",h.USAGE,"bl config set --key <key> --value <value>");let $=D$[n]||n;if(!_n.includes($))throw new u(`Invalid config key "${n}". Valid keys: ${_n.join(", ")}`,h.USAGE);if($==="region"&&!["cn","us","intl"].includes(i))throw new u(`Invalid region "${i}". Valid values: cn, us, intl`,h.USAGE);if($==="output"&&!["text","json"].includes(i))throw new u(`Invalid output format "${i}". Valid values: text, json`,h.USAGE);if($==="timeout"){let y=Number(i);if(isNaN(y)||y<=0)throw new u(`Invalid timeout "${i}". Must be a positive number.`,h.USAGE)}let p=B(e.output);if(e.dryRun){A({would_set:{[$]:i}},p);return}let r=te();if(r[$]=$==="timeout"?Number(i):i,await Je(r),!e.quiet)A({[$]:r[$]},p)}});function l$(e){let t=e.match(/^--([a-zA-Z0-9-]+)/),n=t?t[1]:"",i=n.replace(/-([a-zA-Z0-9])/g,(r,y)=>y.toUpperCase()),$="string",p=!1;if(!e.includes("<")&&!e.includes("["))$="boolean";else if(e.includes("<n>")||e.includes("<hz>")||e.includes("<bps>")||e.includes("<count>"))$="number";if(e.toLowerCase().includes("repeatable"))p=!0;return{name:i,kebabName:n,inferredType:$,isArray:p}}function Ht(e){let n={name:`bailian_${e.name.replace(/ /g,"_")}`,description:e.description,input_schema:{type:"object",properties:{},required:[]}};if(e.options)for(let i of e.options){let{name:$,inferredType:p,isArray:r}=l$(i.flag);if(!$)continue;let y=i.type,m=r?"array":y??p,x={description:i.description};if(m==="array")x.type="array",x.items={type:"string"};else x.type=m;let b=n.input_schema;if(b.properties[$]=x,i.required)b.required.push($)}return n}var f$=["auth ","config ","update"],xn=K({name:"config export-schema",description:"Export all (or one) CLI command(s) as Anthropic/OpenAI-compatible JSON tool schemas",usage:'bl config export-schema [--command "<name>"]',options:[{flag:"--command <name>",description:'Export schema for a specific command only (e.g. "image generate")'}],examples:["bl config export-schema",'bl config export-schema --command "video generate"'],async run(e,t){let n=t.command;if(n){try{let{command:p}=me.resolve(n.split(" ")),r=Ht(p);process.stdout.write(JSON.stringify(r,null,2)+`
183
- `)}catch{throw new u(`Command "${n}" not found.`,h.USAGE)}return}let $=me.getAllCommands().filter((p)=>!f$.some((r)=>p.name.startsWith(r))).map((p)=>Ht(p));process.stdout.write(JSON.stringify($,null,2)+`
184
- `)}});import{execSync as bn}from"child_process";import{writeFileSync as g$}from"fs";import{join as ep}from"path";var ae="0.1.2-beta.0";async function tp(){try{let e=Be.replace("/","%2f"),t=await fetch(`${He}/${e}/latest`,{headers:{Accept:"application/json",...d()},signal:AbortSignal.timeout(5000)});if(!t.ok)return null;return(await t.json()).version??null}catch{return null}}function rp(e="latest"){return{cmd:`npm install -g ${Be}@${e} --registry=${He}`,label:"npm"}}var wn=K({name:"update",description:"Update bl to the latest version",usage:"bl update",examples:["bl update"],async run(){let e=process.stderr.isTTY,t=e?"\x1B[32m":"",n=e?"\x1B[33m":"",i=e?"\x1B[0m":"";process.stderr.write(`Current version: ${n}${ae}${i}
185
- `),process.stderr.write(`Checking for updates...
186
- `);let $=await tp();if($&&$===ae){process.stderr.write(`${t}✓ Already up to date (${ae}).${i}
187
- `);return}if($)process.stderr.write(`Latest version: ${t}${$}${i}
188
-
189
- `);let{cmd:p,label:r}=rp($||"latest");process.stderr.write(`Updating ${Be} via ${r}...
190
-
191
- `);try{bn(p,{stdio:"inherit"});try{let m=bn("bl --version 2>/dev/null",{encoding:"utf-8"}).trim().replace(/^bl\s+/,"");process.stderr.write(`
192
- ${t}✓ Update complete: ${ae} → ${m}${i}
193
- `);try{let x=ep(Re(),"update-state.json");g$(x,JSON.stringify({lastChecked:Date.now(),latestVersion:m}))}catch{}}catch{process.stderr.write(`
194
- ${t}✓ Update complete.${i}
195
- `)}}catch{process.stderr.write(`
110
+ `)}}}),Qn=c({name:`auth status`,description:`Show current authentication state`,usage:`bl auth status`,examples:[`bl auth status`,`bl auth status --output json`],async run(e,t){try{let t=await E(e),n=l(e.output);if(n!==`text`){M({method:t.method,source:t.source,key:x(t.token)},n);return}N(`Authentication Status:`),N(` Method: ${t.method}`),N(` Source: ${t.source}`),N(` Key: ${x(t.token)}`)}catch{let t=l(e.output);M({authenticated:!1,message:`Not authenticated.`,hint:`Run: bl auth login --api-key <your-key>\nOr set DASHSCOPE_API_KEY\nGet API Key: ${J}`},t)}}}),$n=c({name:`auth logout`,description:`Clear stored credentials`,usage:`bl auth logout [--yes] [--dry-run]`,options:[{flag:`--yes`,description:`Skip confirmation prompt`}],examples:[`bl auth logout`,`bl auth logout --dry-run`,`bl auth logout --yes`],async run(e,t){let n=!!y();if(e.dryRun){N(n?`Would clear api_key from ~/.bailian/config.json`:`No credentials to clear.`),N(`No changes made.`);return}n?(await s(),process.stderr.write(`Cleared api_key from ~/.bailian/config.json
111
+ `)):process.stderr.write(`No credentials to clear.
112
+ `)}});function er(e){let t=[],n;if(e.system&&(n=e.system),e.messagesFile){let r=e.messagesFile,i=Ce(r===`-`?`/dev/stdin`:r,`utf-8`),a=JSON.parse(i);for(let e of a)e.role===`system`?n=typeof e.content==`string`?e.content:``:t.push(e)}if(e.message){let r=new Set([`system`,`user`,`assistant`]),i=e.message;for(let e of i){let i=e.indexOf(`:`),a=i===-1?``:e.slice(0,i);if(r.has(a)){let r=e.slice(i+1);a===`system`?n=r:t.push({role:a,content:r})}else t.push({role:`user`,content:e})}}return{system:n,messages:t}}var tr=c({name:`text chat`,description:`Send a chat completion (OpenAI compatible, DashScope)`,apiDocs:`/compatibility-of-openai-with-dashscope`,usage:`bl text chat --message <text> [flags]`,options:[{flag:`--model <model>`,description:`Model ID (default: qwen3.6-plus)`},{flag:`--message <text>`,description:`Message text (repeatable, prefix role: to set role)`,required:!0,type:`array`},{flag:`--messages-file <path>`,description:`JSON file with messages array (use - for stdin)`},{flag:`--system <text>`,description:`System prompt`},{flag:`--max-tokens <n>`,description:`Maximum tokens to generate (default: 4096)`,type:`number`},{flag:`--temperature <n>`,description:`Sampling temperature (0.0, 2.0]`,type:`number`},{flag:`--top-p <n>`,description:`Nucleus sampling threshold`,type:`number`},{flag:`--stream`,description:`Stream response tokens (default: on in TTY)`},{flag:`--tool <json-or-path>`,description:`Tool definition as JSON or file path (repeatable)`,type:`array`},{flag:`--enable-thinking`,description:`Enable thinking/reasoning mode (for qwen3/qwq models)`},{flag:`--thinking-budget <n>`,description:`Max tokens for thinking (default: 4096)`,type:`number`}],examples:[`bl text chat --message "What is Qwen?"`,`bl text chat --model qwen-max --system "You are a coding assistant." --message "Write fizzbuzz in Python"`,`bl text chat --message "Hello" --message "assistant:Hi!" --message "How are you?"`,`cat conversation.json | bl text chat --messages-file - --stream`,`bl text chat --message "Hello" --output json`,`bl text chat --model qwq-plus --message "Solve 1+1" --enable-thinking`],async run(e,t){let{system:n,messages:r}=er(t),i=r;if(i.length===0)if(_({nonInteractive:e.nonInteractive})){let e=await K({message:`Enter your message:`});e||(process.stderr.write(`Chat cancelled.
113
+ `),process.exit(1)),i=[{role:`user`,content:e}]}else q(`message`,`bl text chat --message <text>`);let a=t.model||e.defaultTextModel||`qwen3.6-plus`,s=t.stream===!0||t.stream===void 0&&process.stdout.isTTY,c=l(e.output),u=[];n&&u.push({role:`system`,content:n}),u.push(...i);let d={model:a,messages:u,max_tokens:t.maxTokens??4096,stream:s};if(t.temperature!==void 0&&(d.temperature=t.temperature),t.topP!==void 0&&(d.top_p=t.topP),t.enableThinking&&(d.enable_thinking=!0,t.thinkingBudget!==void 0&&(d.thinking_budget=t.thinkingBudget)),t.tool&&(d.tools=t.tool.map(e=>{try{return JSON.parse(e)}catch{let t=Ce(e,`utf-8`);return JSON.parse(t)}})),e.dryRun){M({request:d},c);return}let f=o(e.baseUrl);if(s){let t=await ae(e,{url:f,method:`POST`,body:d,stream:!0}),n=``,r=!1,i=c===`text`,a=e.noColor?``:`\x1B[2m`,o=e.noColor?``:`\x1B[0m`,s=process.stdout.isTTY,l=c===`json`?process.stderr:s?process.stdout:process.stderr,u=process.stdout;for await(let e of re(t)){if(e.data===`[DONE]`)break;try{let t=JSON.parse(e.data);for(let e of t.choices){let t=e.delta;t.reasoning_content&&(i&&!r&&(r=!0,l.write(`${a}Thinking:\n`)),i&&l.write(t.reasoning_content)),t.content&&(i&&r&&(l.write(`${o}\n\nResponse:\n`),r=!1),n+=t.content,i&&u.write(t.content))}}catch{}}r&&l.write(o),c===`json`?M({content:n},c):u.write(`
114
+ `)}else{let t=await T(e,{url:f,method:`POST`,body:d}),n=t.choices?.[0]?.message?.content??``;e.quiet||c===`text`?N(n):M(t,c)}}});const nr=[`Chelsie`,`Cherry`,`Ethan`,`Serena`,`Tina`];function rr(e){let t=Buffer.alloc(44);return t.write(`RIFF`,0),t.writeUInt32LE(36+e,4),t.write(`WAVE`,8),t.write(`fmt `,12),t.writeUInt32LE(16,16),t.writeUInt16LE(1,20),t.writeUInt16LE(1,22),t.writeUInt32LE(24e3,24),t.writeUInt32LE(48e3,28),t.writeUInt16LE(2,32),t.writeUInt16LE(16,34),t.write(`data`,36),t.writeUInt32LE(e,40),t}var ir=c({name:`omni`,description:`Multimodal chat with text + audio output (Qwen-Omni)`,apiDocs:`/model-studio/qwen-omni`,usage:`bl omni --message <text> [flags]`,options:[{flag:`--message <text>`,description:`Message text (repeatable, prefix role: to set role)`,required:!0,type:`array`},{flag:`--model <model>`,description:`Model ID (default: qwen3.5-omni-plus)`},{flag:`--system <text>`,description:`System prompt`},{flag:`--image <url>`,description:`Image URL or local file (repeatable)`,type:`array`},{flag:`--audio <url>`,description:`Audio URL or local file (repeatable)`,type:`array`},{flag:`--video <url>`,description:`Video file URL / local path, or comma-separated frame URLs`,type:`array`},{flag:`--voice <voice>`,description:`Output voice (default: Cherry). Options: ${nr.join(`, `)}`},{flag:`--audio-format <fmt>`,description:`Audio output format (default: wav)`},{flag:`--audio-out <path>`,description:`Save audio to file (default: auto-generate)`},{flag:`--text-only`,description:`Output text only, no audio generation`},{flag:`--max-tokens <n>`,description:`Maximum tokens to generate`,type:`number`},{flag:`--temperature <n>`,description:`Sampling temperature (0.0, 2.0]`,type:`number`}],examples:[`bl omni --message "你好,你是谁?"`,`bl omni --message "描述这张图片" --image ./photo.jpg`,`bl omni --message "这段音频在说什么?" --audio https://example.com/audio.wav`,`bl omni --message "总结这个视频" --video https://example.com/video.mp4`,`bl omni --message "这个视频讲了什么" --video ./local-video.mp4 --text-only`,`bl omni --message "用四川话回答:今天天气怎么样" --voice Serena`,`bl omni --message "Hello" --text-only --output json`,`bl omni --message "朗读这段话" --audio-out greeting.wav`],async run(e,t){let n=[];if(t.message&&(n=t.message),n.length===0)if(_({nonInteractive:e.nonInteractive})){let e=await K({message:`Enter your message:`});e||(process.stderr.write(`Omni chat cancelled.
115
+ `),process.exit(1)),n=[e]}else q(`message`,`bl text omni --message <text>`);let r=t.model||e.defaultOmniModel||`qwen3.5-omni-plus`,i=t.voice||`Cherry`,a=t.audioFormat||`wav`,s=t.textOnly===!0,c=l(e.output),u=[];t.system&&u.push({role:`system`,content:t.system});let d=new Set([`system`,`user`,`assistant`]);for(let e of n){let t=e.indexOf(`:`),n=t===-1?``:e.slice(0,t);if(d.has(n)){let r=e.slice(t+1);n===`system`?u.push({role:`system`,content:r}):u.push({role:n,content:r})}else u.push({role:`user`,content:e})}let f=t.image||[],p=t.audio||[],m=t.video||[],h=[],g=[],v=[];if(f.length>0||p.length>0||m.length>0){let t=await E(e);for(let e of f){let n=await D(e,t.token,r);h.push(n)}for(let e of p){let n=await D(e,t.token,r);g.push(n)}for(let e of m)if(e.includes(`,`)){let n=e.split(`,`).map(e=>e.trim()).filter(Boolean);for(let e of n){let n=await D(e,t.token,r);v.push(`frame:${n}`)}}else{let n=await D(e,t.token,r);v.push(n)}}if(h.length>0||g.length>0||v.length>0){for(let e=u.length-1;e>=0;e--)if(u[e].role===`user`){let t=u[e].content,n=[];typeof t==`string`?n.push({type:`text`,text:t}):Array.isArray(t)&&n.push(...t);for(let e of h)n.push({type:`image_url`,image_url:{url:e}});for(let e of g)n.push({type:`audio_url`,audio_url:{url:e}});let r=v.filter(e=>e.startsWith(`frame:`)).map(e=>e.slice(6)),i=v.filter(e=>!e.startsWith(`frame:`));r.length>0&&n.push({type:`video`,video:r});for(let e of i)n.push({type:`video_url`,video_url:{url:e}});u[e]={role:`user`,content:n};break}}let y={model:r,messages:u,stream:!0,stream_options:{include_usage:!0}};if(s||(y.modalities=[`text`,`audio`],y.audio={voice:i,format:a}),t.maxTokens!==void 0&&(y.max_tokens=t.maxTokens),t.temperature!==void 0&&(y.temperature=t.temperature),e.dryRun){M({request:y},c);return}if(!e.quiet){let e=s?`text-only`:`text+audio, voice: ${i}`;process.stderr.write(`[Model: ${r}] [${e}]\n`)}let b=await ae(e,{url:o(e.baseUrl),method:`POST`,body:y,stream:!0}),x=``,S=``,ee=process.stdout.isTTY,te=process.stdout;for await(let e of re(b)){if(e.data===`[DONE]`)break;try{let t=JSON.parse(e.data);for(let e of t.choices){let t=e.delta;t.content&&(x+=t.content,ee&&te.write(t.content)),t.audio?.data&&(S+=t.audio.data)}}catch{}}ee&&x&&te.write(`
116
+ `);let C;if(S&&!s){let n=Buffer.from(S,`base64`),r=rr(n.length),i=Buffer.concat([r,n]),a=t.audioOut;if(!a){let{join:t}=await import(`path`);a=t(O(e,{subDir:`omni`}),`omni_${Date.now()}.wav`)}Te(a,i),C=a,e.quiet||process.stderr.write(`Audio saved: ${a}\n`)}if(!ee||c===`json`){let e={content:x};C&&(e.audio_saved=C,e.voice=i),M(e,c)}}});const ar=[`⠋`,`⠙`,`⠹`,`⠸`,`⠼`,`⠴`,`⠦`,`⠧`,`⠇`,`⠏`];function or(e){let t=process.stderr.isTTY,n=0,r=null,i=e;return{start(){t&&(r=setInterval(()=>{process.stderr.write(`\r${ar[n%ar.length]} ${i}`),n++},80))},update(e){i=e},stop(e){r&&=(clearInterval(r),null),t&&(process.stderr.write(`\r\x1B[K`),e&&process.stderr.write(`${e}\n`))}}}function sr(e,t=``){let n=process.stderr.isTTY;return{update(r){if(!n)return;let i=Math.min(1,r/e),a=Math.round(30*i),o=30-a,s=`█`.repeat(a)+`░`.repeat(o),c=`${Math.round(i*100)}%`;process.stderr.write(`\r${t} ${s} ${c}`)},finish(){n&&process.stderr.write(`
117
+ `)}}}async function cr(t,r){let i=Date.now()+r.timeoutSec*1e3,a=or(`Polling...`);t.quiet||a.start();try{for(;Date.now()<i;){let i=await T(t,{url:r.url});if(r.getStatus&&!t.quiet&&a.update(`Status: ${r.getStatus(i)}`),r.isComplete(i))return a.stop(`Done.`),i;if(r.isFailed(i)){a.stop(`Failed.`),t.verbose&&process.stderr.write(`[verbose] Task response: ${JSON.stringify(i,null,2)}\n`);let o=r.getErrorMessage?.(i);throw new e(o?`Task failed: ${o}`:`Task failed.`,n.GENERAL,o?void 0:`Use --verbose to see full API response details.`)}await new Promise(e=>setTimeout(e,r.intervalSec*1e3))}}finally{a.stop()}throw new e(`Polling timed out.`,n.TIMEOUT,`Try increasing --timeout or check task status manually.`)}async function Y(t,r,i){let a=await fetch(t,{headers:ue()});if(!a.ok)throw new e(`Download failed: HTTP ${a.status}`,n.GENERAL);let o=Number(a.headers.get(`content-length`)||0),s=a.body?.getReader();if(!s)throw new e(`No response body`,n.GENERAL);Se(Ee(r),{recursive:!0});let c=be(r),l=o>0&&!i?.quiet?sr(o,`Downloading`):null,u=0,d=!1;try{let e=new Promise((e,t)=>{c.on(`error`,t)});for(;;){let{done:t,value:n}=await Promise.race([s.read(),e]);if(t)break;c.write(n)||await new Promise(e=>c.once(`drain`,()=>e())),u+=n.byteLength,l?.update(u)}d=!0}finally{if(s.releaseLock(),l?.finish(),await new Promise((e,t)=>{c.on(`finish`,e),c.on(`error`,t),c.end()}),!d)try{we(r)}catch{}}return{size:u}}function lr(e){return e<1024?`${e} B`:e<1024*1024?`${(e/1024).toFixed(1)} KB`:e<1024*1024*1024?`${(e/(1024*1024)).toFixed(1)} MB`:`${(e/(1024*1024*1024)).toFixed(1)} GB`}function ur(e){let t=e.concurrent;return Math.max(1,t??1)}async function dr(e,t,n,r=`requests`){if(e<=1)return[await n(0)];t.quiet||process.stderr.write(`[Concurrent: ${e} ${r}]\n`);let i=Array.from({length:e},(e,t)=>n(t));return Promise.all(i)}async function fr(e,t,n){return Promise.all(e.map(({url:e,destPath:r})=>t(e,r,n).then(()=>r)))}const pr=[`qwen-image-2.0`,`qwen-image-max`];function mr(e){return pr.some(t=>e.startsWith(t))}const hr={"16:9":`2688*1536`,"9:16":`1536*2688`,"1:1":`2048*2048`,"4:3":`2368*1728`,"3:4":`1728*2368`},gr={"16:9":`1664*928`,"4:3":`1472*1104`,"1:1":`1328*1328`,"3:4":`1104*1472`,"9:16":`928*1664`};function _r(e,t){return(t?hr:gr)[e]||e}var vr=c({name:`image generate`,description:`Generate images (Qwen-Image / wan2.x)`,apiDocs:`/best-practice/wanx/text-to-image`,usage:`bl image generate --prompt <text> [flags]`,options:[{flag:`--prompt <text>`,description:`Image description`,required:!0},{flag:`--model <model>`,description:`Model ID (default: qwen-image-2.0)`},{flag:`--size <W*H>`,description:`Image size: ratio (3:4, 16:9, 1:1) or pixels (2048*2048)`},{flag:`--n <count>`,description:`Number of images per request (default: 1, max: 6)`,type:`number`},{flag:`--seed <n>`,description:`Random seed for reproducible generation`,type:`number`},{flag:`--negative-prompt <text>`,description:`Negative prompt to exclude unwanted content`},{flag:`--prompt-extend`,description:`Automatically extend prompt for better results (default: true for qwen-image)`},{flag:`--no-prompt-extend`,description:`Disable prompt extend`},{flag:`--watermark`,description:`Add watermark to generated images`},{flag:`--no-wait`,description:`Return task ID immediately without waiting (async models only)`},{flag:`--out-dir <dir>`,description:`Download images to directory`},{flag:`--out-prefix <prefix>`,description:`Filename prefix (default: image)`},{flag:`--poll-interval <seconds>`,description:`Polling interval when waiting (default: 3)`,type:`number`}],examples:[`bl image generate --prompt "一只穿太空服的猫在火星上"`,`bl image generate --prompt "Logo design" --n 3 --out-dir ./generated/`,`bl image generate --prompt "Mountain landscape" --size 2688*1536`,`bl image generate --prompt "A castle" --seed 42 --no-prompt-extend`,`bl image generate --prompt "sunset" --model wan2.6-t2i --no-wait --quiet`,`bl image generate --prompt "Pro quality" --model qwen-image-2.0-pro`,`bl image generate --prompt "Product shots" --n 2 --concurrent 3 # 6 images in parallel`],async run(e,t){let n=t.prompt??t._positional?.[0];if(!n)if(_({nonInteractive:e.nonInteractive})){let e=await K({message:`Enter your image prompt:`});e||(process.stderr.write(`Image generation cancelled.
118
+ `),process.exit(1)),n=e}else q(`prompt`,`bl image generate --prompt <text>`);let r=t.model||e.defaultImageModel||`qwen-image-2.0`,i=mr(r),a=_r(t.size||`1:1`,i),o=t.n??1,s=ur(t),c;t.noPromptExtend===!0?c=!1:(t.promptExtend===!0||i)&&(c=!0);let u={model:r,input:{messages:[{role:`user`,content:[{text:n}]}]},parameters:{size:a,n:o,seed:t.seed,prompt_extend:c,watermark:t.watermark===!0?!0:void 0,negative_prompt:t.negativePrompt||void 0}},d=l(e.output);if(e.dryRun){M({request:u,mode:i?`sync`:`async`},d);return}e.quiet||process.stderr.write(`[Model: ${r}] [Mode: ${i?`sync`:`async`}]\n`),i?await yr(e,r,u,t,d,s):await br(e,r,u,t,d,s)}});async function yr(t,r,i,a,o,s){let c=g(t.baseUrl),l=(await dr(s,t,()=>T(t,{url:c,method:`POST`,body:i}))).flatMap(e=>e.output.choices||[]).flatMap(e=>e.message?.content||[]).map(e=>e.image).filter(Boolean);if(l.length===0)throw new e(`Generation completed but no images returned.`,n.GENERAL);await xr(l,a,t,o)}async function br(t,r,i,a,o,s){let c=h(t.baseUrl),l=(await dr(s,t,()=>T(t,{url:c,method:`POST`,body:i,async:!0}),`tasks`)).map(e=>e.output.task_id);if(a.noWait||t.async){M({task_ids:l},o);return}let u=a.pollInterval??3,d=l.map(e=>cr(t,{url:k(t.baseUrl,e),intervalSec:u,timeoutSec:t.timeout,isComplete:e=>e.output.task_status===`SUCCEEDED`,isFailed:e=>e.output.task_status===`FAILED`,getStatus:e=>e.output.task_status,getErrorMessage:e=>{let t=e.output;return t.message||t.code||void 0}})),f=await Promise.all(d),p=[];for(let e of f){if(e.output.choices){let t=e.output.choices.flatMap(e=>e.message?.content||[]).map(e=>e.image).filter(Boolean);p.push(...t)}if(e.output.results){let t=e.output.results.map(e=>e.url).filter(Boolean);t.length>0&&p.length===0&&p.push(...t)}}if(p.length===0)throw new e(`All tasks completed but no images returned.`,n.GENERAL);await xr(p,a,t,o,l.length===1?l[0]:void 0,l)}async function xr(e,t,n,r,i,a){let o=O(n,{flagDir:t.outDir,subDir:t.outDir?void 0:`images`}),s=t.prompt||t._positional?.[0]||``,c=t.outPrefix||d(`image`,s),l=await fr(e.length>1?e.map((e,t)=>({url:e,destPath:j(o,`${c}_${String(t+1).padStart(3,`0`)}.png`)})):[{url:e[0],destPath:j(o,`${c}.png`)}],Y,{quiet:n.quiet});if(n.quiet)N(l.join(`
119
+ `));else{let t={urls:e,saved:l,total:e.length};i&&(t.task_id=i),a&&a.length>1&&(t.task_ids=a),M(t,r)}}const Sr={"16:9":`2688*1536`,"9:16":`1536*2688`,"1:1":`2048*2048`,"4:3":`2368*1728`,"3:4":`1728*2368`};function Cr(e){if(e)return Sr[e]??e}var wr=c({name:`image edit`,description:`Edit an existing image with text instructions (Qwen-Image)`,apiDocs:`/developer-reference/qwen-image-edit-api`,usage:`bl image edit --image <url> --prompt <text> [flags]`,options:[{flag:`--image <url>`,description:`Source image URL or local file path (repeatable for multi-image merge)`,required:!0,type:`array`},{flag:`--prompt <text>`,description:`Edit instruction text`,required:!0},{flag:`--model <model>`,description:`Model ID (default: qwen-image-2.0)`},{flag:`--size <W*H>`,description:`Output image size: ratio (3:4, 16:9) or pixels (2048*2048)`},{flag:`--n <count>`,description:`Number of images (default: 1, max: 6)`,type:`number`},{flag:`--seed <n>`,description:`Random seed for reproducible results`,type:`number`},{flag:`--negative-prompt <text>`,description:`Negative prompt to exclude unwanted content`},{flag:`--prompt-extend`,description:`Enable prompt smart rewrite (default: true)`},{flag:`--no-prompt-extend`,description:`Disable prompt extend`},{flag:`--watermark`,description:`Add watermark to output images`},{flag:`--out-dir <dir>`,description:`Download images to directory`},{flag:`--out-prefix <prefix>`,description:`Filename prefix (default: edited)`}],examples:[`bl image edit --image ./photo.png --prompt "把背景换成海滩"`,`bl image edit --image https://example.com/logo.png --prompt "Change color to blue" --n 3`,`bl image edit --image ./a.png --image ./b.png --prompt "把两张图合并成一张拼图"`,`bl image edit --image https://example.com/photo.png --prompt "Remove the person" --model qwen-image-2.0-pro`],async run(t,r){let i=[];Array.isArray(r.image)?i=r.image:typeof r.image==`string`&&(i=[r.image]),i.length===0&&q(`image`,`bl image edit --image <url> --prompt <text>`);let a=r.prompt;if(!a)if(_({nonInteractive:t.nonInteractive})){let e=await K({message:`Enter your edit instruction:`});e||(process.stderr.write(`Image editing cancelled.
120
+ `),process.exit(1)),a=e}else q(`prompt`,`bl image edit --image <url> --prompt <text>`);let o=r.model||t.defaultImageModel||`qwen-image-2.0`,s=await E(t),c=await Promise.all(i.map(e=>D(e,s.token,o))),u=r.n??1,f;f=r.noPromptExtend===!0?!1:(r.promptExtend,!0);let p=c.map(e=>({image:e}));p.push({text:a});let m={model:o,input:{messages:[{role:`user`,content:p}]},parameters:{size:Cr(r.size)||void 0,n:u,seed:r.seed,prompt_extend:f,watermark:r.watermark===!0?!0:void 0,negative_prompt:r.negativePrompt||void 0}};le(m.parameters);let h=l(t.output);if(t.dryRun){M({request:m},h);return}t.quiet||process.stderr.write(`[Model: ${o}] [Mode: sync] [Images: ${c.length}]\n`);let v=g(t.baseUrl),y=(await dr(ur(r),t,()=>T(t,{url:v,method:`POST`,body:m}))).flatMap(e=>e.output.choices||[]).flatMap(e=>e.message?.content||[]).map(e=>e.image).filter(Boolean);if(y.length===0)throw new e(`Edit completed but no images returned.`,n.GENERAL);let b=O(t,{flagDir:r.outDir,subDir:r.outDir?void 0:`images`}),x=r.outPrefix||d(`edited`,r?.prompt),S=await fr(y.length>1?y.map((e,t)=>({url:e,destPath:j(b,`${x}_${String(t+1).padStart(3,`0`)}.png`)})):[{url:y[0],destPath:j(b,`${x}.png`)}],Y,{quiet:t.quiet});t.quiet?N(S.join(`
121
+ `)):M({urls:y,saved:S,total:y.length},h)}});const Tr={"720p":`1280*720`,"1080p":`1920*1080`,"480p":`832*480`};function Er(e){if(e)return Tr[e.toLowerCase()]||e}var Dr=c({name:`video generate`,description:`Generate a video from text or image (happyhorse-1.0-t2v / happyhorse-1.0-i2v / wan2.6-t2v)`,apiDocs:`/best-practice/wanx/text-to-video`,usage:`bl video generate --prompt <text> [--image <url>] [flags]`,options:[{flag:`--model <model>`,description:`Model ID (default: happyhorse-1.0-t2v, or happyhorse-1.0-i2v with --image)`},{flag:`--prompt <text>`,description:`Video description`,required:!0},{flag:`--image <url>`,description:`Input image URL for image-to-video generation`},{flag:`--negative-prompt <text>`,description:`Negative prompt to exclude unwanted content`},{flag:`--resolution <res>`,description:`Resolution (e.g. 1280*720, 960*960)`},{flag:`--ratio <ratio>`,description:`Aspect ratio (e.g. 16:9, 1:1)`},{flag:`--duration <seconds>`,description:`Video duration in seconds (default: 5)`,type:`number`},{flag:`--prompt-extend`,description:`Automatically extend prompt for better results`},{flag:`--watermark`,description:`Add watermark to generated video`},{flag:`--seed <n>`,description:`Random seed for reproducible generation`,type:`number`},{flag:`--download <path>`,description:`Save video to file on completion`},{flag:`--no-wait`,description:`Return task ID immediately without waiting`},{flag:`--async`,description:`Return task ID immediately (agent/CI mode, same as --no-wait)`},{flag:`--poll-interval <seconds>`,description:`Polling interval when waiting (default: 5)`,type:`number`}],examples:[`bl video generate --prompt "一个人在读书,静态镜头"`,`bl video generate --prompt "Ocean waves at sunset." --download sunset.mp4`,`bl video generate --image https://example.com/cat.png --prompt "让画面中的猫动起来"`,`bl video generate --prompt "Mountain landscape" --resolution 1280*720 --duration 5`],async run(t,r){let i=r.prompt;if(!i)if(_({nonInteractive:t.nonInteractive})){let e=await K({message:`Enter your video prompt:`});e||(process.stderr.write(`Video generation cancelled.
122
+ `),process.exit(1)),i=e}else q(`prompt`,`bl video generate --prompt <text>`);let a=r.model||t.defaultVideoModel||(r.image?`happyhorse-1.0-i2v`:`happyhorse-1.0-t2v`),o=l(t.output),s=r.image,c;s&&(c=await D(s,(await E(t)).token,a));let u={model:a,input:{prompt:i,negative_prompt:r.negativePrompt||void 0,...c?{media:[{type:`first_frame`,url:c}]}:{}},parameters:{resolution:Er(r.resolution)||void 0,ratio:r.ratio||void 0,duration:r.duration||void 0,prompt_extend:r.promptExtend===!0?!0:void 0,watermark:r.watermark===!0?!0:void 0,seed:r.seed}};if(t.dryRun){M({request:u},o);return}let d=ur(r),f=pe(t.baseUrl),p=(await dr(d,t,()=>T(t,{url:f,method:`POST`,body:u,async:!0}),`tasks`)).map(e=>e.output.task_id);if(t.quiet||process.stderr.write(`[Model: ${a}]\n`),r.noWait||t.async){M(p.length===1?{task_id:p[0]}:{task_ids:p},o);return}let m=r.pollInterval??5,h=p.map(e=>cr(t,{url:k(t.baseUrl,e),intervalSec:m,timeoutSec:t.timeout,isComplete:e=>e.output.task_status===`SUCCEEDED`,isFailed:e=>e.output.task_status===`FAILED`,getStatus:e=>e.output.task_status,getErrorMessage:e=>{let t=e.output;return t.message||t.code||void 0}})),g=await Promise.all(h),v=[];for(let e=0;e<g.length;e++){let t=g[e],n=t.output.video_url||t.output.results&&t.output.results[0]?.url;n&&v.push({taskId:p[e],videoUrl:n})}if(v.length===0)throw new e(`All tasks completed but no video URLs returned.`,n.GENERAL);if(r.download){let e=r.download,{size:n}=await Y(v[0].videoUrl,e,{quiet:t.quiet});t.quiet?N(e):M({task_id:v[0].taskId,video_url:v[0].videoUrl,status:`SUCCEEDED`,saved:e,size:lr(n)},o);return}let y=O(t,{subDir:`videos`}),{join:b}=await import(`path`),x=[];await Promise.all(v.map(async({taskId:e,videoUrl:n})=>{let r=b(y,`${e}.mp4`);await Y(n,r,{quiet:t.quiet}),x.push({task_id:e,video_url:n,saved:r})})),x.length===1?M(x[0],o):M({videos:x,total:x.length},o)}}),Or=c({name:`video edit`,description:`Edit a video with happyhorse-1.0-video-edit (style transfer, object replacement, etc.)`,apiDocs:`/best-practice/wanx/video-edit`,usage:`bl video edit --video <url> --prompt <text> [flags]`,options:[{flag:`--model <model>`,description:`Model ID (default: happyhorse-1.0-video-edit)`},{flag:`--video <url>`,description:`Input video URL or local file (mp4/mov, 2-10s)`,required:!0},{flag:`--prompt <text>`,description:`Edit instruction (e.g. "将画面转换为黏土风格")`},{flag:`--ref-image <url>`,description:`Reference image URL (up to 4, comma-separated)`},{flag:`--negative-prompt <text>`,description:`Negative prompt to exclude unwanted content`},{flag:`--resolution <res>`,description:`Resolution: 720P or 1080P (default: 1080P)`},{flag:`--ratio <ratio>`,description:`Aspect ratio (16:9, 9:16, 1:1, 4:3, 3:4)`},{flag:`--duration <seconds>`,description:`Output video duration in seconds (2-10)`,type:`number`},{flag:`--audio-setting <mode>`,description:`Audio: auto (default) or origin (keep original)`},{flag:`--prompt-extend`,description:`Enable prompt intelligent rewriting (default: true)`},{flag:`--no-prompt-extend`,description:`Disable prompt intelligent rewriting`},{flag:`--watermark`,description:`Add "AI生成" watermark`},{flag:`--seed <n>`,description:`Random seed for reproducible generation`,type:`number`},{flag:`--download <path>`,description:`Save video to file on completion`},{flag:`--no-wait`,description:`Return task ID immediately without waiting`},{flag:`--async`,description:`Return task ID immediately (agent/CI mode, same as --no-wait)`},{flag:`--poll-interval <seconds>`,description:`Polling interval when waiting (default: 15)`,type:`number`}],examples:[`bl video edit --video https://example.com/input.mp4 --prompt "将整个画面转换为黏土风格"`,`bl video edit --video https://example.com/input.mp4 --prompt "替换衣服为图片中的款式" --ref-image https://example.com/clothes.png`,`bl video edit --video https://example.com/input.mp4 --prompt "Convert to anime style" --resolution 720P --download output.mp4`],async run(t,r){let i=r.video;if(!i)if(_({nonInteractive:t.nonInteractive})){let e=await K({message:`Enter the video URL to edit:`});e||(process.stderr.write(`Video editing cancelled.
123
+ `),process.exit(1)),i=e}else q(`video`,`bl video edit --video <url> --prompt <text>`);let a=r.prompt;if(!a&&_({nonInteractive:t.nonInteractive})){let e=await K({message:`Enter your edit instruction:`});e||(process.stderr.write(`Video editing cancelled.
124
+ `),process.exit(1)),a=e}let o=r.model||`happyhorse-1.0-video-edit`,s=l(t.output),c=await E(t),u=[{type:`video`,url:await D(i,c.token,o)}],d=r.refImage;if(d){let e=d.split(`,`).map(e=>e.trim()).filter(Boolean);for(let t of e){let e=await D(t,c.token,o);u.push({type:`reference_image`,url:e})}}let f=r.noPromptExtend===!0?!1:r.promptExtend===!0?!0:void 0,p={model:o,input:{prompt:a||void 0,negative_prompt:r.negativePrompt||void 0,media:u},parameters:{resolution:r.resolution||void 0,ratio:r.ratio||void 0,duration:r.duration||void 0,audio_setting:r.audioSetting||void 0,prompt_extend:f,watermark:r.watermark===!0?!0:void 0,seed:r.seed}};if(t.dryRun){M({request:p},s);return}let m=(await T(t,{url:pe(t.baseUrl),method:`POST`,body:p,async:!0})).output.task_id;if(t.quiet||(process.stderr.write(`[Model: ${o}]\n`),process.stderr.write(`Note: Video editing typically takes 5-8 minutes. Please be patient.
125
+ `)),r.noWait||t.async){M({task_id:m},s);return}let h=r.pollInterval??15,g=await cr(t,{url:k(t.baseUrl,m),intervalSec:h,timeoutSec:Math.max(t.timeout,600),isComplete:e=>e.output.task_status===`SUCCEEDED`,isFailed:e=>e.output.task_status===`FAILED`,getStatus:e=>e.output.task_status,getErrorMessage:e=>{let t=e.output;return t.message||t.code||void 0}}),v=g.output.video_url||g.output.results&&g.output.results[0]?.url;if(!v)throw new e(`Task completed but no video URL returned.`,n.GENERAL);if(r.download){let e=r.download,{size:n}=await Y(v,e,{quiet:t.quiet});t.quiet?N(e):M({task_id:m,video_url:v,status:`SUCCEEDED`,saved:e,size:lr(n)},s);return}let{join:y}=await import(`path`),b=y(O(t,{subDir:`videos`}),`${m}.mp4`);await Y(v,b,{quiet:t.quiet}),M({task_id:m,video_url:v,saved:b},s)}}),kr=c({name:`video ref`,description:`Reference-to-video generation (happyhorse-1.0-r2v / wan2.6-r2v): multi-subject, multi-shot with voice`,apiDocs:`/best-practice/wanx/video-reference`,usage:`bl video ref --prompt <text> --image <url>... [--ref-video <url>...] [flags]`,options:[{flag:`--model <model>`,description:`Model ID (default: happyhorse-1.0-r2v)`},{flag:`--prompt <text>`,description:`Video description with reference markers (图1, 视频1, etc.)`,required:!0},{flag:`--image <url>`,description:`Reference image URL or local file (repeatable for multiple subjects)`,type:`array`},{flag:`--ref-video <url>`,description:`Reference video URL or local file (repeatable)`,type:`array`},{flag:`--image-voice <url>`,description:`Voice URL for corresponding image (pairs by position)`,type:`array`},{flag:`--video-voice <url>`,description:`Voice URL for corresponding ref-video (pairs by position)`,type:`array`},{flag:`--resolution <res>`,description:`Resolution: 720P or 1080P (default: 720P)`},{flag:`--ratio <ratio>`,description:`Aspect ratio (16:9, 9:16, 1:1)`},{flag:`--duration <seconds>`,description:`Video duration in seconds (2-10, default: 5)`,type:`number`},{flag:`--prompt-extend`,description:`Enable prompt intelligent rewriting`},{flag:`--no-prompt-extend`,description:`Disable prompt intelligent rewriting`},{flag:`--watermark`,description:`Add watermark to generated video`},{flag:`--seed <n>`,description:`Random seed for reproducible generation`,type:`number`},{flag:`--download <path>`,description:`Save video to file on completion`},{flag:`--no-wait`,description:`Return task ID immediately without waiting`},{flag:`--async`,description:`Return task ID immediately (agent/CI mode, same as --no-wait)`},{flag:`--poll-interval <seconds>`,description:`Polling interval when waiting (default: 15)`,type:`number`}],examples:[`bl video ref --prompt "图1在草地上奔跑" --image person.jpg`,`bl video ref --prompt "视频1在弹吉他,图1走过来" --ref-video scene.mp4 --image person.jpg`,`bl video ref --prompt "图1说话" --image person.jpg --image-voice voice.mp3 --resolution 1080P`,`bl video ref --prompt "图1和图2在对话" --image a.jpg --image b.jpg --image-voice va.mp3 --image-voice vb.mp3`],async run(t,r){let i=r.prompt;if(!i)if(_({nonInteractive:t.nonInteractive})){let e=await K({message:`Enter your video prompt (use 图1, 视频1 to reference inputs):`});e||(process.stderr.write(`Video generation cancelled.
126
+ `),process.exit(1)),i=e}else q(`prompt`,`bl video ref --prompt <text> --image <url>`);let a=r.image||[],o=r.refVideo||[];if(a.length===0&&o.length===0)throw new e(`At least one --image or --ref-video is required.`,n.USAGE,`bl video ref --prompt "描述" --image person.jpg`);let s=r.imageVoice||[],c=r.videoVoice||[],u=r.model||`happyhorse-1.0-r2v`,d=l(t.output),f=await E(t),p=[];for(let e=0;e<a.length;e++){let t={type:`reference_image`,url:await D(a[e],f.token,u)};s[e]&&(t.reference_voice=await D(s[e],f.token,u)),p.push(t)}for(let e=0;e<o.length;e++){let t={type:`reference_video`,url:await D(o[e],f.token,u)};c[e]&&(t.reference_voice=await D(c[e],f.token,u)),p.push(t)}let m=r.noPromptExtend===!0?!1:r.promptExtend===!0?!0:void 0,h={model:u,input:{prompt:i,media:p},parameters:{resolution:r.resolution||void 0,ratio:r.ratio||void 0,duration:r.duration||void 0,prompt_extend:m,watermark:r.watermark===!0?!0:void 0,seed:r.seed}};if(t.dryRun){M({request:h},d);return}let g=(await T(t,{url:pe(t.baseUrl),method:`POST`,body:h,async:!0})).output.task_id;if(t.quiet||(process.stderr.write(`[Model: ${u}]\n`),process.stderr.write(`Note: Reference-to-video typically takes 5-10 minutes. Please be patient.
127
+ `)),r.noWait||t.async){M({task_id:g},d);return}let v=r.pollInterval??15,y=await cr(t,{url:k(t.baseUrl,g),intervalSec:v,timeoutSec:Math.max(t.timeout,600),isComplete:e=>e.output.task_status===`SUCCEEDED`,isFailed:e=>e.output.task_status===`FAILED`,getStatus:e=>e.output.task_status,getErrorMessage:e=>{let t=e.output;return t.message||t.code||void 0}}),b=y.output.video_url||y.output.results&&y.output.results[0]?.url;if(!b)throw new e(`Task completed but no video URL returned.`,n.GENERAL);if(r.download){let e=r.download,{size:n}=await Y(b,e,{quiet:t.quiet});t.quiet?N(e):M({task_id:g,video_url:b,status:`SUCCEEDED`,saved:e,size:lr(n)},d);return}let{join:x}=await import(`path`),S=x(O(t,{subDir:`videos`}),`${g}.mp4`);await Y(b,S,{quiet:t.quiet}),M({task_id:g,video_url:b,saved:S},d)}}),Ar=c({name:`video task get`,description:`Query async task status`,usage:`bl video task get --task-id <id>`,options:[{flag:`--task-id <id>`,description:`Async task ID`}],examples:[`bl video task get --task-id 3b256896-3e70-xxxx-xxxx-xxxxxxxxxxxx`,`bl video task get --task-id 3b256896-3e70-xxxx --output json`],async run(t,r){let i=r.taskId;if(!i)throw new e(`--task-id is required.`,n.USAGE,`bl video task get --task-id <id>`);let a=l(t.output);if(t.dryRun){M({task_id:i},a);return}let o=await T(t,{url:k(t.baseUrl,i)});if(t.quiet){N(o.output.task_status);return}M({task_id:o.output.task_id,task_status:o.output.task_status,video_url:o.output.video_url,results:o.output.results,submit_time:o.output.submit_time,end_time:o.output.end_time},a)}}),jr=c({name:`video download`,description:`Download a completed video by task ID`,usage:`bl video download --task-id <id> --out <path>`,options:[{flag:`--task-id <id>`,description:`Task ID to download from`},{flag:`--out <path>`,description:`Output file path`}],examples:[`bl video download --task-id 3b256896-xxxx --out video.mp4`,`bl video download --task-id 3b256896-xxxx --out video.mp4 --quiet`],async run(t,r){let i=r.taskId;if(!i)throw new e(`--task-id is required.`,n.USAGE,`bl video download --task-id <id> --out <path>`);let a=r.out;if(!a)throw new e(`--out is required.`,n.USAGE,`bl video download --task-id <id> --out video.mp4
128
+ Or set output_dir: bl config set --key output_dir --value ~/my-output`);let o=l(t.output);if(t.dryRun){M({task_id:i,action:`download`,out:a},o);return}let s=await T(t,{url:k(t.baseUrl,i)});if(s.output.task_status!==`SUCCEEDED`)throw new e(`Task is not complete (status: ${s.output.task_status}).`,n.GENERAL,`Wait for the task to complete before downloading.`);let c=s.output.video_url||s.output.results&&s.output.results[0]?.url;if(!c)throw new e(`No download URL available for this task.`,n.GENERAL);let{size:u}=await Y(c,a,{quiet:t.quiet});if(t.quiet){N(a);return}M({saved:a,size:lr(u)},o)}});const Mr={".jpg":`image/jpeg`,".jpeg":`image/jpeg`,".png":`image/png`,".webp":`image/webp`},Nr=new Set([`.mp4`,`.mov`,`.avi`,`.mkv`,`.webm`,`.flv`,`.wmv`]);function Pr(e){let t=De(e).toLowerCase().split(`?`)[0];return!!(Nr.has(t)||/\.(mp4|mov|avi|mkv|webm|flv|wmv)(\?|$)/i.test(e))}async function Fr(t){if(t.startsWith(`data:`)||t.startsWith(`http://`)||t.startsWith(`https://`)||t.startsWith(`oss://`))return t;if(!xe(t))throw new e(`File not found: ${t}`,n.USAGE);let r=De(t).toLowerCase(),i=Mr[r];if(!i)throw new e(`Unsupported image format "${r}". Supported: jpg, jpeg, png, webp`,n.USAGE);return`data:${i};base64,${Ce(t).toString(`base64`)}`}var Ir=c({name:`vision describe`,description:`Describe an image or video using Qwen-VL`,usage:`bl vision describe --image <path-or-url> [--video <url>] [--prompt <text>]`,options:[{flag:`--image <path-or-url>`,description:`Local image path or URL`},{flag:`--video <url>`,description:`Video file URL or local path (mp4/mov/avi/mkv/webm)`,type:`array`},{flag:`--prompt <text>`,description:`Question about the content (default: auto-detected)`},{flag:`--model <model>`,description:`Vision model (default: qwen-vl-max)`}],examples:[`bl vision describe --image photo.jpg`,`bl vision describe --image https://example.com/photo.jpg --prompt "这只狗是什么品种?"`,`bl vision describe --video https://example.com/video.mp4 --prompt "总结视频内容"`,`bl vision describe --video ./local-video.mp4`,`bl vision describe --image photo.png --prompt "Extract the text" --model qwen-vl-plus`],async run(t,r){let i=r.image??r._positional?.[0],a=r.video??[],s=r.model||`qwen-vl-max`;i&&Pr(i)&&(a.push(i),i=void 0);let c=a.length>0,u=c?`Describe the video.`:`Describe the image.`,d=r.prompt||u;if(!i&&!c)if(_({nonInteractive:t.nonInteractive})){let e=await K({message:`Enter image/video path or URL:`});e||(process.stderr.write(`Vision describe cancelled.
129
+ `),process.exit(1)),Pr(e)?a.push(e):i=e}else throw new e(`Missing required argument --image or --video.`,n.USAGE,`bl vision describe --image <path-or-url>
130
+ bl vision describe --video <url-or-path>`);let f=l(t.output);if(t.dryRun){M({request:{prompt:d,image:i,video:a.length?a:void 0,model:s}},f);return}let p=[];if(a.length>0)for(let r of a){let i=r;if(v(r)){if(!xe(r))throw new e(`Video file not found: ${r}`,n.USAGE);i=await D(r,(await E(t)).token,s)}p.push({type:`video_url`,video_url:{url:i}})}if(i){let e=await Fr(i),n=e;if(v(i)&&e.startsWith(`data:`)){let{statSync:e}=await import(`fs`);if(e(i).size>5*1024*1024){let e=await E(t);n=await D(i,e.token,s)}}p.push({type:`image_url`,image_url:{url:n}})}p.push({type:`text`,text:d});let m={model:s,messages:[{role:`user`,content:p}]},h=await T(t,{url:o(t.baseUrl),method:`POST`,body:m}),g=h.choices?.[0]?.message?.content;if(f!==`text`){M(h,f);return}N(g||``)}}),Lr=c({name:`config show`,description:`Display current configuration`,usage:`bl config show`,examples:[`bl config show`,`bl config show --output json`],async run(e,t){let n=w(),r=l(e.output),i={region:e.region,base_url:e.baseUrl,output:e.output,timeout:e.timeout,config_file:m()};n.api_key&&(i.api_key=x(n.api_key)),n.default_text_model&&(i.default_text_model=n.default_text_model),n.default_video_model&&(i.default_video_model=n.default_video_model),n.default_image_model&&(i.default_image_model=n.default_image_model),M(i,r)}});const Rr=[`region`,`base_url`,`output`,`output_dir`,`timeout`,`api_key`,`default_text_model`,`default_video_model`,`default_image_model`,`default_speech_model`,`default_omni_model`,`access_key_id`,`access_key_secret`,`workspace_id`],zr={"base-url":`base_url`,"output-dir":`output_dir`,"api-key":`api_key`,"default-text-model":`default_text_model`,"default-video-model":`default_video_model`,"default-image-model":`default_image_model`,"default-speech-model":`default_speech_model`,"default-omni-model":`default_omni_model`,"access-key-id":`access_key_id`,"access-key-secret":`access_key_secret`,"workspace-id":`workspace_id`};var Br=c({name:`config set`,description:`Set a config value`,usage:`bl config set --key <key> --value <value>`,options:[{flag:`--key <key>`,description:`Config key (region, base_url, output, output_dir, timeout, api_key, default_*_model, access_key_id, access_key_secret, workspace_id)`},{flag:`--value <value>`,description:`Value to set`}],examples:[`bl config set --key output --value json`,`bl config set --key timeout --value 600`,`bl config set --key base_url --value https://dashscope.aliyuncs.com`],async run(t,r){let i=r.key,a=r.value;if(!i||a===void 0)throw new e(`--key and --value are required.`,n.USAGE,`bl config set --key <key> --value <value>`);let o=zr[i]||i;if(!Rr.includes(o))throw new e(`Invalid config key "${i}". Valid keys: ${Rr.join(`, `)}`,n.USAGE);if(o===`region`&&![`cn`,`us`,`intl`].includes(a))throw new e(`Invalid region "${a}". Valid values: cn, us, intl`,n.USAGE);if(o===`output`&&![`text`,`json`].includes(a))throw new e(`Invalid output format "${a}". Valid values: text, json`,n.USAGE);if(o===`timeout`){let t=Number(a);if(isNaN(t)||t<=0)throw new e(`Invalid timeout "${a}". Must be a positive number.`,n.USAGE)}let s=l(t.output);if(t.dryRun){M({would_set:{[o]:a}},s);return}let c=w();c[o]=o===`timeout`?Number(a):a,await me(c),t.quiet||M({[o]:c[o]},s)}});const Vr=[`auth `,`config `,`update`];var Hr=c({name:`config export-schema`,description:`Export all (or one) CLI command(s) as Anthropic/OpenAI-compatible JSON tool schemas`,usage:`bl config export-schema [--command "<name>"]`,options:[{flag:`--command <name>`,description:`Export schema for a specific command only (e.g. "image generate")`}],examples:[`bl config export-schema`,`bl config export-schema --command "video generate"`],async run(t,r){let i=r.command;if(i){try{let{command:e}=Z.resolve(i.split(` `)),t=f(e);process.stdout.write(JSON.stringify(t,null,2)+`
131
+ `)}catch{throw new e(`Command "${i}" not found.`,n.USAGE)}return}let a=Z.getAllCommands().filter(e=>!Vr.some(t=>e.name.startsWith(t))).map(e=>f(e));process.stdout.write(JSON.stringify(a,null,2)+`
132
+ `)}});const X=`1.0.0-beta.0`,Ur=`bailian-cli`,Wr=()=>j(p(),`update-state.json`);function Gr(e,t){let n=e.split(`.`).map(Number),r=t.split(`.`).map(Number);for(let e=0;e<3;e++){if((n[e]??0)>(r[e]??0))return!0;if((n[e]??0)<(r[e]??0))return!1}return!1}function Kr(){try{let e=Ce(Wr(),`utf-8`);return JSON.parse(e)}catch{return null}}function qr(e){try{Te(Wr(),JSON.stringify(e))}catch{}}async function Jr(e=3e3){try{let t=Ur.replace(`/`,`%2f`),n=await fetch(`https://registry.npmjs.org/${t}/latest`,{headers:{Accept:`application/json`,...ue()},signal:AbortSignal.timeout(e)});return n.ok?(await n.json()).version??null:null}catch{return null}}let Yr=null;function Xr(){return Yr}async function Zr(e){if(process.env.CI||!process.stderr.isTTY)return;let t=Kr(),n=Date.now();if(t&&n-t.lastChecked<144e5){t.latestVersion&&Gr(t.latestVersion,e)&&(Yr=t.latestVersion);return}let r=await Jr();r&&(qr({lastChecked:n,latestVersion:r}),r&&Gr(r,e)&&(Yr=r))}function Qr(){return{cmd:`npm install -g ${Ur}@latest`,label:`npm`}}var $r=c({name:`update`,description:`Update bl to the latest version`,usage:`bl update`,examples:[`bl update`],async run(){let e=process.stderr.isTTY,t=e?`\x1B[32m`:``,n=e?`\x1B[33m`:``,r=e?`\x1B[0m`:``;process.stderr.write(`Current version: ${n}${X}${r}\n`),process.stderr.write(`Checking for updates...
133
+ `);let i=await Jr(5e3);if(i&&i===X){process.stderr.write(`${t}\u2713 Already up to date (${X}).${r}\n`);return}i&&process.stderr.write(`Latest version: ${t}${i}${r}\n\n`);let{cmd:a,label:o}=Qr();process.stderr.write(`Updating ${Ur} via ${o}...\n\n`);try{Oe(a,{stdio:`inherit`});try{let e=Oe(`bl --version 2>/dev/null`,{encoding:`utf-8`}).trim().replace(/^bl\s+/,``);process.stderr.write(`\n${t}\u2713 Update complete: ${X} \u2192 ${e}${r}\n`);try{Te(j(p(),`update-state.json`),JSON.stringify({lastChecked:Date.now(),latestVersion:e}))}catch{}}catch{process.stderr.write(`\n${t}\u2713 Update complete.${r}\n`)}}catch{process.stderr.write(`
196
134
  Automatic update failed. Please run manually:
197
- `),process.stderr.write(` ${p}
198
-
199
- `)}}});var np=[{command:"bl text chat",title:"Text Generation (Chat Completion)",path:"/best-practice/qwen/chat"},{command:"bl image generate",title:"Image Generation (万相文生图)",path:"/best-practice/wanx/text-to-image"},{command:"bl video generate",title:"Video Generation (万相文生视频)",path:"/best-practice/wanx/text-to-video"},{command:"bl vision describe",title:"Vision (Image Understanding)",path:"/best-practice/qwen/qwen-vl"}],hn=K({name:"help",description:"Show Bailian API documentation links",usage:"bl help",async run(e,t){let n=Qe[e.region]||Qe.cn;process.stdout.write(`
200
- Bailian (百炼) API Documentation Links
201
-
202
- Official docs: ${n}
203
- Console: https://bailian.console.aliyun.com/
204
- Get API Key: https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key
205
-
206
- `);for(let i of np)process.stdout.write(` ${i.command.padEnd(30)} ${i.title}
207
- `),process.stdout.write(` ${" ".repeat(30)} ${n}${i.path}
208
-
209
- `)}});var An=K({name:"app call",description:"Call a Bailian application (agent or workflow)",usage:"bl app call --app-id <id> --prompt <text> [flags]",options:[{flag:"--app-id <id>",description:"Application ID (required)",required:!0},{flag:"--prompt <text>",description:"Input prompt text",required:!0},{flag:"--image <url>",description:"Image URL(s) to pass to the app (repeatable)",type:"array"},{flag:"--file-id <id>",description:"Pre-uploaded file ID(s) (repeatable)",type:"array"},{flag:"--session-id <id>",description:"Session ID for multi-turn conversation"},{flag:"--stream",description:"Stream response (default: on in TTY)"},{flag:"--pipeline-ids <ids>",description:"Knowledge base pipeline IDs (comma-separated)"},{flag:"--memory-id <id>",description:"Memory ID for long-term memory"},{flag:"--biz-params <json>",description:"Business parameters JSON (workflow variables)"},{flag:"--has-thoughts",description:"Show agent thinking process"}],examples:['bl app call --app-id abc123 --prompt "你好"','bl app call --app-id abc123 --prompt "描述这张图片" --image https://example.com/photo.jpg','bl app call --app-id abc123 --prompt "分析图片" --image img1.jpg --image img2.jpg','bl app call --app-id abc123 --prompt "继续" --session-id sess_xxx --stream','bl app call --app-id abc123 --prompt "搜索资料" --pipeline-ids pipe1,pipe2',`bl app call --app-id abc123 --prompt "开始" --biz-params '{"key":"value"}'`],async run(e,t){let n=t.appId;if(!n)W("app-id","bl app call --app-id <id> --prompt <text>");let i=t.prompt;if(!i)W("prompt","bl app call --app-id <id> --prompt <text>");let $=t.stream===!0||t.stream===void 0&&process.stdout.isTTY,p=B(e.output),r={input:{prompt:i},parameters:{incremental_output:$}};if(t.sessionId)r.input.session_id=t.sessionId;let y=t.image;if(y&&y.length>0)r.input.image_list=y;let m=t.fileId;if(m&&m.length>0)r.input.file_ids=m;if(t.hasThoughts)r.parameters.has_thoughts=!0;if(t.pipelineIds){let b=t.pipelineIds.split(",").map((w)=>w.trim()).filter(Boolean);r.parameters.rag_options={pipeline_ids:b}}if(t.memoryId)r.parameters.memory_id=t.memoryId;if(t.bizParams)try{r.input.biz_params=JSON.parse(t.bizParams)}catch{process.stderr.write(`Error: --biz-params must be valid JSON
210
- `),process.exit(1)}if(e.dryRun){A({endpoint:nt(e.baseUrl,n),request:r},p);return}let x=nt(e.baseUrl,n);if($){let w=await ye(e,{url:x,method:"POST",body:r,headers:{"X-DashScope-SSE":"enable"},stream:!0}),S="",q="",o=p==="text",k=e.noColor?"":"\x1B[2m",G=e.noColor?"":"\x1B[0m";for await(let z of Ae(w)){if(z.data==="[DONE]")break;try{let J=JSON.parse(z.data),Z=J.output?.text;if(Z){if(o)process.stdout.write(Z);S+=Z}if(J.output?.session_id)q=J.output.session_id;if(J.output?.thoughts&&t.hasThoughts)for(let j of J.output.thoughts){if(j.thought)process.stderr.write(`${k}[Thinking] ${j.thought}${G}
211
- `);if(j.action_name)process.stderr.write(`${k}[Action] ${j.action_name}: ${j.action_input||""}${G}
212
- `);if(j.observation)process.stderr.write(`${k}[Observation] ${j.observation}${G}
213
- `)}}catch{}}if(q&&!e.quiet)process.stderr.write(`${k}Session ID: ${q}${G}
214
- `);if(p==="json")A({text:S,session_id:q},p);else process.stdout.write(`
215
- `)}else{let b=await Q(e,{url:x,method:"POST",body:r}),w=b.output?.text??"";if(e.quiet||p==="text")N(w);else A(b,p)}}});var un=K({name:"memory add",description:"Add memory from messages or custom content",usage:"bl memory add --user-id <id> [--messages <json>] [--content <text>] [flags]",options:[{flag:"--user-id <id>",description:"User ID (required)",required:!0},{flag:"--messages <json>",description:'Messages JSON array: [{"role":"user","content":"..."},...]'},{flag:"--content <text>",description:"Custom content text to memorize"},{flag:"--profile-schema <id>",description:"Profile schema ID for user profiling"},{flag:"--memory-library-id <id>",description:"Memory library ID (isolate memory space)"}],examples:['bl memory add --user-id user1 --content "用户喜欢Python编程"',`bl memory add --user-id user1 --messages '[{"role":"user","content":"我喜欢旅行"}]'`,'bl memory add --user-id user1 --content "住在北京" --profile-schema schema_xxx'],async run(e,t){let n=t.userId;if(!n)W("user-id","bl memory add --user-id <id>");let i={user_id:n};if(t.messages)try{i.messages=JSON.parse(t.messages)}catch{process.stderr.write(`Error: --messages must be valid JSON array
216
- `),process.exit(1)}if(t.content)i.custom_content=t.content;if(!i.messages&&!i.custom_content)process.stderr.write(`Error: at least one of --messages or --content is required
217
- `),process.exit(1);if(t.profileSchema)i.profile_schema=t.profileSchema;if(t.memoryLibraryId)i.memory_library_id=t.memoryLibraryId;let $=B(e.output);if(e.dryRun){A({endpoint:it(e.baseUrl),request:i},$);return}let p=it(e.baseUrl),r=await Q(e,{url:p,method:"POST",body:i});if(e.quiet||$==="text"){let y=r.memory_ids?.join(", ")||"none";N(`Memory added. IDs: ${y}`)}else A(r,$)}});var Sn=K({name:"memory search",description:"Search memory nodes by query or messages",usage:"bl memory search --user-id <id> [--query <text>] [flags]",options:[{flag:"--user-id <id>",description:"User ID (required)",required:!0},{flag:"--query <text>",description:"Search query text"},{flag:"--messages <json>",description:"Messages JSON array for context-based search"},{flag:"--top-k <n>",description:"Number of results to return (default: 10)",type:"number"},{flag:"--memory-library-id <id>",description:"Memory library ID"}],examples:['bl memory search --user-id user1 --query "编程偏好"',`bl memory search --user-id user1 --messages '[{"role":"user","content":"推荐一本书"}]' --top-k 5`],async run(e,t){let n=t.userId;if(!n)W("user-id","bl memory search --user-id <id>");let i={user_id:n};if(t.query)i.query=t.query;if(t.messages)try{i.messages=JSON.parse(t.messages)}catch{process.stderr.write(`Error: --messages must be valid JSON array
218
- `),process.exit(1)}if(!i.messages&&i.query)i.messages=[{role:"user",content:i.query}];if(!i.query&&!i.messages)process.stderr.write(`Error: at least one of --query or --messages is required
219
- `),process.exit(1);if(t.topK!==void 0)i.top_k=t.topK;if(t.memoryLibraryId)i.memory_library_id=t.memoryLibraryId;let $=B(e.output);if(e.dryRun){A({endpoint:$t(e.baseUrl),request:i},$);return}let p=$t(e.baseUrl),r=await Q(e,{url:p,method:"POST",body:i});if(e.quiet||$==="text")if(!r.memory_nodes||r.memory_nodes.length===0)N("No memory nodes found.");else for(let y of r.memory_nodes)N(`[${y.memory_node_id}] ${y.content}`);else A(r,$)}});var kn=K({name:"memory list",description:"List memory nodes for a user",usage:"bl memory list --user-id <id> [flags]",options:[{flag:"--user-id <id>",description:"User ID (required)",required:!0},{flag:"--page-size <n>",description:"Results per page (default: 10)",type:"number"},{flag:"--page-num <n>",description:"Page number (default: 1)",type:"number"},{flag:"--memory-library-id <id>",description:"Memory library ID"}],examples:["bl memory list --user-id user1","bl memory list --user-id user1 --page-size 20 --page-num 2"],async run(e,t){let n=t.userId;if(!n)W("user-id","bl memory list --user-id <id>");let i=B(e.output),$=new URLSearchParams;if($.set("user_id",n),t.pageSize!==void 0)$.set("page_size",String(t.pageSize));if(t.pageNum!==void 0)$.set("page_num",String(t.pageNum));if(t.memoryLibraryId)$.set("memory_library_id",t.memoryLibraryId);let p=`${vt(e.baseUrl)}?${$.toString()}`;if(e.dryRun){A({endpoint:p,method:"GET"},i);return}let r=await Q(e,{url:p,method:"GET"});if(e.quiet||i==="text")if(!r.memory_nodes||r.memory_nodes.length===0)N("No memory nodes found.");else{for(let y of r.memory_nodes)N(`[${y.memory_node_id}] ${y.content}`);if(r.total!==void 0)N(`
220
- Total: ${r.total}`)}else A(r,i)}});var qn=K({name:"memory update",description:"Update a memory node content",usage:"bl memory update --node-id <id> --user-id <id> --content <text>",options:[{flag:"--node-id <id>",description:"Memory node ID (required)",required:!0},{flag:"--user-id <id>",description:"User ID (required)",required:!0},{flag:"--content <text>",description:"New content for the memory node (required)",required:!0}],examples:['bl memory update --node-id node_xxx --user-id user1 --content "更新后的记忆内容"'],async run(e,t){let n=t.nodeId;if(!n)W("node-id","bl memory update --node-id <id> --user-id <id> --content <text>");let i=t.userId;if(!i)W("user-id","bl memory update --node-id <id> --user-id <id> --content <text>");let $=t.content;if(!$)W("content","bl memory update --node-id <id> --user-id <id> --content <text>");let p={user_id:i,custom_content:$},r=B(e.output);if(e.dryRun){A({endpoint:Ze(e.baseUrl,n),method:"PATCH",request:p},r);return}let y=Ze(e.baseUrl,n),m=await Q(e,{url:y,method:"PATCH",body:p});if(e.quiet||r==="text")N(`Memory node ${n} updated.`);else A(m,r)}});var on=K({name:"memory delete",description:"Delete a memory node",usage:"bl memory delete --node-id <id> --user-id <id>",options:[{flag:"--node-id <id>",description:"Memory node ID (required)",required:!0},{flag:"--user-id <id>",description:"User ID (required)",required:!0}],examples:["bl memory delete --node-id node_xxx --user-id user1"],async run(e,t){let n=t.nodeId;if(!n)W("node-id","bl memory delete --node-id <id> --user-id <id>");let i=t.userId;if(!i)W("user-id","bl memory delete --node-id <id> --user-id <id>");let $=B(e.output),p=new URLSearchParams({user_id:i}),r=`${Ze(e.baseUrl,n)}?${p.toString()}`;if(e.dryRun){A({endpoint:r,method:"DELETE"},$);return}let y=await Q(e,{url:r,method:"DELETE"});if(e.quiet||$==="text")N(`Memory node ${n} deleted.`);else A(y,$)}});var Gn=K({name:"memory profile create",description:"Create a user profile schema for memory profiling",usage:"bl memory profile create --name <name> --attributes <json> [flags]",options:[{flag:"--name <name>",description:"Schema name (required)",required:!0},{flag:"--description <text>",description:"Schema description"},{flag:"--attributes <json>",description:'Attributes JSON array: [{"name":"age","description":"年龄"}]',required:!0}],examples:[`bl memory profile create --name "user_basic" --attributes '[{"name":"age","description":"年龄"},{"name":"hobby","description":"爱好"}]'`],async run(e,t){let n=t.name;if(!n)W("name","bl memory profile create --name <name> --attributes <json>");let i=t.attributes;if(!i)W("attributes","bl memory profile create --name <name> --attributes <json>");let $;try{$=JSON.parse(i)}catch{process.stderr.write(`Error: --attributes must be valid JSON array
221
- `),process.exit(1)}let p={name:n,attributes:$};if(t.description)p.description=t.description;let r=B(e.output);if(e.dryRun){A({endpoint:pt(e.baseUrl),request:p},r);return}let y=pt(e.baseUrl),m=await Q(e,{url:y,method:"POST",body:p});if(e.quiet||r==="text")N(`Profile schema created: ${m.profile_schema_id}`);else A(m,r)}});var Kn=K({name:"memory profile get",description:"Get user profile by schema ID and user ID",usage:"bl memory profile get --schema-id <id> --user-id <id>",options:[{flag:"--schema-id <id>",description:"Profile schema ID (required)",required:!0},{flag:"--user-id <id>",description:"User ID (required)",required:!0}],examples:["bl memory profile get --schema-id schema_xxx --user-id user1"],async run(e,t){let n=t.schemaId;if(!n)W("schema-id","bl memory profile get --schema-id <id> --user-id <id>");let i=t.userId;if(!i)W("user-id","bl memory profile get --schema-id <id> --user-id <id>");let $=B(e.output),p=new URLSearchParams({user_id:i}),r=`${st(e.baseUrl,n)}?${p.toString()}`;if(e.dryRun){A({endpoint:r,method:"GET"},$);return}let y=await Q(e,{url:r,method:"GET"});if(e.quiet||$==="text")if(y.profile?.attributes)for(let m of y.profile.attributes)N(`${m.name}: ${m.value??"(empty)"}`);else N("No profile data found.");else A(y,$)}});import{createHmac as ip,createHash as $p,randomUUID as pp}from"crypto";function Bn(e){let t=e.method??"POST",i=new Date().toISOString().replace(/\.\d{3}Z$/,"Z"),$=pp(),p=Nn(e.body),r={host:e.host,"x-acs-action":e.action,"x-acs-version":e.version,"x-acs-date":i,"x-acs-signature-nonce":$,"x-acs-content-sha256":p,"content-type":"application/json"},y=Object.keys(r).filter((k)=>k==="host"||k==="content-type"||k.startsWith("x-acs-")).sort(),m=y.map((k)=>`${k}:${r[k]}`).join(`
222
- `)+`
223
- `,x=y.join(";"),b=[t,e.pathname,"",m,x,p].join(`
224
- `),w="ACS3-HMAC-SHA256",q=`ACS3-HMAC-SHA256
225
- ${Nn(b)}`,o=yp(e.accessKeySecret,q);return r.authorization=`ACS3-HMAC-SHA256 Credential=${e.accessKeyId},SignedHeaders=${x},Signature=${o}`,r}function Nn(e){return $p("sha256").update(e,"utf8").digest("hex")}function yp(e,t){return ip("sha256",e).update(t,"utf8").digest("hex")}var Zt="bailian.cn-beijing.aliyuncs.com",jn=K({name:"knowledge retrieve",description:"Retrieve from a Bailian knowledge base (requires AK/SK)",usage:"bl knowledge retrieve --index-id <id> --query <text> [flags]",options:[{flag:"--index-id <id>",description:"Knowledge base index ID (required)",required:!0},{flag:"--query <text>",description:"Search query (required)",required:!0},{flag:"--workspace-id <id>",description:"Bailian workspace ID (or env BAILIAN_WORKSPACE_ID)"},{flag:"--top-k <n>",description:"Number of results (default: 10)",type:"number"},{flag:"--rerank",description:"Enable rerank"},{flag:"--rerank-top-n <n>",description:"Rerank top N results",type:"number"},{flag:"--access-key-id <key>",description:"Alibaba Cloud Access Key ID (or env)"},{flag:"--access-key-secret <key>",description:"Alibaba Cloud Access Key Secret (or env)"}],examples:['bl knowledge retrieve --index-id idx_xxx --query "如何使用百炼" --workspace-id ws_xxx','bl knowledge retrieve --index-id idx_xxx --query "API限流" --top-k 5 --rerank'],async run(e,t){let n=t.indexId;if(!n)W("index-id","bl knowledge retrieve --index-id <id> --query <text>");let i=t.query;if(!i)W("query","bl knowledge retrieve --index-id <id> --query <text>");let $=t.accessKeyId||e.accessKeyId,p=t.accessKeySecret||e.accessKeySecret,r=t.workspaceId||e.workspaceId;if(!$||!p)throw new u(`Knowledge retrieve requires Alibaba Cloud AK/SK.
135
+ `),process.stderr.write(` ${a}\n\n`)}}});const ei=[{command:`bl text chat`,title:`Text Generation (Chat Completion)`,path:`/best-practice/qwen/chat`},{command:`bl image generate`,title:`Image Generation (万相文生图)`,path:`/best-practice/wanx/text-to-image`},{command:`bl video generate`,title:`Video Generation (万相文生视频)`,path:`/best-practice/wanx/text-to-video`},{command:`bl vision describe`,title:`Vision (Image Understanding)`,path:`/best-practice/qwen/qwen-vl`}];var ti=c({name:`help`,description:`Show Bailian API documentation links`,usage:`bl help`,async run(e,n){let r=t[e.region]||t.cn;process.stdout.write(`
136
+ Bailian (阿里云百炼) API Documentation Links
137
+
138
+ Official docs: ${r}
139
+ Console: ${Xn}/
140
+ Get API Key: ${J}
141
+
142
+ `);for(let e of ei)process.stdout.write(` ${e.command.padEnd(30)} ${e.title}\n`),process.stdout.write(` ${` `.repeat(30)} ${r}${e.path}\n\n`)}}),ni=c({name:`app call`,description:`Call a Bailian application (agent or workflow)`,usage:`bl app call --app-id <id> --prompt <text> [flags]`,options:[{flag:`--app-id <id>`,description:`Application ID (required)`,required:!0},{flag:`--prompt <text>`,description:`Input prompt text`,required:!0},{flag:`--image <url>`,description:`Image URL(s) to pass to the app (repeatable)`,type:`array`},{flag:`--file-id <id>`,description:`Pre-uploaded file ID(s) (repeatable)`,type:`array`},{flag:`--session-id <id>`,description:`Session ID for multi-turn conversation`},{flag:`--stream`,description:`Stream response (default: on in TTY)`},{flag:`--pipeline-ids <ids>`,description:`Knowledge base pipeline IDs (comma-separated)`},{flag:`--memory-id <id>`,description:`Memory ID for long-term memory`},{flag:`--biz-params <json>`,description:`Business parameters JSON (workflow variables)`},{flag:`--has-thoughts`,description:`Show agent thinking process`}],examples:[`bl app call --app-id abc123 --prompt "你好"`,`bl app call --app-id abc123 --prompt "描述这张图片" --image https://example.com/photo.jpg`,`bl app call --app-id abc123 --prompt "分析图片" --image img1.jpg --image img2.jpg`,`bl app call --app-id abc123 --prompt "继续" --session-id sess_xxx --stream`,`bl app call --app-id abc123 --prompt "搜索资料" --pipeline-ids pipe1,pipe2`,`bl app call --app-id abc123 --prompt "开始" --biz-params '{"key":"value"}'`],async run(e,t){let n=t.appId;n||q(`app-id`,`bl app call --app-id <id> --prompt <text>`);let r=t.prompt;r||q(`prompt`,`bl app call --app-id <id> --prompt <text>`);let i=t.stream===!0||t.stream===void 0&&process.stdout.isTTY,o=l(e.output),s={input:{prompt:r},parameters:{incremental_output:i}};t.sessionId&&(s.input.session_id=t.sessionId);let c=t.image;c&&c.length>0&&(s.input.image_list=c);let u=t.fileId;if(u&&u.length>0&&(s.input.file_ids=u),t.hasThoughts&&(s.parameters.has_thoughts=!0),t.pipelineIds){let e=t.pipelineIds.split(`,`).map(e=>e.trim()).filter(Boolean);s.parameters.rag_options={pipeline_ids:e}}if(t.memoryId&&(s.parameters.memory_id=t.memoryId),t.bizParams)try{s.input.biz_params=JSON.parse(t.bizParams)}catch{process.stderr.write(`Error: --biz-params must be valid JSON
143
+ `),process.exit(1)}if(e.dryRun){M({endpoint:a(e.baseUrl,n),request:s},o);return}let d=a(e.baseUrl,n);if(i){let n=await ae(e,{url:d,method:`POST`,body:s,headers:{"X-DashScope-SSE":`enable`},stream:!0}),r=``,i=``,a=o===`text`,c=e.noColor?``:`\x1B[2m`,l=e.noColor?``:`\x1B[0m`;for await(let e of re(n)){if(e.data===`[DONE]`)break;try{let n=JSON.parse(e.data),o=n.output?.text;if(o&&(a&&process.stdout.write(o),r+=o),n.output?.session_id&&(i=n.output.session_id),n.output?.thoughts&&t.hasThoughts)for(let e of n.output.thoughts)e.thought&&process.stderr.write(`${c}[Thinking] ${e.thought}${l}\n`),e.action_name&&process.stderr.write(`${c}[Action] ${e.action_name}: ${e.action_input||``}${l}\n`),e.observation&&process.stderr.write(`${c}[Observation] ${e.observation}${l}\n`)}catch{}}i&&!e.quiet&&process.stderr.write(`${c}Session ID: ${i}${l}\n`),o===`json`?M({text:r,session_id:i},o):process.stdout.write(`
144
+ `)}else{let t=await T(e,{url:d,method:`POST`,body:s}),n=t.output?.text??``;e.quiet||o===`text`?N(n):M(t,o)}}}),ri=c({name:`memory add`,description:`Add memory from messages or custom content`,usage:`bl memory add --user-id <id> [--messages <json>] [--content <text>] [flags]`,options:[{flag:`--user-id <id>`,description:`User ID (required)`,required:!0},{flag:`--messages <json>`,description:`Messages JSON array: [{"role":"user","content":"..."},...]`},{flag:`--content <text>`,description:`Custom content text to memorize`},{flag:`--profile-schema <id>`,description:`Profile schema ID for user profiling`},{flag:`--memory-library-id <id>`,description:`Memory library ID (isolate memory space)`}],examples:[`bl memory add --user-id user1 --content "用户喜欢Python编程"`,`bl memory add --user-id user1 --messages '[{"role":"user","content":"我喜欢旅行"}]'`,`bl memory add --user-id user1 --content "住在北京" --profile-schema schema_xxx`],async run(e,t){let n=t.userId;n||q(`user-id`,`bl memory add --user-id <id>`);let r={user_id:n};if(t.messages)try{r.messages=JSON.parse(t.messages)}catch{process.stderr.write(`Error: --messages must be valid JSON array
145
+ `),process.exit(1)}t.content&&(r.custom_content=t.content),!r.messages&&!r.custom_content&&(process.stderr.write(`Error: at least one of --messages or --content is required
146
+ `),process.exit(1)),t.profileSchema&&(r.profile_schema=t.profileSchema),t.memoryLibraryId&&(r.memory_library_id=t.memoryLibraryId);let i=l(e.output);if(e.dryRun){M({endpoint:ee(e.baseUrl),request:r},i);return}let a=await T(e,{url:ee(e.baseUrl),method:`POST`,body:r});e.quiet||i===`text`?N(`Memory added. IDs: ${a.memory_ids?.join(`, `)||`none`}`):M(a,i)}}),ii=c({name:`memory search`,description:`Search memory nodes by query or messages`,usage:`bl memory search --user-id <id> [--query <text>] [flags]`,options:[{flag:`--user-id <id>`,description:`User ID (required)`,required:!0},{flag:`--query <text>`,description:`Search query text`},{flag:`--messages <json>`,description:`Messages JSON array for context-based search`},{flag:`--top-k <n>`,description:`Number of results to return (default: 10)`,type:`number`},{flag:`--memory-library-id <id>`,description:`Memory library ID`}],examples:[`bl memory search --user-id user1 --query "编程偏好"`,`bl memory search --user-id user1 --messages '[{"role":"user","content":"推荐一本书"}]' --top-k 5`],async run(e,t){let n=t.userId;n||q(`user-id`,`bl memory search --user-id <id>`);let r={user_id:n};if(t.query&&(r.query=t.query),t.messages)try{r.messages=JSON.parse(t.messages)}catch{process.stderr.write(`Error: --messages must be valid JSON array
147
+ `),process.exit(1)}!r.messages&&r.query&&(r.messages=[{role:`user`,content:r.query}]),!r.query&&!r.messages&&(process.stderr.write(`Error: at least one of --query or --messages is required
148
+ `),process.exit(1)),t.topK!==void 0&&(r.top_k=t.topK),t.memoryLibraryId&&(r.memory_library_id=t.memoryLibraryId);let i=l(e.output);if(e.dryRun){M({endpoint:ne(e.baseUrl),request:r},i);return}let a=await T(e,{url:ne(e.baseUrl),method:`POST`,body:r});if(e.quiet||i===`text`)if(!a.memory_nodes||a.memory_nodes.length===0)N(`No memory nodes found.`);else for(let e of a.memory_nodes)N(`[${e.memory_node_id}] ${e.content}`);else M(a,i)}}),ai=c({name:`memory list`,description:`List memory nodes for a user`,usage:`bl memory list --user-id <id> [flags]`,options:[{flag:`--user-id <id>`,description:`User ID (required)`,required:!0},{flag:`--page-size <n>`,description:`Results per page (default: 10)`,type:`number`},{flag:`--page-num <n>`,description:`Page number (default: 1)`,type:`number`},{flag:`--memory-library-id <id>`,description:`Memory library ID`}],examples:[`bl memory list --user-id user1`,`bl memory list --user-id user1 --page-size 20 --page-num 2`],async run(e,t){let n=t.userId;n||q(`user-id`,`bl memory list --user-id <id>`);let r=l(e.output),i=new URLSearchParams;i.set(`user_id`,n),t.pageSize!==void 0&&i.set(`page_size`,String(t.pageSize)),t.pageNum!==void 0&&i.set(`page_num`,String(t.pageNum)),t.memoryLibraryId&&i.set(`memory_library_id`,t.memoryLibraryId);let a=`${te(e.baseUrl)}?${i.toString()}`;if(e.dryRun){M({endpoint:a,method:`GET`},r);return}let o=await T(e,{url:a,method:`GET`});if(e.quiet||r===`text`)if(!o.memory_nodes||o.memory_nodes.length===0)N(`No memory nodes found.`);else{for(let e of o.memory_nodes)N(`[${e.memory_node_id}] ${e.content}`);o.total!==void 0&&N(`\nTotal: ${o.total}`)}else M(o,r)}}),oi=c({name:`memory update`,description:`Update a memory node content`,usage:`bl memory update --node-id <id> --user-id <id> --content <text>`,options:[{flag:`--node-id <id>`,description:`Memory node ID (required)`,required:!0},{flag:`--user-id <id>`,description:`User ID (required)`,required:!0},{flag:`--content <text>`,description:`New content for the memory node (required)`,required:!0},{flag:`--memory-library-id <id>`,description:`Memory library ID (non-default library)`}],examples:[`bl memory update --node-id node_xxx --user-id user1 --content "更新后的记忆内容"`],async run(e,t){let n=t.nodeId;n||q(`node-id`,`bl memory update --node-id <id> --user-id <id> --content <text>`);let r=t.userId;r||q(`user-id`,`bl memory update --node-id <id> --user-id <id> --content <text>`);let i=t.content;i||q(`content`,`bl memory update --node-id <id> --user-id <id> --content <text>`);let a={user_id:r,custom_content:i};t.memoryLibraryId&&(a.memory_library_id=t.memoryLibraryId);let o=l(e.output);if(e.dryRun){M({endpoint:C(e.baseUrl,n),method:`PATCH`,request:a},o);return}let s=await T(e,{url:C(e.baseUrl,n),method:`PATCH`,body:a});e.quiet||o===`text`?N(`Memory node ${n} updated.`):M(s,o)}}),si=c({name:`memory delete`,description:`Delete a memory node`,usage:`bl memory delete --node-id <id> --user-id <id>`,options:[{flag:`--node-id <id>`,description:`Memory node ID (required)`,required:!0},{flag:`--user-id <id>`,description:`User ID (required)`,required:!0},{flag:`--memory-library-id <id>`,description:`Memory library ID (non-default library)`}],examples:[`bl memory delete --node-id node_xxx --user-id user1`],async run(e,t){let n=t.nodeId;n||q(`node-id`,`bl memory delete --node-id <id> --user-id <id>`);let r=t.userId;r||q(`user-id`,`bl memory delete --node-id <id> --user-id <id>`);let i=l(e.output),a=new URLSearchParams({user_id:r});t.memoryLibraryId&&a.set(`memory_library_id`,t.memoryLibraryId);let o=`${C(e.baseUrl,n)}?${a.toString()}`;if(e.dryRun){M({endpoint:o,method:`DELETE`},i);return}let s=await T(e,{url:o,method:`DELETE`});e.quiet||i===`text`?N(`Memory node ${n} deleted.`):M(s,i)}}),ci=c({name:`memory profile create`,description:`Create a user profile schema for memory profiling`,usage:`bl memory profile create --name <name> --attributes <json> [flags]`,options:[{flag:`--name <name>`,description:`Schema name (required)`,required:!0},{flag:`--description <text>`,description:`Schema description`},{flag:`--attributes <json>`,description:`Attributes JSON array: [{"name":"age","description":"年龄"}]`,required:!0}],examples:[`bl memory profile create --name "user_basic" --attributes '[{"name":"age","description":"年龄"},{"name":"hobby","description":"爱好"}]'`],async run(e,t){let n=t.name;n||q(`name`,`bl memory profile create --name <name> --attributes <json>`);let r=t.attributes;r||q(`attributes`,`bl memory profile create --name <name> --attributes <json>`);let i;try{i=JSON.parse(r)}catch{process.stderr.write(`Error: --attributes must be valid JSON array
149
+ `),process.exit(1)}let a={name:n,attributes:i};t.description&&(a.description=t.description);let o=l(e.output);if(e.dryRun){M({endpoint:ie(e.baseUrl),request:a},o);return}let s=await T(e,{url:ie(e.baseUrl),method:`POST`,body:a});e.quiet||o===`text`?N(`Profile schema created: ${s.profile_schema_id}`):M(s,o)}}),li=c({name:`memory profile get`,description:`Get user profile by schema ID and user ID`,usage:`bl memory profile get --schema-id <id> --user-id <id>`,options:[{flag:`--schema-id <id>`,description:`Profile schema ID (required)`,required:!0},{flag:`--user-id <id>`,description:`User ID (required)`,required:!0}],examples:[`bl memory profile get --schema-id schema_xxx --user-id user1`],async run(e,t){let n=t.schemaId;n||q(`schema-id`,`bl memory profile get --schema-id <id> --user-id <id>`);let r=t.userId;r||q(`user-id`,`bl memory profile get --schema-id <id> --user-id <id>`);let i=l(e.output),a=new URLSearchParams({user_id:r}),o=`${fe(e.baseUrl,n)}?${a.toString()}`;if(e.dryRun){M({endpoint:o,method:`GET`},i);return}let s=await T(e,{url:o,method:`GET`});if(e.quiet||i===`text`)if(s.profile?.attributes)for(let e of s.profile.attributes)N(`${e.name}: ${e.value??`(empty)`}`);else N(`No profile data found.`);else M(s,i)}});const ui=`bailian.cn-beijing.aliyuncs.com`;var di=c({name:`knowledge retrieve`,description:`Retrieve from a Bailian knowledge base (requires AK/SK)`,usage:`bl knowledge retrieve --index-id <id> --query <text> [flags]`,options:[{flag:`--index-id <id>`,description:`Knowledge base index ID (required)`,required:!0},{flag:`--query <text>`,description:`Search query (required)`,required:!0},{flag:`--workspace-id <id>`,description:`Bailian workspace ID (or env BAILIAN_WORKSPACE_ID)`},{flag:`--top-k <n>`,description:`Number of results (default: 10)`,type:`number`},{flag:`--rerank`,description:`Enable rerank`},{flag:`--rerank-top-n <n>`,description:`Rerank top N results`,type:`number`},{flag:`--access-key-id <key>`,description:`Alibaba Cloud Access Key ID (or env)`},{flag:`--access-key-secret <key>`,description:`Alibaba Cloud Access Key Secret (or env)`}],examples:[`bl knowledge retrieve --index-id idx_xxx --query "如何使用阿里云百炼" --workspace-id ws_xxx`,`bl knowledge retrieve --index-id idx_xxx --query "API限流" --top-k 5 --rerank`],async run(t,r){let i=r.indexId;i||q(`index-id`,`bl knowledge retrieve --index-id <id> --query <text>`);let a=r.query;a||q(`query`,`bl knowledge retrieve --index-id <id> --query <text>`);let o=r.accessKeyId||t.accessKeyId,s=r.accessKeySecret||t.accessKeySecret,c=r.workspaceId||t.workspaceId;if(!o||!s)throw new e(`Knowledge retrieve requires Alibaba Cloud AK/SK.
226
150
  Set via: --access-key-id / --access-key-secret flags,
227
151
  or env: ALIBABA_CLOUD_ACCESS_KEY_ID / ALIBABA_CLOUD_ACCESS_KEY_SECRET,
228
- or config: bl config set access_key_id <key>`,h.AUTH);if(!r)throw new u(`Knowledge retrieve requires a workspace ID.
229
- Set via: --workspace-id flag, or env: BAILIAN_WORKSPACE_ID, or config: bl config set workspace_id <id>`,h.USAGE);let y={IndexId:n,Query:i};if(t.topK!==void 0)y.TopK=t.topK;if(t.rerank)y.Rerank=!0;if(t.rerankTopN!==void 0)y.RerankTopN=t.rerankTopN;let m=B(e.output),x=`/${r}/index/retrieve`;if(e.dryRun){A({endpoint:`https://${Zt}${x}`,workspaceId:r,request:y},m);return}let b=JSON.stringify(y),w=Bn({accessKeyId:$,accessKeySecret:p,action:"Retrieve",version:"2023-12-29",body:b,host:Zt,pathname:x}),S=`https://${Zt}${x}`;if(e.verbose)process.stderr.write(`> POST ${S}
230
- `),process.stderr.write(`> AK: ${$.slice(0,8)}...
231
- `);let q=e.timeout*1000,o=await fetch(S,{method:"POST",headers:{...w,...d()},body:b,signal:AbortSignal.timeout(q)});if(e.verbose)process.stderr.write(`< ${o.status} ${o.statusText}
232
- `);let k=await o.json();if(!o.ok||k.Code&&k.Code!=="Success")throw new u(`Knowledge retrieve failed: ${k.Code||o.status} - ${k.Message||o.statusText}`,h.GENERAL);if(e.quiet||m==="text"){let G=k.Data?.Nodes||[];if(G.length===0)N("No results found.");else for(let z=0;z<G.length;z++){let J=G[z];N(`[${z+1}] (score: ${J.Score.toFixed(4)})`),N(J.Text),N("")}}else A(k,m)}});class De{baseUrl;sessionId;nextId=1;config;authToken;constructor(e,t){this.config=e,this.baseUrl=t}async initialize(){let e=await V(this.config);this.authToken=e.token,ce(this.config,e.token,void 0);let t=await this.rpc("initialize",{protocolVersion:"2025-03-26",capabilities:{},clientInfo:{name:"bailian-cli",version:"0.1.2-beta.0"}});if(this.config.verbose)process.stderr.write(`[MCP] Session initialized: ${this.sessionId??"no session"}
233
- `),process.stderr.write(`[MCP] Server: ${JSON.stringify(t)}
234
- `);await this.notify("notifications/initialized")}async listTools(){return(await this.rpc("tools/list")).tools||[]}async callTool(e,t){return await this.rpc("tools/call",{name:e,arguments:t})}async rpc(e,t){let i={jsonrpc:"2.0",id:this.nextId++,method:e,...t?{params:t}:{}},p=await(await this.send(i)).json();if(p.error)throw new u(`MCP error (${p.error.code}): ${p.error.message}`,h.GENERAL);return p.result}async notify(e,t){let n={jsonrpc:"2.0",method:e,...t?{params:t}:{}};await this.send(n)}async send(e){let t={"Content-Type":"application/json",Accept:"application/json, text/event-stream","User-Agent":"bailian-cli/0.1.2-beta.0",...d()};if(this.authToken)t.Authorization=`Bearer ${this.authToken}`;if(this.sessionId)t["Mcp-Session-Id"]=this.sessionId;if(this.config.verbose)process.stderr.write(`> POST ${this.baseUrl}
235
- `),process.stderr.write(`> Method: ${e.method}
236
- `);let n=this.config.timeout*1000,i=await fetch(this.baseUrl,{method:"POST",headers:t,body:JSON.stringify(e),signal:AbortSignal.timeout(n)});if(this.config.verbose)process.stderr.write(`< ${i.status} ${i.statusText}
237
- `);let $=i.headers.get("Mcp-Session-Id")||i.headers.get("mcp-session-id");if($)this.sessionId=$;if(!i.ok){let p=`MCP request failed: ${i.status} ${i.statusText}`;try{let r=await i.text();if(r)p+=` - ${r.slice(0,500)}`}catch{}throw new u(p,h.GENERAL)}return i}}var Rn=K({name:"search web",description:"Search the web using DashScope MCP WebSearch service",usage:"bl search web --query <text> [flags]",options:[{flag:"--query <text>",description:"Search query text",required:!0},{flag:"--count <n>",description:"Number of search results (default: 10)",type:"number"},{flag:"--list-tools",description:"List available MCP tools and exit"}],examples:['bl search web --query "阿里云百炼最新功能"','bl search web --query "TypeScript 5.9 new features" --count 5','bl search web --query "今日新闻"',"bl search web --list-tools"],async run(e,t){let n=Ft(e.baseUrl),i=B(e.output);if(t.listTools){if(e.dryRun){A({endpoint:n,action:"tools/list"},i);return}let y=new De(e,n);await y.initialize();let m=await y.listTools();A({tools:m},i);return}let $=t.query;if(!$)if(Y({nonInteractive:e.nonInteractive})){let y=await L({message:"Enter your search query:"});if(!y)process.stderr.write(`Search cancelled.
238
- `),process.exit(1);$=y}else W("query","bl search web --query <text>");if(e.dryRun){A({endpoint:n,action:"tools/call",tool:"bailian_web_search",arguments:{query:$,count:t.count||void 0}},i);return}let p=new De(e,n),r=se("Initializing search...");if(!e.quiet)r.start();try{if(await p.initialize(),!e.quiet)r.update("Searching...");let y={query:$};if(t.count)y.count=t.count;let m=await p.callTool("bailian_web_search",y);if(!e.quiet)r.stop("Done.");if(m.isError){let x=m.content.map((b)=>b.text||"").join(`
239
- `);process.stderr.write(`Search error: ${x}
240
- `),process.exit(1)}if(i==="json")A(m,i);else for(let x of m.content)if(x.type==="text"&&x.text)try{let b=JSON.parse(x.text);if(b.pages&&Array.isArray(b.pages))A({pages:b.pages,total:b.pages.length},i);else A(b,i)}catch{A({text:x.text},i)}}catch(y){throw r.stop("Failed."),y}}});import{readFileSync as _p}from"fs";import{createWriteStream as mp}from"fs";var Jn=[{voice:"longanyang",name:"龙安洋",desc:"阳光大男孩",lang:"中文/英文"},{voice:"longanhuan",name:"龙安欢",desc:"欢脱元气女",lang:"中文/英文"},{voice:"longantai_v3",name:"龙安台",desc:"嗲甜台湾女",lang:"中文/英文"},{voice:"longhua_v3",name:"龙华",desc:"元气甜美女",lang:"中文/英文"},{voice:"longcheng_v3",name:"龙橙",desc:"智慧青年男",lang:"中文/英文"},{voice:"longze_v3",name:"龙泽",desc:"温暖元气男",lang:"中文/英文"},{voice:"longzhe_v3",name:"龙哲",desc:"呆板大暖男",lang:"中文/英文"},{voice:"longyan_v3",name:"龙颜",desc:"温暖春风女",lang:"中文/英文"},{voice:"longxing_v3",name:"龙星",desc:"温婉邻家女",lang:"中文/英文"},{voice:"longtian_v3",name:"龙天",desc:"磁性理智男",lang:"中文/英文"},{voice:"longwan_v3",name:"龙婉",desc:"细腻柔声女",lang:"中文/英文"},{voice:"longqiang_v3",name:"龙嫱",desc:"浪漫风情女",lang:"中文/英文"},{voice:"longfeifei_v3",name:"龙菲菲",desc:"甜美娇气女",lang:"中文/英文"},{voice:"longhao_v3",name:"龙浩",desc:"多情忧郁男",lang:"中文/英文"},{voice:"longanrou_v3",name:"龙安柔",desc:"温柔娴静女",lang:"中文/英文"},{voice:"longxiaochun_v3",name:"龙小淳",desc:"知性积极女",lang:"中文/英文"},{voice:"longxiaoxia_v3",name:"龙小夏",desc:"沉稳权威女",lang:"中文/英文"},{voice:"longyumi_v3",name:"YUMI",desc:"正经青年女",lang:"中文/英文"},{voice:"longanyun_v3",name:"龙安昀",desc:"居家暖男",lang:"中文/英文"},{voice:"longanwen_v3",name:"龙安温",desc:"优雅知性女",lang:"中文/英文"},{voice:"longanli_v3",name:"龙安莉",desc:"利落从容女",lang:"中文/英文"},{voice:"longanlang_v3",name:"龙安朗",desc:"清爽利落男",lang:"中文/英文"},{voice:"longyingmu_v3",name:"龙应沐",desc:"优雅知性女",lang:"中文/英文"},{voice:"longyingxun_v3",name:"龙应询",desc:"年轻青涩男",lang:"中文/英文"},{voice:"longyingjing_v3",name:"龙应静",desc:"低调冷静女",lang:"中文/英文"},{voice:"longyingling_v3",name:"龙应聆",desc:"温和共情女",lang:"中文/英文"},{voice:"longyingtao_v3",name:"龙应桃",desc:"温柔淡定女",lang:"中文/英文"},{voice:"longyingxiao_v3",name:"龙应笑",desc:"清甜推销女",lang:"中文/英文"},{voice:"longfei_v3",name:"龙飞",desc:"热血磁性男",lang:"中文/英文"},{voice:"longhuhu_v3",name:"龙呼呼",desc:"天真烂漫女童",lang:"中文/英文"},{voice:"longpaopao_v3",name:"龙泡泡",desc:"飞天泡泡音",lang:"中文/英文"},{voice:"longjielidou_v3",name:"龙杰力豆",desc:"阳光顽皮男",lang:"中文/英文"},{voice:"longxian_v3",name:"龙仙",desc:"豪放可爱女",lang:"中文/英文"},{voice:"longling_v3",name:"龙铃",desc:"稚气呆板女",lang:"中文/英文"},{voice:"longshanshan_v3",name:"龙闪闪",desc:"戏剧化童声",lang:"中文/英文"},{voice:"longniuniu_v3",name:"龙牛牛",desc:"阳光男童声",lang:"中文/英文"},{voice:"longjiaxin_v3",name:"龙嘉欣",desc:"优雅粤语女",lang:"粤语/英文"},{voice:"longjiayi_v3",name:"龙嘉怡",desc:"知性粤语女",lang:"粤语/英文"},{voice:"longanyue_v3",name:"龙安粤",desc:"欢脱粤语男",lang:"粤语/英文"},{voice:"longlaotie_v3",name:"龙老铁",desc:"东北直率男",lang:"东北话/英文"},{voice:"longshange_v3",name:"龙陕哥",desc:"原味陕北男",lang:"陕西话/英文"},{voice:"longanmin_v3",name:"龙安闽",desc:"清纯萝莉女",lang:"闽南话/英文"},{voice:"loongabby_v3",name:"loongabby",desc:"美式英文女",lang:"美式英语"},{voice:"loongandy_v3",name:"loongandy",desc:"美式英文男",lang:"美式英语"},{voice:"loongannie_v3",name:"loongannie",desc:"美式英文女",lang:"美式英语"},{voice:"loongava_v3",name:"loongava",desc:"美式英文女",lang:"美式英语"},{voice:"loongbeth_v3",name:"loongbeth",desc:"美式英文女",lang:"美式英语"},{voice:"loongbetty_v3",name:"loongbetty",desc:"美式英文女",lang:"美式英语"},{voice:"loongcally_v3",name:"loongcally",desc:"美式英文女",lang:"美式英语"},{voice:"loongcindy_v3",name:"loongcindy",desc:"美式英文女",lang:"美式英语"},{voice:"loongdavid_v3",name:"loongdavid",desc:"美式英文男",lang:"美式英语"},{voice:"loongdonna_v3",name:"loongdonna",desc:"美式英文女",lang:"美式英语"},{voice:"loongemily_v3",name:"loongemily",desc:"英式英文女",lang:"英式英语"},{voice:"loongeric_v3",name:"loongeric",desc:"英式英文男",lang:"英式英语"},{voice:"loongluna_v3",name:"loongluna",desc:"英式英文女",lang:"英式英语"},{voice:"loongluca_v3",name:"loongluca",desc:"英式英文男",lang:"英式英语"},{voice:"loongriko_v3",name:"Riko",desc:"二次元霓虹女",lang:"日语"},{voice:"loongtomoka_v3",name:"loongtomoka",desc:"日语女",lang:"日语"},{voice:"loongtomoya_v3",name:"loongtomoya",desc:"日语男",lang:"日语"},{voice:"loongyuuna_v3",name:"Yuuna",desc:"日语女",lang:"日语"},{voice:"loongyuuma_v3",name:"Yuuma",desc:"日语男",lang:"日语"},{voice:"loongkyong_v3",name:"loongkyong",desc:"韩语女",lang:"韩语"},{voice:"loongjihun_v3",name:"Jihun",desc:"韩语男",lang:"韩语"},{voice:"loongindah_v3",name:"loongindah",desc:"印尼女",lang:"印尼语"}],zt={"cosyvoice-v3-flash":Jn,"cosyvoice-v3-plus":Jn,"cosyvoice-v3.5-flash":[],"cosyvoice-v3.5-plus":[],"cosyvoice-v2":[]};function xp(e){let t=zt[e];if(!t){process.stdout.write(`No built-in voice list available for model: ${e}
241
- `);return}if(t.length===0){process.stdout.write(`Model ${e} has no system voices.
242
- `),process.stdout.write(`Use clone or design voices created via the CosyVoice API.
243
- `),process.stdout.write(`See: https://help.aliyun.com/zh/model-studio/cosyvoice-clone-design-api
244
- `);return}let n=(i,$)=>i.padEnd($);process.stdout.write(`
245
- System voices for ${e}:
246
- `),process.stdout.write(`${n("VOICE ID",26)} ${n("NAME",10)} ${n("DESCRIPTION",16)} LANGUAGE
247
- `),process.stdout.write(`${"-".repeat(26)} ${"-".repeat(10)} ${"-".repeat(16)} ${"-".repeat(12)}
248
- `);for(let i of t)process.stdout.write(`${n(i.voice,26)} ${n(i.name,10)} ${n(i.desc,16)} ${i.lang}
249
- `);process.stdout.write(`
250
- Total: ${t.length} voices
251
- `)}var Wn=K({name:"speech synthesize",description:"Synthesize speech from text (CosyVoice TTS)",apiDocs:"/developer-reference/cosyvoice",usage:"bl speech synthesize --text <text> [flags]",options:[{flag:"--text <text>",description:"Text to synthesize into speech",required:!0},{flag:"--text-file <path>",description:"Read text from a file instead of --text"},{flag:"--model <model>",description:"Model ID (default: cosyvoice-v3-flash). System voices available for cosyvoice-v3-flash"},{flag:"--voice <voice>",description:"Voice ID. Use --list-voices to see system voices for cosyvoice-v3-flash; for v3.5-flash provide a clone/design voice ID"},{flag:"--list-voices",description:"List available system voices for the selected model and exit"},{flag:"--format <format>",description:"Audio format: mp3, pcm, wav, opus (default: mp3)"},{flag:"--sample-rate <rate>",description:"Audio sample rate in Hz (e.g. 24000)"},{flag:"--volume <volume>",description:"Volume 0-100 (default: 50)"},{flag:"--rate <rate>",description:"Speech rate 0.5-2.0 (default: 1.0)"},{flag:"--pitch <pitch>",description:"Pitch multiplier 0.5-2.0 (default: 1.0)"},{flag:"--seed <seed>",description:"Random seed 0-65535 for reproducible synthesis"},{flag:"--language <lang>",description:"Language hint (e.g. zh, en, ja, ko, fr, de)"},{flag:"--instruction <text>",description:'Natural language instruction to control speech style (e.g. "请用温柔的语调")'},{flag:"--enable-ssml",description:"Enable SSML markup parsing in input text"},{flag:"--out <path>",description:"Save audio to file (default: auto-generate in temp dir)"},{flag:"--stream",description:"Stream raw PCM audio to stdout (pipe to player)"}],examples:["bl speech synthesize --list-voices --model cosyvoice-v3-flash",'bl speech synthesize --text "你好,我是千问" --voice <voice_id>','bl speech synthesize --text "Hello world" --voice <voice_id> --language en',"bl speech synthesize --text-file script.txt --out speech.wav --voice <voice_id>",'bl speech synthesize --text "今天天气真好" --voice <voice_id> --instruction "请用温柔的语调说话"','bl speech synthesize --text "Hello" --voice <voice_id> --format wav --sample-rate 24000',"# Stream to audio player (macOS)",'bl speech synthesize --text "你好" --voice <voice_id> --stream | afplay -',"# Pipe to ffplay",'bl speech synthesize --text "Hello" --voice <voice_id> --stream | ffplay -nodisp -autoexit -f s16le -ar 24000 -ac 1 -'],async run(e,t){let n=t.model||e.defaultSpeechModel||"cosyvoice-v3-flash";if(t.listVoices){xp(n);return}let i=t.text;if(!i&&t.textFile){let J=t.textFile;try{i=_p(J,"utf-8").trim()}catch{throw new u(`Cannot read text file: ${J}`,h.USAGE)}}if(!i)if(Y({nonInteractive:e.nonInteractive})){let J=await L({message:"Enter text to synthesize:"});if(!J)process.stderr.write(`Speech synthesis cancelled.
252
- `),process.exit(1);i=J}else W("text","bl speech synthesize --text <text>");let $=t.voice||void 0;if(!$)if(Y({nonInteractive:e.nonInteractive})){let J=zt[n];if(J&&J.length>0){let Z=J[0].voice,j=J.map((X)=>({value:X.voice,label:`${X.name} (${X.voice})`,hint:`${X.desc} · ${X.lang}`})),T=await Or({message:`Select a voice (default: ${Z}):`,choices:j,defaultValue:Z});if(!T)process.stderr.write(`Speech synthesis cancelled.
253
- `),process.exit(1);$=T}else{let Z=await L({message:"Enter voice ID (clone/design voice):"});if(!Z)process.stderr.write(`Speech synthesis cancelled.
254
- `),process.exit(1);$=Z}}else{let J=zt[n];if(J&&J.length>0)throw new u(`--voice is required.
255
- Run the following to see available voices:
256
- bl speech synthesize --list-voices --model ${n}`,h.USAGE);else throw new u(`--voice is required. Model ${n} has no built-in system voices.
257
- Create a clone or design voice first, then pass its ID via --voice <voice_id>.
258
- See: https://help.aliyun.com/zh/model-studio/cosyvoice-clone-design-api`,h.USAGE)}let p=t.language||void 0,r=t.instruction||void 0,y=t.format||void 0,m=t.sampleRate!==void 0?Number(t.sampleRate):void 0,x=t.volume!==void 0?Number(t.volume):void 0,b=t.rate!==void 0?Number(t.rate):void 0,w=t.pitch!==void 0?Number(t.pitch):void 0,S=t.seed!==void 0?Number(t.seed):void 0,q=t.enableSsml===!0?!0:void 0,o=t.stream===!0,k=B(e.output),G={model:n,input:{text:i,voice:$,format:y,sample_rate:m,volume:x,rate:b,pitch:w,seed:S,language_hints:p?[p]:void 0,instruction:r,enable_ssml:q}};if(Me(G.input),e.dryRun){A({request:G},k);return}if(!e.quiet)process.stderr.write(`[Model: ${n}] [Voice: ${$}]
259
- `);let z=Ut(e.baseUrl);if(o)await wp(e,z,G,t,k);else await bp(e,z,G,t,k)}});async function bp(e,t,n,i,$){let p=Se(i),r=await _e(p,e,()=>Q(e,{url:t,method:"POST",body:n})),y=r.map((S)=>S.output?.audio?.url).filter(Boolean);if(y.length===0)throw new u("API returned no audio URL.",h.GENERAL);let{join:m}=await import("path"),x=l(e,{subDir:"speech"}),b=y.map((S,q)=>{let o=i.out;if(o&&y.length===1);else{let k=Date.now(),G=y.length>1?`_${String(q+1).padStart(3,"0")}`:"",z=n.input.format??"mp3";o=m(x,`tts_${k}${G}.${z}`)}return{url:S,destPath:o}}),w=await Te(b,s,{quiet:e.quiet});if(e.quiet)N(w.join(`
260
- `));else if(w.length===1){let S=r[0].output?.audio?.expires_at;A({saved:w[0],audio_url:y[0],model:n.model,voice:n.input.voice,...S?{url_expires_at:S}:{}},$)}else A({saved:w,audio_urls:y,total:w.length,model:n.model,voice:n.input.voice},$)}async function wp(e,t,n,i,$){let p=await ye(e,{url:t,method:"POST",body:n,stream:!0,headers:{Accept:"text/event-stream","X-DashScope-SSE":"enable"}}),r=i.out,y=r?mp(r):null,m;try{for await(let x of Ae(p)){if(!x.data||x.data==="[DONE]")continue;let b;try{b=JSON.parse(x.data)}catch{continue}let w=b.output?.audio?.data;if(w){let S=Buffer.from(w,"base64");if(y){if(!y.write(S))await new Promise((o)=>y.once("drain",o))}else process.stdout.write(S)}if(b.output?.finish_reason==="stop"){if(m=b.output?.audio?.url,m&&!e.quiet)process.stderr.write(`
261
- Full audio URL: ${m}
262
- `);break}}}finally{if(y){if(await new Promise((x,b)=>{y.on("finish",x),y.on("error",b),y.end()}),!e.quiet&&r)process.stderr.write(`Saved: ${r}
263
- `)}}if(r)A({saved:r,...m?{audio_url:m}:{},model:n.model,voice:n.input.voice},$)}import{writeFileSync as hp}from"fs";var Tn=K({name:"speech recognize",description:"Recognize speech from audio files (FunAudio-ASR)",apiDocs:"/developer-reference/recording-file-recognition",usage:"bl speech recognize --url <audio-url> [flags]",options:[{flag:"--url <url>",description:"Audio file URL or local file path (repeatable, max 100)",required:!0,type:"array"},{flag:"--model <model>",description:"Model ID (default: fun-asr)"},{flag:"--language <lang>",description:"Language hint (e.g. zh, en, ja)"},{flag:"--diarization",description:"Enable automatic speaker diarization"},{flag:"--speaker-count <n>",description:"Expected number of speakers (requires --diarization)",type:"number"},{flag:"--vocabulary-id <id>",description:"Hot-word vocabulary ID for improved accuracy"},{flag:"--channel-id <n>",description:"Audio channel ID (default: 0)",type:"number"},{flag:"--out <path>",description:"Save full transcription result to JSON file"},{flag:"--no-wait",description:"Return task ID immediately without polling"},{flag:"--poll-interval <seconds>",description:"Polling interval in seconds (default: 2)",type:"number"}],examples:["bl speech recognize --url https://example.com/audio.mp3","bl speech recognize --url https://example.com/a.mp3 --url https://example.com/b.mp3","bl speech recognize --url https://example.com/meeting.wav --diarization --speaker-count 3","bl speech recognize --url https://example.com/audio.mp3 --language zh","bl speech recognize --url https://example.com/audio.mp3 --vocabulary-id vocab-abc123","bl speech recognize --url https://example.com/audio.mp3 --out result.json","bl speech recognize --url https://example.com/audio.mp3 --no-wait --quiet"],async run(e,t){let n=[];if(Array.isArray(t.url))n=t.url;else if(typeof t.url==="string")n=[t.url];if(n.length===0)W("url","bl speech recognize --url <audio-url>");let i=t.speakerCount,$=t.diarization===!0;if(i!==void 0&&!$)throw new u(`--speaker-count requires --diarization to be enabled.
264
- Hint: Add --diarization flag to enable speaker separation.`,h.USAGE);let p=t.model||"fun-asr",r=B(e.output),y=await V(e),m=await Promise.all(n.map((k)=>E(k,y.token,p,e.quiet))),x=m.some((k)=>k.startsWith("oss://")),b=t.channelId,w=t.language,S=t.vocabularyId,q={model:p,input:{file_urls:m},parameters:{channel_id:b!==void 0?[b]:[0],language_hints:w?[w]:void 0,diarization_enabled:$?!0:void 0,speaker_count:i,vocabulary_id:S}};if(Me(q.parameters),e.dryRun){A({request:q,mode:"async"},r);return}if(!e.quiet)process.stderr.write(`[Model: ${p}] [Mode: async] [Files: ${m.length}]
265
- `);let o=dt(e.baseUrl);await Ap(e,o,q,t,r,m.length,x)}});async function Ap(e,t,n,i,$,p,r){let m=(await Q(e,{url:t,method:"POST",body:n,async:!0,ossResolve:r})).output.task_id;if(i.noWait||e.async){A({task_id:m},$);return}let x=i.pollInterval??2,b=a(e.baseUrl,m),w=await pe(e,{url:b,intervalSec:x,timeoutSec:e.timeout,isComplete:(o)=>o.output.task_status==="SUCCEEDED",isFailed:(o)=>o.output.task_status==="FAILED",getStatus:(o)=>o.output.task_status,getErrorMessage:(o)=>{return o.output.message}}),S=w.output.results??[];if(S.length===0){A({task_id:m,status:w.output.task_status},$);return}let q=[];for(let o=0;o<S.length;o++){let k=S[o],G=p>1;if(G)process.stdout.write(`=== [${o+1}/${S.length}] ${k.file_url??""} ===
266
- `);if(k.subtask_status==="FAILED"){let j=k.message??k.code??"unknown error";if(process.stdout.write(`[FAILED] ${k.file_url??""} ${j}
267
- `),G)process.stdout.write(`
268
- `);continue}if(!k.transcription_url){if(G)process.stdout.write(`
269
- `);continue}let z=await fetch(k.transcription_url,{headers:d()});if(!z.ok)throw new u(`Failed to download transcription: HTTP ${z.status}`,h.GENERAL);let J=await z.json();q.push(J);let Z=J.transcripts;if(Z&&Z.length>0){for(let j of Z)if(j.sentences&&j.sentences.length>0)for(let T of j.sentences){let X=T.speaker_id!==void 0?` [Speaker ${T.speaker_id}]`:"";process.stdout.write(`${T.text}${X}
270
- `)}else if(j.text)process.stdout.write(j.text+`
271
- `)}else N(JSON.stringify(J));if(G)process.stdout.write(`
272
- `)}if(i.out){let o=i.out,k=q.length===1?q[0]:q;if(hp(o,JSON.stringify(k,null,2)+`
273
- `),!e.quiet)process.stderr.write(`Full result saved to: ${o}
274
- `)}}var Mn=K({name:"file upload",description:"Upload a local file to DashScope temporary storage (48h)",apiDocs:"/developer-reference/get-temporary-file-url",usage:"bl file upload --file <path> --model <model>",options:[{flag:"--file <path>",description:"Local file to upload (image, video, audio)",required:!0},{flag:"--model <model>",description:"Target model name (file is bound to this model)",required:!0}],examples:["bl file upload --file photo.jpg --model qwen-vl-max","bl file upload --file video.mp4 --model wan2.1-t2v-plus","bl file upload --file audio.wav --model qwen3-asr-flash","bl file upload --file cat.png --model qwen-image-2.0"],async run(e,t){let n=t.file;if(!n)W("file","bl file upload --file <path> --model <model>");let i=t.model;if(!i)W("model","bl file upload --file <path> --model <model>");let $=B(e.output);if(e.dryRun){A({action:"upload",file:n,model:i},$);return}let p=await V(e),r=await Qt({apiKey:p.token,model:i,filePath:n,quiet:e.quiet});if(e.quiet)N(r);else A({url:r,model:i,expires_in:"48 hours",note:"When using this URL in API calls, add header: X-DashScope-OssResourceResolve: enable"},$)}});class Qn{root={children:new Map};constructor(e){for(let[t,n]of Object.entries(e))this.register(t,n)}register(e,t){let n=e.split(" "),i=this.root;for(let $ of n){if(!i.children.has($))i.children.set($,{children:new Map});i=i.children.get($)}i.command=t}getAllCommands(){let e=[],t=(n)=>{if(n.command)e.push(n.command);for(let i of n.children.values())t(i)};return t(this.root),e}isGroupPath(e){let t=this.root;for(let n of e){let i=t.children.get(n);if(!i)return!1;t=i}return!t.command&&t.children.size>0}resolve(e){let t=this.root,n=[];for(let i of e){let $=t.children.get(i);if(!$)break;t=$,n.push(i)}if(t.command)return{command:t.command,extra:e.slice(n.length)};if(n.length>0&&t.children.size===1){let[,i]=t.children.entries().next().value;if(i.command)return{command:i.command,extra:e.slice(n.length)}}if(n.length>0&&t.children.size>0){let i=Array.from(t.children.entries()).map(([$,p])=>{if(p.command)return` ${n.join(" ")} ${$} ${p.command.description}`;let r=Array.from(p.children.keys()).join(", ");return` ${n.join(" ")} ${$} [${r}]`}).join(`
275
- `);throw new u(`Unknown command: bl ${e.join(" ")}
276
-
277
- Available commands:
278
- ${i}`,h.USAGE,`bl ${n.join(" ")} --help`)}throw new u(`Unknown command: bl ${e.join(" ")}`,h.USAGE,"bl --help")}bold=(e,t)=>t.isTTY?`\x1B[1m${e}\x1B[0m`:e;accent=(e,t)=>t.isTTY?`\x1B[38;2;59;130;246m${e}\x1B[0m`:e;dim=(e,t)=>t.isTTY?`\x1B[2m${e}\x1B[0m`:e;printHelp(e,t=process.stdout,n="cn"){if(e.length===0){this.printRootHelp(t);return}let i=this.root;for(let p of e){let r=i.children.get(p);if(!r){this.printRootHelp(t);return}i=r}if(i.command){this.printCommandHelp(i.command,t,n);return}let $=e.join(" ");t.write(`
279
- ${this.bold("Usage:",t)} bl ${$} <command> [flags]
280
-
281
- `),t.write(`${this.bold("Commands:",t)}
282
- `),this.printChildren(i,$,t),t.write(`
283
- `)}printRootHelp(e){let t=["██████╗ █████╗ ██╗██╗ ██╗ █████╗ ███╗ ██╗","██╔══██╗██╔══██╗██║██║ ██║██╔══██╗████╗ ██║","██████╔╝███████║██║██║ ██║███████║██╔██╗ ██║","██╔══██╗██╔══██║██║██║ ██║██╔══██║██║╚██╗██║","██████╔╝██║ ██║██║███████╗██║██║ ██║██║ ╚████║","╚═════╝ ╚═╝ ╚═╝╚═╝╚══════╝╚═╝╚═╝ ╚═╝╚═╝ ╚═══╝"],n="\x1B[1;35m",i="\x1B[0m";e.write(`
284
- `);for(let y of t)if(e.isTTY)e.write(`\x1B[1;35m${y}\x1B[0m
285
- `);else e.write(y+`
286
- `);let $=(y)=>this.bold(y,e),p=(y)=>this.accent(y,e),r=(y)=>this.dim(y,e);e.write(`
287
- ${$("Usage:")} bl <resource> <command> [flags]
288
-
289
- ${$("Resources:")}
290
- ${p("auth")} ${r("Authentication (login, status, logout)")}
291
- ${p("text")} ${r("Text generation (chat)")}
292
- ${p("omni")} ${r("Multimodal chat with text + audio (Qwen-Omni)")}
293
- ${p("image")} ${r("Image generation & editing (generate, edit)")}
294
- ${p("video")} ${r("Video generation, editing & reference (generate, edit, ref, task get, download)")}
295
- ${p("vision")} ${r("Image understanding (describe)")}
296
- ${p("app")} ${r("Application call (agent / workflow)")}
297
- ${p("memory")} ${r("Memory management (add, search, list, update, delete, profile)")}
298
- ${p("knowledge")} ${r("Knowledge base (retrieve)")}
299
- ${p("search")} ${r("Web search (web)")}
300
- ${p("speech")} ${r("Speech (synthesize, recognize)")}
301
- ${p("file")} ${r("File upload (temporary URL for model input)")}
302
- ${p("config")} ${r("CLI configuration (show, set, export-schema)")}
303
- ${p("update")} ${r("Update bl to a newer version")}
304
-
305
- ${$("Global Flags:")}
306
- ${p("--api-key <key>")} ${r("API key (overrides all other auth)")}
307
- ${p("--region <region>")} ${r("API region: cn (default), us, intl")}
308
- ${p("--base-url <url>")} ${r("API base URL (overrides region)")}
309
- ${p("--output <format>")} ${r("Output format: text, json")}
310
- ${p("--quiet")} ${r("Suppress non-essential output")}
311
- ${p("--verbose")} ${r("Print HTTP request/response details")}
312
- ${p("--timeout <seconds>")} ${r("Request timeout (default: 300)")}
313
- ${p("--no-color")} ${r("Disable ANSI colors and spinners")}
314
- ${p("--dry-run")} ${r("Show what would happen without executing")}
315
- ${p("--non-interactive")} ${r("Disable interactive prompts (CI/agent mode)")}
316
- ${p("--concurrent <n>")} ${r("Run N parallel requests (default: 1)")}
317
- ${p("--version")} ${r("Print version and exit")}
318
- ${p("--help")} ${r("Show help")}
319
-
320
- ${$("Getting Help:")}
321
- ${r("Add --help after any command to see its full list of options, defaults,")}
322
- ${r("and usage examples. For example:")} bl text chat --help
323
- `)}printCommandHelp(e,t,n="cn"){let i=(r)=>this.bold(r,t),$=(r)=>this.accent(r,t),p=(r)=>this.dim(r,t);if(t.write(`
324
- ${e.description}
325
- `),e.usage)t.write(`${i("Usage:")} ${e.usage}
326
- `);if(e.options&&e.options.length>0){let r=Math.max(...e.options.map((y)=>y.flag.length));t.write(`
327
- ${i("Options:")}
328
- `);for(let y of e.options)t.write(` ${$(y.flag.padEnd(r+2))} ${p(y.description)}
329
- `)}if(e.examples&&e.examples.length>0){t.write(`
330
- ${i("Examples:")}
331
- `);for(let r of e.examples)t.write(` ${p(r)}
332
- `)}if(e.apiDocs)t.write(`
333
- ${i("API Reference:")} ${p(Qe[n]+e.apiDocs)}
334
- `);t.write(`
335
- ${p("Global flags (--api-key, --output, --quiet, etc.) are always available.")}
336
- `),t.write(`${p("Run")} bl --help ${p("for the full list.")}
337
- `)}printChildren(e,t,n){let i=[],$=(r,y)=>{for(let[m,x]of r.children){if(x.command)i.push({fullName:`${y} ${m}`,description:x.command.description});if(x.children.size>0)$(x,`${y} ${m}`)}};$(e,t);let p=Math.max(...i.map((r)=>r.fullName.length));for(let{fullName:r,description:y}of i)n.write(` ${this.accent(r.padEnd(p),n)} ${this.dim(y,n)}
338
- `)}}var me=new Qn({"auth login":Mr,"auth status":Qr,"auth logout":Pr,"text chat":cr,omni:Er,"image generate":sr,"image edit":Dr,"video generate":lr,"video edit":fr,"video ref":gr,"video task get":en,"video download":tn,"vision describe":pn,"app call":An,"memory add":un,"memory search":Sn,"memory list":kn,"memory update":qn,"memory delete":on,"memory profile create":Gn,"memory profile get":Kn,"knowledge retrieve":jn,"search web":Rn,"speech synthesize":Wn,"speech recognize":Tn,"file upload":Mn,"config show":yn,"config set":mn,"config export-schema":xn,update:wn,help:hn});function up(e=process.argv.slice(2),t=process.env.DASHSCOPE_OUTPUT){for(let n=0;n<e.length;n++){let i=e[n];if(i==="--output")return B(e[n+1]||t);if(i?.startsWith("--output="))return B(i.slice(9))}return B(t)}function Ke(e){if(e instanceof u){if(up()==="json")process.stderr.write(JSON.stringify(e.toJSON(),null,2)+`
339
- `);else{if(process.stderr.write(`
340
- Error: ${e.message}
341
- `),e.hint)process.stderr.write(`
342
- ${e.hint.split(`
152
+ or config: bl config set access_key_id <key>`,n.AUTH);if(!c)throw new e(`Knowledge retrieve requires a workspace ID.
153
+ Set via: --workspace-id flag, or env: BAILIAN_WORKSPACE_ID, or config: bl config set workspace_id <id>`,n.USAGE);let u={IndexId:i,Query:a};r.topK!==void 0&&(u.TopK=r.topK),r.rerank&&(u.Rerank=!0),r.rerankTopN!==void 0&&(u.RerankTopN=r.rerankTopN);let d=l(t.output),f=`/${c}/index/retrieve`;if(t.dryRun){M({endpoint:`https://${ui}${f}`,workspaceId:c,request:u},d);return}let p=JSON.stringify(u),m=oe({accessKeyId:o,accessKeySecret:s,action:`Retrieve`,version:`2023-12-29`,body:p,host:ui,pathname:f}),h=`https://${ui}${f}`;t.verbose&&(process.stderr.write(`> POST ${h}\n`),process.stderr.write(`> AK: ${o.slice(0,8)}...\n`));let g=t.timeout*1e3,_=await fetch(h,{method:`POST`,headers:{...m,...ue()},body:p,signal:AbortSignal.timeout(g)});t.verbose&&process.stderr.write(`< ${_.status} ${_.statusText}\n`);let v=await _.json();if(!_.ok||v.Code&&v.Code!==`Success`)throw new e(`Knowledge retrieve failed: ${v.Code||_.status} - ${v.Message||_.statusText}`,n.GENERAL);if(t.quiet||d===`text`){let e=v.Data?.Nodes||[];if(e.length===0)N(`No results found.`);else for(let t=0;t<e.length;t++){let n=e[t];N(`[${t+1}] (score: ${n.Score.toFixed(4)})`),N(n.Text),N(``)}}else M(v,d)}}),fi=c({name:`search web`,description:`Search the web using DashScope MCP WebSearch service`,usage:`bl search web --query <text> [flags]`,options:[{flag:`--query <text>`,description:`Search query text`,required:!0},{flag:`--count <n>`,description:`Number of search results (default: 10)`,type:`number`},{flag:`--list-tools`,description:`List available MCP tools and exit`}],examples:[`bl search web --query "阿里云百炼最新功能"`,`bl search web --query "TypeScript 5.9 new features" --count 5`,`bl search web --query "今日新闻"`,`bl search web --list-tools`],async run(e,t){let n=S(e.baseUrl),r=l(e.output);if(t.listTools){if(e.dryRun){M({endpoint:n,action:`tools/list`},r);return}let t=new i(e,n);await t.initialize(),M({tools:await t.listTools()},r);return}let a=t.query;if(!a)if(_({nonInteractive:e.nonInteractive})){let e=await K({message:`Enter your search query:`});e||(process.stderr.write(`Search cancelled.
154
+ `),process.exit(1)),a=e}else q(`query`,`bl search web --query <text>`);if(e.dryRun){M({endpoint:n,action:`tools/call`,tool:`bailian_web_search`,arguments:{query:a,count:t.count||void 0}},r);return}let o=new i(e,n),s=or(`Initializing search...`);e.quiet||s.start();try{await o.initialize(),e.quiet||s.update(`Searching...`);let n={query:a};t.count&&(n.count=t.count);let i=await o.callTool(`bailian_web_search`,n);if(e.quiet||s.stop(`Done.`),i.isError){let e=i.content.map(e=>e.text||``).join(`
155
+ `);process.stderr.write(`Search error: ${e}\n`),process.exit(1)}if(r===`json`)M(i,r);else for(let e of i.content)if(e.type===`text`&&e.text)try{let t=JSON.parse(e.text);t.pages&&Array.isArray(t.pages)?M({pages:t.pages,total:t.pages.length},r):M(t,r)}catch{M({text:e.text},r)}}catch(e){throw s.stop(`Failed.`),e}}});const pi=`${t.cn}/cosyvoice-clone-design-api`,mi=[{voice:`longanyang`,name:`龙安洋`,desc:`阳光大男孩`,lang:`中文/英文`},{voice:`longanhuan`,name:`龙安欢`,desc:`欢脱元气女`,lang:`中文/英文`},{voice:`longantai_v3`,name:`龙安台`,desc:`嗲甜台湾女`,lang:`中文/英文`},{voice:`longhua_v3`,name:`龙华`,desc:`元气甜美女`,lang:`中文/英文`},{voice:`longcheng_v3`,name:`龙橙`,desc:`智慧青年男`,lang:`中文/英文`},{voice:`longze_v3`,name:`龙泽`,desc:`温暖元气男`,lang:`中文/英文`},{voice:`longzhe_v3`,name:`龙哲`,desc:`呆板大暖男`,lang:`中文/英文`},{voice:`longyan_v3`,name:`龙颜`,desc:`温暖春风女`,lang:`中文/英文`},{voice:`longxing_v3`,name:`龙星`,desc:`温婉邻家女`,lang:`中文/英文`},{voice:`longtian_v3`,name:`龙天`,desc:`磁性理智男`,lang:`中文/英文`},{voice:`longwan_v3`,name:`龙婉`,desc:`细腻柔声女`,lang:`中文/英文`},{voice:`longqiang_v3`,name:`龙嫱`,desc:`浪漫风情女`,lang:`中文/英文`},{voice:`longfeifei_v3`,name:`龙菲菲`,desc:`甜美娇气女`,lang:`中文/英文`},{voice:`longhao_v3`,name:`龙浩`,desc:`多情忧郁男`,lang:`中文/英文`},{voice:`longanrou_v3`,name:`龙安柔`,desc:`温柔娴静女`,lang:`中文/英文`},{voice:`longxiaochun_v3`,name:`龙小淳`,desc:`知性积极女`,lang:`中文/英文`},{voice:`longxiaoxia_v3`,name:`龙小夏`,desc:`沉稳权威女`,lang:`中文/英文`},{voice:`longyumi_v3`,name:`YUMI`,desc:`正经青年女`,lang:`中文/英文`},{voice:`longanyun_v3`,name:`龙安昀`,desc:`居家暖男`,lang:`中文/英文`},{voice:`longanwen_v3`,name:`龙安温`,desc:`优雅知性女`,lang:`中文/英文`},{voice:`longanli_v3`,name:`龙安莉`,desc:`利落从容女`,lang:`中文/英文`},{voice:`longanlang_v3`,name:`龙安朗`,desc:`清爽利落男`,lang:`中文/英文`},{voice:`longyingmu_v3`,name:`龙应沐`,desc:`优雅知性女`,lang:`中文/英文`},{voice:`longyingxun_v3`,name:`龙应询`,desc:`年轻青涩男`,lang:`中文/英文`},{voice:`longyingjing_v3`,name:`龙应静`,desc:`低调冷静女`,lang:`中文/英文`},{voice:`longyingling_v3`,name:`龙应聆`,desc:`温和共情女`,lang:`中文/英文`},{voice:`longyingtao_v3`,name:`龙应桃`,desc:`温柔淡定女`,lang:`中文/英文`},{voice:`longyingxiao_v3`,name:`龙应笑`,desc:`清甜推销女`,lang:`中文/英文`},{voice:`longfei_v3`,name:`龙飞`,desc:`热血磁性男`,lang:`中文/英文`},{voice:`longhuhu_v3`,name:`龙呼呼`,desc:`天真烂漫女童`,lang:`中文/英文`},{voice:`longpaopao_v3`,name:`龙泡泡`,desc:`飞天泡泡音`,lang:`中文/英文`},{voice:`longjielidou_v3`,name:`龙杰力豆`,desc:`阳光顽皮男`,lang:`中文/英文`},{voice:`longxian_v3`,name:`龙仙`,desc:`豪放可爱女`,lang:`中文/英文`},{voice:`longling_v3`,name:`龙铃`,desc:`稚气呆板女`,lang:`中文/英文`},{voice:`longshanshan_v3`,name:`龙闪闪`,desc:`戏剧化童声`,lang:`中文/英文`},{voice:`longniuniu_v3`,name:`龙牛牛`,desc:`阳光男童声`,lang:`中文/英文`},{voice:`longjiaxin_v3`,name:`龙嘉欣`,desc:`优雅粤语女`,lang:`粤语/英文`},{voice:`longjiayi_v3`,name:`龙嘉怡`,desc:`知性粤语女`,lang:`粤语/英文`},{voice:`longanyue_v3`,name:`龙安粤`,desc:`欢脱粤语男`,lang:`粤语/英文`},{voice:`longlaotie_v3`,name:`龙老铁`,desc:`东北直率男`,lang:`东北话/英文`},{voice:`longshange_v3`,name:`龙陕哥`,desc:`原味陕北男`,lang:`陕西话/英文`},{voice:`longanmin_v3`,name:`龙安闽`,desc:`清纯萝莉女`,lang:`闽南话/英文`},{voice:`loongabby_v3`,name:`loongabby`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongandy_v3`,name:`loongandy`,desc:`美式英文男`,lang:`美式英语`},{voice:`loongannie_v3`,name:`loongannie`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongava_v3`,name:`loongava`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongbeth_v3`,name:`loongbeth`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongbetty_v3`,name:`loongbetty`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongcally_v3`,name:`loongcally`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongcindy_v3`,name:`loongcindy`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongdavid_v3`,name:`loongdavid`,desc:`美式英文男`,lang:`美式英语`},{voice:`loongdonna_v3`,name:`loongdonna`,desc:`美式英文女`,lang:`美式英语`},{voice:`loongemily_v3`,name:`loongemily`,desc:`英式英文女`,lang:`英式英语`},{voice:`loongeric_v3`,name:`loongeric`,desc:`英式英文男`,lang:`英式英语`},{voice:`loongluna_v3`,name:`loongluna`,desc:`英式英文女`,lang:`英式英语`},{voice:`loongluca_v3`,name:`loongluca`,desc:`英式英文男`,lang:`英式英语`},{voice:`loongriko_v3`,name:`Riko`,desc:`二次元霓虹女`,lang:`日语`},{voice:`loongtomoka_v3`,name:`loongtomoka`,desc:`日语女`,lang:`日语`},{voice:`loongtomoya_v3`,name:`loongtomoya`,desc:`日语男`,lang:`日语`},{voice:`loongyuuna_v3`,name:`Yuuna`,desc:`日语女`,lang:`日语`},{voice:`loongyuuma_v3`,name:`Yuuma`,desc:`日语男`,lang:`日语`},{voice:`loongkyong_v3`,name:`loongkyong`,desc:`韩语女`,lang:`韩语`},{voice:`loongjihun_v3`,name:`Jihun`,desc:`韩语男`,lang:`韩语`},{voice:`loongindah_v3`,name:`loongindah`,desc:`印尼女`,lang:`印尼语`}],hi={"cosyvoice-v3-flash":mi,"cosyvoice-v3-plus":mi,"cosyvoice-v3.5-flash":[],"cosyvoice-v3.5-plus":[],"cosyvoice-v2":[]};function gi(e){let t=hi[e];if(!t){process.stdout.write(`No built-in voice list available for model: ${e}\n`);return}if(t.length===0){process.stdout.write(`Model ${e} has no system voices.\n`),process.stdout.write(`Use clone or design voices created via the CosyVoice API.
156
+ `),process.stdout.write(`See: ${pi}\n`);return}let n=(e,t)=>e.padEnd(t);process.stdout.write(`\nSystem voices for ${e}:\n`),process.stdout.write(`${n(`VOICE ID`,26)} ${n(`NAME`,10)} ${n(`DESCRIPTION`,16)} LANGUAGE\n`),process.stdout.write(`${`-`.repeat(26)} ${`-`.repeat(10)} ${`-`.repeat(16)} ${`-`.repeat(12)}\n`);for(let e of t)process.stdout.write(`${n(e.voice,26)} ${n(e.name,10)} ${n(e.desc,16)} ${e.lang}\n`);process.stdout.write(`\nTotal: ${t.length} voices\n`)}var _i=c({name:`speech synthesize`,description:`Synthesize speech from text (CosyVoice TTS)`,apiDocs:`/developer-reference/cosyvoice`,usage:`bl speech synthesize --text <text> [flags]`,options:[{flag:`--text <text>`,description:`Text to synthesize into speech`,required:!0},{flag:`--text-file <path>`,description:`Read text from a file instead of --text`},{flag:`--model <model>`,description:`Model ID (default: cosyvoice-v3-flash). System voices available for cosyvoice-v3-flash`},{flag:`--voice <voice>`,description:`Voice ID. Use --list-voices to see system voices for cosyvoice-v3-flash; for v3.5-flash provide a clone/design voice ID`},{flag:`--list-voices`,description:`List available system voices for the selected model and exit`},{flag:`--format <format>`,description:`Audio format: mp3, pcm, wav, opus (default: mp3)`},{flag:`--sample-rate <rate>`,description:`Audio sample rate in Hz (e.g. 24000)`},{flag:`--volume <volume>`,description:`Volume 0-100 (default: 50)`},{flag:`--rate <rate>`,description:`Speech rate 0.5-2.0 (default: 1.0)`},{flag:`--pitch <pitch>`,description:`Pitch multiplier 0.5-2.0 (default: 1.0)`},{flag:`--seed <seed>`,description:`Random seed 0-65535 for reproducible synthesis`},{flag:`--language <lang>`,description:`Language hint (e.g. zh, en, ja, ko, fr, de)`},{flag:`--instruction <text>`,description:`Natural language instruction to control speech style (e.g. "请用温柔的语调")`},{flag:`--enable-ssml`,description:`Enable SSML markup parsing in input text`},{flag:`--out <path>`,description:`Save audio to file (default: auto-generate in temp dir)`},{flag:`--stream`,description:`Stream raw PCM audio to stdout (pipe to player)`}],examples:[`bl speech synthesize --list-voices --model cosyvoice-v3-flash`,`bl speech synthesize --text "你好,我是千问" --voice <voice_id>`,`bl speech synthesize --text "Hello world" --voice <voice_id> --language en`,`bl speech synthesize --text-file script.txt --out speech.wav --voice <voice_id>`,`bl speech synthesize --text "今天天气真好" --voice <voice_id> --instruction "请用温柔的语调说话"`,`bl speech synthesize --text "Hello" --voice <voice_id> --format wav --sample-rate 24000`,`# Stream to audio player (macOS)`,`bl speech synthesize --text "你好" --voice <voice_id> --stream | afplay -`,`# Pipe to ffplay`,`bl speech synthesize --text "Hello" --voice <voice_id> --stream | ffplay -nodisp -autoexit -f s16le -ar 24000 -ac 1 -`],async run(t,r){let i=r.model||t.defaultSpeechModel||`cosyvoice-v3-flash`;if(r.listVoices){gi(i);return}let a=r.text;if(!a&&r.textFile){let t=r.textFile;try{a=Ce(t,`utf-8`).trim()}catch{throw new e(`Cannot read text file: ${t}`,n.USAGE)}}if(!a)if(_({nonInteractive:t.nonInteractive})){let e=await K({message:`Enter text to synthesize:`});e||(process.stderr.write(`Speech synthesis cancelled.
157
+ `),process.exit(1)),a=e}else q(`text`,`bl speech synthesize --text <text>`);let o=r.voice||void 0;if(!o)if(_({nonInteractive:t.nonInteractive})){let e=hi[i];if(e&&e.length>0){let t=e[0].voice,n=e.map(e=>({value:e.voice,label:`${e.name} (${e.voice})`,hint:`${e.desc} · ${e.lang}`})),r=await Yn({message:`Select a voice (default: ${t}):`,choices:n,defaultValue:t});r||(process.stderr.write(`Speech synthesis cancelled.
158
+ `),process.exit(1)),o=r}else{let e=await K({message:`Enter voice ID (clone/design voice):`});e||(process.stderr.write(`Speech synthesis cancelled.
159
+ `),process.exit(1)),o=e}}else{let t=hi[i];throw t&&t.length>0?new e(`--voice is required.\nRun the following to see available voices:\n bl speech synthesize --list-voices --model ${i}`,n.USAGE):new e(`--voice is required. Model ${i} has no built-in system voices.\nCreate a clone or design voice first, then pass its ID via --voice <voice_id>.\nSee: ${pi}`,n.USAGE)}let s=r.language||void 0,c=r.instruction||void 0,u=r.format||void 0,d=r.sampleRate===void 0?void 0:Number(r.sampleRate),f=r.volume===void 0?void 0:Number(r.volume),p=r.rate===void 0?void 0:Number(r.rate),m=r.pitch===void 0?void 0:Number(r.pitch),h=r.seed===void 0?void 0:Number(r.seed),g=r.enableSsml===!0?!0:void 0,v=r.stream===!0,y=l(t.output),b={model:i,input:{text:a,voice:o,format:u,sample_rate:d,volume:f,rate:p,pitch:m,seed:h,language_hints:s?[s]:void 0,instruction:c,enable_ssml:g}};if(le(b.input),t.dryRun){M({request:b},y);return}t.quiet||process.stderr.write(`[Model: ${i}] [Voice: ${o}]\n`);let x=ce(t.baseUrl);v?await yi(t,x,b,r,y):await vi(t,x,b,r,y)}});async function vi(t,r,i,a,o){let s=await dr(ur(a),t,()=>T(t,{url:r,method:`POST`,body:i})),c=s.map(e=>e.output?.audio?.url).filter(Boolean);if(c.length===0)throw new e(`API returned no audio URL.`,n.GENERAL);let{join:l}=await import(`path`),u=O(t,{subDir:`speech`}),d=await fr(c.map((e,t)=>{let n=a.out;return n&&c.length===1||(n=l(u,`tts_${Date.now()}${c.length>1?`_${String(t+1).padStart(3,`0`)}`:``}.${i.input.format??`mp3`}`)),{url:e,destPath:n}}),Y,{quiet:t.quiet});if(t.quiet)N(d.join(`
160
+ `));else if(d.length===1){let e=s[0].output?.audio?.expires_at;M({saved:d[0],audio_url:c[0],model:i.model,voice:i.input.voice,...e?{url_expires_at:e}:{}},o)}else M({saved:d,audio_urls:c,total:d.length,model:i.model,voice:i.input.voice},o)}async function yi(e,t,n,r,i){let a=await ae(e,{url:t,method:`POST`,body:n,stream:!0,headers:{Accept:`text/event-stream`,"X-DashScope-SSE":`enable`}}),o=r.out,s=o?be(o):null,c;try{for await(let t of re(a)){if(!t.data||t.data===`[DONE]`)continue;let n;try{n=JSON.parse(t.data)}catch{continue}let r=n.output?.audio?.data;if(r){let e=Buffer.from(r,`base64`);s?s.write(e)||await new Promise(e=>s.once(`drain`,()=>e())):process.stdout.write(e)}if(n.output?.finish_reason===`stop`){c=n.output?.audio?.url,c&&!e.quiet&&process.stderr.write(`\nFull audio URL: ${c}\n`);break}}}finally{s&&(await new Promise((e,t)=>{s.on(`finish`,e),s.on(`error`,t),s.end()}),!e.quiet&&o&&process.stderr.write(`Saved: ${o}\n`))}o&&M({saved:o,...c?{audio_url:c}:{},model:n.model,voice:n.input.voice},i)}var bi=c({name:`speech recognize`,description:`Recognize speech from audio files (FunAudio-ASR)`,apiDocs:`/developer-reference/recording-file-recognition`,usage:`bl speech recognize --url <audio-url> [flags]`,options:[{flag:`--url <url>`,description:`Audio file URL or local file path (repeatable, max 100)`,required:!0,type:`array`},{flag:`--model <model>`,description:`Model ID (default: fun-asr)`},{flag:`--language <lang>`,description:`Language hint (e.g. zh, en, ja)`},{flag:`--diarization`,description:`Enable automatic speaker diarization`},{flag:`--speaker-count <n>`,description:`Expected number of speakers (requires --diarization)`,type:`number`},{flag:`--vocabulary-id <id>`,description:`Hot-word vocabulary ID for improved accuracy`},{flag:`--channel-id <n>`,description:`Audio channel ID (default: 0)`,type:`number`},{flag:`--out <path>`,description:`Save full transcription result to JSON file`},{flag:`--no-wait`,description:`Return task ID immediately without polling`},{flag:`--poll-interval <seconds>`,description:`Polling interval in seconds (default: 2)`,type:`number`}],examples:[`bl speech recognize --url https://example.com/audio.mp3`,`bl speech recognize --url https://example.com/a.mp3 --url https://example.com/b.mp3`,`bl speech recognize --url https://example.com/meeting.wav --diarization --speaker-count 3`,`bl speech recognize --url https://example.com/audio.mp3 --language zh`,`bl speech recognize --url https://example.com/audio.mp3 --vocabulary-id vocab-abc123`,`bl speech recognize --url https://example.com/audio.mp3 --out result.json`,`bl speech recognize --url https://example.com/audio.mp3 --no-wait --quiet`],async run(t,r){let i=[];Array.isArray(r.url)?i=r.url:typeof r.url==`string`&&(i=[r.url]),i.length===0&&q(`url`,`bl speech recognize --url <audio-url>`);let a=r.speakerCount,o=r.diarization===!0;if(a!==void 0&&!o)throw new e(`--speaker-count requires --diarization to be enabled.
161
+ Hint: Add --diarization flag to enable speaker separation.`,n.USAGE);let s=r.model||`fun-asr`,c=l(t.output),u=await E(t),d=await Promise.all(i.map(e=>D(e,u.token,s))),f=r.channelId,p=r.language,m=r.vocabularyId,h={model:s,input:{file_urls:d},parameters:{channel_id:f===void 0?[0]:[f],language_hints:p?[p]:void 0,diarization_enabled:o?!0:void 0,speaker_count:a,vocabulary_id:m}};if(le(h.parameters),t.dryRun){M({request:h,mode:`async`},c);return}t.quiet||process.stderr.write(`[Model: ${s}] [Mode: async] [Files: ${d.length}]\n`),await xi(t,se(t.baseUrl),h,r,c,d.length)}});async function xi(t,r,i,a,o,s){let c=(await T(t,{url:r,method:`POST`,body:i,async:!0})).output.task_id;if(a.noWait||t.async){M({task_id:c},o);return}let l=a.pollInterval??2,u=await cr(t,{url:k(t.baseUrl,c),intervalSec:l,timeoutSec:t.timeout,isComplete:e=>e.output.task_status===`SUCCEEDED`,isFailed:e=>e.output.task_status===`FAILED`,getStatus:e=>e.output.task_status,getErrorMessage:e=>e.output.message}),d=u.output.results??[];if(d.length===0){M({task_id:c,status:u.output.task_status},o);return}let f=[];for(let t=0;t<d.length;t++){let r=d[t],i=s>1;if(i&&process.stdout.write(`=== [${t+1}/${d.length}] ${r.file_url??``} ===\n`),r.subtask_status===`FAILED`){let e=r.message??r.code??`unknown error`;process.stdout.write(`[FAILED] ${r.file_url??``} ${e}\n`),i&&process.stdout.write(`
162
+ `);continue}if(!r.transcription_url){i&&process.stdout.write(`
163
+ `);continue}let a=await fetch(r.transcription_url,{headers:ue()});if(!a.ok)throw new e(`Failed to download transcription: HTTP ${a.status}`,n.GENERAL);let o=await a.json();f.push(o);let c=o.transcripts;if(c&&c.length>0)for(let e of c)if(e.sentences&&e.sentences.length>0)for(let t of e.sentences){let e=t.speaker_id===void 0?``:` [Speaker ${t.speaker_id}]`;process.stdout.write(`${t.text}${e}\n`)}else e.text&&process.stdout.write(e.text+`
164
+ `);else N(JSON.stringify(o));i&&process.stdout.write(`
165
+ `)}if(a.out){let e=a.out,n=f.length===1?f[0]:f;Te(e,JSON.stringify(n,null,2)+`
166
+ `),t.quiet||process.stderr.write(`Full result saved to: ${e}\n`)}}var Si=c({name:`file upload`,description:`Upload a local file to DashScope temporary storage (48h)`,apiDocs:`/developer-reference/get-temporary-file-url`,usage:`bl file upload --file <path> --model <model>`,options:[{flag:`--file <path>`,description:`Local file to upload (image, video, audio)`,required:!0},{flag:`--model <model>`,description:`Target model name (file is bound to this model)`,required:!0}],examples:[`bl file upload --file photo.jpg --model qwen-vl-max`,`bl file upload --file video.mp4 --model wan2.1-t2v-plus`,`bl file upload --file audio.wav --model qwen3-asr-flash`,`bl file upload --file cat.png --model qwen-image-2.0`],async run(e,t){let n=t.file;n||q(`file`,`bl file upload --file <path> --model <model>`);let r=t.model;r||q(`model`,`bl file upload --file <path> --model <model>`);let i=l(e.output);if(e.dryRun){M({action:`upload`,file:n,model:r},i);return}let a=await de({apiKey:(await E(e)).token,model:r,filePath:n});e.quiet?N(a):M({url:a,model:r,expires_in:`48 hours`,note:`When using this URL in API calls, add header: X-DashScope-OssResourceResolve: enable`},i)}});const Z=new class{root={children:new Map};constructor(e){for(let[t,n]of Object.entries(e))this.register(t,n)}register(e,t){let n=e.split(` `),r=this.root;for(let e of n)r.children.has(e)||r.children.set(e,{children:new Map}),r=r.children.get(e);r.command=t}getAllCommands(){let e=[],t=n=>{n.command&&e.push(n.command);for(let e of n.children.values())t(e)};return t(this.root),e}isGroupPath(e){let t=this.root;for(let n of e){let e=t.children.get(n);if(!e)return!1;t=e}return!t.command&&t.children.size>0}resolve(t){let r=this.root,i=[];for(let e of t){let t=r.children.get(e);if(!t)break;r=t,i.push(e)}if(r.command)return{command:r.command,extra:t.slice(i.length)};if(i.length>0&&r.children.size===1){let[,e]=r.children.entries().next().value;if(e.command)return{command:e.command,extra:t.slice(i.length)}}if(i.length>0&&r.children.size>0){let a=Array.from(r.children.entries()).map(([e,t])=>{if(t.command)return` ${i.join(` `)} ${e} ${t.command.description}`;let n=Array.from(t.children.keys()).join(`, `);return` ${i.join(` `)} ${e} [${n}]`}).join(`
167
+ `);throw new e(`Unknown command: bl ${t.join(` `)}\n\nAvailable commands:\n${a}`,n.USAGE,`bl ${i.join(` `)} --help`)}throw new e(`Unknown command: bl ${t.join(` `)}`,n.USAGE,`bl --help`)}bold=(e,t)=>t.isTTY?`\x1b[1m${e}\x1b[0m`:e;accent=(e,t)=>t.isTTY?`\x1b[38;2;59;130;246m${e}\x1b[0m`:e;dim=(e,t)=>t.isTTY?`\x1b[2m${e}\x1b[0m`:e;printHelp(e,t=process.stdout,n=`cn`){if(e.length===0){this.printRootHelp(t);return}let r=this.root;for(let n of e){let e=r.children.get(n);if(!e){this.printRootHelp(t);return}r=e}if(r.command){this.printCommandHelp(r.command,t,n);return}let i=e.join(` `);t.write(`\n${this.bold(`Usage:`,t)} bl ${i} <command> [flags]\n\n`),t.write(`${this.bold(`Commands:`,t)}\n`),this.printChildren(r,i,t),t.write(`
168
+ `)}printRootHelp(e){let t=[`██████╗ █████╗ ██╗██╗ ██╗ █████╗ ███╗ ██╗`,`██╔══██╗██╔══██╗██║██║ ██║██╔══██╗████╗ ██║`,`██████╔╝███████║██║██║ ██║███████║██╔██╗ ██║`,`██╔══██╗██╔══██║██║██║ ██║██╔══██║██║╚██╗██║`,`██████╔╝██║ ██║██║███████╗██║██║ ██║██║ ╚████║`,`╚═════╝ ╚═╝ ╚═╝╚═╝╚══════╝╚═╝╚═╝ ╚═╝╚═╝ ╚═══╝`];e.write(`
169
+ `);for(let n of t)e.isTTY?e.write(`${n}\n`):e.write(n+`
170
+ `);let n=t=>this.bold(t,e),r=t=>this.accent(t,e),i=t=>this.dim(t,e);e.write(`
171
+ ${n(`Usage:`)} bl <resource> <command> [flags]
172
+
173
+ ${n(`Resources:`)}
174
+ ${r(`auth`)} ${i(`Authentication (login, status, logout)`)}
175
+ ${r(`text`)} ${i(`Text generation (chat)`)}
176
+ ${r(`omni`)} ${i(`Multimodal chat with text + audio (Qwen-Omni)`)}
177
+ ${r(`image`)} ${i(`Image generation & editing (generate, edit)`)}
178
+ ${r(`video`)} ${i(`Video generation, editing & reference (generate, edit, ref, task get, download)`)}
179
+ ${r(`vision`)} ${i(`Image understanding (describe)`)}
180
+ ${r(`app`)} ${i(`Application call (agent / workflow)`)}
181
+ ${r(`memory`)} ${i(`Memory management (add, search, list, update, delete, profile)`)}
182
+ ${r(`knowledge`)} ${i(`Knowledge base (retrieve)`)}
183
+ ${r(`search`)} ${i(`Web search (web)`)}
184
+ ${r(`speech`)} ${i(`Speech (synthesize, recognize)`)}
185
+ ${r(`file`)} ${i(`File upload (temporary URL for model input)`)}
186
+ ${r(`config`)} ${i(`CLI configuration (show, set, export-schema)`)}
187
+ ${r(`update`)} ${i(`Update bl to a newer version`)}
188
+
189
+ ${n(`Global Flags:`)}
190
+ ${r(`--api-key <key>`)} ${i(`API key (overrides all other auth)`)}
191
+ ${r(`--region <region>`)} ${i(`API region: cn (default), us, intl`)}
192
+ ${r(`--base-url <url>`)} ${i(`API base URL (overrides region)`)}
193
+ ${r(`--output <format>`)} ${i(`Output format: text, json`)}
194
+ ${r(`--quiet`)} ${i(`Suppress non-essential output`)}
195
+ ${r(`--verbose`)} ${i(`Print HTTP request/response details`)}
196
+ ${r(`--timeout <seconds>`)} ${i(`Request timeout (default: 300)`)}
197
+ ${r(`--no-color`)} ${i(`Disable ANSI colors and spinners`)}
198
+ ${r(`--dry-run`)} ${i(`Show what would happen without executing`)}
199
+ ${r(`--non-interactive`)} ${i(`Disable interactive prompts (CI/agent mode)`)}
200
+ ${r(`--concurrent <n>`)} ${i(`Run N parallel requests (default: 1)`)}
201
+ ${r(`--version`)} ${i(`Print version and exit`)}
202
+ ${r(`--help`)} ${i(`Show help`)}
203
+
204
+ ${n(`Getting Help:`)}
205
+ ${i(`Add --help after any command to see its full list of options, defaults,`)}
206
+ ${i(`and usage examples. For example:`)} bl text chat --help
207
+ `)}printCommandHelp(e,n,r=`cn`){let i=e=>this.bold(e,n),a=e=>this.accent(e,n),o=e=>this.dim(e,n);if(n.write(`\n${e.description}\n`),e.usage&&n.write(`${i(`Usage:`)} ${e.usage}\n`),e.options&&e.options.length>0){let t=Math.max(...e.options.map(e=>e.flag.length));n.write(`\n${i(`Options:`)}\n`);for(let r of e.options)n.write(` ${a(r.flag.padEnd(t+2))} ${o(r.description)}\n`)}if(e.examples&&e.examples.length>0){n.write(`\n${i(`Examples:`)}\n`);for(let t of e.examples)n.write(` ${o(t)}\n`)}e.apiDocs&&n.write(`\n${i(`API Reference:`)} ${o(t[r]+e.apiDocs)}\n`),n.write(`\n${o(`Global flags (--api-key, --output, --quiet, etc.) are always available.`)}\n`),n.write(`${o(`Run`)} bl --help ${o(`for the full list.`)}\n`)}printChildren(e,t,n){let r=[],i=(e,t)=>{for(let[n,a]of e.children)a.command&&r.push({fullName:`${t} ${n}`,description:a.command.description}),a.children.size>0&&i(a,`${t} ${n}`)};i(e,t);let a=Math.max(...r.map(e=>e.fullName.length));for(let{fullName:e,description:t}of r)n.write(` ${this.accent(e.padEnd(a),n)} ${this.dim(t,n)}\n`)}}({"auth login":Zn,"auth status":Qn,"auth logout":$n,"text chat":tr,omni:ir,"image generate":vr,"image edit":wr,"video generate":Dr,"video edit":Or,"video ref":kr,"video task get":Ar,"video download":jr,"vision describe":Ir,"app call":ni,"memory add":ri,"memory search":ii,"memory list":ai,"memory update":oi,"memory delete":si,"memory profile create":ci,"memory profile get":li,"knowledge retrieve":di,"search web":fi,"speech synthesize":_i,"speech recognize":bi,"file upload":Si,"config show":Lr,"config set":Br,"config export-schema":Hr,update:$r,help:ti});async function Ci(t){if(t.apiKey||t.fileApiKey)return;let r=process.env.DASHSCOPE_API_KEY,i;if(r&&(_({nonInteractive:t.nonInteractive})?await Jn({message:`Found DASHSCOPE_API_KEY in environment (${x(r)}). Save it to config file?`})&&(i=r):i=r),!i){if(!_({nonInteractive:t.nonInteractive}))throw new e(`No API key found.`,n.AUTH,`Set DASHSCOPE_API_KEY environment variable, pass --api-key, or run interactively to be prompted.`);let r=await K({message:`Enter your DashScope API key:`});if(!r)throw new e(`API key is required.`,n.AUTH);i=r}await me({...w(),api_key:i}),t.fileApiKey=i;let a=t.configPath??`~/.bailian/config.json`;process.stderr.write(`API key saved to ${a}\n`)}function wi(e){return e.exitCode===n.AUTH?[e.hint,``,`bl auth login --api-key <your-key>`,`bl auth status`,`Get API Key: ${J}`].filter(e=>e!==void 0).join(`
208
+ `):e.exitCode===n.QUOTA?[e.hint,``,`Console: ${J}`].filter(e=>e!==void 0).join(`
209
+ `):e.hint}function Ti(e=process.argv.slice(2),t=process.env.DASHSCOPE_OUTPUT){for(let n=0;n<e.length;n++){let r=e[n];if(r===`--output`)return l(e[n+1]||t);if(r?.startsWith(`--output=`))return l(r.slice(9))}return l(t)}function Q(t){if(t instanceof e){if(Ti()===`json`)process.stderr.write(JSON.stringify(t.toJSON(),null,2)+`
210
+ `);else{process.stderr.write(`\nError: ${t.message}\n`);let e=wi(t);e&&process.stderr.write(`\n ${e.split(`
343
211
  `).join(`
344
- `)}
345
- `);process.stderr.write(` (exit code ${e.exitCode})
346
- `)}process.exit(e.exitCode)}if(e instanceof Error){if(e.name==="AbortError"||e.name==="TimeoutError"||e.message.includes("timed out")){let $=new u("Request timed out.",h.TIMEOUT,`Try increasing --timeout (e.g. --timeout 60).
212
+ `)}\n`),process.stderr.write(` (exit code ${t.exitCode})\n`)}process.exit(t.exitCode)}if(t instanceof Error){if(t.name===`AbortError`||t.name===`TimeoutError`||t.message.includes(`timed out`))return Q(new e(`Request timed out.`,n.TIMEOUT,`Try increasing --timeout (e.g. --timeout 60).
347
213
  If this happens on every request with a valid API key, you may be hitting the wrong region.
348
- `+`Run: bl auth status — to check your credentials and region.
349
- `+"Run: bl config set --key region --value cn — to override the region.");return Ke($)}if(e instanceof TypeError&&e.message==="fetch failed"){let $=new u("Network request failed.",h.NETWORK,"Check your network connection and proxy settings. Also verify DASHSCOPE_BASE_URL is a valid URL.");return Ke($)}let t=e.message.toLowerCase();if(t.includes("failed to fetch")||t.includes("connection refused")||t.includes("econnrefused")||t.includes("connection reset")||t.includes("econnreset")||t.includes("network error")||t.includes("enotfound")||t.includes("getaddrinfo")||t.includes("proxy")||t.includes("socket")||t.includes("etimedout")||t.includes("timeout")||t.includes("eai_AGAIN")){let $="Check your network connection and proxy settings.";if(t.includes("proxy"))$="Proxy error — check HTTP_PROXY / HTTPS_PROXY environment variables and proxy authentication.";let p=new u("Network request failed.",h.NETWORK,$);return Ke(p)}let i=e.code;if(i==="ENOENT"||i==="EACCES"||i==="ENOSPC"||i==="ENOTDIR"||i==="EISDIR"||i==="EPERM"||i==="EBUSY"){let $="Check the file path and permissions.";if(i==="ENOENT")$="File or directory not found.";if(i==="EACCES"||i==="EPERM")$="Permission denied — check file or directory permissions.";if(i==="ENOSPC")$="Disk full — free up space and try again.";let p=new u(`File system error: ${e.message}`,h.GENERAL,$);return Ke(p)}else if(typeof i==="string"&&i.startsWith("E")){let $=new u(`File system error: ${e.message}`,h.GENERAL,"Check the file path and permissions.");return Ke($)}if(process.stderr.write(`
350
- Error: ${e.message}
351
- `),process.env.DASHSCOPE_VERBOSE==="1")process.stderr.write(`${e.stack}
352
- `)}else process.stderr.write(`
353
- Error: ${String(e)}
354
- `);process.exit(h.GENERAL)}import{join as Sp}from"path";import{readFileSync as kp,writeFileSync as qp}from"fs";var Zn=()=>Sp(Re(),"update-state.json"),op=14400000,Gp=3000;function Hn(e,t){let n=e.split(".").map(Number),i=t.split(".").map(Number);for(let $=0;$<3;$++){if((n[$]??0)>(i[$]??0))return!0;if((n[$]??0)<(i[$]??0))return!1}return!1}function Kp(){try{let e=kp(Zn(),"utf-8");return JSON.parse(e)}catch{return null}}function Np(e){try{qp(Zn(),JSON.stringify(e))}catch{}}async function Bp(){try{let e=Be.replace("/","%2f"),t=await fetch(`${He}/${e}/latest`,{headers:{Accept:"application/json",...d()},signal:AbortSignal.timeout(Gp)});if(!t.ok)return null;return(await t.json()).version??null}catch{return null}}var Xt=null;function zn(){return Xt}async function Xn(e){if(process.env.CI||!process.stderr.isTTY)return;let t=Kp(),n=Date.now();if(t&&n-t.lastChecked<op){if(t.latestVersion&&Hn(t.latestVersion,e))Xt=t.latestVersion;return}let i=await Bp();if(!i)return;if(Np({lastChecked:n,latestVersion:i}),i&&Hn(i,e))Xt=i}async function Pn(e){if(e.apiKey||e.fileApiKey)return;let t=process.env.DASHSCOPE_API_KEY,n;if(t){if(!Y({nonInteractive:e.nonInteractive}))n=t;else if(await Yr({message:`Found DASHSCOPE_API_KEY in environment (${g(t)}). Save it to config file?`}))n=t}if(!n){if(!Y({nonInteractive:e.nonInteractive}))throw new u("No API key found.",h.AUTH,`Set env var: export DASHSCOPE_API_KEY=sk-xxxxx
355
- Pass directly: --api-key sk-xxxxx
356
- Get API Key: https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key`);let p=await L({message:"Enter your DashScope API key:"});if(!p)throw new u("API key is required.",h.AUTH);n=p}let i={...te(),api_key:n};await Je(i),e.fileApiKey=n;let $=e.configPath??"~/.bailian/config.json";process.stderr.write(`API key saved to ${$}
357
- `)}var Pt="0.1.2-beta.0";process.on("SIGINT",()=>{process.stderr.write(`
358
- Interrupted. Exiting.
359
- `),process.exit(130)});process.stdout.on("error",(e)=>{if(e.code==="EPIPE")process.exit(0);else throw e});var jp=[["auth","login"],["auth","logout"],["config","show"],["config","set"],["config","export-schema"],["update"],["knowledge","retrieve"]];async function Rp(){let e=process.argv.slice(2);if(e.includes("--version")||e.includes("-v"))process.stdout.write(`bl ${Pt}
360
- `),process.exit(0);let t=Ct(e,Oe);if(e.includes("--help")||e.includes("-h")){let b=e.indexOf("--region"),w=b>=0&&e[b+1]||process.env.DASHSCOPE_REGION||te().region||"cn";me.printHelp(t,process.stderr,w),process.exit(0)}if(t.length===0){me.printHelp([],process.stderr);let b=ge(e,Oe),w=mt(b);if(!(w.apiKey||w.fileApiKey)){let q=process.stderr.isTTY,o=q?"\x1B[38;2;147;51;234m":"",k=q?"\x1B[0m":"";process.stderr.write(`
361
- Welcome to ${o}Bailian${k} CLI!
362
-
363
- `),process.stderr.write(` Get started in 2 steps:
364
- `),process.stderr.write(` 1. Get your API Key: https://bailian.console.aliyun.com/cn-beijing/?source_channel=aliway&tab=app#/api-key
365
- `),process.stderr.write(` 2. Login: bl auth login --api-key <your-key>
214
+ Run: bl auth status — to check your credentials and region.
215
+ Run: bl config set --key region --value cn — to override the region.`));if(t instanceof TypeError&&t.message===`fetch failed`)return Q(new e(`Network request failed.`,n.NETWORK,`Check your network connection and proxy settings. Also verify DASHSCOPE_BASE_URL is a valid URL.`));let r=t.message.toLowerCase();if(r.includes(`failed to fetch`)||r.includes(`connection refused`)||r.includes(`econnrefused`)||r.includes(`connection reset`)||r.includes(`econnreset`)||r.includes(`network error`)||r.includes(`enotfound`)||r.includes(`getaddrinfo`)||r.includes(`proxy`)||r.includes(`socket`)||r.includes(`etimedout`)||r.includes(`timeout`)||r.includes(`eai_AGAIN`)){let t=`Check your network connection and proxy settings.`;return r.includes(`proxy`)&&(t=`Proxy error — check HTTP_PROXY / HTTPS_PROXY environment variables and proxy authentication.`),Q(new e(`Network request failed.`,n.NETWORK,t))}let i=t.code;if(i===`ENOENT`||i===`EACCES`||i===`ENOSPC`||i===`ENOTDIR`||i===`EISDIR`||i===`EPERM`||i===`EBUSY`){let r=`Check the file path and permissions.`;return i===`ENOENT`&&(r=`File or directory not found.`),(i===`EACCES`||i===`EPERM`)&&(r=`Permission denied — check file or directory permissions.`),i===`ENOSPC`&&(r=`Disk full — free up space and try again.`),Q(new e(`File system error: ${t.message}`,n.GENERAL,r))}else if(typeof i==`string`&&i.startsWith(`E`))return Q(new e(`File system error: ${t.message}`,n.GENERAL,`Check the file path and permissions.`));process.stderr.write(`\nError: ${t.message}\n`),process.env.DASHSCOPE_VERBOSE===`1`&&process.stderr.write(`${t.stack}\n`)}else process.stderr.write(`\nError: ${String(t)}\n`);process.exit(n.GENERAL)}const $=`\x1B[0m`,Ei=`\x1B[2m`;function Di(e){return e.startsWith(ke())?e.replace(ke(),`~`):e}function Oi(e,t){if(e.quiet||!process.stderr.isTTY)return;let n=e.configPath?Di(e.configPath):`~/.bailian/config.json`,r=e.fileRegion?`${e.fileRegion} (file)`:`cn (default)`,i=e.apiKey?`(flag)`:`(file)`,a=x(t);process.stderr.write(`BAILIAN${$} ${Ei}${n}${$} ${Ei}|${$} ${Ei}Region:${$} ${r}${$} ${Ei}|${$} ${Ei}Key:${$} ${a}${$} ${Ei}${i}${$}\n`)}const ki=[`帮我生成一套鸭舌帽的亚马逊电商主图(白底 + 场景图 + 模特上身图)`,`帮我生成一段 3 分钟的幽默相声音频`,`帮我生成一套小红帽故事绘本 PDF(含插图)`,`帮我分析这个视频的内容并写一篇小红书文案`];function Ai(){let e=process.stderr.isTTY;return{purple:e?`\x1B[38;2;147;51;234m`:``,dim:e?`\x1B[2m`:``,reset:e?`\x1B[0m`:``}}function ji(){let{purple:e,reset:t}=Ai();process.stderr.write(`\n Welcome to ${e}Bailian${t} CLI!\n\n`),process.stderr.write(` Get started in 2 steps:
216
+ `),process.stderr.write(` 1. Get your API Key: ${J}\n`),process.stderr.write(` 2. Login: bl auth login --api-key <your-key>
366
217
 
367
- `)}else{let q=process.stderr.isTTY,o=q?"\x1B[38;2;147;51;234m":"",k=q?"\x1B[2m":"",G=q?"\x1B[0m":"";process.stderr.write(`
368
- ${o}Quick Start${G} — try these with your AI coding assistant:
369
-
370
- `),["帮我生成一套鸭舌帽的亚马逊电商主图(白底 + 场景图 + 模特上身图)","帮我生成一段 3 分钟的幽默相声音频","帮我生成一套小红帽故事绘本 PDF(含插图)","帮我分析这个视频的内容并写一篇小红书文案"].forEach((J,Z)=>{process.stderr.write(` ${k}${Z+1}${G} ${J}
371
- `)}),process.stderr.write(`
372
- `)}process.exit(0)}if(me.isGroupPath(t)){let b=e.indexOf("--region"),w=b>=0&&e[b+1]||process.env.DASHSCOPE_REGION||te().region||"cn";me.printHelp(t,process.stderr,w),process.exit(0)}let{command:n,extra:i}=me.resolve(t),$=ge(e,[...Oe,...n.options??[]]);if(i.length>0)$._positional=i;let p=mt($);if(!jp.some((b)=>b.every((w,S)=>t[S]===w)))await Pn(p);let y=Xn(Pt).catch(()=>{});await n.execute(p,$),await y;let m=t.length===1&&t[0]==="update",x=zn();if(x&&!p.quiet&&!m){let b=process.stderr.isTTY,w=b?"\x1B[33m":"",S=b?"\x1B[36m":"",q=b?"\x1B[0m":"";process.stderr.write(`
373
- ${w}Update available: ${Pt} → ${x}${q}
374
- `),process.stderr.write(` Run ${S}bl update${q} to upgrade
375
-
376
- `)}}Rp().catch(Ke);
218
+ `)}function Mi(){let{purple:e,dim:t,reset:n}=Ai();process.stderr.write(`\n ${e}Quick Start${n} — try these with your AI coding assistant:\n\n`),ki.forEach((e,r)=>{process.stderr.write(` ${t}${r+1}${n} ${e}\n`)}),process.stderr.write(`
219
+ `)}process.on(`SIGINT`,()=>{process.stderr.write(`
220
+ Interrupted. Exiting.
221
+ `),process.exit(130)}),process.stdout.on(`error`,e=>{if(e.code===`EPIPE`)process.exit(0);else throw e});const Ni=[[`auth`,`login`],[`auth`,`logout`],[`config`,`show`],[`config`,`set`],[`config`,`export-schema`],[`update`],[`knowledge`,`retrieve`]];async function Pi(){let e=process.argv.slice(2);(e.includes(`--version`)||e.includes(`-v`))&&(process.stdout.write(`bl ${X}\n`),process.exit(0));let t=Ge(e,r);if(e.includes(`--help`)||e.includes(`-h`)){let n=e.indexOf(`--region`),r=n>=0&&e[n+1]||process.env.DASHSCOPE_REGION||w().region||`cn`;Z.printHelp(t,process.stderr,r),process.exit(0)}if(t.length===0){Z.printHelp([],process.stderr);let t=b(Ke(e,r));t.clientName=`bailian-cli`,t.clientVersion=X,t.apiKey||t.fileApiKey?Mi():ji(),process.exit(0)}if(Z.isGroupPath(t)){let n=e.indexOf(`--region`),r=n>=0&&e[n+1]||process.env.DASHSCOPE_REGION||w().region||`cn`;Z.printHelp(t,process.stderr,r),process.exit(0)}let{command:n,extra:i}=Z.resolve(t),a=Ke(e,[...r,...n.options??[]]);i.length>0&&(a._positional=i);let o=b(a);if(o.clientName=`bailian-cli`,o.clientVersion=X,!Ni.some(e=>e.every((e,n)=>t[n]===e))){await Ci(o);try{Oi(o,(await E(o)).token)}catch{}}let s=Zr(X).catch(()=>{});await n.execute(o,a),await s;let c=t.length===1&&t[0]===`update`,l=Xr();if(l&&!o.quiet&&!c){let e=process.stderr.isTTY,t=e?`\x1B[33m`:``,n=e?`\x1B[36m`:``,r=e?`\x1B[0m`:``;process.stderr.write(`\n ${t}Update available: ${X}${l}${r}\n`),process.stderr.write(` Run ${n}bl update${r} to upgrade\n\n`)}}Pi().catch(Q);export{};