@lark-apaas/openclaw-extension-miaoda-coding 1.0.3-beta.6 → 1.0.3-beta.8

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/index.mjs CHANGED
@@ -1,10 +1,26 @@
1
- import{createRequire as e}from"node:module";import{spawn as t}from"node:child_process";import n,{readFileSync as r}from"node:fs";import i,{dirname as a,join as o,resolve as s}from"node:path";import{appendFile as c,mkdir as l,readFile as u,readdir as d,rm as f,writeFile as p}from"node:fs/promises";import{fileURLToPath as m}from"node:url";var h=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),g=e(import.meta.url);function _(){return s(process.env.OPENCLAW_STATE_DIR||process.cwd())}function v(e){return o(e,`.agent`)}function y(e,t){return o(e,t)}function b(e){let t=typeof e.workspaceDir==`string`&&e.workspaceDir!==``,n=typeof e.agentDir==`string`&&e.agentDir!==``;if(!t||!n)throw Error(`resolveToolPaths: workspaceDir and agentDir are required in tool factory context`);return{workspaceDir:e.workspaceDir,agentDir:e.agentDir,agentId:e.agentId,sessionKey:e.sessionKey}}var x=h(((e,t)=>{var n=Object.defineProperty,r=Object.getOwnPropertyDescriptor,i=Object.getOwnPropertyNames,a=Object.prototype.hasOwnProperty,o=(e,t)=>{for(var r in t)n(e,r,{get:t[r],enumerable:!0})},s=(e,t,o,s)=>{if(t&&typeof t==`object`||typeof t==`function`)for(let c of i(t))!a.call(e,c)&&c!==o&&n(e,c,{get:()=>t[c],enumerable:!(s=r(t,c))||s.enumerable});return e},c=e=>s(n({},`__esModule`,{value:!0}),e),l={};o(l,{DEFAULT_CLOCK_TOLERANCE_SEC:()=>f,DEFAULT_JWT_EXPIRE_TIME_MS:()=>d,FileTokenProvider:()=>w,HttpClient:()=>L,HttpError:()=>P,generateJWTToken:()=>m,parseJWTTokenWithVerify:()=>h,registerPlatformPlugin:()=>k,resolvePlatformBaseURL:()=>O}),t.exports=c(l);var u=g(`crypto`),d=1800*1e3,f=60,p={alg:`HS256`,typ:`JWT`};function m(e,t){let n=Math.floor(Date.now()/1e3),r={...e,iss:e.access_key,iat:n,nbf:n,exp:n+Math.floor(t.expireTimeMs/1e3),jti:(0,u.randomUUID)()},i=v(JSON.stringify(p)),a=v(JSON.stringify(r));return`${i}.${a}.${_(`${i}.${a}`,t.secretKey)}`}function h(e,t,n){let r=e.split(`.`);if(r.length!==3)throw Error(`invalid JWT token format`);let[i,a,o]=r;if(JSON.parse(y(i)).alg!==`HS256`)throw Error(`unsupported JWT alg`);let s=_(`${i}.${a}`,t.secretKey),c=Buffer.from(s),l=Buffer.from(o);if(c.length!==l.length||!(0,u.timingSafeEqual)(c,l))throw Error(`JWT signature verification failed`);let d=JSON.parse(y(a));if(!n?.skipExpiration){let e=n?.clockTolerance??f,t=Math.floor(Date.now()/1e3);if(d.exp!==void 0&&d.exp+e<t)throw Error(`JWT token expired at ${new Date(d.exp*1e3).toISOString()}`);if(d.nbf!==void 0&&d.nbf-e>t)throw Error(`JWT token not yet valid, will be valid at ${new Date(d.nbf*1e3).toISOString()}`);if(d.iat!==void 0&&d.iat-e>t)throw Error(`JWT token issued in the future at ${new Date(d.iat*1e3).toISOString()}`)}return d}function _(e,t){return(0,u.createHmac)(`sha256`,t).update(e).digest(`base64`).replace(/=/g,``).replace(/\+/g,`-`).replace(/\//g,`_`)}function v(e){return Buffer.from(e).toString(`base64`).replace(/=/g,``).replace(/\+/g,`-`).replace(/\//g,`_`)}function y(e){let t=(4-(e.length%4||4))%4,n=`${e}${`=`.repeat(t)}`.replace(/-/g,`+`).replace(/_/g,`/`);return Buffer.from(n,`base64`).toString(`utf8`)}var b=class{cache=new Map;config;constructor(e){this.config={refreshBeforeMs:300*1e3,...e}}getToken(e){let t=this.getCacheKey(e),n=this.cache.get(t),r=Date.now();if(n&&n.expiresAtMs-r>this.config.refreshBeforeMs)return n.token;let i=m(e,this.config),a=r+this.config.expireTimeMs;return this.cache.set(t,{token:i,expiresAtMs:a}),i}clearCache(){this.cache.clear()}clearCacheFor(e){let t=this.getCacheKey(e);this.cache.delete(t)}getCacheKey(e){return[e.access_key,e.tenant_id?.toString()||``,e.user_id||``,e.app_id||``,e.app_env||``,e.sandbox_id||``].join(`:`)}getCacheStats(){let e=Date.now(),t=0,n=0;for(let r of this.cache.values())r.expiresAtMs>e?t++:n++;return{total:this.cache.size,valid:t,expired:n}}},x=g(`fs`),S=300*1e3,C=[`/home/gem/workspace/.force/openclaw/miaoda-provider-key`],w=class{cache=new Map;paths;refreshBeforeMs;constructor(e){this.paths=e?.paths??C,this.refreshBeforeMs=e?.refreshBeforeMs??S}getToken(){let e=Date.now();for(let t of this.paths){let n=this.cache.get(t);if(n&&n.expiresAtMs-e>this.refreshBeforeMs)return{token:n.token,accessKey:n.accessKey};let r=this.readAndParse(t);if(r&&(this.cache.set(t,r),r.expiresAtMs>e))return{token:r.token,accessKey:r.accessKey};if(n&&n.expiresAtMs>e)return{token:n.token,accessKey:n.accessKey}}return null}clearCache(){this.cache.clear()}readAndParse(e){try{let t=(0,x.readFileSync)(e,`utf-8`).trim();if(!t)return null;let n=this.decodePayload(t);return n?.exp?{token:t,accessKey:n.access_key??``,expiresAtMs:n.exp*1e3}:null}catch{return null}}decodePayload(e){try{let t=e.split(`.`);if(t.length!==3)return null;let n=(4-(t[1].length%4||4))%4,r=`${t[1]}${`=`.repeat(n)}`.replace(/-/g,`+`).replace(/_/g,`/`);return JSON.parse(Buffer.from(r,`base64`).toString(`utf8`))}catch{return null}}},T=`FORCE_AUTHN_INNERAPI_DOMAIN`,E=`FORCE_AUTHN_ACCESS_KEY`,D=`FORCE_AUTHN_ACCESS_SECRET`;function O(e){if(!e?.enabled)return e?.baseURL;if(e.baseURL)return e.baseURL;let t=e.domainEnv||T,n=process.env[t];if(!n)throw Error(`\u5E73\u53F0\u6A21\u5F0F\u9700\u8981\u57FA\u7840\u57DF\u540D\uFF0C\u8BF7\u8BBE\u7F6E\u73AF\u5883\u53D8\u91CF ${t}`);return n}function k(e,t){if(!t.enabled)return;A(`platform.defaultClaims`,t.defaultClaims);let n;t.tokenProvider?.type===`file`&&(n=new w({paths:t.tokenProvider.paths,refreshBeforeMs:t.refreshBeforeMs}));let r=t.accessKeyEnv||E,i=t.secretKeyEnv||D,a=t.accessKey??(process.env[r]||``),o=new b({accessKey:a,secretKey:t.secretKey??(process.env[i]||``),expireTimeMs:t.expireTimeMs??d,refreshBeforeMs:t.refreshBeforeMs});return e.request.use(e=>{if(n){let t=n.getToken();if(t){let n={...e.headers,Authorization:`Bearer ${t.token}`,"x-api-key":t.accessKey};return{...e,headers:n}}}A(`request.platformAuth.customClaims`,e.platformAuth?.customClaims);let r={...t.defaultClaims||{},...e.platformAuth?.customClaims||{},access_key:a},i=o.getToken(r),s={...e.headers,Authorization:`Bearer ${i}`,"x-api-key":a};return{...e,headers:s}}),o}function A(e,t){if(t&&Object.prototype.hasOwnProperty.call(t,`access_key`))throw Error(`${e} \u4E0D\u5141\u8BB8\u8BBE\u7F6E access_key`)}var j=class{interceptors=[];use(e,t){return this.interceptors.push({onFulfilled:e,onRejected:t}),this.interceptors.length-1}eject(e){this.interceptors[e]&&(this.interceptors[e]=null)}clear(){this.interceptors=[]}forEach(e){this.interceptors.forEach(t=>{t!==null&&e(t)})}};function M(e){if(typeof e!=`object`||!e)return!1;let t=Object.getPrototypeOf(e);return t===Object.prototype||t===null}function N(e){if(!e)return{};if(e instanceof Headers){let t={};return e.forEach((e,n)=>{t[n]=e}),t}if(Array.isArray(e))return e.reduce((e,[t,n])=>(e[t]=n,e),{});let t={};return Object.entries(e).forEach(([e,n])=>{t[e]=Array.isArray(n)?n.join(`,`):n}),t}var P=class e extends Error{isHttpError=!0;response;config;constructor(t,n,r){super(r||`Request failed with status ${t?.status||`unknown`}`),this.name=`HttpError`,this.response=t,this.config=F(n),Object.setPrototypeOf(this,e.prototype)}};function F(e){let{headers:t,...n}=e;return{...n,headers:I(t)}}function I(e){if(!e)return;let t=N(e),n={},r=[`authorization`,`x-api-key`,`cookie`,`x-secret`];for(let[e,i]of Object.entries(t)){let t=e.toLowerCase();r.includes(t)?n[e]=`[REDACTED]`:n[e]=i}return n}var L=class{defaultConfig;securityConfig;interceptors={request:new j,response:new j};constructor(e){let{platform:t,security:n,...r}=e||{};this.defaultConfig={timeout:5e3,...r};let i=n?.strictMode??!1;this.securityConfig={allowedProtocols:i?[`http:`,`https:`]:null,maxResponseSize:i?50*1024*1024:0,strictMode:i,...n},t?.enabled&&(this.defaultConfig.baseURL||(this.defaultConfig.baseURL=O(t)),k(this.interceptors,t))}async get(e,t){return this.request({...t,url:e,method:`GET`})}async post(e,t,n){let r={...n?.headers},i=t;return M(t)&&(i=JSON.stringify(t),Object.keys(r).some(e=>e.toLowerCase()===`content-type`)||(r[`Content-Type`]=`application/json`)),this.request({...n,url:e,method:`POST`,body:i,headers:r})}async put(e,t,n){let r={...n?.headers},i=t;return M(t)&&(i=JSON.stringify(t),Object.keys(r).some(e=>e.toLowerCase()===`content-type`)||(r[`Content-Type`]=`application/json`)),this.request({...n,url:e,method:`PUT`,body:i,headers:r})}async delete(e,t){return this.request({...t,url:e,method:`DELETE`})}async patch(e,t,n){let r={...n?.headers},i=t;return M(t)&&(i=JSON.stringify(t),Object.keys(r).some(e=>e.toLowerCase()===`content-type`)||(r[`Content-Type`]=`application/json`)),this.request({...n,url:e,method:`PATCH`,body:i,headers:r})}async request(e){let t=N(this.defaultConfig.headers),n=N(e.headers),r={};for(let e in t)r[e.toLowerCase()]={key:e,value:t[e]};for(let e in n)r[e.toLowerCase()]={key:e,value:n[e]};let i={};for(let e in r){let{key:t,value:n}=r[e];i[t]=n}let a={...this.defaultConfig,...e,headers:i};try{a=await this.runRequestInterceptors(a)}catch(e){return Promise.reject(e)}a.headers=N(a.headers);let o=this.buildUrl(a.url,a.params),s=a.timeout||this.defaultConfig.timeout||5e3,c=new AbortController,l=setTimeout(()=>c.abort(),s),u=a.signal;u&&(u.aborted?(clearTimeout(l),c.abort()):u.addEventListener(`abort`,()=>c.abort(),{once:!0}));let{platformAuth:d,params:f,timeout:p,baseURL:m,url:h,...g}=a;try{let e=await fetch(o,{...g,signal:c.signal});if(clearTimeout(l),this.securityConfig.maxResponseSize>0){let t=e.headers.get(`content-length`);if(t){let e=parseInt(t,10);if(e>this.securityConfig.maxResponseSize)throw Error(`Response size ${e} bytes exceeds limit of ${this.securityConfig.maxResponseSize} bytes`)}}if(!e.ok){let t=new P(e,a);return this.runResponseInterceptors(Promise.reject(t))}return this.runResponseInterceptors(Promise.resolve(e))}catch(e){clearTimeout(l);let t=e instanceof P?e:new P(void 0,a,e.name===`AbortError`?`Request aborted`:e.message);return this.runResponseInterceptors(Promise.reject(t))}}runRequestInterceptors(e){let t=Promise.resolve(e),n=[];this.interceptors.request.forEach(e=>{n.push(e)});for(let e of n)t=t.then(e.onFulfilled,e.onRejected);return t}async runResponseInterceptors(e){let t=e,n=[];this.interceptors.response.forEach(e=>{n.push(e)});for(let e of n)t=t.then(e.onFulfilled,e.onRejected);return t}buildUrl(e,t){let n=this.defaultConfig.baseURL,r;r=!n||/^https?:\/\//i.test(e)?e:n.replace(/\/+$/,``)+`/`+e.replace(/^\/+/,``);let i=new URL(r),{allowedProtocols:a}=this.securityConfig;if(a&&!a.includes(i.protocol))throw Error(`Protocol ${i.protocol} is not allowed. Allowed: ${a.join(`, `)}`);if(t)for(let[e,n]of Object.entries(t))n!=null&&i.searchParams.set(e,String(n));return i.href}}}))();let S;function C(){if(S)return S;try{let e=s(a(m(import.meta.url)),`..`,`package.json`);S=JSON.parse(r(e,`utf-8`))}catch(e){console.warn(`[miaoda-coding] failed to read package.json: ${e instanceof Error?e.message:e}`),S={}}return S}function w(){let e=process.env.FORCE_AUTHN_INNERAPI_DOMAIN;if(!e)throw Error(`studio-client: 缺少环境变量,需要: FORCE_AUTHN_INNERAPI_DOMAIN`);return{apiUrl:e}}const T=new Set([`k_st_ec_400002683`]);var E=class extends Error{userFacing=!0;constructor(e,t){super(e),this.statusCode=t,this.name=`UserFacingError`}};function D(e){return!!e&&typeof e==`object`&&!Array.isArray(e)&&Object.values(e).every(e=>typeof e==`string`)}function O(...e){for(let t of e)if(typeof t==`string`&&t)return t}async function*k(e){let t=new TextDecoder,n=``,r;for await(let i of e){n+=t.decode(i,{stream:!0});let e=n.split(`
1
+ import{createRequire as e}from"node:module";import{execFile as t,spawn as n}from"node:child_process";import{randomUUID as r}from"node:crypto";import i,{readFileSync as a}from"node:fs";import o,{dirname as s,join as c,resolve as l}from"node:path";import{appendFile as u,mkdir as d,readFile as f,readdir as p,rm as m,writeFile as h}from"node:fs/promises";import*as g from"fs";import{readdir as _,readdirSync as v,realpath as y,realpathSync as b,stat as x,statSync as S}from"fs";import{basename as C,dirname as w,isAbsolute as T,normalize as E,posix as D,relative as O,resolve as k,sep as A}from"path";import{fileURLToPath as j}from"url";import{createRequire as M}from"module";import{fileURLToPath as N}from"node:url";var P=Object.create,F=Object.defineProperty,I=Object.getOwnPropertyDescriptor,L=Object.getOwnPropertyNames,R=Object.getPrototypeOf,z=Object.prototype.hasOwnProperty,B=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),V=(e,t,n,r)=>{if(t&&typeof t==`object`||typeof t==`function`)for(var i=L(t),a=0,o=i.length,s;a<o;a++)s=i[a],!z.call(e,s)&&s!==n&&F(e,s,{get:(e=>t[e]).bind(null,s),enumerable:!(r=I(t,s))||r.enumerable});return e},H=(e,t,n)=>(n=e==null?{}:P(R(e)),V(t||!e||!e.__esModule?F(n,`default`,{value:e,enumerable:!0}):n,e)),U=e(import.meta.url);function W(){return l(process.env.OPENCLAW_STATE_DIR||process.cwd())}function G(e){return c(e,`.agent`)}function K(e,t){return c(e,`app`,t)}function q(e,t){return c(e,t)}function J(e){let t=typeof e.workspaceDir==`string`&&e.workspaceDir!==``,n=typeof e.agentDir==`string`&&e.agentDir!==``;if(!t||!n)throw Error(`resolveToolPaths: workspaceDir and agentDir are required in tool factory context`);return{workspaceDir:e.workspaceDir,agentDir:e.agentDir,agentId:e.agentId,sessionKey:e.sessionKey}}var ee=M(import.meta.url);function Y(e){let t=E(e);return t.length>1&&t[t.length-1]===A&&(t=t.substring(0,t.length-1)),t}const X=/[\\/]/g;function Z(e,t){return e.replace(X,t)}const te=/^[a-z]:[\\/]$/i;function ne(e){return e===`/`||te.test(e)}function re(e,t){let{resolvePaths:n,normalizePath:r,pathSeparator:i}=t,a=process.platform===`win32`&&e.includes(`/`)||e.startsWith(`.`);return n&&(e=k(e)),(r||a)&&(e=Y(e)),e===`.`?``:Z(e[e.length-1]===i?e:e+i,i)}function ie(e,t){return t+e}function ae(e,t){return function(n,r){return r.startsWith(e)?r.slice(e.length)+n:Z(O(e,r),t.pathSeparator)+t.pathSeparator+n}}function oe(e){return e}function se(e,t,n){return t+e+n}function ce(e,t){let{relativePaths:n,includeBasePath:r}=t;return n&&e?ae(e,t):r?ie:oe}function le(e){return function(t,n){n.push(t.substring(e.length)||`.`)}}function ue(e){return function(t,n,r){let i=t.substring(e.length)||`.`;r.every(e=>e(i,!0))&&n.push(i)}}const de=(e,t)=>{t.push(e||`.`)},fe=(e,t,n)=>{let r=e||`.`;n.every(e=>e(r,!0))&&t.push(r)},pe=()=>{};function me(e,t){let{includeDirs:n,filters:r,relativePaths:i}=t;return n?i?r&&r.length?ue(e):le(e):r&&r.length?fe:de:pe}const he=(e,t,n,r)=>{r.every(t=>t(e,!1))&&n.files++},ge=(e,t,n,r)=>{r.every(t=>t(e,!1))&&t.push(e)},_e=(e,t,n,r)=>{n.files++},ve=(e,t)=>{t.push(e)},ye=()=>{};function be(e){let{excludeFiles:t,filters:n,onlyCounts:r}=e;return t?ye:n&&n.length?r?he:ge:r?_e:ve}const xe=e=>e,Se=()=>[``].slice(0,0);function Ce(e){return e.group?Se:xe}const we=(e,t,n)=>{e.push({directory:t,files:n,dir:t})},Te=()=>{};function Ee(e){return e.group?we:Te}const De=function(e,t,n){let{queue:r,fs:i,options:{suppressErrors:a}}=t;r.enqueue(),i.realpath(e,(o,s)=>{if(o)return r.dequeue(a?null:o,t);i.stat(s,(i,o)=>{if(i)return r.dequeue(a?null:i,t);if(o.isDirectory()&&Ae(e,s,t))return r.dequeue(null,t);n(o,s),r.dequeue(null,t)})})},Oe=function(e,t,n){let{queue:r,fs:i,options:{suppressErrors:a}}=t;r.enqueue();try{let r=i.realpathSync(e),a=i.statSync(r);if(a.isDirectory()&&Ae(e,r,t))return;n(a,r)}catch(e){if(!a)throw e}};function ke(e,t){return!e.resolveSymlinks||e.excludeSymlinks?null:t?Oe:De}function Ae(e,t,n){if(n.options.useRealPaths)return je(t,n);let r=w(e),i=1;for(;r!==n.root&&i<2;){let e=n.symlinks.get(r);e&&(e===t||e.startsWith(t)||t.startsWith(e))?i++:r=w(r)}return n.symlinks.set(e,t),i>1}function je(e,t){return t.visited.includes(e+t.options.pathSeparator)}const Me=e=>e.counts,Ne=e=>e.groups,Pe=e=>e.paths,Fe=e=>e.paths.slice(0,e.options.maxFiles),Ie=(e,t,n)=>(Be(t,n,e.counts,e.options.suppressErrors),null),Le=(e,t,n)=>(Be(t,n,e.paths,e.options.suppressErrors),null),Re=(e,t,n)=>(Be(t,n,e.paths.slice(0,e.options.maxFiles),e.options.suppressErrors),null),ze=(e,t,n)=>(Be(t,n,e.groups,e.options.suppressErrors),null);function Be(e,t,n,r){t(e&&!r?e:null,n)}function Ve(e,t){let{onlyCounts:n,group:r,maxFiles:i}=e;return n?t?Me:Ie:r?t?Ne:ze:i?t?Fe:Re:t?Pe:Le}const He={withFileTypes:!0},Ue=(e,t,n,r,i)=>{if(e.queue.enqueue(),r<0)return e.queue.dequeue(null,e);let{fs:a}=e;e.visited.push(t),e.counts.directories++,a.readdir(t||`.`,He,(t,a=[])=>{i(a,n,r),e.queue.dequeue(e.options.suppressErrors?null:t,e)})},We=(e,t,n,r,i)=>{let{fs:a}=e;if(r<0)return;e.visited.push(t),e.counts.directories++;let o=[];try{o=a.readdirSync(t||`.`,He)}catch(t){if(!e.options.suppressErrors)throw t}i(o,n,r)};function Ge(e){return e?We:Ue}var Ke=class{count=0;constructor(e){this.onQueueEmpty=e}enqueue(){return this.count++,this.count}dequeue(e,t){this.onQueueEmpty&&(--this.count<=0||e)&&(this.onQueueEmpty(e,t),e&&(t.controller.abort(),this.onQueueEmpty=void 0))}},qe=class{_files=0;_directories=0;set files(e){this._files=e}get files(){return this._files}set directories(e){this._directories=e}get directories(){return this._directories}get dirs(){return this._directories}},Je=class{aborted=!1;abort(){this.aborted=!0}},Ye=class{root;isSynchronous;state;joinPath;pushDirectory;pushFile;getArray;groupFiles;resolveSymlink;walkDirectory;callbackInvoker;constructor(e,t,n){this.isSynchronous=!n,this.callbackInvoker=Ve(t,this.isSynchronous),this.root=re(e,t),this.state={root:ne(this.root)?this.root:this.root.slice(0,-1),paths:[``].slice(0,0),groups:[],counts:new qe,options:t,queue:new Ke((e,t)=>this.callbackInvoker(t,e,n)),symlinks:new Map,visited:[``].slice(0,0),controller:new Je,fs:t.fs||g},this.joinPath=ce(this.root,t),this.pushDirectory=me(this.root,t),this.pushFile=be(t),this.getArray=Ce(t),this.groupFiles=Ee(t),this.resolveSymlink=ke(t,this.isSynchronous),this.walkDirectory=Ge(this.isSynchronous)}start(){return this.pushDirectory(this.root,this.state.paths,this.state.options.filters),this.walkDirectory(this.state,this.root,this.root,this.state.options.maxDepth,this.walk),this.isSynchronous?this.callbackInvoker(this.state,null):null}walk=(e,t,n)=>{let{paths:r,options:{filters:i,resolveSymlinks:a,excludeSymlinks:o,exclude:s,maxFiles:c,signal:l,useRealPaths:u,pathSeparator:d},controller:f}=this.state;if(f.aborted||l&&l.aborted||c&&r.length>c)return;let p=this.getArray(this.state.paths);for(let c=0;c<e.length;++c){let l=e[c];if(l.isFile()||l.isSymbolicLink()&&!a&&!o){let e=this.joinPath(l.name,t);this.pushFile(e,p,this.state.counts,i)}else if(l.isDirectory()){let e=se(l.name,t,this.state.options.pathSeparator);if(s&&s(l.name,e))continue;this.pushDirectory(e,r,i),this.walkDirectory(this.state,e,e,n-1,this.walk)}else if(this.resolveSymlink&&l.isSymbolicLink()){let e=ie(l.name,t);this.resolveSymlink(e,this.state,(t,r)=>{if(t.isDirectory()){if(r=re(r,this.state.options),s&&s(l.name,u?r:e+d))return;this.walkDirectory(this.state,r,u?r:e+d,n-1,this.walk)}else{r=u?r:e;let t=C(r),n=re(w(r),this.state.options);r=this.joinPath(t,n),this.pushFile(r,p,this.state.counts,i)}})}}this.groupFiles(this.state.groups,t,p)}};function Xe(e,t){return new Promise((n,r)=>{Ze(e,t,(e,t)=>{if(e)return r(e);n(t)})})}function Ze(e,t,n){new Ye(e,t,n).start()}function Qe(e,t){return new Ye(e,t).start()}var $e=class{constructor(e,t){this.root=e,this.options=t}withPromise(){return Xe(this.root,this.options)}withCallback(e){Ze(this.root,this.options,e)}sync(){return Qe(this.root,this.options)}};let et=null;try{ee.resolve(`picomatch`),et=ee(`picomatch`)}catch{}var tt=class{globCache={};options={maxDepth:1/0,suppressErrors:!0,pathSeparator:A,filters:[]};globFunction;constructor(e){this.options={...this.options,...e},this.globFunction=this.options.globFunction}group(){return this.options.group=!0,this}withPathSeparator(e){return this.options.pathSeparator=e,this}withBasePath(){return this.options.includeBasePath=!0,this}withRelativePaths(){return this.options.relativePaths=!0,this}withDirs(){return this.options.includeDirs=!0,this}withMaxDepth(e){return this.options.maxDepth=e,this}withMaxFiles(e){return this.options.maxFiles=e,this}withFullPaths(){return this.options.resolvePaths=!0,this.options.includeBasePath=!0,this}withErrors(){return this.options.suppressErrors=!1,this}withSymlinks({resolvePaths:e=!0}={}){return this.options.resolveSymlinks=!0,this.options.useRealPaths=e,this.withFullPaths()}withAbortSignal(e){return this.options.signal=e,this}normalize(){return this.options.normalizePath=!0,this}filter(e){return this.options.filters.push(e),this}onlyDirs(){return this.options.excludeFiles=!0,this.options.includeDirs=!0,this}exclude(e){return this.options.exclude=e,this}onlyCounts(){return this.options.onlyCounts=!0,this}crawl(e){return new $e(e||`.`,this.options)}withGlobFunction(e){return this.globFunction=e,this}crawlWithOptions(e,t){return this.options={...this.options,...t},new $e(e||`.`,this.options)}glob(...e){return this.globFunction?this.globWithOptions(e):this.globWithOptions(e,{dot:!0})}globWithOptions(e,...t){let n=this.globFunction||et;if(!n)throw Error(`Please specify a glob function to use glob matching.`);var r=this.globCache[e.join(`\0`)];return r||(r=n(e,...t),this.globCache[e.join(`\0`)]=r),this.options.filters.push(e=>r(e)),this}},nt=B(((e,t)=>{let n=`[^\\\\/]`,r=`[^/]`,i=`(?:\\/|$)`,a=`(?:^|\\/)`,o=`\\.{1,2}${i}`,s={DOT_LITERAL:`\\.`,PLUS_LITERAL:`\\+`,QMARK_LITERAL:`\\?`,SLASH_LITERAL:`\\/`,ONE_CHAR:`(?=.)`,QMARK:r,END_ANCHOR:i,DOTS_SLASH:o,NO_DOT:`(?!\\.)`,NO_DOTS:`(?!${a}${o})`,NO_DOT_SLASH:`(?!\\.{0,1}${i})`,NO_DOTS_SLASH:`(?!${o})`,QMARK_NO_DOT:`[^.\\/]`,STAR:`${r}*?`,START_ANCHOR:a,SEP:`/`},c={...s,SLASH_LITERAL:`[\\\\/]`,QMARK:n,STAR:`${n}*?`,DOTS_SLASH:`\\.{1,2}(?:[\\\\/]|$)`,NO_DOT:`(?!\\.)`,NO_DOTS:`(?!(?:^|[\\\\/])\\.{1,2}(?:[\\\\/]|$))`,NO_DOT_SLASH:`(?!\\.{0,1}(?:[\\\\/]|$))`,NO_DOTS_SLASH:`(?!\\.{1,2}(?:[\\\\/]|$))`,QMARK_NO_DOT:`[^.\\\\/]`,START_ANCHOR:`(?:^|[\\\\/])`,END_ANCHOR:`(?:[\\\\/]|$)`,SEP:`\\`};t.exports={DEFAULT_MAX_EXTGLOB_RECURSION:0,MAX_LENGTH:1024*64,POSIX_REGEX_SOURCE:{__proto__:null,alnum:`a-zA-Z0-9`,alpha:`a-zA-Z`,ascii:`\\x00-\\x7F`,blank:` \\t`,cntrl:`\\x00-\\x1F\\x7F`,digit:`0-9`,graph:`\\x21-\\x7E`,lower:`a-z`,print:`\\x20-\\x7E `,punct:`\\-!"#$%&'()\\*+,./:;<=>?@[\\]^_\`{|}~`,space:` \\t\\r\\n\\v\\f`,upper:`A-Z`,word:`A-Za-z0-9_`,xdigit:`A-Fa-f0-9`},REGEX_BACKSLASH:/\\(?![*+?^${}(|)[\]])/g,REGEX_NON_SPECIAL_CHARS:/^[^@![\].,$*+?^{}()|\\/]+/,REGEX_SPECIAL_CHARS:/[-*+?.^${}(|)[\]]/,REGEX_SPECIAL_CHARS_BACKREF:/(\\?)((\W)(\3*))/g,REGEX_SPECIAL_CHARS_GLOBAL:/([-*+?.^${}(|)[\]])/g,REGEX_REMOVE_BACKSLASH:/(?:\[.*?[^\\]\]|\\(?=.))/g,REPLACEMENTS:{__proto__:null,"***":`*`,"**/**":`**`,"**/**/**":`**`},CHAR_0:48,CHAR_9:57,CHAR_UPPERCASE_A:65,CHAR_LOWERCASE_A:97,CHAR_UPPERCASE_Z:90,CHAR_LOWERCASE_Z:122,CHAR_LEFT_PARENTHESES:40,CHAR_RIGHT_PARENTHESES:41,CHAR_ASTERISK:42,CHAR_AMPERSAND:38,CHAR_AT:64,CHAR_BACKWARD_SLASH:92,CHAR_CARRIAGE_RETURN:13,CHAR_CIRCUMFLEX_ACCENT:94,CHAR_COLON:58,CHAR_COMMA:44,CHAR_DOT:46,CHAR_DOUBLE_QUOTE:34,CHAR_EQUAL:61,CHAR_EXCLAMATION_MARK:33,CHAR_FORM_FEED:12,CHAR_FORWARD_SLASH:47,CHAR_GRAVE_ACCENT:96,CHAR_HASH:35,CHAR_HYPHEN_MINUS:45,CHAR_LEFT_ANGLE_BRACKET:60,CHAR_LEFT_CURLY_BRACE:123,CHAR_LEFT_SQUARE_BRACKET:91,CHAR_LINE_FEED:10,CHAR_NO_BREAK_SPACE:160,CHAR_PERCENT:37,CHAR_PLUS:43,CHAR_QUESTION_MARK:63,CHAR_RIGHT_ANGLE_BRACKET:62,CHAR_RIGHT_CURLY_BRACE:125,CHAR_RIGHT_SQUARE_BRACKET:93,CHAR_SEMICOLON:59,CHAR_SINGLE_QUOTE:39,CHAR_SPACE:32,CHAR_TAB:9,CHAR_UNDERSCORE:95,CHAR_VERTICAL_LINE:124,CHAR_ZERO_WIDTH_NOBREAK_SPACE:65279,extglobChars(e){return{"!":{type:`negate`,open:`(?:(?!(?:`,close:`))${e.STAR})`},"?":{type:`qmark`,open:`(?:`,close:`)?`},"+":{type:`plus`,open:`(?:`,close:`)+`},"*":{type:`star`,open:`(?:`,close:`)*`},"@":{type:`at`,open:`(?:`,close:`)`}}},globChars(e){return e===!0?c:s}}})),rt=B((e=>{let{REGEX_BACKSLASH:t,REGEX_REMOVE_BACKSLASH:n,REGEX_SPECIAL_CHARS:r,REGEX_SPECIAL_CHARS_GLOBAL:i}=nt();e.isObject=e=>typeof e==`object`&&!!e&&!Array.isArray(e),e.hasRegexChars=e=>r.test(e),e.isRegexChar=t=>t.length===1&&e.hasRegexChars(t),e.escapeRegex=e=>e.replace(i,`\\$1`),e.toPosixSlashes=e=>e.replace(t,`/`),e.isWindows=()=>{if(typeof navigator<`u`&&navigator.platform){let e=navigator.platform.toLowerCase();return e===`win32`||e===`windows`}return typeof process<`u`&&process.platform?process.platform===`win32`:!1},e.removeBackslashes=e=>e.replace(n,e=>e===`\\`?``:e),e.escapeLast=(t,n,r)=>{let i=t.lastIndexOf(n,r);return i===-1?t:t[i-1]===`\\`?e.escapeLast(t,n,i-1):`${t.slice(0,i)}\\${t.slice(i)}`},e.removePrefix=(e,t={})=>{let n=e;return n.startsWith(`./`)&&(n=n.slice(2),t.prefix=`./`),n},e.wrapOutput=(e,t={},n={})=>{let r=`${n.contains?``:`^`}(?:${e})${n.contains?``:`$`}`;return t.negated===!0&&(r=`(?:^(?!${r}).*$)`),r},e.basename=(e,{windows:t}={})=>{let n=e.split(t?/[\\/]/:`/`),r=n[n.length-1];return r===``?n[n.length-2]:r}})),it=B(((e,t)=>{let n=rt(),{CHAR_ASTERISK:r,CHAR_AT:i,CHAR_BACKWARD_SLASH:a,CHAR_COMMA:o,CHAR_DOT:s,CHAR_EXCLAMATION_MARK:c,CHAR_FORWARD_SLASH:l,CHAR_LEFT_CURLY_BRACE:u,CHAR_LEFT_PARENTHESES:d,CHAR_LEFT_SQUARE_BRACKET:f,CHAR_PLUS:p,CHAR_QUESTION_MARK:m,CHAR_RIGHT_CURLY_BRACE:h,CHAR_RIGHT_PARENTHESES:g,CHAR_RIGHT_SQUARE_BRACKET:_}=nt(),v=e=>e===l||e===a,y=e=>{e.isPrefix!==!0&&(e.depth=e.isGlobstar?1/0:1)};t.exports=(e,t)=>{let b=t||{},x=e.length-1,S=b.parts===!0||b.scanToEnd===!0,C=[],w=[],T=[],E=e,D=-1,O=0,k=0,A=!1,j=!1,M=!1,N=!1,P=!1,F=!1,I=!1,L=!1,R=!1,z=!1,B=0,V,H,U={value:``,depth:0,isGlob:!1},W=()=>D>=x,G=()=>E.charCodeAt(D+1),K=()=>(V=H,E.charCodeAt(++D));for(;D<x;){H=K();let e;if(H===a){I=U.backslashes=!0,H=K(),H===u&&(F=!0);continue}if(F===!0||H===u){for(B++;W()!==!0&&(H=K());){if(H===a){I=U.backslashes=!0,K();continue}if(H===u){B++;continue}if(F!==!0&&H===s&&(H=K())===s){if(A=U.isBrace=!0,M=U.isGlob=!0,z=!0,S===!0)continue;break}if(F!==!0&&H===o){if(A=U.isBrace=!0,M=U.isGlob=!0,z=!0,S===!0)continue;break}if(H===h&&(B--,B===0)){F=!1,A=U.isBrace=!0,z=!0;break}}if(S===!0)continue;break}if(H===l){if(C.push(D),w.push(U),U={value:``,depth:0,isGlob:!1},z===!0)continue;if(V===s&&D===O+1){O+=2;continue}k=D+1;continue}if(b.noext!==!0&&(H===p||H===i||H===r||H===m||H===c)&&G()===d){if(M=U.isGlob=!0,N=U.isExtglob=!0,z=!0,H===c&&D===O&&(R=!0),S===!0){for(;W()!==!0&&(H=K());){if(H===a){I=U.backslashes=!0,H=K();continue}if(H===g){M=U.isGlob=!0,z=!0;break}}continue}break}if(H===r){if(V===r&&(P=U.isGlobstar=!0),M=U.isGlob=!0,z=!0,S===!0)continue;break}if(H===m){if(M=U.isGlob=!0,z=!0,S===!0)continue;break}if(H===f){for(;W()!==!0&&(e=K());){if(e===a){I=U.backslashes=!0,K();continue}if(e===_){j=U.isBracket=!0,M=U.isGlob=!0,z=!0;break}}if(S===!0)continue;break}if(b.nonegate!==!0&&H===c&&D===O){L=U.negated=!0,O++;continue}if(b.noparen!==!0&&H===d){if(M=U.isGlob=!0,S===!0){for(;W()!==!0&&(H=K());){if(H===d){I=U.backslashes=!0,H=K();continue}if(H===g){z=!0;break}}continue}break}if(M===!0){if(z=!0,S===!0)continue;break}}b.noext===!0&&(N=!1,M=!1);let q=E,J=``,ee=``;O>0&&(J=E.slice(0,O),E=E.slice(O),k-=O),q&&M===!0&&k>0?(q=E.slice(0,k),ee=E.slice(k)):M===!0?(q=``,ee=E):q=E,q&&q!==``&&q!==`/`&&q!==E&&v(q.charCodeAt(q.length-1))&&(q=q.slice(0,-1)),b.unescape===!0&&(ee&&=n.removeBackslashes(ee),q&&I===!0&&(q=n.removeBackslashes(q)));let Y={prefix:J,input:e,start:O,base:q,glob:ee,isBrace:A,isBracket:j,isGlob:M,isExtglob:N,isGlobstar:P,negated:L,negatedExtglob:R};if(b.tokens===!0&&(Y.maxDepth=0,v(H)||w.push(U),Y.tokens=w),b.parts===!0||b.tokens===!0){let t;for(let n=0;n<C.length;n++){let r=t?t+1:O,i=C[n],a=e.slice(r,i);b.tokens&&(n===0&&O!==0?(w[n].isPrefix=!0,w[n].value=J):w[n].value=a,y(w[n]),Y.maxDepth+=w[n].depth),(n!==0||a!==``)&&T.push(a),t=i}if(t&&t+1<e.length){let n=e.slice(t+1);T.push(n),b.tokens&&(w[w.length-1].value=n,y(w[w.length-1]),Y.maxDepth+=w[w.length-1].depth)}Y.slashes=C,Y.parts=T}return Y}})),at=B(((e,t)=>{let n=nt(),r=rt(),{MAX_LENGTH:i,POSIX_REGEX_SOURCE:a,REGEX_NON_SPECIAL_CHARS:o,REGEX_SPECIAL_CHARS_BACKREF:s,REPLACEMENTS:c}=n,l=(e,t)=>{if(typeof t.expandRange==`function`)return t.expandRange(...e,t);e.sort();let n=`[${e.join(`-`)}]`;try{new RegExp(n)}catch{return e.map(e=>r.escapeRegex(e)).join(`..`)}return n},u=(e,t)=>`Missing ${e}: "${t}" - use "\\\\${t}" to match literal characters`,d=e=>{let t=[],n=0,r=0,i=0,a=``,o=!1;for(let s of e){if(o===!0){a+=s,o=!1;continue}if(s===`\\`){a+=s,o=!0;continue}if(s===`"`){i=i===1?0:1,a+=s;continue}if(i===0){if(s===`[`)n++;else if(s===`]`&&n>0)n--;else if(n===0){if(s===`(`)r++;else if(s===`)`&&r>0)r--;else if(s===`|`&&r===0){t.push(a),a=``;continue}}}a+=s}return t.push(a),t},f=e=>{let t=!1;for(let n of e){if(t===!0){t=!1;continue}if(n===`\\`){t=!0;continue}if(/[?*+@!()[\]{}]/.test(n))return!1}return!0},p=e=>{let t=e.trim(),n=!0;for(;n===!0;)n=!1,/^@\([^\\()[\]{}|]+\)$/.test(t)&&(t=t.slice(2,-1),n=!0);if(f(t))return t.replace(/\\(.)/g,`$1`)},m=e=>{let t=e.map(p).filter(Boolean);for(let e=0;e<t.length;e++)for(let n=e+1;n<t.length;n++){let r=t[e],i=t[n],a=r[0];if(!(!a||r!==a.repeat(r.length)||i!==a.repeat(i.length))&&(r===i||r.startsWith(i)||i.startsWith(r)))return!0}return!1},h=(e,t=!0)=>{if(e[0]!==`+`&&e[0]!==`*`||e[1]!==`(`)return;let n=0,r=0,i=0,a=!1;for(let o=1;o<e.length;o++){let s=e[o];if(a===!0){a=!1;continue}if(s===`\\`){a=!0;continue}if(s===`"`){i=i===1?0:1;continue}if(i!==1){if(s===`[`){n++;continue}if(s===`]`&&n>0){n--;continue}if(!(n>0)){if(s===`(`){r++;continue}if(s===`)`&&(r--,r===0))return t===!0&&o!==e.length-1?void 0:{type:e[0],body:e.slice(2,o),end:o}}}}},g=e=>{let t=0,n=[];for(;t<e.length;){let r=h(e.slice(t),!1);if(!r||r.type!==`*`)return;let i=d(r.body).map(e=>e.trim());if(i.length!==1)return;let a=p(i[0]);if(!a||a.length!==1)return;n.push(a),t+=r.end+1}if(!(n.length<1))return`${n.length===1?r.escapeRegex(n[0]):`[${n.map(e=>r.escapeRegex(e)).join(``)}]`}*`},_=e=>{let t=0,n=e.trim(),r=h(n);for(;r;)t++,n=r.body.trim(),r=h(n);return t},v=(e,t)=>{if(t.maxExtglobRecursion===!1)return{risky:!1};let r=typeof t.maxExtglobRecursion==`number`?t.maxExtglobRecursion:n.DEFAULT_MAX_EXTGLOB_RECURSION,i=d(e).map(e=>e.trim());if(i.length>1&&(i.some(e=>e===``)||i.some(e=>/^[*?]+$/.test(e))||m(i)))return{risky:!0};for(let e of i){let t=g(e);if(t)return{risky:!0,safeOutput:t};if(_(e)>r)return{risky:!0}}return{risky:!1}},y=(e,t)=>{if(typeof e!=`string`)throw TypeError(`Expected a string`);e=c[e]||e;let d={...t},f=typeof d.maxLength==`number`?Math.min(i,d.maxLength):i,p=e.length;if(p>f)throw SyntaxError(`Input length: ${p}, exceeds maximum allowed length: ${f}`);let m={type:`bos`,value:``,output:d.prepend||``},h=[m],g=d.capture?``:`?:`,_=n.globChars(d.windows),b=n.extglobChars(_),{DOT_LITERAL:x,PLUS_LITERAL:S,SLASH_LITERAL:C,ONE_CHAR:w,DOTS_SLASH:T,NO_DOT:E,NO_DOT_SLASH:D,NO_DOTS_SLASH:O,QMARK:k,QMARK_NO_DOT:A,STAR:j,START_ANCHOR:M}=_,N=e=>`(${g}(?:(?!${M}${e.dot?T:x}).)*?)`,P=d.dot?``:E,F=d.dot?k:A,I=d.bash===!0?N(d):j;d.capture&&(I=`(${I})`),typeof d.noext==`boolean`&&(d.noextglob=d.noext);let L={input:e,index:-1,start:0,dot:d.dot===!0,consumed:``,output:``,prefix:``,backtrack:!1,negated:!1,brackets:0,braces:0,parens:0,quotes:0,globstar:!1,tokens:h};e=r.removePrefix(e,L),p=e.length;let R=[],z=[],B=[],V=m,H,U=()=>L.index===p-1,W=L.peek=(t=1)=>e[L.index+t],G=L.advance=()=>e[++L.index]||``,K=()=>e.slice(L.index+1),q=(e=``,t=0)=>{L.consumed+=e,L.index+=t},J=e=>{L.output+=e.output==null?e.value:e.output,q(e.value)},ee=()=>{let e=1;for(;W()===`!`&&(W(2)!==`(`||W(3)===`?`);)G(),L.start++,e++;return e%2==0?!1:(L.negated=!0,L.start++,!0)},Y=e=>{L[e]++,B.push(e)},X=e=>{L[e]--,B.pop()},Z=e=>{if(V.type===`globstar`){let t=L.braces>0&&(e.type===`comma`||e.type===`brace`),n=e.extglob===!0||R.length&&(e.type===`pipe`||e.type===`paren`);e.type!==`slash`&&e.type!==`paren`&&!t&&!n&&(L.output=L.output.slice(0,-V.output.length),V.type=`star`,V.value=`*`,V.output=I,L.output+=V.output)}if(R.length&&e.type!==`paren`&&(R[R.length-1].inner+=e.value),(e.value||e.output)&&J(e),V&&V.type===`text`&&e.type===`text`){V.output=(V.output||V.value)+e.value,V.value+=e.value;return}e.prev=V,h.push(e),V=e},te=(e,t)=>{let n={...b[t],conditions:1,inner:``};n.prev=V,n.parens=L.parens,n.output=L.output,n.startIndex=L.index,n.tokensIndex=h.length;let r=(d.capture?`(`:``)+n.open;Y(`parens`),Z({type:e,value:t,output:L.output?``:w}),Z({type:`paren`,extglob:!0,value:G(),output:r}),R.push(n)},ne=n=>{let i=e.slice(n.startIndex,L.index+1),a=v(e.slice(n.startIndex+2,L.index),d);if((n.type===`plus`||n.type===`star`)&&a.risky){let e=a.safeOutput?(n.output?``:w)+(d.capture?`(${a.safeOutput})`:a.safeOutput):void 0,t=h[n.tokensIndex];t.type=`text`,t.value=i,t.output=e||r.escapeRegex(i);for(let e=n.tokensIndex+1;e<h.length;e++)h[e].value=``,h[e].output=``,delete h[e].suffix;L.output=n.output+t.output,L.backtrack=!0,Z({type:`paren`,extglob:!0,value:H,output:``}),X(`parens`);return}let o=n.close+(d.capture?`)`:``),s;if(n.type===`negate`){let e=I;n.inner&&n.inner.length>1&&n.inner.includes(`/`)&&(e=N(d)),(e!==I||U()||/^\)+$/.test(K()))&&(o=n.close=`)$))${e}`),n.inner.includes(`*`)&&(s=K())&&/^\.[^\\/.]+$/.test(s)&&(o=n.close=`)${y(s,{...t,fastpaths:!1}).output})${e})`),n.prev.type===`bos`&&(L.negatedExtglob=!0)}Z({type:`paren`,extglob:!0,value:H,output:o}),X(`parens`)};if(d.fastpaths!==!1&&!/(^[*!]|[/()[\]{}"])/.test(e)){let n=!1,i=e.replace(s,(e,t,r,i,a,o)=>i===`\\`?(n=!0,e):i===`?`?t?t+i+(a?k.repeat(a.length):``):o===0?F+(a?k.repeat(a.length):``):k.repeat(r.length):i===`.`?x.repeat(r.length):i===`*`?t?t+i+(a?I:``):I:t?e:`\\${e}`);return n===!0&&(i=d.unescape===!0?i.replace(/\\/g,``):i.replace(/\\+/g,e=>e.length%2==0?`\\\\`:e?`\\`:``)),i===e&&d.contains===!0?(L.output=e,L):(L.output=r.wrapOutput(i,L,t),L)}for(;!U();){if(H=G(),H===`\0`)continue;if(H===`\\`){let e=W();if(e===`/`&&d.bash!==!0||e===`.`||e===`;`)continue;if(!e){H+=`\\`,Z({type:`text`,value:H});continue}let t=/^\\+/.exec(K()),n=0;if(t&&t[0].length>2&&(n=t[0].length,L.index+=n,n%2!=0&&(H+=`\\`)),d.unescape===!0?H=G():H+=G(),L.brackets===0){Z({type:`text`,value:H});continue}}if(L.brackets>0&&(H!==`]`||V.value===`[`||V.value===`[^`)){if(d.posix!==!1&&H===`:`){let e=V.value.slice(1);if(e.includes(`[`)&&(V.posix=!0,e.includes(`:`))){let e=V.value.lastIndexOf(`[`),t=V.value.slice(0,e),n=a[V.value.slice(e+2)];if(n){V.value=t+n,L.backtrack=!0,G(),!m.output&&h.indexOf(V)===1&&(m.output=w);continue}}}(H===`[`&&W()!==`:`||H===`-`&&W()===`]`)&&(H=`\\${H}`),H===`]`&&(V.value===`[`||V.value===`[^`)&&(H=`\\${H}`),d.posix===!0&&H===`!`&&V.value===`[`&&(H=`^`),V.value+=H,J({value:H});continue}if(L.quotes===1&&H!==`"`){H=r.escapeRegex(H),V.value+=H,J({value:H});continue}if(H===`"`){L.quotes=L.quotes===1?0:1,d.keepQuotes===!0&&Z({type:`text`,value:H});continue}if(H===`(`){Y(`parens`),Z({type:`paren`,value:H});continue}if(H===`)`){if(L.parens===0&&d.strictBrackets===!0)throw SyntaxError(u(`opening`,`(`));let e=R[R.length-1];if(e&&L.parens===e.parens+1){ne(R.pop());continue}Z({type:`paren`,value:H,output:L.parens?`)`:`\\)`}),X(`parens`);continue}if(H===`[`){if(d.nobracket===!0||!K().includes(`]`)){if(d.nobracket!==!0&&d.strictBrackets===!0)throw SyntaxError(u(`closing`,`]`));H=`\\${H}`}else Y(`brackets`);Z({type:`bracket`,value:H});continue}if(H===`]`){if(d.nobracket===!0||V&&V.type===`bracket`&&V.value.length===1){Z({type:`text`,value:H,output:`\\${H}`});continue}if(L.brackets===0){if(d.strictBrackets===!0)throw SyntaxError(u(`opening`,`[`));Z({type:`text`,value:H,output:`\\${H}`});continue}X(`brackets`);let e=V.value.slice(1);if(V.posix!==!0&&e[0]===`^`&&!e.includes(`/`)&&(H=`/${H}`),V.value+=H,J({value:H}),d.literalBrackets===!1||r.hasRegexChars(e))continue;let t=r.escapeRegex(V.value);if(L.output=L.output.slice(0,-V.value.length),d.literalBrackets===!0){L.output+=t,V.value=t;continue}V.value=`(${g}${t}|${V.value})`,L.output+=V.value;continue}if(H===`{`&&d.nobrace!==!0){Y(`braces`);let e={type:`brace`,value:H,output:`(`,outputIndex:L.output.length,tokensIndex:L.tokens.length};z.push(e),Z(e);continue}if(H===`}`){let e=z[z.length-1];if(d.nobrace===!0||!e){Z({type:`text`,value:H,output:H});continue}let t=`)`;if(e.dots===!0){let e=h.slice(),n=[];for(let t=e.length-1;t>=0&&(h.pop(),e[t].type!==`brace`);t--)e[t].type!==`dots`&&n.unshift(e[t].value);t=l(n,d),L.backtrack=!0}if(e.comma!==!0&&e.dots!==!0){let n=L.output.slice(0,e.outputIndex),r=L.tokens.slice(e.tokensIndex);e.value=e.output=`\\{`,H=t=`\\}`,L.output=n;for(let e of r)L.output+=e.output||e.value}Z({type:`brace`,value:H,output:t}),X(`braces`),z.pop();continue}if(H===`|`){R.length>0&&R[R.length-1].conditions++,Z({type:`text`,value:H});continue}if(H===`,`){let e=H,t=z[z.length-1];t&&B[B.length-1]===`braces`&&(t.comma=!0,e=`|`),Z({type:`comma`,value:H,output:e});continue}if(H===`/`){if(V.type===`dot`&&L.index===L.start+1){L.start=L.index+1,L.consumed=``,L.output=``,h.pop(),V=m;continue}Z({type:`slash`,value:H,output:C});continue}if(H===`.`){if(L.braces>0&&V.type===`dot`){V.value===`.`&&(V.output=x);let e=z[z.length-1];V.type=`dots`,V.output+=H,V.value+=H,e.dots=!0;continue}if(L.braces+L.parens===0&&V.type!==`bos`&&V.type!==`slash`){Z({type:`text`,value:H,output:x});continue}Z({type:`dot`,value:H,output:x});continue}if(H===`?`){if(!(V&&V.value===`(`)&&d.noextglob!==!0&&W()===`(`&&W(2)!==`?`){te(`qmark`,H);continue}if(V&&V.type===`paren`){let e=W(),t=H;(V.value===`(`&&!/[!=<:]/.test(e)||e===`<`&&!/<([!=]|\w+>)/.test(K()))&&(t=`\\${H}`),Z({type:`text`,value:H,output:t});continue}if(d.dot!==!0&&(V.type===`slash`||V.type===`bos`)){Z({type:`qmark`,value:H,output:A});continue}Z({type:`qmark`,value:H,output:k});continue}if(H===`!`){if(d.noextglob!==!0&&W()===`(`&&(W(2)!==`?`||!/[!=<:]/.test(W(3)))){te(`negate`,H);continue}if(d.nonegate!==!0&&L.index===0){ee();continue}}if(H===`+`){if(d.noextglob!==!0&&W()===`(`&&W(2)!==`?`){te(`plus`,H);continue}if(V&&V.value===`(`||d.regex===!1){Z({type:`plus`,value:H,output:S});continue}if(V&&(V.type===`bracket`||V.type===`paren`||V.type===`brace`)||L.parens>0){Z({type:`plus`,value:H});continue}Z({type:`plus`,value:S});continue}if(H===`@`){if(d.noextglob!==!0&&W()===`(`&&W(2)!==`?`){Z({type:`at`,extglob:!0,value:H,output:``});continue}Z({type:`text`,value:H});continue}if(H!==`*`){(H===`$`||H===`^`)&&(H=`\\${H}`);let e=o.exec(K());e&&(H+=e[0],L.index+=e[0].length),Z({type:`text`,value:H});continue}if(V&&(V.type===`globstar`||V.star===!0)){V.type=`star`,V.star=!0,V.value+=H,V.output=I,L.backtrack=!0,L.globstar=!0,q(H);continue}let t=K();if(d.noextglob!==!0&&/^\([^?]/.test(t)){te(`star`,H);continue}if(V.type===`star`){if(d.noglobstar===!0){q(H);continue}let n=V.prev,r=n.prev,i=n.type===`slash`||n.type===`bos`,a=r&&(r.type===`star`||r.type===`globstar`);if(d.bash===!0&&(!i||t[0]&&t[0]!==`/`)){Z({type:`star`,value:H,output:``});continue}let o=L.braces>0&&(n.type===`comma`||n.type===`brace`),s=R.length&&(n.type===`pipe`||n.type===`paren`);if(!i&&n.type!==`paren`&&!o&&!s){Z({type:`star`,value:H,output:``});continue}for(;t.slice(0,3)===`/**`;){let n=e[L.index+4];if(n&&n!==`/`)break;t=t.slice(3),q(`/**`,3)}if(n.type===`bos`&&U()){V.type=`globstar`,V.value+=H,V.output=N(d),L.output=V.output,L.globstar=!0,q(H);continue}if(n.type===`slash`&&n.prev.type!==`bos`&&!a&&U()){L.output=L.output.slice(0,-(n.output+V.output).length),n.output=`(?:${n.output}`,V.type=`globstar`,V.output=N(d)+(d.strictSlashes?`)`:`|$)`),V.value+=H,L.globstar=!0,L.output+=n.output+V.output,q(H);continue}if(n.type===`slash`&&n.prev.type!==`bos`&&t[0]===`/`){let e=t[1]===void 0?``:`|$`;L.output=L.output.slice(0,-(n.output+V.output).length),n.output=`(?:${n.output}`,V.type=`globstar`,V.output=`${N(d)}${C}|${C}${e})`,V.value+=H,L.output+=n.output+V.output,L.globstar=!0,q(H+G()),Z({type:`slash`,value:`/`,output:``});continue}if(n.type===`bos`&&t[0]===`/`){V.type=`globstar`,V.value+=H,V.output=`(?:^|${C}|${N(d)}${C})`,L.output=V.output,L.globstar=!0,q(H+G()),Z({type:`slash`,value:`/`,output:``});continue}L.output=L.output.slice(0,-V.output.length),V.type=`globstar`,V.output=N(d),V.value+=H,L.output+=V.output,L.globstar=!0,q(H);continue}let n={type:`star`,value:H,output:I};if(d.bash===!0){n.output=`.*?`,(V.type===`bos`||V.type===`slash`)&&(n.output=P+n.output),Z(n);continue}if(V&&(V.type===`bracket`||V.type===`paren`)&&d.regex===!0){n.output=H,Z(n);continue}(L.index===L.start||V.type===`slash`||V.type===`dot`)&&(V.type===`dot`?(L.output+=D,V.output+=D):d.dot===!0?(L.output+=O,V.output+=O):(L.output+=P,V.output+=P),W()!==`*`&&(L.output+=w,V.output+=w)),Z(n)}for(;L.brackets>0;){if(d.strictBrackets===!0)throw SyntaxError(u(`closing`,`]`));L.output=r.escapeLast(L.output,`[`),X(`brackets`)}for(;L.parens>0;){if(d.strictBrackets===!0)throw SyntaxError(u(`closing`,`)`));L.output=r.escapeLast(L.output,`(`),X(`parens`)}for(;L.braces>0;){if(d.strictBrackets===!0)throw SyntaxError(u(`closing`,`}`));L.output=r.escapeLast(L.output,`{`),X(`braces`)}if(d.strictSlashes!==!0&&(V.type===`star`||V.type===`bracket`)&&Z({type:`maybe_slash`,value:``,output:`${C}?`}),L.backtrack===!0){L.output=``;for(let e of L.tokens)L.output+=e.output==null?e.value:e.output,e.suffix&&(L.output+=e.suffix)}return L};y.fastpaths=(e,t)=>{let a={...t},o=typeof a.maxLength==`number`?Math.min(i,a.maxLength):i,s=e.length;if(s>o)throw SyntaxError(`Input length: ${s}, exceeds maximum allowed length: ${o}`);e=c[e]||e;let{DOT_LITERAL:l,SLASH_LITERAL:u,ONE_CHAR:d,DOTS_SLASH:f,NO_DOT:p,NO_DOTS:m,NO_DOTS_SLASH:h,STAR:g,START_ANCHOR:_}=n.globChars(a.windows),v=a.dot?m:p,y=a.dot?h:p,b=a.capture?``:`?:`,x={negated:!1,prefix:``},S=a.bash===!0?`.*?`:g;a.capture&&(S=`(${S})`);let C=e=>e.noglobstar===!0?S:`(${b}(?:(?!${_}${e.dot?f:l}).)*?)`,w=e=>{switch(e){case`*`:return`${v}${d}${S}`;case`.*`:return`${l}${d}${S}`;case`*.*`:return`${v}${S}${l}${d}${S}`;case`*/*`:return`${v}${S}${u}${d}${y}${S}`;case`**`:return v+C(a);case`**/*`:return`(?:${v}${C(a)}${u})?${y}${d}${S}`;case`**/*.*`:return`(?:${v}${C(a)}${u})?${y}${S}${l}${d}${S}`;case`**/.*`:return`(?:${v}${C(a)}${u})?${l}${d}${S}`;default:{let t=/^(.*?)\.(\w+)$/.exec(e);if(!t)return;let n=w(t[1]);return n?n+l+t[2]:void 0}}},T=w(r.removePrefix(e,x));return T&&a.strictSlashes!==!0&&(T+=`${u}?`),T},t.exports=y})),ot=B(((e,t)=>{let n=it(),r=at(),i=rt(),a=nt(),o=e=>e&&typeof e==`object`&&!Array.isArray(e),s=(e,t,n=!1)=>{if(Array.isArray(e)){let r=e.map(e=>s(e,t,n));return e=>{for(let t of r){let n=t(e);if(n)return n}return!1}}let r=o(e)&&e.tokens&&e.input;if(e===``||typeof e!=`string`&&!r)throw TypeError(`Expected pattern to be a non-empty string`);let i=t||{},a=i.windows,c=r?s.compileRe(e,t):s.makeRe(e,t,!1,!0),l=c.state;delete c.state;let u=()=>!1;if(i.ignore){let e={...t,ignore:null,onMatch:null,onResult:null};u=s(i.ignore,e,n)}let d=(n,r=!1)=>{let{isMatch:o,match:d,output:f}=s.test(n,c,t,{glob:e,posix:a}),p={glob:e,state:l,regex:c,posix:a,input:n,output:f,match:d,isMatch:o};return typeof i.onResult==`function`&&i.onResult(p),o===!1?(p.isMatch=!1,r?p:!1):u(n)?(typeof i.onIgnore==`function`&&i.onIgnore(p),p.isMatch=!1,r?p:!1):(typeof i.onMatch==`function`&&i.onMatch(p),r?p:!0)};return n&&(d.state=l),d};s.test=(e,t,n,{glob:r,posix:a}={})=>{if(typeof e!=`string`)throw TypeError(`Expected input to be a string`);if(e===``)return{isMatch:!1,output:``};let o=n||{},c=o.format||(a?i.toPosixSlashes:null),l=e===r,u=l&&c?c(e):e;return l===!1&&(u=c?c(e):e,l=u===r),(l===!1||o.capture===!0)&&(l=o.matchBase===!0||o.basename===!0?s.matchBase(e,t,n,a):t.exec(u)),{isMatch:!!l,match:l,output:u}},s.matchBase=(e,t,n)=>(t instanceof RegExp?t:s.makeRe(t,n)).test(i.basename(e)),s.isMatch=(e,t,n)=>s(t,n)(e),s.parse=(e,t)=>Array.isArray(e)?e.map(e=>s.parse(e,t)):r(e,{...t,fastpaths:!1}),s.scan=(e,t)=>n(e,t),s.compileRe=(e,t,n=!1,r=!1)=>{if(n===!0)return e.output;let i=t||{},a=i.contains?``:`^`,o=i.contains?``:`$`,c=`${a}(?:${e.output})${o}`;e&&e.negated===!0&&(c=`^(?!${c}).*$`);let l=s.toRegex(c,t);return r===!0&&(l.state=e),l},s.makeRe=(e,t={},n=!1,i=!1)=>{if(!e||typeof e!=`string`)throw TypeError(`Expected a non-empty string`);let a={negated:!1,fastpaths:!0};return t.fastpaths!==!1&&(e[0]===`.`||e[0]===`*`)&&(a.output=r.fastpaths(e,t)),a.output||(a=r(e,t)),s.compileRe(a,t,n,i)},s.toRegex=(e,t)=>{try{let n=t||{};return new RegExp(e,n.flags||(n.nocase?`i`:``))}catch(e){if(t&&t.debug===!0)throw e;return/$^/}},s.constants=a,t.exports=s})),st=H(B(((e,t)=>{let n=ot(),r=rt();function i(e,t,i=!1){return t&&(t.windows===null||t.windows===void 0)&&(t={...t,windows:r.isWindows()}),n(e,t,i)}Object.assign(i,n),t.exports=i}))(),1);const ct=Array.isArray,lt=/\\/g,ut=process.platform===`win32`,dt=/^(\/?\.\.)+$/;function ft(e,t={}){let n=e.length,r=Array(n),i=Array(n),a,o;for(a=0;a<n;a++){let n=vt(e[a]);r[a]=n;let s=n.length,c=Array(s);for(o=0;o<s;o++)c[o]=(0,st.default)(n[o],t);i[a]=c}return e=>{let s=e.split(`/`);if(s[0]===`..`&&dt.test(e))return!0;for(a=0;a<n;a++){let e=r[a],n=i[a],c=s.length,l=Math.min(c,e.length);for(o=0;o<l;){let r=e[o];if(r.includes(`/`))return!0;if(!n[o](s[o]))break;if(!t.noglobstar&&r===`**`)return!0;o++}if(o===c)return!0}return!1}}const pt=/^[A-Z]:\/$/i,mt=ut?e=>pt.test(e):e=>e===`/`;function ht(e,t,n){if(e===t||t.startsWith(`${e}/`)){if(n){let t=e.length+ +!mt(e);return(e,n)=>e.slice(t,n?-1:void 0)||`.`}let r=t.slice(e.length+1);return r?(e,t)=>{if(e===`.`)return r;let n=`${r}/${e}`;return t?n.slice(0,-1):n}:(e,t)=>t&&e!==`.`?e.slice(0,-1):e}return n?t=>D.relative(e,t)||`.`:n=>D.relative(e,`${t}/${n}`)||`.`}function gt(e,t){if(t.startsWith(`${e}/`)){let n=t.slice(e.length+1);return e=>`${n}/${e}`}return n=>{let r=D.relative(e,`${t}/${n}`);return n[n.length-1]===`/`&&r!==``?`${r}/`:r||`.`}}const _t={parts:!0};function vt(e){let t=st.default.scan(e,_t);return t.parts?.length?t.parts:[e]}const yt=/(?<!\\)([()[\]{}*?|]|^!|[!+@](?=\()|\\(?![()[\]{}!*+?@|]))/g,bt=/(?<!\\)([()[\]{}]|^!|[!+@](?=\())/g,xt=ut?e=>e.replace(bt,`\\$&`):e=>e.replace(yt,`\\$&`);function St(e,t){if(t?.caseSensitiveMatch===!1)return!0;let n=st.default.scan(e);return n.isGlob||n.negated}function Ct(...e){console.log(`[tinyglobby ${new Date().toLocaleTimeString(`es`)}]`,...e)}function wt(e){return typeof e==`string`?[e]:e??[]}const Tt=/^(\/?\.\.)+/,Et=/\\(?=[()[\]{}!*+?@|])/g;function Dt(e,t,n,r){let i=t.cwd,a=e;e[e.length-1]===`/`&&(a=e.slice(0,-1)),a[a.length-1]!==`*`&&t.expandDirectories&&(a+=`/**`);let o=xt(i);a=T(a.replace(Et,``))?D.relative(o,a):D.normalize(a);let s=Tt.exec(a)?.[0],c=vt(a);if(s){let e=(s.length+1)/3,t=0,r=o.split(`/`);for(;t<e&&c[t+e]===r[r.length+t-e];)a=a.slice(0,(e-t-1)*3)+a.slice((e-t)*3+c[t+e].length+1)||`.`,t++;let l=D.join(i,s.slice(t*3));l[0]!==`.`&&n.root.length>l.length&&(n.root=l,n.depthOffset=-e+t)}if(!r&&n.depthOffset>=0){n.commonPath??=c;let e=[],t=Math.min(n.commonPath.length,c.length);for(let r=0;r<t;r++){let t=c[r];if(t===`**`&&!c[r+1]){e.pop();break}if(r===c.length-1||t!==n.commonPath[r]||St(t))break;e.push(t)}n.depthOffset=e.length,n.commonPath=e,n.root=e.length>0?D.join(i,...e):i}return a}function Ot(e,t,n){let r=[],i=[];for(let t of e.ignore)t&&(t[0]!==`!`||t[1]===`(`)&&i.push(Dt(t,e,n,!0));for(let a of t)a&&(a[0]!==`!`||a[1]===`(`?r.push(Dt(a,e,n,!1)):(a[1]!==`!`||a[2]===`(`)&&i.push(Dt(a.slice(1),e,n,!0)));return{match:r,ignore:i}}function kt(e,t){let n=e.cwd,r={root:n,depthOffset:0},i=Ot(e,t,r);e.debug&&Ct(`internal processing patterns:`,i);let{absolute:a,caseSensitiveMatch:o,debug:s,dot:c,followSymbolicLinks:l,onlyDirectories:u}=e,d=r.root.replace(lt,``),f={dot:c,nobrace:e.braceExpansion===!1,nocase:!o,noextglob:e.extglob===!1,noglobstar:e.globstar===!1,posix:!0},p=(0,st.default)(i.match,f),m=(0,st.default)(i.ignore,f),h=ft(i.match,f),g=ht(n,d,a),_=a?g:ht(n,d,!0),v=(e,t)=>{let n=_(t,!0);return n!==`.`&&!h(n)||m(n)},y;e.deep!==void 0&&(y=Math.round(e.deep-r.depthOffset));let b=new tt({filters:[s?(e,t)=>{let n=g(e,t),r=p(n)&&!m(n);return r&&Ct(`matched ${n}`),r}:(e,t)=>{let n=g(e,t);return p(n)&&!m(n)}],exclude:s?(e,t)=>{let n=v(e,t);return Ct(`${n?`skipped`:`crawling`} ${t}`),n}:v,fs:e.fs,pathSeparator:`/`,relativePaths:!a,resolvePaths:a,includeBasePath:a,resolveSymlinks:l,excludeSymlinks:!l,excludeFiles:u,includeDirs:u||!e.onlyFiles,maxDepth:y,signal:e.signal}).crawl(d);return e.debug&&Ct(`internal properties:`,{...r,root:d}),[b,n!==d&&!a&&gt(n,d)]}function At(e,t){if(t)for(let n=e.length-1;n>=0;n--)e[n]=t(e[n]);return e}const jt={caseSensitiveMatch:!0,cwd:process.cwd(),debug:!!process.env.TINYGLOBBY_DEBUG,expandDirectories:!0,followSymbolicLinks:!0,onlyFiles:!0};function Mt(e){let t={...jt,...e};return t.cwd=(t.cwd instanceof URL?j(t.cwd):k(t.cwd)).replace(lt,`/`),t.ignore=wt(t.ignore),t.fs&&={readdir:t.fs.readdir||_,readdirSync:t.fs.readdirSync||v,realpath:t.fs.realpath||y,realpathSync:t.fs.realpathSync||b,stat:t.fs.stat||x,statSync:t.fs.statSync||S},t.debug&&Ct(`globbing with options:`,t),t}function Nt(e,t={}){if(e&&t?.patterns)throw Error(`Cannot pass patterns as both an argument and an option`);let n=ct(e)||typeof e==`string`,r=wt((n?e:e.patterns)??`**/*`),i=Mt(n?t:e);return r.length>0?kt(i,r):[]}async function Pt(e,t){let[n,r]=Nt(e,t);return n?At(await n.withPromise(),r):[]}var Ft=B(((e,t)=>{var n=Object.defineProperty,r=Object.getOwnPropertyDescriptor,i=Object.getOwnPropertyNames,a=Object.prototype.hasOwnProperty,o=(e,t)=>{for(var r in t)n(e,r,{get:t[r],enumerable:!0})},s=(e,t,o,s)=>{if(t&&typeof t==`object`||typeof t==`function`)for(let c of i(t))!a.call(e,c)&&c!==o&&n(e,c,{get:()=>t[c],enumerable:!(s=r(t,c))||s.enumerable});return e},c=e=>s(n({},`__esModule`,{value:!0}),e),l={};o(l,{DEFAULT_CLOCK_TOLERANCE_SEC:()=>f,DEFAULT_JWT_EXPIRE_TIME_MS:()=>d,FileTokenProvider:()=>C,HttpClient:()=>I,HttpError:()=>N,generateJWTToken:()=>m,parseJWTTokenWithVerify:()=>h,registerPlatformPlugin:()=>O,resolvePlatformBaseURL:()=>D}),t.exports=c(l);var u=U(`crypto`),d=1800*1e3,f=60,p={alg:`HS256`,typ:`JWT`};function m(e,t){let n=Math.floor(Date.now()/1e3),r={...e,iss:e.access_key,iat:n,nbf:n,exp:n+Math.floor(t.expireTimeMs/1e3),jti:(0,u.randomUUID)()},i=_(JSON.stringify(p)),a=_(JSON.stringify(r));return`${i}.${a}.${g(`${i}.${a}`,t.secretKey)}`}function h(e,t,n){let r=e.split(`.`);if(r.length!==3)throw Error(`invalid JWT token format`);let[i,a,o]=r;if(JSON.parse(v(i)).alg!==`HS256`)throw Error(`unsupported JWT alg`);let s=g(`${i}.${a}`,t.secretKey),c=Buffer.from(s),l=Buffer.from(o);if(c.length!==l.length||!(0,u.timingSafeEqual)(c,l))throw Error(`JWT signature verification failed`);let d=JSON.parse(v(a));if(!n?.skipExpiration){let e=n?.clockTolerance??f,t=Math.floor(Date.now()/1e3);if(d.exp!==void 0&&d.exp+e<t)throw Error(`JWT token expired at ${new Date(d.exp*1e3).toISOString()}`);if(d.nbf!==void 0&&d.nbf-e>t)throw Error(`JWT token not yet valid, will be valid at ${new Date(d.nbf*1e3).toISOString()}`);if(d.iat!==void 0&&d.iat-e>t)throw Error(`JWT token issued in the future at ${new Date(d.iat*1e3).toISOString()}`)}return d}function g(e,t){return(0,u.createHmac)(`sha256`,t).update(e).digest(`base64`).replace(/=/g,``).replace(/\+/g,`-`).replace(/\//g,`_`)}function _(e){return Buffer.from(e).toString(`base64`).replace(/=/g,``).replace(/\+/g,`-`).replace(/\//g,`_`)}function v(e){let t=(4-(e.length%4||4))%4,n=`${e}${`=`.repeat(t)}`.replace(/-/g,`+`).replace(/_/g,`/`);return Buffer.from(n,`base64`).toString(`utf8`)}var y=class{cache=new Map;config;constructor(e){this.config={refreshBeforeMs:300*1e3,...e}}getToken(e){let t=this.getCacheKey(e),n=this.cache.get(t),r=Date.now();if(n&&n.expiresAtMs-r>this.config.refreshBeforeMs)return n.token;let i=m(e,this.config),a=r+this.config.expireTimeMs;return this.cache.set(t,{token:i,expiresAtMs:a}),i}clearCache(){this.cache.clear()}clearCacheFor(e){let t=this.getCacheKey(e);this.cache.delete(t)}getCacheKey(e){return[e.access_key,e.tenant_id?.toString()||``,e.user_id||``,e.app_id||``,e.app_env||``,e.sandbox_id||``].join(`:`)}getCacheStats(){let e=Date.now(),t=0,n=0;for(let r of this.cache.values())r.expiresAtMs>e?t++:n++;return{total:this.cache.size,valid:t,expired:n}}},b=U(`fs`),x=300*1e3,S=[`/home/gem/workspace/.force/openclaw/miaoda-provider-key`],C=class{cache=new Map;paths;refreshBeforeMs;constructor(e){this.paths=e?.paths??S,this.refreshBeforeMs=e?.refreshBeforeMs??x}getToken(){let e=Date.now();for(let t of this.paths){let n=this.cache.get(t);if(n&&n.expiresAtMs-e>this.refreshBeforeMs)return{token:n.token,accessKey:n.accessKey};let r=this.readAndParse(t);if(r&&(this.cache.set(t,r),r.expiresAtMs>e))return{token:r.token,accessKey:r.accessKey};if(n&&n.expiresAtMs>e)return{token:n.token,accessKey:n.accessKey}}return null}clearCache(){this.cache.clear()}readAndParse(e){try{let t=(0,b.readFileSync)(e,`utf-8`).trim();if(!t)return null;let n=this.decodePayload(t);return n?.exp?{token:t,accessKey:n.access_key??``,expiresAtMs:n.exp*1e3}:null}catch{return null}}decodePayload(e){try{let t=e.split(`.`);if(t.length!==3)return null;let n=(4-(t[1].length%4||4))%4,r=`${t[1]}${`=`.repeat(n)}`.replace(/-/g,`+`).replace(/_/g,`/`);return JSON.parse(Buffer.from(r,`base64`).toString(`utf8`))}catch{return null}}},w=`FORCE_AUTHN_INNERAPI_DOMAIN`,T=`FORCE_AUTHN_ACCESS_KEY`,E=`FORCE_AUTHN_ACCESS_SECRET`;function D(e){if(!e?.enabled)return e?.baseURL;if(e.baseURL)return e.baseURL;let t=e.domainEnv||w,n=process.env[t];if(!n)throw Error(`\u5E73\u53F0\u6A21\u5F0F\u9700\u8981\u57FA\u7840\u57DF\u540D\uFF0C\u8BF7\u8BBE\u7F6E\u73AF\u5883\u53D8\u91CF ${t}`);return n}function O(e,t){if(!t.enabled)return;k(`platform.defaultClaims`,t.defaultClaims);let n;t.tokenProvider?.type===`file`&&(n=new C({paths:t.tokenProvider.paths,refreshBeforeMs:t.refreshBeforeMs}));let r=t.accessKeyEnv||T,i=t.secretKeyEnv||E,a=t.accessKey??(process.env[r]||``),o=new y({accessKey:a,secretKey:t.secretKey??(process.env[i]||``),expireTimeMs:t.expireTimeMs??d,refreshBeforeMs:t.refreshBeforeMs});return e.request.use(e=>{if(n){let t=n.getToken();if(t){let n={...e.headers,Authorization:`Bearer ${t.token}`,"x-api-key":t.accessKey};return{...e,headers:n}}}k(`request.platformAuth.customClaims`,e.platformAuth?.customClaims);let r={...t.defaultClaims||{},...e.platformAuth?.customClaims||{},access_key:a},i=o.getToken(r),s={...e.headers,Authorization:`Bearer ${i}`,"x-api-key":a};return{...e,headers:s}}),o}function k(e,t){if(t&&Object.prototype.hasOwnProperty.call(t,`access_key`))throw Error(`${e} \u4E0D\u5141\u8BB8\u8BBE\u7F6E access_key`)}var A=class{interceptors=[];use(e,t){return this.interceptors.push({onFulfilled:e,onRejected:t}),this.interceptors.length-1}eject(e){this.interceptors[e]&&(this.interceptors[e]=null)}clear(){this.interceptors=[]}forEach(e){this.interceptors.forEach(t=>{t!==null&&e(t)})}};function j(e){if(typeof e!=`object`||!e)return!1;let t=Object.getPrototypeOf(e);return t===Object.prototype||t===null}function M(e){if(!e)return{};if(e instanceof Headers){let t={};return e.forEach((e,n)=>{t[n]=e}),t}if(Array.isArray(e))return e.reduce((e,[t,n])=>(e[t]=n,e),{});let t={};return Object.entries(e).forEach(([e,n])=>{t[e]=Array.isArray(n)?n.join(`,`):n}),t}var N=class e extends Error{isHttpError=!0;response;config;constructor(t,n,r){super(r||`Request failed with status ${t?.status||`unknown`}`),this.name=`HttpError`,this.response=t,this.config=P(n),Object.setPrototypeOf(this,e.prototype)}};function P(e){let{headers:t,...n}=e;return{...n,headers:F(t)}}function F(e){if(!e)return;let t=M(e),n={},r=[`authorization`,`x-api-key`,`cookie`,`x-secret`];for(let[e,i]of Object.entries(t)){let t=e.toLowerCase();r.includes(t)?n[e]=`[REDACTED]`:n[e]=i}return n}var I=class{defaultConfig;securityConfig;interceptors={request:new A,response:new A};constructor(e){let{platform:t,security:n,...r}=e||{};this.defaultConfig={timeout:5e3,...r};let i=n?.strictMode??!1;this.securityConfig={allowedProtocols:i?[`http:`,`https:`]:null,maxResponseSize:i?50*1024*1024:0,strictMode:i,...n},t?.enabled&&(this.defaultConfig.baseURL||(this.defaultConfig.baseURL=D(t)),O(this.interceptors,t))}async get(e,t){return this.request({...t,url:e,method:`GET`})}async post(e,t,n){let r={...n?.headers},i=t;return j(t)&&(i=JSON.stringify(t),Object.keys(r).some(e=>e.toLowerCase()===`content-type`)||(r[`Content-Type`]=`application/json`)),this.request({...n,url:e,method:`POST`,body:i,headers:r})}async put(e,t,n){let r={...n?.headers},i=t;return j(t)&&(i=JSON.stringify(t),Object.keys(r).some(e=>e.toLowerCase()===`content-type`)||(r[`Content-Type`]=`application/json`)),this.request({...n,url:e,method:`PUT`,body:i,headers:r})}async delete(e,t){return this.request({...t,url:e,method:`DELETE`})}async patch(e,t,n){let r={...n?.headers},i=t;return j(t)&&(i=JSON.stringify(t),Object.keys(r).some(e=>e.toLowerCase()===`content-type`)||(r[`Content-Type`]=`application/json`)),this.request({...n,url:e,method:`PATCH`,body:i,headers:r})}async request(e){let t=M(this.defaultConfig.headers),n=M(e.headers),r={};for(let e in t)r[e.toLowerCase()]={key:e,value:t[e]};for(let e in n)r[e.toLowerCase()]={key:e,value:n[e]};let i={};for(let e in r){let{key:t,value:n}=r[e];i[t]=n}let a={...this.defaultConfig,...e,headers:i};try{a=await this.runRequestInterceptors(a)}catch(e){return Promise.reject(e)}a.headers=M(a.headers);let o=this.buildUrl(a.url,a.params),s=a.timeout||this.defaultConfig.timeout||5e3,c=new AbortController,l=setTimeout(()=>c.abort(),s),u=a.signal;u&&(u.aborted?(clearTimeout(l),c.abort()):u.addEventListener(`abort`,()=>c.abort(),{once:!0}));let{platformAuth:d,params:f,timeout:p,baseURL:m,url:h,...g}=a;try{let e=await fetch(o,{...g,signal:c.signal});if(clearTimeout(l),this.securityConfig.maxResponseSize>0){let t=e.headers.get(`content-length`);if(t){let e=parseInt(t,10);if(e>this.securityConfig.maxResponseSize)throw Error(`Response size ${e} bytes exceeds limit of ${this.securityConfig.maxResponseSize} bytes`)}}if(!e.ok){let t=new N(e,a);return this.runResponseInterceptors(Promise.reject(t))}return this.runResponseInterceptors(Promise.resolve(e))}catch(e){clearTimeout(l);let t=e instanceof N?e:new N(void 0,a,e.name===`AbortError`?`Request aborted`:e.message);return this.runResponseInterceptors(Promise.reject(t))}}runRequestInterceptors(e){let t=Promise.resolve(e),n=[];this.interceptors.request.forEach(e=>{n.push(e)});for(let e of n)t=t.then(e.onFulfilled,e.onRejected);return t}async runResponseInterceptors(e){let t=e,n=[];this.interceptors.response.forEach(e=>{n.push(e)});for(let e of n)t=t.then(e.onFulfilled,e.onRejected);return t}buildUrl(e,t){let n=this.defaultConfig.baseURL,r;r=!n||/^https?:\/\//i.test(e)?e:n.replace(/\/+$/,``)+`/`+e.replace(/^\/+/,``);let i=new URL(r),{allowedProtocols:a}=this.securityConfig;if(a&&!a.includes(i.protocol))throw Error(`Protocol ${i.protocol} is not allowed. Allowed: ${a.join(`, `)}`);if(t)for(let[e,n]of Object.entries(t))n!=null&&i.searchParams.set(e,String(n));return i.href}}}))();const It=new Set([`forced_quota_failed`,`k_st_ec_400002680`,`k_st_ec_400002681`,`k_st_ec_400002682`,`k_st_ec_400002683`,`k_st_ec_400002684`,`k_st_ec_400002685`,`k_st_ec_400002686`,`k_st_ec_400002687`,`k_st_ec_400002688`,`k_st_ec_400002690`,`k_st_ec_400002698`]),Lt=new Set([`k_st_ec_400002680`,`k_st_ec_400002681`,`k_st_ec_400002682`,`k_st_ec_400002683`,`k_st_ec_400002684`,`k_st_ec_400002685`,`k_st_ec_400002686`,`k_st_ec_400002687`,`k_st_ec_400002688`,`k_st_ec_400002689`,`k_st_ec_400002690`,`k_st_ec_400002698`]);function Rt(e){return!!e&&It.has(e)}function zt(e){return!!e&&Lt.has(e)}let Bt;function Vt(){if(Bt)return Bt;try{let e=l(s(N(import.meta.url)),`..`,`package.json`);Bt=JSON.parse(a(e,`utf-8`))}catch(e){console.warn(`[miaoda-coding] failed to read package.json: ${e instanceof Error?e.message:e}`),Bt={}}return Bt}function Ht(){let e=process.env.FORCE_AUTHN_INNERAPI_DOMAIN;if(!e)throw Error(`studio-client: 缺少环境变量,需要: FORCE_AUTHN_INNERAPI_DOMAIN`);return{apiUrl:e}}var Ut=class extends Error{userFacing=!0;constructor(e,t,n){super(e),this.statusCode=t,this.logId=n,this.name=`UserFacingError`}};function Wt(e){return!!e&&typeof e==`object`&&!Array.isArray(e)&&Object.values(e).every(e=>typeof e==`string`)}function Gt(...e){for(let t of e)if(typeof t==`string`&&t)return t}async function*Kt(e){let t=new TextDecoder,n=``,r;for await(let i of e){n+=t.decode(i,{stream:!0});let e=n.split(`
2
2
 
3
3
  `);n=e.pop();for(let t of e){let e=t.split(`
4
- `),n=e.find(e=>e.startsWith(`id:`));n&&(r=n.slice(3).trim());let i=e.find(e=>e.startsWith(`data:`));if(!i)continue;let a=i.slice(5).trim();if(a){if(a===`[DONE]`){yield{data:null,id:r,done:!0};return}try{yield{data:JSON.parse(a),id:r,done:!1}}catch{}}}}}var A=class{#e;#t;constructor(){this.#t=w();let e=C().headers;this.#e=new x.HttpClient({baseURL:this.#t.apiUrl,timeout:9e5,...process.env.FORCE_FRAMEWORK_ENVIRONMENT!==`online`&&D(e)?{headers:e}:{},platform:{enabled:!0,tokenProvider:{type:`file`}}})}async createSubApp(e={}){let t=`${this.#t.apiUrl}/api/v1/studio/innerapi/openclaw/sub_app/create`,n={};e.message&&(n.message=e.message),e.agentId&&(n.agentId=e.agentId);let r;try{r=await this.#e.post(t,n,{headers:{"Content-Type":`application/json`}})}catch(e){if(e instanceof x.HttpError&&e.response){let t=e.response.headers.get(`x-tt-logid`)??``;throw Error(`createSubApp 请求失败 (logID: ${t}): ${e.response.status}`)}throw e}let i=r.headers?.get?.(`x-tt-logid`)??``,a=await r.json();if(a.BaseResp?.StatusCode!==0&&a.BaseResp?.StatusMessage)throw Error(`createSubApp 业务错误 (logID: ${i}): ${a.BaseResp.StatusMessage}`);if(a.error_msg&&a.status_code!==`0`)throw T.has(a.status_code)?new E(a.error_msg,a.status_code):Error(`createSubApp 服务错误 (logID: ${i}): ${a.error_msg}`);let o=O(a.appID,a.appId,a.app_id,a.data?.appID,a.data?.appId,a.data?.app_id),s=O(a.conversationID,a.conversationId,a.conversation_id,a.data?.conversationID,a.data?.conversationId,a.data?.conversation_id);if(!o){let e=Object.keys(a).join(`,`)||`(none)`,t=a.data&&typeof a.data==`object`&&Object.keys(a.data).join(`,`)||`(none)`;throw Error(`createSubApp 返回异常 (logID: ${i}): 缺少 appID,topLevelKeys=${e} dataKeys=${t}`)}return{appID:o,conversationID:s,logId:i}}async*streamChat(e){let t=`${this.#t.apiUrl}/api/v1/studio/innerapi/openclaw/sub_app/${e.appID}/stream_chat`,n={appID:e.appID,message:e.message};e.workDir&&(n.workDir=e.workDir);let r={"Content-Type":`application/json`,Accept:`text/event-stream`};e.lastEventID&&(r[`Last-Event-ID`]=e.lastEventID);let i;try{i=await this.#e.post(t,n,{headers:r})}catch(e){if(e instanceof x.HttpError&&e.response){let t=e.response.headers.get(`x-tt-logid`)??``,n=Error(`streamChat 请求失败 (logID: ${t}): ${e.response.status}`);throw n.logId=t,n}let t=e.cause?` cause: ${e.cause.message||e.cause}`:``,n=e.code?` code: ${e.code}`:``;throw Error(`streamChat 网络错误: ${e.message}${n}${t}`)}yield{__meta:!0,logId:i.headers?.get?.(`x-tt-logid`)??``},yield*k(i.body)}};const j=`.spark`,M=`meta.json`;function N(e){return o(e,j,M)}async function P(e){try{return JSON.parse(await u(N(e),`utf8`))}catch{return null}}async function F(e){for(let t of[o(e,`..`,`..`,j,M),o(e,`..`,j,M)])try{return JSON.parse(await u(t,`utf8`))}catch{}return null}async function I(e,t){await l(o(e,j),{recursive:!0});let n=await P(e),r={...n??{},...t};if(r.features||=[],!n){let t=await F(e);if(t)for(let[e,n]of Object.entries(t))e in r||(r[e]=n)}await p(N(e),JSON.stringify(r,null,2),`utf8`)}function L(e){let t=e;return t?.data?.message??t?.Data?.Message??null}async function ee(e){let t=e.maxReconnect??2,n=e.maxTotalReconnect??10,r=e.reconnectDelayMs??1500,i,a=0,o=0,s=0,c,l;for(;;){let u=!1,d=!1,f=!1,p=i;try{for await(let t of e.createStream(p)){if(e.signal?.aborted)return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,success:!1,error:`cancelled`};let n=t;if(n?.__meta){l=n.logId||l;continue}let r=n;if(r.id&&(i=r.id),r.id&&p&&r.id===p)continue;if(r.done)break;s++,a>0&&(a=0);let d=L(r.data);if(d?.type===`metadata`&&d?.status!==`in_progress`&&(u=!0),d?.role===`assistant`&&d?.type===`message`&&d?.status===`completed`&&typeof d?.content==`string`&&d.content&&(c=d.content),e.onEvent&&e.onEvent(r,{lastEventId:i,reconnectCount:o})===!1){f=!0;break}}}catch(e){if(!u){let t=e instanceof Error?e.message:String(e);if(/\b4[0-9]{2}\b/.test(t)||t.includes(`业务错误`))return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,success:!1,error:t};d=!0}}if(f)break;if(s===0&&!u&&!d)return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,success:!1,error:`stream returned no events`};if(u)break;if(d||i){if(a++,o++,a<=t&&o<=n&&i){if(e.onReconnect?.(o,i),await new Promise(t=>{let n=setTimeout(t,r);e.signal&&e.signal.addEventListener(`abort`,()=>{clearTimeout(n),t()},{once:!0})}),e.signal?.aborted)return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,success:!1,error:`cancelled`};continue}let u=`stream disconnected, reconnect exhausted`;return e.onFailed?.(u),{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,success:!1,error:u}}break}return e.onComplete?.({totalEvents:s,reconnectCount:o,lastEventId:i}),{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,success:!0}}const R=`.spark`,te=new Intl.DateTimeFormat(`en-CA`,{timeZone:`Asia/Shanghai`,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1,timeZoneName:`longOffset`});function z(e){return o(e,R,`progress.txt`)}function B(){let e=Object.fromEntries(te.formatToParts(new Date).filter(e=>e.type!==`literal`).map(e=>[e.type,e.value])),t=e.timeZoneName===`GMT`?`+00:00`:e.timeZoneName.replace(/^GMT/,``);return`${e.year}-${e.month}-${e.day}T${e.hour}:${e.minute}:${e.second}${t}`}function V(e){let t=[],n=``,r=``,i=``,a=e.includes(`## 已完成`)||e.includes(`## 当前任务`),o=!1,s=!a;for(let c of e.split(`
5
- `)){let e=c.trim();if(a){if(e===`## 已完成`){o=!0,s=!1;continue}if(e.startsWith(`## 当前任务`)){s=!0,o=!1;continue}if(e===``)continue}if(o&&e)t.push(e);else if(s&&e){let t=e.match(/^\[([^\]]+)\]\s*(.*)/);if(t){let e=t[2];i=t[1],r=e,!a&&e.startsWith(`需求: `)&&(n=e.slice(4))}else n||=e}}return{history:t,taskDesc:n,lastStatus:r,lastTimestamp:i}}async function ne(e,t){await l(o(e,R),{recursive:!0});let n=z(e),r=[];try{let e=await u(n,`utf8`);if(e.trim()){let t=V(e);if(r.push(...t.history),t.taskDesc){let e=t.lastTimestamp||B(),n;n=t.lastStatus.startsWith(`失败:`)?t.lastStatus:t.lastStatus===`处理完成`?`成功`:t.lastStatus||`未知状态`,r.push(`[${e}] ${t.taskDesc} — ${n}`)}}}catch{}await p(n,`## 已完成\n\n${r.length?r.join(`
4
+ `),n=e.find(e=>e.startsWith(`id:`));n&&(r=n.slice(3).trim());let i=e.find(e=>e.startsWith(`data:`));if(!i)continue;let a=i.slice(5).trim();if(a){if(a===`[DONE]`){yield{data:null,id:r,done:!0};return}try{yield{data:JSON.parse(a),id:r,done:!1}}catch{}}}}}var qt=class{#e;#t;constructor(){this.#t=Ht();let e=Vt().headers;this.#e=new Ft.HttpClient({baseURL:this.#t.apiUrl,timeout:9e5,...process.env.FORCE_FRAMEWORK_ENVIRONMENT!==`online`&&Wt(e)?{headers:e}:{},platform:{enabled:!0,tokenProvider:{type:`file`}}})}async createSubApp(e={}){let t=`${this.#t.apiUrl}/api/v1/studio/innerapi/openclaw/sub_app/create`,n={};e.message&&(n.message=e.message),e.agentId&&(n.agentId=e.agentId);let r;try{r=await this.#e.post(t,n,{headers:{"Content-Type":`application/json`}})}catch(e){if(e instanceof Ft.HttpError&&e.response){let t=e.response.headers.get(`x-tt-logid`)??``;throw Error(`createSubApp 请求失败 (logID: ${t}): ${e.response.status}`)}throw e}let i=r.headers?.get?.(`x-tt-logid`)??``,a=await r.json();if(a.BaseResp?.StatusCode!==0&&a.BaseResp?.StatusMessage)throw Error(`createSubApp 业务错误 (logID: ${i}): ${a.BaseResp.StatusMessage}`);if(a.error_msg&&a.status_code!==`0`)throw zt(a.status_code)?new Ut(a.error_msg,a.status_code,i):Error(`createSubApp 服务错误 (logID: ${i}): ${a.error_msg}`);let o=Gt(a.appID,a.appId,a.app_id,a.data?.appID,a.data?.appId,a.data?.app_id),s=Gt(a.conversationID,a.conversationId,a.conversation_id,a.data?.conversationID,a.data?.conversationId,a.data?.conversation_id);if(!o){let e=Object.keys(a).join(`,`)||`(none)`,t=a.data&&typeof a.data==`object`&&Object.keys(a.data).join(`,`)||`(none)`;throw Error(`createSubApp 返回异常 (logID: ${i}): 缺少 appID,topLevelKeys=${e} dataKeys=${t}`)}return{appID:o,conversationID:s,logId:i}}async*streamChat(e){let t=`${this.#t.apiUrl}/api/v1/studio/innerapi/openclaw/sub_app/${e.appID}/stream_chat`,n={appID:e.appID,message:e.message};e.workDir&&(n.workDir=e.workDir),e.channelAppId&&(n.channelAppId=e.channelAppId);let r={"Content-Type":`application/json`,Accept:`text/event-stream`};e.lastEventID&&(r[`Last-Event-ID`]=e.lastEventID);let i;try{i=await this.#e.post(t,n,{headers:r})}catch(e){if(e instanceof Ft.HttpError&&e.response){let t=e.response.headers.get(`x-tt-logid`)??``,n=Error(`streamChat 请求失败 (logID: ${t}): ${e.response.status}`);throw n.logId=t,n}let t=e.cause?` cause: ${e.cause.message||e.cause}`:``,n=e.code?` code: ${e.code}`:``;throw Error(`streamChat 网络错误: ${e.message}${n}${t}`)}yield{__meta:!0,logId:i.headers?.get?.(`x-tt-logid`)??``},yield*Kt(i.body)}};const Jt=`.spark`,Yt=`meta.json`;function Xt(e){return c(e,Jt,Yt)}async function Zt(e){try{return JSON.parse(await f(Xt(e),`utf8`))}catch{return null}}async function Qt(e){if(!e)return null;try{return JSON.parse(await f(c(l(e),Jt,Yt),`utf8`))}catch{return null}}async function $t(e,t,n){await d(c(e,Jt),{recursive:!0});let r=await Zt(e),i={...r??{},...t};if(i.features||=[],!r){let e=await Qt(n?.rootDir);if(e)for(let[t,n]of Object.entries(e))t in i||(i[t]=n)}await h(Xt(e),JSON.stringify(i,null,2),`utf8`)}function en(e){let t=e;return t?.data?.message??t?.Data?.Message??null}function tn(e){return(typeof e?.finishReason==`string`&&e.finishReason?e.finishReason:void 0)||(typeof e?.metadata?.finishReason==`string`&&e.metadata.finishReason?e.metadata.finishReason:void 0)}function nn(e){let t=[e?.metadata?.error?.message,e?.metadata?.error?.Message,e?.error?.message,e?.error?.Message];for(let e of t)if(typeof e==`string`&&e.trim())return e.trim()}function rn(e){let t=[e?.metadata?.error?.code,e?.metadata?.error?.Code,e?.error?.code,e?.error?.Code];for(let e of t)if(typeof e==`string`&&e.trim())return e.trim()}function an(e){return e===`credit_limit`}function on(e){let t=e;if(en(t))return;let n=t?.BaseResp??t?.baseResp,r=typeof t?.StatusMessage==`string`?t.StatusMessage:void 0,i=typeof t?.StatusCode==`number`?t.StatusCode:typeof t?.status_code==`number`?t.status_code:void 0,a=typeof n?.KStatusMessage==`string`&&n.KStatusMessage?n.KStatusMessage:typeof n?.StatusMessage==`string`&&n.StatusMessage?n.StatusMessage:void 0,o=typeof n?.KStatusCode==`string`&&n.KStatusCode?n.KStatusCode:void 0;if(r===`error`||typeof i==`number`&&i!==0||o||a&&a!==`success`)return{message:a??r??`stream service failed`,code:o}}async function sn(e){let t=e.maxReconnect??2,n=e.maxTotalReconnect??10,r=e.reconnectDelayMs??1500,i,a=0,o=0,s=0,c,l,u,d,f,p;for(;;){let m=!1,h=!1,g=!1,_=i;try{for await(let t of e.createStream(_)){if(e.signal?.aborted)return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,terminalReason:`stream_interrupted`,finishReasonRaw:f,errorCodeRaw:p,success:!1,error:`cancelled`};let n=t;if(n?.__meta){l=n.logId||l;continue}let r=n;r.id&&(i=r.id);let h=en(r.data),v=on(r.data),y=!!(r.id&&_&&r.id===_);v&&(p=v.code??p,u=Rt(v.code)?`quota_exceeded`:`service_failed`,d=v.message);let b=tn(h);b&&(f=b);let x=h?.type===`metadata`&&h?.status!==`in_progress`;x&&(m=!0,b===`user_stop`&&u!==`service_failed`&&u!==`quota_exceeded`&&(u=`user_stopped`,d=`user stopped`));let S=h?.status===`failed`;if(S){let e=rn(h);p=e??p,u=Rt(e)||an(b)?`quota_exceeded`:`service_failed`,d=nn(h)??(b?`stream failed: ${b}`:`stream failed`)}if(y){if(x||S||v)break;continue}if(r.done)break;if(s++,a>0&&(a=0),h?.role===`assistant`&&h?.type===`message`&&h?.status===`completed`&&typeof h?.content==`string`&&h.content&&(c=h.content),e.onEvent&&e.onEvent(r,{lastEventId:i,reconnectCount:o})===!1){g=!0;break}}}catch(e){if(!m){let t=e instanceof Error?e.message:String(e);if(/\b4[0-9]{2}\b/.test(t)||t.includes(`业务错误`))return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,terminalReason:`service_failed`,finishReasonRaw:f,errorCodeRaw:p,success:!1,error:t};h=!0}}if(g)break;if(u===`service_failed`||u===`quota_exceeded`)return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,terminalReason:u,finishReasonRaw:f,errorCodeRaw:p,success:!1,error:d??`stream failed`};if(u===`user_stopped`)break;if(s===0&&!m&&!h)return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,terminalReason:`stream_interrupted`,finishReasonRaw:f,errorCodeRaw:p,success:!1,error:`stream returned no events`};if(m){u??=`completed`;break}if(h||i){if(a++,o++,a<=t&&o<=n&&i){if(e.onReconnect?.(o,i),await new Promise(t=>{let n=setTimeout(t,r);e.signal&&e.signal.addEventListener(`abort`,()=>{clearTimeout(n),t()},{once:!0})}),e.signal?.aborted)return{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,terminalReason:`stream_interrupted`,finishReasonRaw:f,errorCodeRaw:p,success:!1,error:`cancelled`};continue}let u=`stream disconnected, reconnect exhausted`;return e.onFailed?.(u),{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,terminalReason:`stream_interrupted`,finishReasonRaw:f,errorCodeRaw:p,success:!1,error:u}}break}return u===`completed`&&e.onComplete?.({totalEvents:s,reconnectCount:o,lastEventId:i}),{totalEvents:s,reconnectCount:o,lastEventId:i,finalText:c,logId:l,terminalReason:u,finishReasonRaw:f,errorCodeRaw:p,success:!u||u===`completed`,error:u===`user_stopped`?d:void 0}}let cn=``,ln=0;function un(e){try{let t=dn(e);if(!t)return null;let n=t.replace(/\s*\(.*\)$/,``).replace(/\s*:.*$/,``),r=Date.now();return n===cn&&r-ln<3e4?null:(cn=n,ln=r,t)}catch{return null}}function dn(e){let t=e.role,n=e.tool_calls,r=e.content;if(e.finish_reason,t===`assistant`&&n?.length)for(let e of n){let t=e?.function?.name??e?.name,n={};try{let t=e?.function?.arguments??e?.arguments;n=typeof t==`string`?JSON.parse(t):t??{}}catch{}if(t===`bash`){let e=String(n.command??``);if(e.includes(`init`))return`初始化项目`;if(e.includes(`db sql`))return`数据库操作`;if(e.includes(`deploy`))return`部署中`}}return t===`tool`&&typeof r==`string`&&(r.startsWith(`执行 run_shell_command 工具失败`)||r.startsWith(`command exitcode:`))?`失败: ${r.slice(0,200)+(r.length>200?`...`:``)}`:null}const fn=`.spark`,pn=new Intl.DateTimeFormat(`en-CA`,{timeZone:`Asia/Shanghai`,year:`numeric`,month:`2-digit`,day:`2-digit`,hour:`2-digit`,minute:`2-digit`,second:`2-digit`,hour12:!1,timeZoneName:`longOffset`});async function mn(e){return(await Pt(`**/SKILL.md`,{cwd:e,followSymbolicLinks:!0}).catch(()=>[])).length>0}async function hn(e){try{return JSON.parse(await f(c(e,`.spark`,`meta.json`),`utf8`))}catch{return null}}async function gn(e,t){if(!await mn(c(e,`.agent`,`skills`)))return`.agent/skills 下未找到 SKILL.md,项目 Agent 技能未配置`;let n=await hn(e)??(t?await hn(t):null);return n?!n.stack||!n.version?`.spark/meta.json 缺少 stack 或 version 字段`:null:`缺少 .spark/meta.json,项目未初始化`}function _n(e){return c(e,fn,`progress.txt`)}function vn(){let e=Object.fromEntries(pn.formatToParts(new Date).filter(e=>e.type!==`literal`).map(e=>[e.type,e.value])),t=e.timeZoneName===`GMT`?`+00:00`:e.timeZoneName.replace(/^GMT/,``);return`${e.year}-${e.month}-${e.day}T${e.hour}:${e.minute}:${e.second}${t}`}function yn(e){let t=[],n=``,r=``,i=``,a=e.includes(`## 已完成`)||e.includes(`## 当前任务`),o=!1,s=!a;for(let c of e.split(`
5
+ `)){let e=c.trim();if(a){if(e===`## 已完成`){o=!0,s=!1;continue}if(e.startsWith(`## 当前任务`)){s=!0,o=!1;continue}if(e===``)continue}if(o&&e)t.push(e);else if(s&&e){let t=e.match(/^\[([^\]]+)\]\s*(.*)/);if(t){let e=t[2];i=t[1],r=e,!a&&e.startsWith(`需求: `)&&(n=e.slice(4))}else n||=e}}return{history:t,taskDesc:n,lastStatus:r,lastTimestamp:i}}async function bn(e,t){await d(c(e,fn),{recursive:!0});let n=_n(e),r=[];try{let e=await f(n,`utf8`);if(e.trim()){let t=yn(e);if(r.push(...t.history),t.taskDesc){let e=t.lastTimestamp||vn(),n;n=t.lastStatus.startsWith(`失败:`)?t.lastStatus:t.lastStatus===`处理完成`?`成功`:t.lastStatus||`未知状态`,r.push(`[${e}] ${t.taskDesc} — ${n}`)}}}catch{}await h(n,`## 已完成\n\n${r.length?r.join(`
6
6
  `)+`
7
- `:``}\n## 当前任务\n\n${t}\n`,`utf8`)}async function H(e,t){await c(z(e),`[${B()}] ${t}\n`,`utf8`)}async function*re(e){let{cwd:t,task:n,agentId:r,signal:i}=e;try{let a=new A;await ne(t,(e.requestText??n).slice(0,200)),await H(t,`已接收需求`),yield{type:`progress`,message:`已接收需求`};let o=await P(t),s=!o?.appId,c=B();if(s){let e;try{e=await a.createSubApp({message:n,agentId:r})}catch(e){let n=e instanceof Error?e.message:String(e),r=e instanceof E;try{await H(t,`失败: ${n}`)}catch{}yield{type:`failed`,error:n,phase:`create`,userFacing:r};return}let{appID:i,conversationID:s,logId:l}=e;o={appId:i,conversationId:s,createdAt:c,updatedAt:c},await I(t,o),await H(t,`应用已创建(appId: ${i})`),yield{type:`app_created`,appId:i,conversationId:s,logId:l}}await H(t,`正在处理`),yield{type:`progress`,message:`正在处理`};let l=!1,u=Date.now(),d=setInterval(()=>{H(t,`正在开发中(已 ${Math.floor((Date.now()-u)/6e4)} 分钟)`).catch(()=>{})},6e4),f;try{f=await ee({createStream:e=>a.streamChat({appID:o.appId,message:n,workDir:t,...e?{lastEventID:e}:{}}),onEvent:e=>{if(i?.aborted)return!1;let n=L(e.data),r=n?.delta?.type;!l&&n?.role===`assistant`&&(n?.status===`in_progress`||r===`text`)&&(l=!0,H(t,`正在输出结果`).catch(()=>{}))},onReconnect:(t,n)=>{e.onReconnect?.(t,n)},onFailed:n=>{e.onStreamFailed?.(n),H(t,`失败: ${n}`).catch(()=>{})},signal:i})}finally{clearInterval(d)}if(!f.success){let e=f.error?.includes(`disconnected`)||f.error?.includes(`no events`);yield{type:`failed`,error:f.error||`stream failed`,retryable:e};return}let{finalText:p,logId:m}=f;if(l&&(yield{type:`progress`,message:`正在输出结果`,logId:m||void 0}),i?.aborted){await H(t,`失败: cancelled`),yield{type:`failed`,error:`cancelled`};return}let h=B();await I(t,{...o,updatedAt:h,finalText:p}),await H(t,`处理完成`),yield{type:`completed`,appId:o.appId,logId:m||void 0,finalText:p}}catch(e){let n=e instanceof Error?e.message:String(e);try{await H(t,`失败: ${n}`)}catch{}yield{type:`failed`,error:n,logId:e?.logId}}}const U=[`research`,`design`,`feedback`];function ie(e){return e.replace(/[^a-zA-Z0-9\u4e00-\u9fff-]/g,`-`).replace(/-+/g,`-`).replace(/^-|-$/g,``).slice(0,60)||`reference`}async function ae(e){let t;try{t=await d(e)}catch{return 1}let n=0;for(let e of t){let t=e.match(/^(\d{3})-/);if(t){let e=parseInt(t[1],10);e>n&&(n=e)}}return n+1}async function oe(e){try{let t=await u(o(e,`reference`,`manifest.json`),`utf8`);return JSON.parse(t)}catch{return{updatedAt:new Date().toISOString(),files:[]}}}async function se(e,t){await l(o(e,`reference`),{recursive:!0}),await p(o(e,`reference`,`manifest.json`),JSON.stringify(t,null,2),`utf8`)}async function W(e){let{appCwd:t,category:n,content:r,filename:i,mode:a=`append`}=e,s=o(t,`reference`,n);if(a===`replace`)try{await f(s,{recursive:!0,force:!0})}catch{}await l(s,{recursive:!0});let c=await ae(s),u=`${n}/${`${String(c).padStart(3,`0`)}-${ie(i??`reference`)}.md`}`,d=`reference/${u}`;await p(o(t,d),r,`utf8`);let m=await oe(t);return a===`replace`&&(m.files=m.files.filter(e=>e.category!==n)),m.files.push({path:u,category:n,writtenAt:new Date().toISOString()}),m.updatedAt=new Date().toISOString(),await se(t,m),{relativePath:d,category:n,seq:c}}async function G(e){let t=o(e,`reference`),n;try{n=await d(t)}catch{return{totalFiles:0,categories:{}}}let r={},i=0;for(let e of n){if(!U.includes(e))continue;let n;try{n=(await d(o(t,e))).filter(e=>e.endsWith(`.md`)).sort()}catch{continue}n.length>0&&(r[e]={count:n.length,files:n},i+=n.length)}return{totalFiles:i,categories:r}}async function ce(e){return(await G(e)).totalFiles>0}const le=/^[a-z0-9][a-z0-9-]{0,63}$/,ue=new Set([`.`,`..`,`con`,`nul`,`prn`,`aux`]);function K(e){let t=e?.config?.plugins?.entries?.[`openclaw-extension-miaoda-coding`]?.config??{};return{verbose:t?.verbose===!0,hooks:{allowPromptInjection:t?.hooks?.allowPromptInjection!==!1}}}function q(e,n){if(!e)return;let r=i.dirname(process.execPath),a=t(`openclaw`,[`message`,`send`,`--channel`,`feishu`,`--target`,e,`--message`,n],{stdio:[`ignore`,`ignore`,`pipe`],env:{...process.env,PATH:`${r}:${process.env.PATH||``}`}});a.stderr.on(`data`,()=>{}),a.on(`close`,()=>{}),a.unref()}function J(e){return String(e??``).replace(/[\u0000-\u0008\u000B\u000C\u000E-\u001F\u007F]/g,``).replace(/\s+/g,` `).trim()}function Y(e){let t=String(e??``).replace(/[\u0000-\u0008\u000B\u000C\u000E-\u001F\u007F]/g,``).trim();if(!t)throw Error(`task 不能为空`);if(t.length>4e3)throw Error(`task 不能超过 4000 个字符`);return t}function X(e){let t=J(e);if(!Z(t))throw Error(`project_id 不合法: "${t}"`);return t}function Z(e){return le.test(e)&&!ue.has(e)}function de(e){if(e==null||e===``)return;let t=J(e);if(!/^(user|chat|thread):\S+$/.test(t))throw Error(`target 不合法`);return t}function fe(e){try{return n.readFileSync(e,`utf8`).split(`
8
- `).map(e=>e.trim()).filter(Boolean)}catch{return[]}}function pe(e){return e.replace(/^\[[^\]]+\]\s*/,``)}function Q(e){return e.replace(/应用已创建(appId:\s*[^)]+)/g,`应用已创建`)}function $(e){return e.slice(-3).map(pe).map(Q).join(` | `)||`暂无进度记录`}function me(e){let t=$(e);return t.includes(`失败:`)?`failed`:t.includes(`处理完成`)?`completed`:t===`暂无进度记录`?`pending`:`running`}var he={id:`openclaw-extension-miaoda-coding`,name:`妙搭`,description:`妙搭制品创建与修改`,register(e){let t=`[miaoda-coding]`,r={info:n=>e.logger.info?.(`${t} ${n}`),warn:n=>e.logger.warn?.(`${t} ${n}`),error:n=>e.logger.error?.(`${t} ${n}`)},a={verbose:!1,hooks:{allowPromptInjection:!0}},o=new Set([`miaoda_coding`]),s=new Set([`miaoda_check_progress`]);e.on(`before_tool_call`,(e,t)=>{let n=e.toolName,i=t?.sessionKey??``,a=i.toLowerCase().split(`:`).includes(`subagent`);if(o.has(n)&&!a)return r.warn(`blocked ${n} from non-subagent session: ${i}`),{block:!0,blockReason:`${n} 只能由 subagent 调用。请通过 sessions_spawn(runtime="subagent", mode="run") 派活,不要直接调用此工具。读 miaoda-coding skill 了解完整流程。`};if(s.has(n)&&a)return r.warn(`blocked ${n} from subagent session: ${i}`),{block:!0,blockReason:`${n} 不能由 subagent 调用。subagent 不应直接操作参考资料或查询进度。`}}),e.on(`before_prompt_build`,(e,t)=>{if(K(t).hooks.allowPromptInjection)return{prependSystemContext:[`【硬规则 — 妙搭】`,`当用户要求创建或修改应用、网页、页面时,必须通过 sessions_spawn(runtime="subagent", mode="run") 交给妙搭。`,`读 miaoda-coding skill 后严格按指示操作。只传 runtime、mode、task 三个参数,不要传 streamTo/sandbox 等。`,`绝对不要自己写代码或用 exec 生成文件。如果 spawn 失败,重试而不是 fallback。`,`如果对话中有需要传递给 code agent 的上下文(研究结果、用户偏好等),先调 miaoda_write_reference 写入 reference 目录,再 spawn。用户反悔或需要替换之前的上下文时,使用 miaoda_write_reference 的 mode=replace。妙搭只做制品生成,不做研究。`,`不要用 sessions_history 读取子 agent 的 session,查进度用 miaoda_check_progress tool。`,`subagent 完成后只发一条消息(总结+预览链接),严禁发多条。不要调 message tool。预览链接必须使用加粗 Markdown 链接格式 **[url](url)**,不要发裸 URL。`].join(` `)}}),e.registerTool(e=>{let t=b(e);return{name:`list_projects`,label:`列出妙搭项目`,description:`列出已创建的妙搭项目,返回 project_id、appId、updatedAt、finalText、status 和进度摘要。修改已有项目时必须先调此工具。`,parameters:{type:`object`,properties:{}},async execute(){let e=[];try{e=n.readdirSync(t.workspaceDir,{withFileTypes:!0}).filter(e=>e.isDirectory()&&Z(e.name)).map(e=>{let r=i.join(t.workspaceDir,e.name,`.spark`,`meta.json`),a=i.join(t.workspaceDir,e.name,`.spark`,`progress.txt`),o=null;try{o=JSON.parse(n.readFileSync(r,`utf8`))}catch{}let s=fe(a);return{project_id:e.name,appId:o?.appId??null,updatedAt:o?.updatedAt??null,finalText:o?.finalText??null,status:me(s),progressSummary:$(s)}})}catch{}return{content:[{type:`text`,text:JSON.stringify({projects:e},null,2)}]}}}}),e.registerTool(e=>{let t=b(e);return{name:`miaoda_check_progress`,label:`查看妙搭项目进度`,description:`查看妙搭项目的生成进度。用户问"做到哪了"、"进度如何"、"好了吗"时调此工具。`,parameters:{type:`object`,properties:{project_id:{type:`string`,description:`项目目录名(从 list_projects 获取)`}},required:[`project_id`]},async execute(e,r){try{let e=X(r.project_id),a=i.join(t.workspaceDir,e,`.spark`,`progress.txt`),o=n.readFileSync(a,`utf8`).trim().split(`
9
- `).filter(Boolean),s=null;try{s=JSON.parse(n.readFileSync(i.join(t.workspaceDir,e,`.spark`,`meta.json`),`utf8`))}catch{}let c=!!s?.finalText,l=o.slice(-20).map(Q).join(`
10
- `);return{content:[{type:`text`,text:JSON.stringify({status:`ok`,project_id:e,lines:o.length,progress:l,delivery_ready:c,finalTextAvailable:c,note:`miaoda_check_progress 只用于查看进度,不能根据 appId 或进度文本推导预览链接;最终链接只以 subagent completion result 中的 output/finalText 为准。`})}]}}catch{return{content:[{type:`text`,text:JSON.stringify({status:`no_progress`,project_id:r.project_id,message:`暂无进度记录`,delivery_ready:!1,finalTextAvailable:!1,note:`miaoda_check_progress 只用于查看进度,不能根据 appId 或进度文本推导预览链接;最终链接只以 subagent completion result 中的 output/finalText 为准。`})}]}}}}}),e.registerTool(e=>{let t=b(e);return{name:`miaoda_write_reference`,label:`写入妙搭参考资料`,description:`将参考资料写入妙搭项目的 reference 目录,供 code agent 在生成时自行查阅。按 category 分类写入。mode=append(默认)追加,mode=replace 替换该 category 全部内容(用于反悔/调整场景)。`,parameters:{type:`object`,properties:{project_id:{type:`string`,description:`项目目录名`},category:{type:`string`,enum:[`research`,`design`,`feedback`],description:`资料类别:research(调研结果)、design(设计要求)、feedback(用户反馈)`},content:{type:`string`,description:`参考资料内容(Markdown 格式,摘要+关键原文引用)`},filename:{type:`string`,description:`可选文件名(不含扩展名)`},mode:{type:`string`,enum:[`append`,`replace`],description:`写入模式:append(追加,默认)、replace(替换该 category 全部内容)`}},required:[`project_id`,`category`,`content`]},async execute(e,n){try{let e=X(n.project_id);if(!U.includes(n.category))throw Error(`category 不合法,必须是 ${U.join(`、`)} 之一`);let r=n.content?.trim();if(!r)throw Error(`content 不能为空`);if(r.length>5e4)throw Error(`content 不能超过 50000 个字符`);let i=n.mode===`replace`?`replace`:`append`,a=y(t.workspaceDir,e),o=await W({appCwd:a,category:n.category,content:r,filename:n.filename,mode:i}),s=await G(a);return{content:[{type:`text`,text:JSON.stringify({status:`ok`,...o,summary:s},null,2)}]}}catch(e){return{content:[{type:`text`,text:JSON.stringify({status:`error`,error:e instanceof Error?e.message:String(e)})}]}}}}});let c=900*1e3;e.registerTool(e=>{let t=b(e);return{name:`miaoda_coding`,label:`妙搭`,description:`创建或修改妙搭应用/网页。只接受生成指令,不接受搜索/调研等任务。如有参考资料,应事先通过 miaoda_write_reference 写入 reference 目录。修改已有项目时必须先调 list_projects 获取 project_id。返回结构化 JSON(status/appId/finalText/output/meta)。`,parameters:{type:`object`,properties:{generation_request:{type:`string`,description:`生成指令(如'做一个学习网站,包含章节、题库、测验')`},project_id:{type:`string`,description:`本地项目目录名,仅允许小写字母、数字和短横线`},target:{type:`string`,description:`飞书消息推送目标(如 user:ou_xxx)`}},required:[`generation_request`,`project_id`]},async execute(e,o){try{let e=Y(o.generation_request),s=X(o.project_id),l=de(o.target),u=y(t.workspaceDir,s);n.mkdirSync(u,{recursive:!0}),r.info(`miaoda_coding called (project=${s}, isNew=${!n.existsSync(i.join(u,`.spark`,`meta.json`))})`);let d=await ce(u)?`工作目录下有 reference/ 目录,包含参考资料,请先查阅再开始工作。\n\n${e}`:e,f=i.join(u,`.agent`);if(!n.existsSync(f)){let e=v(_());if(n.existsSync(e))try{n.symlinkSync(e,f)}catch{}}let p=[],m,h=!1,g=!1,b=null,x=new AbortController,S=setTimeout(()=>x.abort(),c);try{for await(let n of re({cwd:u,task:d,requestText:e,agentId:t.agentId,signal:x.signal,onReconnect:(e,t)=>{r.warn(`stream reconnect (project=${s}, attempt=${e}, lastEventId=${t??`none`})`)},onStreamFailed:e=>{r.error(`stream failed (project=${s}): ${e}`)}})){if(`logId`in n&&n.logId&&p.push(n.logId),a.verbose&&l)switch(n.type){case`app_created`:q(l,`应用已创建(appId: ${n.appId})`);break;case`failed`:q(l,`处理失败: ${n.error}`);break}if(n.type===`completed`&&(b={appId:n.appId,finalText:n.finalText}),n.type===`failed`&&(m=n.error,h=n.retryable??!1,n.phase===`create`)){r.error(`createSubApp failed (project=${s}): ${n.error}`),clearTimeout(S),l&&q(l,n.userFacing?n.error:`createSubApp 失败: ${n.error}`);let e=n.userFacing?{status:`error`,project_id:s,appId:null,meta:null,hint:`创建失败,详情已通过飞书发送给用户,不要重复发送错误内容`}:{status:`error`,project_id:s,appId:null,error:n.error,meta:null,hint:`createSubApp 失败,错误已通过飞书发送。根据 error 内容用通俗语言告诉用户具体原因,不要重试`};return{content:[{type:`text`,text:JSON.stringify(e)}]}}}}catch{}clearTimeout(S),g=x.signal.aborted;let C=null;try{C=JSON.parse(n.readFileSync(i.join(u,`.spark`,`meta.json`),`utf8`))}catch{}let w={status:g?`timeout`:m?`error`:`ok`,project_id:s,appId:b?.appId??C?.appId??null,finalText:b?.finalText??C?.finalText,output:b?.finalText??C?.finalText,logIds:p.length?p:void 0,meta:C};if(r.info(`miaoda_coding done (project=${s}, status=${w.status}, logIds=${p.join(`,`)})`),g?(w.error=`执行超时(${c/1e3}秒)`,w.retryable=!0,w.hint=`执行超时,任务可能仍在后台运行。建议先调用 miaoda_check_progress 查看进度,再决定是否重试`):m&&(w.error=m,h&&(w.retryable=!0,w.hint=`网络连接中断,任务可能已部分完成。建议先调用 miaoda_check_progress 查看当前状态,再决定下一步`)),l&&w.status===`ok`){let e=C?.appUrl;if(r.info(`delivery check (project=${s}, target=${l}, appUrl=${e??`missing`})`),typeof e==`string`&&e.trim()){let t=e.includes(`?`)?`&`:`?`,n=`${e.trim()}${t}mode=sidebar-semi`;q(l,`**[${n}](${n})**`),r.info(`delivery sent (project=${s}, url=${n})`),w.hint=`预览链接已自动发送给用户,announce 时不要再带预览链接`}else r.warn(`delivery skipped: no appUrl in meta.json (project=${s})`)}return{content:[{type:`text`,text:JSON.stringify(w,null,2)}]}}catch(e){return{content:[{type:`text`,text:JSON.stringify({status:`error`,error:e instanceof Error?e.message:String(e)})}]}}}}}),e.registerService({id:`miaoda-coding-config`,async start(e){a=K(e)},async stop(){}})}};export{he as default};
7
+ `:``}\n## 当前任务\n\n${t}\n`,`utf8`)}async function Q(e,t){await u(_n(e),`[${vn()}] ${t}\n`,`utf8`)}async function*xn(e){let{cwd:t,rootDir:n,task:r,agentId:i,signal:a}=e;try{let o=await gn(t,n);if(o){yield{type:`failed`,phase:`pre-create`,userFacing:!1,error:o};return}let s=new qt,c=e.requestText??r;await bn(t,c.slice(0,200)+(c.length>200?`...`:``)),e.traceId&&await Q(t,`trace_id: ${e.traceId}`),await Q(t,`已接收需求`),yield{type:`progress`,message:`已接收需求`};let l=await Zt(t),u=!l?.appId,d=vn();if(u){let e;try{e=await s.createSubApp({message:r,agentId:i})}catch(e){let n=e instanceof Error?e.message:String(e),r=e instanceof Ut,i=e?.logId;try{await Q(t,`失败: ${n}`)}catch{}yield{type:`failed`,error:n,phase:`create`,userFacing:r,logId:i};return}let{appID:a,conversationID:o,logId:c}=e;l={appId:a,conversationId:o,createdAt:d,updatedAt:d},await $t(t,l,{rootDir:n}),await Q(t,`应用已创建(appId: ${a})`),yield{type:`app_created`,appId:a,conversationId:o,logId:c}}await Q(t,`正在处理`),yield{type:`progress`,message:`正在处理`};let f=!1,p=Date.now(),m=setInterval(()=>{Q(t,`正在开发中(已 ${Math.floor((Date.now()-p)/6e4)} 分钟)`).catch(()=>{})},6e4),h;try{h=await sn({createStream:n=>s.streamChat({appID:l.appId,message:r,workDir:t,channelAppId:e.channelAppId,...n?{lastEventID:n}:{}}),onEvent:e=>{if(a?.aborted)return!1;let n=en(e.data),r=n?.delta?.type;!f&&n?.role===`assistant`&&(n?.status===`in_progress`||r===`text`)&&(f=!0,Q(t,`正在输出结果`).catch(()=>{}));try{if(n?.status===`completed`){let e=un(n);e&&Q(t,e).catch(()=>{})}}catch{}},onReconnect:(t,n)=>{e.onReconnect?.(t,n)},onFailed:t=>{e.onStreamFailed?.(t)},signal:a})}finally{clearInterval(m)}if(!h.success){let e=h.terminalReason??`stream_interrupted`,n=e===`stream_interrupted`;await Q(t,`失败: ${h.error??e}`),yield{type:`failed`,error:h.error||`stream failed`,appId:l.appId,logId:h.logId,lastEventId:h.lastEventId,phase:`stream`,retryable:n,terminalReason:e,sseEventCount:h.totalEvents,reconnectCount:h.reconnectCount,finishReasonRaw:h.finishReasonRaw,errorCodeRaw:h.errorCodeRaw};return}let{finalText:g,logId:_,totalEvents:v,reconnectCount:y,finishReasonRaw:b}=h;if(f&&(yield{type:`progress`,message:`正在输出结果`,logId:_||void 0}),a?.aborted){await Q(t,`失败: cancelled`),yield{type:`failed`,error:`cancelled`,appId:l.appId,phase:`stream`,lastEventId:h.lastEventId,retryable:!0,terminalReason:`stream_interrupted`,sseEventCount:v,reconnectCount:y,finishReasonRaw:b,errorCodeRaw:h.errorCodeRaw};return}let x=vn();await $t(t,{...l,updatedAt:x,finalText:g},{rootDir:n}),g&&await Q(t,`Agent 回复: ${g.slice(0,200)+(g.length>200?`...`:``)}`),await Q(t,`处理完成`),yield{type:`completed`,appId:l.appId,logId:_||void 0,lastEventId:h.lastEventId,finalText:g,terminalReason:`completed`,sseEventCount:v,reconnectCount:y,finishReasonRaw:b}}catch(e){let n=e instanceof Error?e.message:String(e);try{await Q(t,`失败: ${n}`)}catch{}yield{type:`failed`,error:n,logId:e?.logId}}}const Sn=[`research`,`design`,`feedback`];function Cn(e){return e.replace(/[^a-zA-Z0-9\u4e00-\u9fff-]/g,`-`).replace(/-+/g,`-`).replace(/^-|-$/g,``).slice(0,60)||`reference`}async function wn(e){let t;try{t=await p(e)}catch{return 1}let n=0;for(let e of t){let t=e.match(/^(\d{3})-/);if(t){let e=parseInt(t[1],10);e>n&&(n=e)}}return n+1}async function Tn(e){try{let t=await f(c(e,`reference`,`manifest.json`),`utf8`);return JSON.parse(t)}catch{return{updatedAt:new Date().toISOString(),files:[]}}}async function En(e,t){await d(c(e,`reference`),{recursive:!0}),await h(c(e,`reference`,`manifest.json`),JSON.stringify(t,null,2),`utf8`)}async function Dn(e){let{appCwd:t,category:n,content:r,filename:i,mode:a=`append`}=e,o=c(t,`reference`,n);if(a===`replace`)try{await m(o,{recursive:!0,force:!0})}catch{}await d(o,{recursive:!0});let s=await wn(o),l=`${n}/${`${String(s).padStart(3,`0`)}-${Cn(i??`reference`)}.md`}`,u=`reference/${l}`;await h(c(t,u),r,`utf8`);let f=await Tn(t);return a===`replace`&&(f.files=f.files.filter(e=>e.category!==n)),f.files.push({path:l,category:n,writtenAt:new Date().toISOString()}),f.updatedAt=new Date().toISOString(),await En(t,f),{relativePath:u,category:n,seq:s}}async function On(e){let t=c(e,`reference`),n;try{n=await p(t)}catch{return{totalFiles:0,categories:{}}}let r={},i=0;for(let e of n){if(!Sn.includes(e))continue;let n;try{n=(await p(c(t,e))).filter(e=>e.endsWith(`.md`)).sort()}catch{continue}n.length>0&&(r[e]={count:n.length,files:n},i+=n.length)}return{totalFiles:i,categories:r}}async function kn(e){return(await On(e)).totalFiles>0}function An(e){let t=e?.log,n=e?.timeoutMs??5e3,r=null,i=null,a=null;return{onSessionStart(e){t?.info?.(`db-schema: session_start sessionId=${e??`unknown`}, clearing cache`),r=null,i=null,a=e??null},async getSchemaSummary(e){return e&&a!==null&&e!==a?(t?.warn?.(`db-schema: session changed without session_start: ${a} -> ${e}, resetting cache`),r=null,i=null,a=e):e&&a===null&&(a=e),r===null?i||(i=(async()=>{t?.info?.(`db-schema: fetching (timeout=${n}ms)`);try{let{stdout:e}=await jn(Mn(),n),i=Nn(e);if(i.length===0)return t?.info?.(`db-schema: empty, skip injection for this session`),r=``,null;let a=Pn(i);return r=a,t?.info?.(`db-schema: cached ${i.length} table(s), ${a.length} chars`),a}catch(e){let n=e instanceof Error?e.message:String(e);return t?.warn?.(`db-schema: fetch failed (will not retry this session): ${n}`),r=``,null}finally{i=null}})(),i):r===``?null:r}}}function jn(e,t){return new Promise((n,r)=>{let i=setTimeout(()=>r(Error(`timeout after ${t}ms`)),t);e.then(e=>{clearTimeout(i),n(e)},e=>{clearTimeout(i),r(e)})})}function Mn(){return new Promise((e,n)=>{t(`npx`,[`-y`,`@lark-apaas/miaoda-data-cli`,`db`,`schema`,`--json`],{timeout:3e4,maxBuffer:10*1024*1024},(t,r,i)=>{if(t)return n(Error(`execFile failed: ${t.message} | stderr: ${i?.slice(0,500)??``} | stdout: ${r?.slice(0,500)??``}`));e({stdout:r,stderr:i})})})}function Nn(e){let t=e.trim();if(!t)return[];let n=JSON.parse(t);return Array.isArray(n)?n:n&&typeof n==`object`&&n.tableName?[n]:[]}function Pn(e){return`【当前数据库表结构】\n${e.map(e=>{let t=e.fields.map(e=>`${e.fieldName}(${e.type})`).join(`, `),n=e.comment?` (${e.comment})`:``;return`- ${e.tableName}${n}: ${t}`}).join(`
8
+ `)}`}function Fn(){return`dev`}var In=H(B((e=>{Object.defineProperty(e,`__esModule`,{value:!0});var t=10,n=1e3,r=function(e){return JSON.stringify({ev_type:`batch`,list:e})};function i(e){var i=e.transport,a=e.endpoint,o=e.size,s=o===void 0?t:o,c=e.wait,l=c===void 0?n:c,u=[],d=0,f,p,m={getSize:function(){return s},getWait:function(){return l},setSize:function(e){s=e},setWait:function(e){l=e},getEndpoint:function(){return a},setEndpoint:function(e){a=e},send:function(e){u.push(e),u.length>=s&&h.call(this),clearTimeout(d),d=setTimeout(h.bind(this),l)},flush:function(){clearTimeout(d),h.call(this)},getBatchData:function(){return u.length?r(u):``},clear:function(){clearTimeout(d),u=[]},fail:function(e){f=e},success:function(e){p=e}};function h(){if(u.length){var e=this.getBatchData();i.post({url:a,data:e,fail:function(t){f&&f(t,e)},success:function(){p&&p(e)}}),u=[]}}return m}
9
+ /*! *****************************************************************************
10
+ Copyright (c) Microsoft Corporation.
11
+
12
+ Permission to use, copy, modify, and/or distribute this software for any
13
+ purpose with or without fee is hereby granted.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
16
+ REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
17
+ AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
18
+ INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
19
+ LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
20
+ OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
21
+ PERFORMANCE OF THIS SOFTWARE.
22
+ ***************************************************************************** */
23
+ var a=function(){return a=Object.assign||function(e){for(var t,n=1,r=arguments.length;n<r;n++)for(var i in t=arguments[n],t)Object.prototype.hasOwnProperty.call(t,i)&&(e[i]=t[i]);return e},a.apply(this,arguments)};function o(e){var t=typeof Symbol==`function`&&Symbol.iterator,n=t&&e[t],r=0;if(n)return n.call(e);if(e&&typeof e.length==`number`)return{next:function(){return e&&r>=e.length&&(e=void 0),{value:e&&e[r++],done:!e}}};throw TypeError(t?`Object is not iterable.`:`Symbol.iterator is not defined.`)}function s(e,t){var n=typeof Symbol==`function`&&e[Symbol.iterator];if(!n)return e;var r=n.call(e),i,a=[],o;try{for(;(t===void 0||t-- >0)&&!(i=r.next()).done;)a.push(i.value)}catch(e){o={error:e}}finally{try{i&&!i.done&&(n=r.return)&&n.call(r)}finally{if(o)throw o.error}}return a}function c(e,t,n){if(n||arguments.length===2)for(var r=0,i=t.length,a;r<i;r++)(a||!(r in t))&&(a||=Array.prototype.slice.call(t,0,r),a[r]=t[r]);return e.concat(a||Array.prototype.slice.call(t))}var l=function(){return{}};function u(e){return e}function d(e){return typeof e==`object`&&!!e}var f=Object.prototype;function p(e){return f.toString.call(e)===`[object Array]`}function m(e){return typeof e==`boolean`}function h(e){return typeof e==`number`}function g(e){return typeof e==`string`}function _(e,t){if(!p(e)||e.length===0)return!1;for(var n=0;n<e.length;){if(e[n]===t)return!0;n++}return!1}var v=function(e,t){if(!p(e))return e;var n=e.indexOf(t);if(n>=0){var r=e.slice();return r.splice(n,1),r}return e},y=function(e,t,n){for(var r,i,a=s(t.split(`.`)),o=a[0],c=a.slice(1);e&&c.length>0;)e=e[o],r=c,i=s(r),o=i[0],c=i.slice(1);if(e)return n(e,o)};function b(e){try{return g(e)?e:JSON.stringify(e)}catch(e){return`[FAILED_TO_STRINGIFY]:`+String(e)}}function x(){var e={},t={},n={set:function(r,i){return e[r]=i,t[r]=b(i),n},merge:function(r){return e=a(a({},e),r),Object.keys(r).forEach(function(e){t[e]=b(r[e])}),n},delete:function(r){return delete e[r],delete t[r],n},clear:function(){return e={},t={},n},get:function(e){return t[e]},toString:function(){return a({},t)}};return n}var S=function(){return``.padStart?function(e,t){return t===void 0&&(t=8),e.padStart(t,` `)}:function(e){return e}}(),C=0,w=function(){var e=[...arguments];console.error.apply(console,c([`[SDK]`,Date.now(),S(``+ C++)],s(e),!1))},T=0,E=function(){var e=[...arguments];console.warn.apply(console,c([`[SDK]`,Date.now(),S(``+ T++)],s(e),!1))},D=function(e){return Math.random()<Number(e)},O=function(e,t){return e<Number(t)},k=function(e){return function(t){for(var n=t,r=0;r<e.length&&n;r++)try{n=e[r](n)}catch(e){w(e)}return n}};function A(){for(var e=Array(16),t=0,n=0;n<16;n++)n&3||(t=Math.random()*4294967296),e[n]=t>>>((n&3)<<3)&255;return e}function j(e){for(var t=[],n=0;n<256;++n)t[n]=(n+256).toString(16).substr(1);var r=0,i=t;return[i[e[r++]],i[e[r++]],i[e[r++]],i[e[r++]],`-`,i[e[r++]],i[e[r++]],`-`,i[e[r++]],i[e[r++]],`-`,i[e[r++]],i[e[r++]],`-`,i[e[r++]],i[e[r++]],i[e[r++]],i[e[r++]],i[e[r++]],i[e[r++]]].join(``)}function M(){var e=A();return e[6]=e[6]&15|64,e[8]=e[8]&63|128,j(e)}function N(){var e=!1,t={},n=function(e){e.length&&e.forEach(function(e){try{e()}catch{}}),e.length=0},r=function(e){t[e]&&t[e].forEach(function(e){n(e[1])}),t[e]=void 0};return{set:function(r,i,a){t[r]?t[r].push([i,a]):t[r]=[[i,a]],e&&n(a)},has:function(e){return!!t[e]},remove:r,removeByEvType:function(e){Object.keys(t).forEach(function(r){t[r]&&t[r].forEach(function(t){t[0]===e&&n(t[1])})})},clear:function(){e=!0,Object.keys(t).forEach(function(e){r(e)})}}}var P=500,F=50;function I(e,t,n){if(t.push(n),!(t.length<P)){var r=t.splice(0,F);e.savePreStartDataToDb&&e.savePreStartDataToDb(r)}}function L(e){var t=e.getPreStartQueue();t.forEach(function(t){return e.build(t)}),t.length=0}var R=[`init`,`start`,`config`,`beforeDestroy`,`provide`,`beforeReport`,`report`,`beforeBuild`,`build`,`beforeSend`,`send`,`beforeConfig`];function z(e){var t=e.builder,n=e.createSender,r=e.createDefaultConfig,i=e.createConfigManager,a=e.userConfigNormalizer,o=e.initConfigNormalizer,l=e.validateInitConfig,u,f,p={};R.forEach(function(e){return p[e]=[]});var m=!1,h=!1,g=!1,y=[],b=[],x=N(),S={getBuilder:function(){return t},getSender:function(){return u},getPreStartQueue:function(){return y},init:function(e){if(m){E(`already inited`);return}if(e&&d(e)&&l(e)){var t=r(e);if(!t)throw Error(`defaultConfig missing`);var a=o(e);if(f=i(t),f.setConfig(a),f.onChange(function(){C(`config`)}),u=n(f.getConfig()),!u)throw Error(`sender missing`);m=!0,C(`init`,!0)}else throw Error(`invalid InitConfig, init failed`)},set:function(e){m&&e&&d(e)&&(C(`beforeConfig`,!1,e),f?.setConfig(e))},config:function(e){if(m)return e&&d(e)&&(C(`beforeConfig`,!1,e),f?.setConfig(a(e))),f?.getConfig()},provide:function(e,t){if(_(b,e)){E(`cannot provide `+e+`, reserved`);return}S[e]=t,C(`provide`,!1,e)},start:function(){m&&(h||f?.onReady(function(){h=!0,C(`start`,!0),L(S)}))},report:function(e){if(e){var t=k(p.beforeReport)(e);if(t){var n=k(p.report)(t);n&&(h?this.build(n):I(S,y,n))}}},build:function(e){if(h){var n=k(p.beforeBuild)(e);if(n){var r=t.build(n);if(r){var i=k(p.build)(r);i&&this.send(i)}}}},send:function(e){if(h){var t=k(p.beforeSend)(e);t&&(u.send(t),C(`send`,!1,t))}},destroy:function(){x.clear(),g=!0,y.length=0,C(`beforeDestroy`,!0)},on:function(e,t){if(e===`init`&&m||e===`start`&&h||e===`beforeDestroy`&&g)try{t()}catch{}else p[e]&&p[e].push(t)},off:function(e,t){p[e]&&(p[e]=v(p[e],t))},destroyAgent:x};return b=Object.keys(S),S;function C(e,t){t===void 0&&(t=!1);var n=[...arguments].slice(2);p[e].forEach(function(e){try{e.apply(void 0,c([],s(n),!1))}catch{}}),t&&(p[e].length=0)}}var B=function(e){var t=x();e.provide(`context`,t),e.on(`report`,function(e){return e.extra||={},e.extra.context=t.toString(),e})};function V(e,t){e.on(`init`,function(){var n=[],r=function(r){r.forEach(function(r){var i=r.name;_(n,i)||(n.push(i),r.setup(e),t&&t(i,r.setup),e.destroyAgent.set(i,i,[function(){n=v(n,i),r.tearDown&&r.tearDown()}]))})};e.provide(`applyIntegrations`,r);var i=e.config();i&&i.integrations&&r(i.integrations)})}var H=function(e){try{typeof window==`object`&&d(window)&&window.__SLARDAR_DEVTOOLS_GLOBAL_HOOK__&&window.__SLARDAR_DEVTOOLS_GLOBAL_HOOK__.push(e)}catch{}},U=function(){return Date.now()};function W(){if(typeof window==`object`&&d(window))return window}var G=function(e){if(e)return e.__SLARDAR_REGISTRY__||={Slardar:{plugins:[],errors:[],subject:{}}},e.__SLARDAR_REGISTRY__.Slardar},K=function(){var e=[...arguments],t=G(W());t&&(t.errors||=[],t.errors.push(e))},q=function(e){var t;if(!(typeof window!=`object`||!window.__perfsee__)){var n={};return(t=Error.captureStackTrace)==null||t.call(Error,n,e),n.stack}},J=`custom`,ee=`event`,Y=`log`,X=function(e){if(!(!e||!d(e))&&!(!e.name||!g(e.name))){var t={name:e.name,type:ee};if(`metrics`in e&&d(e.metrics)){var n=e.metrics,r={};for(var i in n)h(n[i])&&(r[i]=n[i]);t.metrics=r}if(`categories`in e&&d(e.categories)){var a=e.categories,o={};for(var i in a)o[i]=b(a[i]);t.categories=o}return`attached_log`in e&&g(e.attached_log)&&(t.attached_log=e.attached_log),t}},Z=function(e){if(!(!e||!d(e))&&!(!e.content||!g(e.content))){var t=e.content,n={content:b(t),type:Y,level:`info`};if(`level`in e&&(n.level=e.level),`extra`in e&&d(e.extra)){var r=e.extra,i={},a={};for(var o in r)h(r[o])?i[o]=r[o]:a[o]=b(r[o]);n.metrics=i,n.categories=a}return`attached_log`in e&&g(e.attached_log)&&(n.attached_log=e.attached_log),n}},te=function(e){var t=function(n){var r=X(n);if(r){var i=q(t);i&&(r.stacks=i),e.report({ev_type:J,payload:r,extra:{timestamp:U()}})}};e.provide(`sendEvent`,t),e.provide(`sendLog`,function(t){var n=Z(t);n&&e.report({ev_type:J,payload:n,extra:{timestamp:U()}})})},ne=function(e,t){var n=e.common||{};return n.sample_rate=t,e.common=n,e},re=function(e,t,n,r,i){return e?(function(e){return function(){return e}})(i(r,t)):function(){return n(t)}},ie=function(e,t){return e.map(function(e){switch(t){case`number`:return Number(e);case`boolean`:return e===`1`;default:return String(e)}})},ae=function(e,t,n){switch(n){case`eq`:return _(t,e);case`neq`:return!_(t,e);case`gt`:return e>t[0];case`gte`:return e>=t[0];case`lt`:return e<t[0];case`lte`:return e<=t[0];case`regex`:return!!e.match(new RegExp(t.join(`|`)));case`not_regex`:return!e.match(new RegExp(t.join(`|`)));default:return!1}},oe=function(e,t,n,r){var i=y(e,t,function(e,t){return e[t]});return i===void 0?!1:ae(i,ie(r,m(i)?`bool`:h(i)?`number`:`string`),n)},se=function(e,t){try{return t.type===`rule`?oe(e,t.field,t.op,t.values):t.type===`and`?t.children.every(function(t){return se(e,t)}):t.children.some(function(t){return se(e,t)})}catch(e){return K(e),!1}},ce=function(e,t,n,r,i,a){var o={};return Object.keys(e).forEach(function(s){var c=e[s],l=c.enable,u=c.sample_rate,d=c.conditional_sample_rules;l?(o[s]={enable:l,sample_rate:u,effectiveSampleRate:u*n,hit:re(t,u,r,i,a)},d&&(o[s].conditional_hit_rules=d.map(function(e){var o=e.sample_rate,s=e.filter;return{sample_rate:o,hit:re(t,o,r,i,a),effectiveSampleRate:o*n,filter:s}}))):o[s]={enable:l,hit:function(){return!1},sample_rate:0,effectiveSampleRate:0}}),o},le=function(e,t,n,r,i){if(!t)return u;var a=t.sample_rate,o=t.include_users,s=t.sample_granularity,c=t.rules,l=t.r,d=l===void 0?Math.random():l;if(_(o,e))return function(e){return ne(e,1)};var f=s===`session`,p=re(f,a,n,d,r),m=ce(c,f,a,n,d,r);return function(e){if(!p())return f&&i[0](),!1;if(!(e.ev_type in m))return ne(e,a);if(!m[e.ev_type].enable)return f&&i[1](e.ev_type),!1;if(e.common?.sample_rate)return e;var t=m[e.ev_type],n=t.conditional_hit_rules;if(n){for(var r=0;r<n.length;r++)if(se(e,n[r].filter))return n[r].hit()?ne(e,n[r].effectiveSampleRate):!1}return t.hit()?ne(e,t.effectiveSampleRate):(!(n&&n.length)&&f&&i[1](e.ev_type),!1)}},ue=function(e){e.on(`start`,function(){var t=e.config(),n=t.userId,r=t.sample,i=le(n,r,D,O,[function(){e.destroy()},function(t){e.destroyAgent.removeByEvType(t)}]);e.on(`build`,i)})},de={build:function(e){return{ev_type:e.ev_type,payload:e.payload,common:a(a({},e.extra||{}),e.overrides||{})}}},fe=`mon.zijieapi.com`,pe=fe,me=`2.1.8`,he=`SDK_BASE`,ge=`/monitor_web/settings/browser-settings`,_e=`/monitor_browser/collect/batch/`,ve={sample_rate:1,include_users:[],sample_granularity:`session`,rules:{}},ye=20,be=`session`;function xe(e){var t,n,r=[`userId`,`deviceId`,`sessionId`,`env`];try{for(var i=o(r),a=i.next();!a.done;a=i.next()){var s=a.value;e[s]||delete e[s]}}catch(e){t={error:e}}finally{try{a&&!a.done&&(n=i.return)&&n.call(i)}finally{if(t)throw t.error}}return e}function Se(e){return xe(a({},e))}function Ce(e){return d(e)&&`bid`in e&&`transport`in e}function we(e){return xe(a({},e))}function Te(e){if(!e)return{};var t=e.sample,n=e.timestamp,r=e.quota_rate,i=r===void 0?1:r;if(!t)return{};var a=t.sample_rate,o=t.sample_granularity,s=o===void 0?be:o,c=t.include_users,l=t.rules,u=l===void 0?[]:l;return{sample:{include_users:c,sample_rate:a*i,sample_granularity:s,rules:u.reduce(function(e,t){var n=t.name;return e[n]={enable:t.enable,sample_rate:t.sample_rate,conditional_sample_rules:t.conditional_sample_rules},e},{})},serverTimestamp:n}}var Ee=function(e,t){return t===void 0&&(t=_e),(e&&e.indexOf(`//`)>=0?``:`https://`)+e+t},De=function(e,t){return t===void 0&&(t=ge),(e&&e.indexOf(`//`)>=0?``:`https://`)+e+t},Oe=function(){return M()},ke=function(){return M()},Ae=function(e){return e+`_`+Date.now()},je=function(){return M()},Me=function(e){var t=e,n,r={},i,o,s=l,c=l;return{getConfig:function(){return t},setConfig:function(e){return r=a(a({},r),e||{}),u(),n||(n=e,t.useLocalConfig||!t.bid?(o={},s()):Ne(t.transport,t.domain,t.bid,function(e){i=e,d()})),t},onChange:function(e){c=e},onReady:function(e){s=e,o&&s()}};function u(){var n=a(a(a({},e),o||{}),r);n.sample=Pe(Pe(e.sample,o?.sample),r.sample),t=n,c()}function d(){o=Te(i),u(),s()}};function Ne(e,t,n,r){if(!e.get)return r({});e.get({withCredentials:!0,url:De(t)+`?bid=`+n+`&store=1`,success:function(e){r(e.data||{})},fail:function(){r({sample:{sample_rate:.001}})}})}function Pe(e,t){if(!e||!t)return e||t;var n=a(a({},e),t);return n.include_users=c(c([],s(e.include_users||[]),!1),s(t.include_users||[]),!1),n.rules=c(c([],s(Object.keys(e.rules||{})),!1),s(Object.keys(t.rules||{})),!1).reduce(function(n,r){return r in n||(r in(e.rules||{})&&r in(t.rules||{})?(n[r]=a(a({},e.rules[r]),t.rules[r]),n[r].conditional_sample_rules=c(c([],s(e.rules[r].conditional_sample_rules||[]),!1),s(t.rules[r].conditional_sample_rules||[]),!1)):n[r]=e.rules?.[r]||t.rules?.[r]),n},{}),n}var Fe=function(e,t){var n=t||{},r=n.version,i=n.name,o={url:``,protocol:``,domain:``,path:``,query:``,timestamp:Date.now(),sdk_version:r||me,sdk_name:i||he};return a(a({},e),{extra:a(a({},o),e.extra||{})})},Ie=function(e){e.on(`report`,function(t){return Fe(t,e.config())})},Le=function(e,t){var n={};return n.bid=t.bid,n.pid=t.pid,n.view_id=t.viewId,n.user_id=t.userId,n.device_id=t.deviceId,n.session_id=t.sessionId,n.release=t.release,n.env=t.env,a(a({},e),{extra:a(a({},n),e.extra||{})})},Re=function(e){e.on(`beforeBuild`,function(t){return Le(t,e.config())})};function ze(e){return i(e)}var Be=function(e){return{bid:``,pid:``,viewId:Ae(`_`),userId:Oe(),deviceId:ke(),sessionId:je(),domain:fe,release:``,env:`production`,sample:ve,plugins:{},transport:{get:l,post:l},useLocalConfig:!1}},Ve=function(e){var t=e===void 0?{}:e,n=t.createSender,r=n===void 0?function(e){return ze({size:ye,endpoint:Ee(e.domain),transport:e.transport})}:n,i=t.builder,a=i===void 0?de:i,o=t.createDefaultConfig,s=z({validateInitConfig:Ce,initConfigNormalizer:Se,userConfigNormalizer:we,createSender:r,builder:a,createDefaultConfig:o===void 0?Be:o,createConfigManager:Me});return B(s),Re(s),Ie(s),V(s),H(s),s},He=function(e){e===void 0&&(e={});var t=Ve(e);return ue(t),te(t),t},Ue=He();e.BATCH_REPORT_PATH=_e,e.CustomPlugin=te,e.DEFAULT_SAMPLE_CONFIG=ve,e.DEFAULT_SAMPLE_GRANULARITY=be,e.DEFAULT_SENDER_SIZE=ye,e.InjectConfigPlugin=Re,e.InjectEnvPlugin=Ie,e.REPORT_DOMAIN=fe,e.SDK_NAME=he,e.SDK_VERSION=me,e.SETTINGS_DOMAIN=pe,e.SETTINGS_PATH=ge,e.addConfigToReportEvent=Le,e.addEnvToSendEvent=Fe,e.builder=de,e.createBaseClient=He,e.createConfigManager=Me,e.createMinimalClient=Ve,e.default=Ue,e.getDefaultConfig=Be,e.getDefaultDeviceId=ke,e.getDefaultSessionId=je,e.getDefaultUserId=Oe,e.getReportUrl=Ee,e.getServerConfig=Ne,e.getSettingsUrl=De,e.getViewId=Ae,e.mergeSampleConfig=Pe,e.normalizeInitConfig=Se,e.normalizeStrictFields=xe,e.normalizeUserConfig=we,e.parseServerConfig=Te,e.validateInitConfig=Ce}))(),1);function Ln(e){return!e||typeof e!=`object`||!(`default`in e)?e:e.default}function Rn(e){let t=Ln(e);return Ln(t)??t??e??{}}const zn=Rn(In.default);let Bn=!1;function Vn(){if(!Bn)try{let e=Vt();zn.init({bid:`apaas_miaoda`,release:String(e.version??`unknown`),env:Fn(),transport:{get:({url:e,success:t,fail:n})=>fetch(e).then(e=>e.json()).then(e=>t?.(e)).catch(e=>n?.(e)),post:({url:e,data:t})=>{let n=typeof t==`string`?t:JSON.stringify(t);return fetch(e,{method:`POST`,headers:{"Content-Type":`application/json`},body:n}).catch(()=>{})}}}),zn.start(),Bn=!0}catch{}}function Hn(e){if(e!==void 0)return String(e)}function Un(e){let t={source:`node-plugin`},n=e.traceId,r=e.projectId,i=Hn(e.isNew),a=e.appId,o=e.agentId,s=e.sessionKey;return n&&(t.trace_id=n),r&&(t.project_id=r),i&&(t.is_new=i),a&&(t.app_id=a),o&&(t.agent_id=o),e.domain&&(t.domain=e.domain),s&&(t.session_key=s),t}function Wn(e,t){let n={...e};for(let[e,r]of Object.entries(t??{}))r!=null&&(n[e]=typeof r==`boolean`?String(r):r);return n}function Gn(e){switch(e){case`user_stopped`:return`user_stopped`;case`quota_exceeded`:return`quota_exceeded`;case`service_failed`:return`service_failed`;case`stream_interrupted`:return`stream_interrupted`;default:return}}function Kn(e){return e===`user_stopped`||e===`quota_exceeded`}function qn(e){try{let t={},n=Un(e),r=e.durationMs,i=e.sseEventCount,a=e.reconnectCount,o=e.createDurationMs;typeof r==`number`&&(t.duration_ms=r),typeof i==`number`&&(t.sse_event_count=i),typeof a==`number`&&(t.reconnect_count=a),typeof o==`number`&&(t.create_duration_ms=o);let s={...n,status:e.status,is_new:n.is_new??`false`},c=e.errorType;e.phase&&(s.phase=e.phase),c&&(s.error_type=c.slice(0,100)),e.terminalReason&&(s.terminal_reason=e.terminalReason.slice(0,100)),e.errorCode&&(s.error_code=e.errorCode.slice(0,100)),zn.sendEvent?.({name:`miaoda_coding_task`,metrics:t,categories:s})}catch{}}function Jn(e){try{let t={},n=Un(e);typeof e.durationMs==`number`&&(t.duration_ms=e.durationMs),typeof e.sseEventCount==`number`&&(t.sse_event_count=e.sseEventCount),typeof e.reconnectCount==`number`&&(t.reconnect_count=e.reconnectCount);let r={...n,request_name:e.requestName,status:e.status};e.logId&&(r.log_id=e.logId),e.phase&&(r.phase=e.phase),e.errorType&&(r.error_type=e.errorType.slice(0,100)),e.terminalReason&&(r.terminal_reason=e.terminalReason.slice(0,100)),e.errorCode&&(r.error_code=e.errorCode.slice(0,100)),zn.sendEvent?.({name:`miaoda_coding_request`,metrics:t,categories:r})}catch{}}function Yn(e){try{if(!e.projectId)return;let t=Wn(Un(e),{event:e.event,phase:e.phase}),n=e.logIds;n?.length&&(t.log_ids=n.join(`,`)),zn.sendLog?.({content:e.error,level:`error`,extra:t})}catch{}}function $(e){try{let t=Wn(Un(e),{event:e.event,phase:e.phase,status:e.status,...e.extra});zn.sendLog?.({content:e.message,level:e.level??`info`,extra:t})}catch{}}const Xn=/^[a-z0-9][a-z0-9-]{0,63}$/,Zn=new Set([`.`,`..`,`con`,`nul`,`prn`,`aux`]);function Qn(e){let t=e?.config?.plugins?.entries?.[`openclaw-extension-miaoda-coding`]?.config??{};return{verbose:t?.verbose===!0,hooks:{allowPromptInjection:t?.hooks?.allowPromptInjection!==!1}}}function $n(e,t){i.mkdirSync(o.dirname(e),{recursive:!0});let n=`${e}.tmp.${process.pid}.${Date.now()}`;try{i.writeFileSync(n,JSON.stringify(t,null,2)),i.renameSync(n,e)}catch(e){try{i.unlinkSync(n)}catch{}throw e}}function er(e){try{$n(e,{});return}catch(t){try{i.unlinkSync(e);return}catch(e){if(e?.code===`ENOENT`)return;throw t}}}function tr(e,t){if(!e)return;let r=o.dirname(process.execPath),i=n(`openclaw`,[`message`,`send`,`--channel`,`feishu`,`--target`,e,`--message`,t],{stdio:[`ignore`,`ignore`,`pipe`],env:{...process.env,PATH:`${r}:${process.env.PATH||``}`}});i.stderr.on(`data`,()=>{}),i.on(`close`,()=>{}),i.unref()}function nr(e){return String(e??``).replace(/[\u0000-\u0008\u000B\u000C\u000E-\u001F\u007F]/g,``).replace(/\s+/g,` `).trim()}function rr(e){let t=String(e??``).replace(/[\u0000-\u0008\u000B\u000C\u000E-\u001F\u007F]/g,``).trim();if(!t)throw Error(`task 不能为空`);if(t.length>4e3)throw Error(`task 不能超过 4000 个字符`);return t}function ir(e){let t=nr(e);if(!ar(t))throw Error(`project_id 不合法: "${t}"`);return t}function ar(e){return Xn.test(e)&&!Zn.has(e)}function or(e){if(e==null||e===``)return;let t=nr(e);if(t!==`none`){if(!/^(user|chat|thread):\S+$/.test(t))throw Error(`target 不合法`);return t}}function sr(e,t){let n=K(e,t);if(i.existsSync(n))return n;let r=q(e,t);return i.existsSync(r)?r:n}function cr(e){let t=new Map,n=o.join(e,`app`);try{for(let e of i.readdirSync(n,{withFileTypes:!0}))!e.isDirectory()||!ar(e.name)||t.set(e.name,o.join(n,e.name))}catch{}try{for(let n of i.readdirSync(e,{withFileTypes:!0}))!n.isDirectory()||n.name===`app`||!ar(n.name)||t.has(n.name)||t.set(n.name,o.join(e,n.name))}catch{}return[...t.entries()].map(([e,t])=>({projectId:e,appCwd:t}))}function lr(e){try{return i.readFileSync(e,`utf8`).split(`
24
+ `).map(e=>e.trim()).filter(Boolean)}catch{return[]}}function ur(e){return e.replace(/^\[[^\]]+\]\s*/,``)}function dr(e){return e.replace(/应用已创建(appId:\s*[^)]+)/g,`应用已创建`)}function fr(e){return e.slice(-3).map(ur).map(dr).join(` | `)||`暂无进度记录`}function pr(e){let t=fr(e);return t.includes(`失败:`)?`failed`:t.includes(`处理完成`)?`completed`:t===`暂无进度记录`?`pending`:`running`}function mr(e){try{let t=JSON.parse(i.readFileSync(o.join(e,`.spark`,`meta.json`),`utf8`));return typeof t?.appId==`string`&&t.appId.trim().length>0}catch{return!1}}var hr={id:`openclaw-extension-miaoda-coding`,name:`妙搭`,description:`妙搭制品创建与修改`,register(e){let t=`[miaoda-coding]`,n={info:n=>e.logger.info?.(`${t} ${n}`),warn:n=>e.logger.warn?.(`${t} ${n}`),error:n=>e.logger.error?.(`${t} ${n}`)},a={verbose:!1,hooks:{allowPromptInjection:!0}},s=An({log:n});n.info(`plugin registered`),Vn(),e.on(`session_start`,(e,t)=>{try{s.onSessionStart(e?.sessionId)}catch(e){n.warn(`session_start reset failed: ${String(e)}`)}});let c=new Set([`miaoda_coding`]),l=new Set([`miaoda_check_progress`]);e.on(`before_tool_call`,(e,t)=>{let r=e.toolName,i=t?.sessionKey??``,a=i.toLowerCase().split(`:`).includes(`subagent`);if(c.has(r)&&!a)return n.warn(`blocked ${r} from non-subagent session: ${i}`),{block:!0,blockReason:`${r} 只能由 subagent 调用。请通过 sessions_spawn(runtime="subagent", mode="run") 派活,不要直接调用此工具。读 miaoda-coding skill 了解完整流程。`};if(l.has(r)&&a)return n.warn(`blocked ${r} from subagent session: ${i}`),{block:!0,blockReason:`${r} 不能由 subagent 调用。subagent 不应直接操作参考资料或查询进度。`}}),e.on(`before_prompt_build`,async(e,t)=>{if(!Qn(t).hooks.allowPromptInjection)return;let r={prependSystemContext:[`【硬规则 — 妙搭】`,`当用户要求创建或修改应用、网页、页面时,必须通过 sessions_spawn(runtime="subagent", mode="run") 交给妙搭。`,`读 miaoda-coding skill 后严格按指示操作。只传 runtime、mode、task 三个参数,不要传 streamTo/sandbox 等。`,`如果需求在支持范围内并且已经派活给 subagent,最终回复只发一条简短总结;是否附上预览链接严格按 miaoda-coding skill 第 6 条(读 .spark/delivery.json 和 .spark/meta.json)判断,不要自行决定;不要把"不适用场景"的主站引导规则误用到正常交付场景。`,`绝对不要自己写代码或用 exec 生成文件。如果 sessions_spawn 调用本身返回错误,去掉多余参数后重试。如果 subagent 执行失败需要重试,generation_request 填"继续"(不要重复发完整需求),详见 skill 中的重试流程。`,`如果对话中有需要传递给 code agent 的上下文(研究结果、用户偏好等),先调 miaoda_write_reference 写入 reference 目录,再 spawn。用户反悔或需要替换之前的上下文时,使用 miaoda_write_reference 的 mode=replace。妙搭只做制品生成,不做研究。`,`不要用 sessions_history 读取子 agent 的 session,查进度用 miaoda_check_progress tool(仅限建应用场景,数据库操作等不要用)。`,`subagent 完成后只发一条总结消息,严禁发多条。是否带预览链接严格按 miaoda-coding skill 第 6 条的 delivery.json/meta.json 判断流程,不要自己决定。不要调 message tool。`].join(` `)};try{let e=await s.getSchemaSummary(t?.sessionId);e&&(r.appendSystemContext=e)}catch(e){n.error(`db schema injection threw unexpected error: ${String(e)}`)}return r}),e.registerTool(e=>{let t=J(e);return{name:`list_projects`,label:`列出妙搭项目`,description:`列出已创建的妙搭项目,返回 project_id、appId、updatedAt、finalText、status 和进度摘要。修改已有项目时必须先调此工具。`,parameters:{type:`object`,properties:{}},async execute(){let e=[];try{e=cr(t.workspaceDir).map(({projectId:e,appCwd:t})=>{let n=o.join(t,`.spark`,`meta.json`),r=o.join(t,`.spark`,`progress.txt`),a=null;try{a=JSON.parse(i.readFileSync(n,`utf8`))}catch{}let s=lr(r);return{project_id:e,appId:a?.appId??null,updatedAt:a?.updatedAt??null,finalText:a?.finalText??null,status:pr(s),progressSummary:fr(s)}})}catch{}return{content:[{type:`text`,text:JSON.stringify({projects:e},null,2)}]}}}}),e.registerTool(e=>{let t=J(e);return{name:`miaoda_check_progress`,label:`查看妙搭应用生成进度`,description:`查看通过 miaoda_coding 创建的应用的生成进度。仅用于 sessions_spawn 派活建应用后查看进度,不适用于数据库操作等其他场景。`,parameters:{type:`object`,properties:{project_id:{type:`string`,description:`项目目录名(从 list_projects 获取)`}},required:[`project_id`]},async execute(e,n){try{let e=ir(n.project_id),r=sr(t.workspaceDir,e),a=o.join(r,`.spark`,`progress.txt`),s=i.readFileSync(a,`utf8`).trim().split(`
25
+ `).filter(Boolean),c=null;try{c=JSON.parse(i.readFileSync(o.join(r,`.spark`,`meta.json`),`utf8`))}catch{}let l=!!c?.finalText,u=s.slice(-20).map(dr).join(`
26
+ `);return{content:[{type:`text`,text:JSON.stringify({status:`ok`,project_id:e,lines:s.length,progress:u,delivery_ready:l,finalTextAvailable:l,note:`miaoda_check_progress 只用于查看进度,不能根据 appId 或进度文本推导预览链接;最终链接只以 subagent completion result 中的 output/finalText 为准。`})}]}}catch{return{content:[{type:`text`,text:JSON.stringify({status:`no_progress`,project_id:n.project_id,message:`暂无进度记录`,delivery_ready:!1,finalTextAvailable:!1,note:`miaoda_check_progress 只用于查看进度,不能根据 appId 或进度文本推导预览链接;最终链接只以 subagent completion result 中的 output/finalText 为准。`})}]}}}}}),e.registerTool(e=>{let t=J(e);return{name:`miaoda_write_reference`,label:`写入妙搭参考资料`,description:`将参考资料写入妙搭项目的 reference 目录,供 code agent 在生成时自行查阅。按 category 分类写入。mode=append(默认)追加,mode=replace 替换该 category 全部内容(用于反悔/调整场景)。`,parameters:{type:`object`,properties:{project_id:{type:`string`,description:`项目目录名`},category:{type:`string`,enum:[`research`,`design`,`feedback`],description:`资料类别:research(调研结果)、design(设计要求)、feedback(用户反馈)`},content:{type:`string`,description:`参考资料内容(Markdown 格式,摘要+关键原文引用)`},filename:{type:`string`,description:`可选文件名(不含扩展名)`},mode:{type:`string`,enum:[`append`,`replace`],description:`写入模式:append(追加,默认)、replace(替换该 category 全部内容)`}},required:[`project_id`,`category`,`content`]},async execute(e,n){try{let e=ir(n.project_id);if(!Sn.includes(n.category))throw Error(`category 不合法,必须是 ${Sn.join(`、`)} 之一`);let r=n.content?.trim();if(!r)throw Error(`content 不能为空`);if(r.length>5e4)throw Error(`content 不能超过 50000 个字符`);let i=n.mode===`replace`?`replace`:`append`,a=sr(t.workspaceDir,e),o=await Dn({appCwd:a,category:n.category,content:r,filename:n.filename,mode:i}),s=await On(a);return{content:[{type:`text`,text:JSON.stringify({status:`ok`,...o,summary:s},null,2)}]}}catch(e){return{content:[{type:`text`,text:JSON.stringify({status:`error`,error:e instanceof Error?e.message:String(e)})}]}}}}});let u=3600*1e3;e.registerTool(e=>{let t=J(e),s=e.config?.channels?.feishu,c=e.agentAccountId,l=(c?s?.accounts?.[c]:void 0)?.appId??s?.appId;return n.info(`channelAppId resolved: ${l??`(none)`} (accountId=${c??`(none)`})`),{name:`miaoda_coding`,label:`妙搭`,description:`创建或修改妙搭应用/网页。只接受生成指令,不接受搜索/调研等任务。如有参考资料,应事先通过 miaoda_write_reference 写入 reference 目录。修改已有项目时必须先调 list_projects 获取 project_id。返回结构化 JSON(status/appId/finalText/output/meta)。`,parameters:{type:`object`,properties:{generation_request:{type:`string`,description:`生成指令(如'做一个学习网站,包含章节、题库、测验')`},project_id:{type:`string`,description:`本地项目目录名,仅允许小写字母、数字和短横线`},target:{type:`string`,description:`飞书消息推送目标:单聊用 user:ou_xxx,群聊用 chat:oc_xxx,非飞书渠道传 none`}},required:[`generation_request`,`project_id`,`target`]},async execute(s,c){let d=r();try{let r=Date.now(),s=rr(c.generation_request),f=ir(c.project_id),p=or(c.target),m=process.env.FORCE_AUTHN_INNERAPI_DOMAIN,h=sr(t.workspaceDir,f);i.mkdirSync(h,{recursive:!0});let g=!mr(h),_={traceId:d,projectId:f,isNew:g,agentId:t.agentId,domain:m,sessionKey:e?.sessionKey};n.info(`miaoda_coding called (project=${f}, isNew=${g}, traceId=${d})`),$({..._,event:`start`,message:`miaoda_coding started for ${f}`,extra:{target:p??`none`}});let v=o.join(h,`.spark`,`delivery.json`);try{er(v)}catch(e){throw n.error(`failed to reset delivery marker (project=${f}, traceId=${d}): ${String(e)}`),$({..._,event:`miaoda_coding_delivery_marker_reset_failed`,message:`aborting run — unable to establish clean delivery.json state`,level:`error`,extra:{error:String(e)}}),Error(`无法初始化投递状态文件: ${String(e)}`)}g&&$({..._,event:`create_start`,message:`createSubApp started for ${f}`});let y=await kn(h)?`工作目录下有 reference/ 目录,包含参考资料,请先查阅再开始工作。\n\n${s}`:s,b=o.join(h,`.agent`);if(!i.existsSync(b)){let e=G(W());if(i.existsSync(e))try{i.symlinkSync(e,b)}catch{}}let x=[],S,C=!1,w,T,E,D,O,k,A=!1,j=null,M=g?Date.now():void 0,N=g?void 0:Date.now(),P=new AbortController,F=setTimeout(()=>P.abort(),u);try{for await(let e of xn({cwd:h,rootDir:W(),task:y,requestText:s,traceId:d,agentId:t.agentId,channelAppId:l,signal:P.signal,onReconnect:(e,t)=>{n.warn(`stream reconnect (project=${f}, attempt=${e}, lastEventId=${t??`none`}, traceId=${d})`),$({..._,event:`stream_reconnect`,message:`stream reconnect for ${f}`,level:`warn`,extra:{attempt:e,last_event_id:t??`none`}})},onStreamFailed:e=>{n.error(`stream failed (project=${f}, traceId=${d}): ${e}`),$({..._,event:`stream_failed`,message:String(e),level:`error`})}})){if(`logId`in e&&e.logId&&x.push(e.logId),a.verbose&&p)switch(e.type){case`app_created`:tr(p,`应用已创建(appId: ${e.appId})`);break;case`failed`:tr(p,`处理失败: ${e.error}`);break}if(e.type===`completed`){let t=e.terminalReason??`completed`;j={appId:e.appId,finalText:e.finalText},w=t,T=e.sseEventCount,E=e.reconnectCount,D=e.finishReasonRaw,O=e.errorCodeRaw,k=e.lastEventId,Jn({..._,requestName:`stream_chat`,status:`ok`,appId:e.appId,logId:e.logId,phase:`stream`,durationMs:N?Date.now()-N:void 0,terminalReason:t,sseEventCount:e.sseEventCount,reconnectCount:e.reconnectCount}),$({..._,event:`stream_completed`,message:`streamChat completed for ${f}`,appId:e.appId,extra:{log_id:e.logId??`none`}}),$({..._,event:`stream_terminal`,message:`stream terminal: ${t}`,appId:e.appId,extra:{terminal_reason:t,finish_reason_raw:e.finishReasonRaw??`none`,last_event_id:e.lastEventId??`none`,reconnect_count:e.reconnectCount??0,sse_event_count:e.sseEventCount??0,log_id:e.logId??`none`}})}if(e.type===`app_created`&&(Jn({..._,requestName:`create_sub_app`,status:`ok`,appId:e.appId,logId:e.logId,phase:`create`,durationMs:M?Date.now()-M:void 0}),N=Date.now(),$({..._,event:`create_succeeded`,message:`createSubApp completed for ${f}`,appId:e.appId,extra:{log_id:e.logId,conversation_id:e.conversationId??`none`}})),e.type===`failed`){let t=e.terminalReason??(e.retryable?`stream_interrupted`:`service_failed`);if(S=e.error,C=e.retryable??!1,w=t,T=e.sseEventCount??T,E=e.reconnectCount??E,D=e.finishReasonRaw??D,O=e.errorCodeRaw??O,k=e.lastEventId??k,e.phase===`pre-create`){n.error(`pre-create validation failed (project=${f}): ${e.error}`),clearTimeout(F),qn({..._,status:`error`,phase:`pre-create`,appId:null,durationMs:Date.now()-r}),$({..._,event:`pre_create_validation_failed`,message:e.error,level:`error`,phase:`pre-create`});let t={status:`error`,project_id:f,appId:null,error:e.error,meta:null,hint:`这是运行环境配置问题,不是用户操作失误。直接将 error 字段内容告知用户,并说明需要联系管理员修复配置;不要建议换 project_id,不要重试`};return{content:[{type:`text`,text:JSON.stringify(t)}]}}if(e.phase===`create`){n.error(`createSubApp failed (project=${f}, traceId=${d}): ${e.error}`);let t=!!p;if(p){let t=e.userFacing?e.error:`createSubApp 失败: ${e.error}`;n.info(`delivering create error via feishu (project=${f}, target=${p}, traceId=${d})`),tr(p,t)}else n.warn(`create failed but no target for feishu delivery (project=${f}, traceId=${d})`);let i=e.userFacing?{status:`error`,project_id:f,appId:null,meta:null,logIds:x.length?x:void 0,hint:t?`创建失败,详情已通过飞书发送给用户,不要重复发送错误内容`:`创建失败,将 error 字段的内容原样发送给用户,不要改写、不要删减、不要重试`,error:t?void 0:e.error}:{status:`error`,project_id:f,appId:null,error:e.error,meta:null,logIds:x.length?x:void 0,hint:t?`createSubApp 失败,错误已通过飞书发送。根据 error 内容用通俗语言告诉用户具体原因,不要重试`:`createSubApp 失败,根据 error 内容用通俗语言告诉用户具体原因,不要重试`};return qn({..._,status:`error`,phase:`create`,appId:null,durationMs:Date.now()-r}),Jn({..._,requestName:`create_sub_app`,status:`error`,appId:null,logId:e.logId,phase:`create`,durationMs:M?Date.now()-M:void 0,errorType:e.userFacing?`user_facing`:`request_failed`}),$({..._,event:`create_failed`,message:e.error,level:`error`,phase:`create`,extra:{delivered:t,log_id:e.logId??`none`,user_facing:e.userFacing??!1}}),t&&$({..._,event:`delivery_sent`,message:`create failure delivered via feishu`,level:`info`,extra:{target:p,delivery_type:`create_error`}}),{content:[{type:`text`,text:JSON.stringify(i)}]}}e.phase===`stream`&&(Jn({..._,requestName:`stream_chat`,status:`error`,appId:e.appId??j?.appId??null,logId:e.logId,phase:`stream`,durationMs:N?Date.now()-N:void 0,errorType:Gn(t)??(e.retryable?`stream_interrupted`:`service_failed`),terminalReason:t,errorCode:e.errorCodeRaw,sseEventCount:e.sseEventCount,reconnectCount:e.reconnectCount}),$({..._,event:`stream_terminal`,message:`stream terminal: ${t}`,level:Kn(t)?`info`:`error`,appId:e.appId??j?.appId??null,extra:{terminal_reason:t,finish_reason_raw:e.finishReasonRaw??`none`,error_code_raw:e.errorCodeRaw??`none`,last_event_id:e.lastEventId??`none`,reconnect_count:e.reconnectCount??0,sse_event_count:e.sseEventCount??0,log_id:e.logId??`none`}}))}}}catch(e){if(!P.signal.aborted)throw e}finally{clearTimeout(F)}A=P.signal.aborted;let I=null;try{I=JSON.parse(i.readFileSync(o.join(h,`.spark`,`meta.json`),`utf8`))}catch{}let L={status:A?`timeout`:S?`error`:`ok`,project_id:f,appId:j?.appId??I?.appId??null,finalText:j?.finalText??I?.finalText,output:j?.finalText??I?.finalText,logIds:x.length?x:void 0,meta:I};if(n.info(`miaoda_coding done (project=${f}, status=${L.status}, logIds=${x.join(`,`)}, traceId=${d})`),qn({..._,status:L.status,projectId:f,appId:L.appId,durationMs:Date.now()-r,phase:L.status===`ok`||w?`stream`:void 0,errorType:Gn(w),terminalReason:w,errorCode:O,sseEventCount:T,reconnectCount:E}),$({..._,event:`task_done`,message:`miaoda_coding completed for ${f}`,status:L.status,appId:L.appId,extra:{last_log_id:x.at(-1)??`none`,log_id_count:x.length,terminal_reason:w??`none`,finish_reason_raw:D??`none`,error_code_raw:O??`none`,last_event_id:k??`none`}}),A?(L.error=`执行超时(${u/1e3}秒)`,L.retryable=!0,L.hint=`执行超时,任务可能仍在后台运行。建议先调用 miaoda_check_progress 查看进度,再决定是否重试`):S&&(L.error=S,C&&(L.retryable=!0,L.hint=`网络连接中断,任务可能已部分完成。建议先调用 miaoda_check_progress 查看当前状态,再决定下一步`)),L.status===`ok`&&!p&&(n.warn(`delivery skipped: target is missing (project=${f}, traceId=${d})`),$({..._,event:`delivery_skipped`,message:`preview link delivery skipped because target is missing (subagent passed none/empty)`,level:`warn`,appId:L.appId,extra:{reason:`missing_target`}})),p&&L.status===`ok`){let e=I?.appUrl;if(n.info(`delivery check (project=${f}, target=${p}, appUrl=${e??`missing`}, traceId=${d})`),typeof e==`string`&&e.trim()){let t=e.includes(`?`)?`&`:`?`,r=`${e.trim()}${t}mode=sidebar-semi`;tr(p,`**[${r}](${r})**`),n.info(`delivery sent (project=${f}, url=${r}, traceId=${d})`),$({..._,event:`delivery_sent`,message:`preview link delivered via feishu`,level:`info`,appId:L.appId,extra:{target:p,preview_url:r,delivery_type:`preview_link`}});try{$n(v,{deliveredAt:Date.now(),deliveredUrl:r,deliveredForTrace:d}),$({..._,event:`miaoda_coding_delivery_marker_written`,message:`delivery.json recorded successful feishu preview-link delivery`,level:`info`,appId:L.appId,extra:{preview_url:r}})}catch(e){n.warn(`failed to write delivery marker (project=${f}, traceId=${d}): ${String(e)}`),$({..._,event:`miaoda_coding_delivery_marker_write_failed`,message:`failed to write delivery.json after successful feishu delivery`,level:`warn`,appId:L.appId,extra:{error:String(e),preview_url:r}})}L.hint=`预览链接已自动发送给用户,announce 时不要再带预览链接`}else n.warn(`delivery skipped: no appUrl in meta.json (project=${f}, traceId=${d})`),$({..._,event:`delivery_skipped`,message:`preview link delivery skipped because appUrl is missing`,level:`warn`,appId:L.appId,extra:{target:p,reason:`missing_app_url`}})}return{content:[{type:`text`,text:JSON.stringify(L,null,2)}]}}catch(e){return Yn({error:e instanceof Error?e.message:String(e),event:`top_level_error`,traceId:d,projectId:c.project_id,agentId:t.agentId,domain:process.env.FORCE_AUTHN_INNERAPI_DOMAIN}),{content:[{type:`text`,text:JSON.stringify({status:`error`,error:e instanceof Error?e.message:String(e)})}]}}}}}),e.registerService({id:`miaoda-coding-config`,async start(e){a=Qn(e)},async stop(){}})}};export{hr as default};
package/package.json CHANGED
@@ -1,14 +1,16 @@
1
1
  {
2
2
  "name": "@lark-apaas/openclaw-extension-miaoda-coding",
3
- "version": "1.0.3-beta.6",
3
+ "version": "1.0.3-beta.8",
4
4
  "description": "妙搭 Coding Agent — 通过 AI 创建和修改妙搭应用",
5
5
  "type": "module",
6
6
  "scripts": {
7
- "build": "tsdown",
8
- "build:dev": "MINIFY=false tsdown",
7
+ "prepack": "MIAODA_SLARDAR_ENV=${MIAODA_SLARDAR_ENV:-dev} tsdown",
8
+ "build": "MIAODA_SLARDAR_ENV=online tsdown",
9
+ "build:dev": "MIAODA_SLARDAR_ENV=dev MINIFY=false tsdown",
9
10
  "test": "vitest run",
10
11
  "test:cov": "vitest --coverage",
11
- "ci": "npm run test"
12
+ "ci": "npm run test",
13
+ "prepublishOnly": "npm run build"
12
14
  },
13
15
  "files": [
14
16
  "dist/",
@@ -25,8 +27,10 @@
25
27
  },
26
28
  "devDependencies": {
27
29
  "@lark-apaas/http-client": "^0.1.3",
30
+ "@slardar/base": "^2.1.8",
28
31
  "@vitest/coverage-v8": "^4.0.18",
29
32
  "openclaw": "^2026.3.2",
33
+ "tinyglobby": "^0.2.16",
30
34
  "tsdown": "^0.21.0",
31
35
  "vitest": "^4.0.18"
32
36
  }
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  name: miaoda-coding
3
- description: 用户要求创建或修改应用、网页、页面、PPT、幻灯片、演示文稿,或提到"妙搭""vibe coding"时适用。
3
+ description: 通过妙搭开发插件来创建简单网页,例如信息可视化展示(图表、看板、简报、报表等)、PPT/演示文稿、简单工具或应用原型。用户提到"妙搭""vibe coding"时也适用。注意:CRM/ERP/OA等管理系统(但用户明确说做"原型/demo/展示页"时仍适用本skill),AI对话/智能体/AI助手(核心功能是对话交互的)、定时任务/自动化/推送、AI智能能力、知识库等需求不适用本skill;纯创作类需求(写文章/脚本/文案/生成图片/视频等不是做一个应用的)、写个脚本(Python 等)及纯数据分析(用户只要分析结论、未要求做报告/看板/可视化)不要包装成应用。
4
4
  user-invocable: false
5
5
  ---
6
6
 
@@ -8,9 +8,97 @@ user-invocable: false
8
8
 
9
9
  **重要:创建或修改应用、网页、PPT 等制品的执行环节,必须通过 sessions_spawn 交给妙搭。绝对不要自己动手写代码。**
10
10
 
11
+ ## 首屏硬规则
12
+
13
+ 1. 先做能力边界判断,再决定是派活给妙搭、引导去妙搭主站、还是本 skill 不处理。
14
+ 2. 命中不适用场景(AI对话/智能体/助手、定时任务/自动化等)时,**本 skill 不处理**。
15
+ 3. 命中复杂管理系统/复杂业务平台时,引导去妙搭主站(见「引导文案格式」)。但用户**主动、明确**说做”原型/demo/展示页”时,可以走妙搭生成原型。**不要替用户决定降级为原型**。
16
+ 4. 不要解释能力边界、不要给替代方案、不要展开原因说明,也不要输出 HTML `<a>` 标签。
17
+
18
+ ## ⚠️ 能力边界判断(必须首先执行)
19
+
20
+ 妙搭开发插件可以做**四类事情**,收到用户请求后,**必须先判断是否属于这四类**,再决定是派活还是引导去妙搭主站。
21
+
22
+ ### 支持的四类场景 → 派活给妙搭
23
+
24
+ 1. **信息可视化展示(最核心的场景)**:基于用户提供的数据做图表、看板、简报、报表、数据大屏、趋势分析图、对比展示等呈现。只要需求偏向"把信息/数据用可视化的方式展示出来",都应该走妙搭。包括但不限于:行业简报、经营数据看板、项目进度展示、竞品对比、方案汇报页、数据报告展示页等
25
+ 2. **简单应用原型**:用于展示产品思路或交互方案的原型页面,不是一个真正投入使用的系统(如落地页、概念演示、方案展示)
26
+ 3. **PPT / 演示文稿**:幻灯片、课件、汇报材料
27
+ 4. **简单工具**:有页面、也有一些基础的数据增删改查能力,但功能单一、不涉及复杂业务流程,重点是和 Agent 协同的工具,人和 Agent 都可以操作背后的数据
28
+
29
+ ### 不适用的场景(本 skill 不处理)
30
+
31
+ 以下需求**不属于本 skill 的能力范围,不要派活给妙搭**:
32
+
33
+ | 类别 | 识别关键词 |
34
+ |------|-----------|
35
+ | **AI 对话/智能体/助手** | “AI对话/聊天/陪伴”、”AI助手/XX助手”(核心功能是 AI 对话交互的助手)、”智能体/Agent”、”智能客服”、”AI工作台”、”配置智能体/搭建智能体”、”机器人配置/Bot配置” |
36
+ | **定时任务/自动化/推送** | “每日/每天/每周/每月”、”定时/定期执行”、”自动采集/抓取/同步/更新”、”实时监控/监测/预警”、”爬虫/爬取”、”推送通知/实时推送/按需推送/订阅推送”、”聚合订阅” |
37
+ | **AI 智能能力** | “AI分析/生成/推荐/预测/识别”、”AI辅助/AI驱动/AI赋能”、”智能匹配/评分/批改”、”预测分析/预测报告” |
38
+ | **知识库/智能问答** | “知识库”、”文档问答”、”智能搜索”、”知识图谱” |
39
+ | **纯文字创作** | “写文章/脚本/文案/小说/诗歌/演讲稿/邮件”、”撰写/创作/润色/改写/翻译”、”初稿写作/大纲生成/选题推荐”。**只要用户要的是纯文字产出,就直接以文字回复,不要做成网页/应用/PPT** |
40
+ | **纯数据分析** | “分析这份数据”、”帮我看看这些数字”、”算一下/统计一下”、”得出结论/给出建议”等——用户**只要分析结论**、没有明确要求”做个报告/看板/页面/可视化”时。**直接用文字或表格回答分析结果即可,不要自作主张包装成应用** |
41
+ | **复杂 PDF 生成** | “生成 PDF”、”导出 PDF”、”转 PDF”、”思维导图 PDF” |
42
+ | **需要外部数据源** | “实时行情/价格/股价”、”获取最新数据”、”接入 API”、”全网搜索/新闻聚合”、”历史开奖数据/历史行情数据” |
43
+ | **抢票/秒杀** | “抢票”、”秒杀”、”自动抢/购”、”监控库存” |
44
+ | **部署/运维** | “部署实例/一键部署”、”运维/服务器管理”、”环境配置/实例管理” |
45
+ | **数据对接/桥接** | “数据源连接/桥接”、”API 对接”、”数据库连接” |
46
+ | **AI 图片生成** | “AI生成图片/一键生成图片”、”文生图/图生图”、”AI绘画/AI作画” |
47
+
48
+ **”XX助手”的判断**:看核心功能而非名称——核心是 AI 对话/问答/智能推荐的(如”AI写作助手””智能客服助手”)属于不适用;名字叫”助手”但本质是页面工具的(如”记账助手””配色助手”)按实际功能归类,可以走妙搭。
49
+
50
+ ### 复杂管理系统 / 复杂业务平台 → 引导用户到妙搭主站
51
+
52
+ | 类别 | 识别关键词 |
53
+ |------|-----------|
54
+ | **复杂管理系统** | “XX管理系统/平台”(客户管理、人力管理、财务管理、库存管理、生产管理、设备管理、物流管理、车队管理、物业管理、门店管理、医疗管理、安全管理等)、”CRM/ERP/OA/HRM/MES/WMS/进销存”、”全流程管理/一站式管理/端到端”、”多角色登录/权限管理/角色管理”、”工单/审批流/工作流” |
55
+ | **复杂业务平台** | “电商平台/交易平台/商城”、”教育/学习/培训/考试平台”、”医疗/健康管理平台”、”社交/社区平台”、”内容/直播运营平台”、”招聘平台” |
56
+
57
+ 遇到这两类需求时:
58
+ - 用户**主动、明确**说要做”原型/demo/展示页/概念验证”(如”做一个CRM的原型给老板看看”)→ 可以走妙搭,按「简单应用原型」场景生成
59
+ - 用户意图是做一个真正可用的系统 → 输出引导文案(见下方格式),引导去妙搭主站
60
+ - **不要替用户降级**——用户说”做一个CRM”就是想做系统,不要自作主张改成做 CRM 原型
61
+
62
+ #### 引导文案格式
63
+
64
+ ```md
65
+ 这个需求比较复杂,你可以去妙搭搭建试试:
66
+
67
+ [去妙搭创建<贴合需求的描述>](https://miaoda.feishu.cn/home?userInput=<URL编码后的需求摘要>&mode=application&open-from=openclaw)
68
+ ```
69
+
70
+ 规则:
71
+ - `label` 换成最贴合需求的一句话,例如”去妙搭创建电商平台””去妙搭创建客户管理系统”
72
+ - `query` 填需求摘要,尽量忠实保留用户需求,**200 字以内**(URL 编码前)
73
+ - 第一行固定用:`这个需求比较复杂,你可以去妙搭搭建试试:`
74
+ - 链接前后不要再补任何能力边界说明、替代方案、原因分析或额外格式修饰
75
+ - 不能输出 HTML `<a>` 标签
76
+ - 不要输出任何内部标记或 XML/HTML 风格包裹内容
77
+
78
+ 正确示例:
79
+
80
+ ```md
81
+ 这个需求比较复杂,你可以去妙搭搭建试试:
82
+
83
+ [去妙搭创建电商平台](https://miaoda.feishu.cn/home?userInput=%E5%B8%A6%E7%94%A8%E6%88%B7%E7%99%BB%E5%BD%95%E3%80%81%E6%94%AF%E4%BB%98%E3%80%81%E8%AE%A2%E5%8D%95%E7%AE%A1%E7%90%86%E3%80%81%E5%90%8E%E5%8F%B0%E5%AE%A1%E6%A0%B8%E5%92%8C%E6%95%B0%E6%8D%AE%E6%8A%A5%E8%A1%A8%E7%9A%84%E5%A4%A7%E5%9E%8B%E7%94%B5%E5%95%86%E5%B9%B3%E5%8F%B0&mode=application&open-from=openclaw)
84
+ ```
85
+
86
+ ```md
87
+ 这个需求比较复杂,你可以去妙搭搭建试试:
88
+
89
+ [去妙搭创建客户管理系统](https://miaoda.feishu.cn/home?userInput=%E5%AE%A2%E6%88%B7%E7%AE%A1%E7%90%86%E7%B3%BB%E7%BB%9F%EF%BC%8C%E6%94%AF%E6%8C%81%E5%AE%A2%E6%88%B7%E4%BF%A1%E6%81%AF%E7%AE%A1%E7%90%86%E3%80%81%E8%B7%9F%E8%BF%9B%E8%AE%B0%E5%BD%95%E5%92%8C%E6%95%B0%E6%8D%AE%E6%8A%A5%E8%A1%A8&mode=application&open-from=openclaw)
90
+ ```
91
+
92
+ ### 边界模糊时的判断原则
93
+
94
+ 问自己三个问题(**按顺序判断,第 1 条优先级最高**):
95
+ 1. **”需求是否命中不适用场景表?”** — 命中则本 skill 不处理
96
+ 2. **”需求是复杂管理系统或复杂业务平台吗?”** — 是的话,看用户是否**主动明确**说了要做原型/demo/展示页:说了 → 按「简单应用原型」场景走妙搭;没说 → 引导去妙搭主站
97
+ 3. **”这是一个简单工具/原型/展示页,还是一个真正的业务系统?”** — 如果用户期望的是一个可以真正投入日常使用、涉及多角色/多流程/复杂业务逻辑的系统,应该引导去妙搭主站
98
+
11
99
  ## 判断是否需要先做前置工作
12
100
 
13
- 妙搭只负责**生成制品**(网页、应用、PPT),不负责搜索、分析、总结等研究工作。
101
+ 妙搭开发插件只负责**生成制品**(网页、应用、PPT),不负责搜索、分析、总结等研究工作。
14
102
 
15
103
  收到用户请求后,先判断:
16
104
 
@@ -53,20 +141,25 @@ user-invocable: false
53
141
  - `mode`: `"run"`
54
142
  - `task`: 按下面模板填写
55
143
 
56
- 如果 sessions_spawn 返回错误,去掉多余参数后重试,**绝对不要 fallback 到自己写代码**。
144
+ 如果 sessions_spawn 调用本身返回错误(如参数错误),去掉多余参数后重试,**绝对不要 fallback 到自己写代码**。
57
145
 
58
146
  **创建新项目:**
59
147
 
60
148
  1. 如有上下文需要传递,先调 `miaoda_write_reference`
61
149
  2. 调 `sessions_spawn`,task 内容:
62
150
 
151
+ **generation_request 编写原则**:
152
+ - 忠实传递用户的功能需求,不要自行添加技术选型(如数据库方案、存储方式、第三方 API 等)
153
+ - code agent 运行在独立沙箱中,不具备你(openclaw)的插件和工具能力(如飞书多维表格、飞书文档等),不要推荐你自己的能力给它
154
+ - 技术方案由 code agent 根据平台内置能力自行决定
155
+
63
156
  ```
64
157
  调用 miaoda_coding tool,参数:
65
158
  - generation_request: "<生成指令>"
66
159
  - project_id: "<project_id>"
67
160
  - name: "<面向人类可读的应用名称>"
68
161
  - description: "<根据用户需求整理的一句话简介,单行,80 字以内>"
69
- - target: "user:<sender_id>"
162
+ - target:(**必填,不可省略**)根据消息来源判断——群聊中用 "chat:<chat_id>"(如 chat:oc_xxx),单聊中用 "user:<sender_id>"(如 user:ou_xxx),非飞书渠道传 "none"。缺少 target 会导致错误消息无法投递给用户。
70
163
 
71
164
  如果 reference/ 目录已有参考资料,tool 会自动提示 code agent 查阅。
72
165
 
@@ -90,7 +183,7 @@ tool 返回的 JSON 里如果有 `hint` 字段,严格按 hint 指示行事。
90
183
  3. 调用 miaoda_coding tool,参数:
91
184
  - generation_request: "<修改要求>"
92
185
  - project_id: "<上一步取到的 project_id>"
93
- - target: "user:<sender_id>"
186
+ - target:(**必填,不可省略**)根据消息来源判断——群聊中用 "chat:<chat_id>"(如 chat:oc_xxx),单聊中用 "user:<sender_id>"(如 user:ou_xxx),非飞书渠道传 "none"。缺少 target 会导致错误消息无法投递给用户。
94
187
 
95
188
  tool 会返回结构化 JSON(status/appId/finalText/output 等)。
96
189
 
@@ -100,6 +193,7 @@ tool 返回的 JSON 里如果有 `hint` 字段,严格按 hint 指示行事。
100
193
  ```
101
194
 
102
195
  `<sender_id>` 从消息上下文的 sender_id 字段获取(格式如 `ou_xxx`)。
196
+ `<chat_id>` 从消息上下文的 chat_id / ChatType / To 字段判断:ChatType 为 `"group"` 时取 chat_id(格式如 `oc_xxx`)。
103
197
 
104
198
  `<project_id>` 仅允许小写字母、数字和短横线,创建新项目时根据用户需求生成,例如:
105
199
  - "帮我做一个 hello world 网页" → `hello-world-webpage`
@@ -108,17 +202,22 @@ tool 返回的 JSON 里如果有 `hint` 字段,严格按 hint 指示行事。
108
202
 
109
203
  ## 你(主 agent)的行为
110
204
 
111
- 1. 读完这个 skill 后,判断是否需要写参考资料,需要则调 `miaoda_write_reference`
112
- 2. sessions_spawn
113
- 3. 回复用户"交给妙搭了,稍等"
114
- 4. **不要** 调 sessions_history、subagents、或任何 poll 操作
115
- 5. subagent announce 回来后,**只发一条总结消息**:简短总结做了什么
116
- - **不需要发预览链接** 预览链接由插件自动投递给用户,你不需要从 output/finalText 中提取
205
+ 1. 读完这个 skill 后,**首先执行能力边界判断**。如果不在支持范围内,**立即直接输出最终引导文案**:第一行是“这个需求比较复杂,你可以去妙搭搭建试试:”,第二行是指向 `https://miaoda.feishu.cn/home?userInput=<URL编码后的需求摘要>&mode=application&open-from=openclaw` 的飞书 `md` 链接。不要自己补能力边界说明、替代方案或原因分析。
206
+ 2. 确认在能力范围内后,判断是否需要写参考资料,需要则调 `miaoda_write_reference`
207
+ 3. 调 sessions_spawn
208
+ 4. 回复用户"交给妙搭了,稍等"
209
+ 5. **不要** sessions_history、subagents、或任何 poll 操作
210
+ 6. subagent announce 回来后,按 plugin 写的投递标记判断该不该带链接(路径默认 `workspace/app/<project_id>/.spark/`,如不存在再回退 `workspace/<project_id>/.spark/`):
211
+ - 读 `.spark/delivery.json`(每次 run 开头 plugin 会 atomic 覆写成空对象,投递成功后再覆写成含 `deliveredAt` 的对象;所以它永远只反映**本次 run** 的状态)
212
+ - **`delivery.json` 里有 `deliveredAt` 字段**(plugin 本次 run 已自动投递预览链接)→ 只发一条简短纯文字总结,**不要带预览链接**(plugin 已经发过一条,主 agent 再带就是两条)
213
+ - **`delivery.json` 存在但没有 `deliveredAt` 字段 / 文件不存在 / 读不了**:读 `.spark/meta.json`
214
+ - **有 `appUrl`**(plugin 本次 run 没投递,常见于 subagent 把 target 填成 "none")→ 主 agent **自己补发链接**:把 `appUrl` 拼上 `?mode=sidebar-semi`(如已有 query 参数则用 `&mode=sidebar-semi`),用加粗 Markdown 链接 `**[url](url)**` 放在简短总结里一起发,只发一条
215
+ - **没有 `appUrl`**(部署未成功)→ 按下方「处理失败和异常」第 4 条处理
117
216
  - **严禁发多条消息**
118
217
  - 不要提系统、子任务、announce、subagent 等内部细节
119
- 6. `miaoda_check_progress` 用于两种场景:(a) 用户主动问进度时,(b) 任务失败且结果中有 `hint` 建议查进度时
120
- 7. **不要** 调 message tool 自己推送消息,所有回复通过正常对话投递
121
- 8. **不要** 自己写代码或用 exec/write 生成 HTML/JS/CSS 文件
218
+ 7. `miaoda_check_progress` 用于两种场景:(a) 用户主动问进度时,(b) 任务失败且结果中有 `hint` 建议查进度时
219
+ 8. **不要** 调 message tool 自己推送消息,所有回复通过正常对话投递
220
+ 9. **不要** 自己写代码或用 exec/write 生成 HTML/JS/CSS 文件
122
221
 
123
222
  ## 处理失败和异常
124
223
 
@@ -128,11 +227,25 @@ subagent 返回的结果 JSON 中可能包含 `status: "error"` 或 `status: "ti
128
227
  - 如果 progress 显示已完成 → 正常回复结果
129
228
  - 如果 progress 显示仍在运行 → 告诉用户"还在处理中,稍后再查"
130
229
  - 如果 progress 显示失败 → 问用户是否要重试
230
+ - **重试时**:走**修改已有项目**流程,`generation_request` 填 `"继续"`。feida-ai 的 conversation 中已有完整上下文(需求 + 之前的代码 + 失败日志),发"继续"即可让 Agent 接着上次的进度工作。**禁止**用创建模板重复发送完整的原始需求——这会导致 Agent 看到重复的需求消息,浪费 token 并造成混乱
131
231
  2. **`hint` 包含"createSubApp 失败"**:createSubApp 是创建应用的前置步骤,失败原因可能是用户额度不足、权限不够、或服务异常等。根据 `error` 字段的具体内容用通俗语言告诉用户(如"额度用完了"、"没有权限"、"服务暂时不可用"),**不要重试,不要调 miaoda_check_progress**
132
232
  3. **`retryable: false` 或无 `retryable` 字段**:直接告诉用户失败了,附上错误信息,问用户怎么处理
133
- 4. **结果里没有预览链接**(`hint` 提到"未检测到预览链接"):调 `miaoda_check_progress` 查看最新状态,可能链接还没生成
233
+ 4. **subagent 总结里提到部署失败 / 没生成预览链接**:如实告诉用户"应用生成/部署失败",根据错误信息用通俗语言说明原因,问用户要不要重试。**不要自己拼预览链接**,也**不要调 `miaoda_check_progress`**(这个 tool 不返回 appUrl,查了也拿不到链接)
134
234
 
135
235
  **禁止行为**:
136
236
  - 不要在用户不知情的情况下自动重试——先告诉用户情况,等用户确认
137
237
  - 不要把 `retryable`、`hint`、`logId` 等内部字段暴露给用户
138
238
  - 不要说"stream disconnected"、"reconnect exhausted"等技术术语
239
+
240
+ ## 查看执行详情
241
+
242
+ 项目执行信息默认位于 `workspace/app/<project_id>/.spark/`;如果该目录不存在,再回退到旧路径 `workspace/<project_id>/.spark/`。可直接读取:
243
+
244
+ - `meta.json`:应用元信息(appId、appUrl 等),用于获取预览链接
245
+ - `progress.txt`:关键节点进度日志(轻量,适合快速了解当前状态)
246
+
247
+ ## 判定任务是否完成
248
+
249
+ subagent announce 后,优先读 `workspace/app/<project_id>/.spark/progress.txt`;如果不存在,再回退读 `workspace/<project_id>/.spark/progress.txt` 了解实际执行情况。
250
+
251
+ 基于对实际情况的了解,自行判断下一步行动。
@@ -0,0 +1,244 @@
1
+ ---
2
+ name: miaoda-database-skill
3
+ description: 创建数据库、建表、执行 SQL、查询数据、查看表结构。当用户需要数据库、数据表、数据持久化、PostgreSQL 操作时使用。通过 miaoda-data-cli db 子命令(db init / db sql / db schema)完成数据库初始化、DDL/DML/SELECT 执行和表结构查看。
4
+ ---
5
+ # Database Skill
6
+
7
+ 本技能指导 Agent 通过 `miaoda-data-cli db` 命令操作数据库,包括:
8
+ - **db sql**:执行 SQL 语句(DDL/SELECT/DML)
9
+ - **db schema**:查看数据库表结构(默认 DDL,`--json` 输出结构化 JSON)
10
+
11
+ ### 使用方式
12
+
13
+ 推荐通过 `npx -y` 直接运行,无需预先安装:
14
+
15
+ ```bash
16
+ npx -y @lark-apaas/miaoda-data-cli db sql "SELECT 1"
17
+ ```
18
+
19
+ ## 通用约定
20
+
21
+ ### 错误处理
22
+
23
+ 所有命令失败时退出码为 **1**,错误信息输出到 **stderr**,格式为 JSON:
24
+
25
+ ```json
26
+ {"statusCode": 2, "message": "SQL 执行失败", "detail": "[k_dl_1300002] ERROR: relation \"xxx\" does not exist"}
27
+ ```
28
+
29
+ | statusCode | 含义 | 是否重试 | 触发场景 |
30
+ |------------|------|----------|---------|
31
+ | 1 | 语法/参数错误 | 否 | SQL 语法错误、参数缺失、表名不合法 |
32
+ | 2 | 执行失败 / 业务错误 | 否 | 表不存在、插入失败、权限不足等 |
33
+ | 3 | 服务异常 | 是,最多 1 次 | 网络错误、数据库暂时不可用 |
34
+
35
+ **处理策略**:
36
+ - statusCode 1 → 检查语法,修正后重新执行
37
+ - statusCode 2 → 读取 `detail` 字段定位原因,修正后重新执行
38
+ - 若 message 包含"数据库未初始化",说明尚未执行 `db init`,需先执行 `db init` 初始化数据库后再重试
39
+ - statusCode 3 → 重试一次,仍失败则告知用户
40
+
41
+ ### 输出约定
42
+
43
+ - `db sql`:默认输出表格到 **stdout**,`--json` 输出结构化 JSON
44
+ - `db schema`:默认输出 DDL 到 **stdout**,`--json` 输出表结构 JSON
45
+
46
+ ---
47
+
48
+ ## 命令:db init
49
+
50
+ 初始化数据库。**首次使用 `db sql` / `db schema` 前必须执行**。此命令是幂等的,重复执行不会报错。
51
+
52
+ ### 格式
53
+
54
+ ```bash
55
+ npx -y @lark-apaas/miaoda-data-cli db init
56
+ ```
57
+
58
+ ### 输出
59
+
60
+ ```
61
+ Database initialized.
62
+ ```
63
+
64
+ ### 典型工作流
65
+
66
+ ```bash
67
+ # 1. 初始化数据库
68
+ npx -y @lark-apaas/miaoda-data-cli db init
69
+
70
+ # 2. 建表(建议添加表注释和字段注释,便于后续理解用途)
71
+ npx -y @lark-apaas/miaoda-data-cli db sql "CREATE TABLE note (id UUID PRIMARY KEY DEFAULT gen_random_uuid(), title VARCHAR(255) NOT NULL); COMMENT ON TABLE note IS '笔记表';"
72
+
73
+ # 3. 查看表结构
74
+ npx -y @lark-apaas/miaoda-data-cli db schema note
75
+ ```
76
+
77
+ ---
78
+
79
+ ## 命令:db sql
80
+
81
+ 执行 SQL 语句并返回结果。
82
+
83
+ ### 格式
84
+
85
+ ```bash
86
+ npx -y @lark-apaas/miaoda-data-cli db sql "<SQL 语句>"
87
+
88
+ # 加 --json 输出结构化 JSON
89
+ npx -y @lark-apaas/miaoda-data-cli db sql --json "<SQL 语句>"
90
+ ```
91
+
92
+ ### 示例
93
+
94
+ ```bash
95
+ # DDL
96
+ npx -y @lark-apaas/miaoda-data-cli db sql "
97
+ CREATE TABLE note (id UUID PRIMARY KEY DEFAULT gen_random_uuid(), title VARCHAR(255) NOT NULL, content TEXT);
98
+ COMMENT ON TABLE note IS 'note table';
99
+ CREATE INDEX idx_note_title ON note(title);
100
+ "
101
+
102
+ # SELECT
103
+ npx -y @lark-apaas/miaoda-data-cli db sql "SELECT title, content FROM note LIMIT 10"
104
+
105
+ # INSERT
106
+ npx -y @lark-apaas/miaoda-data-cli db sql "INSERT INTO note (title, content) VALUES ('hello', 'world')"
107
+ ```
108
+
109
+ ### 默认输出(表格格式)
110
+
111
+ **SELECT**:
112
+ ```
113
+ title | content
114
+ ------+--------
115
+ hello | world
116
+ (1 row)
117
+ ```
118
+
119
+ **DML**:
120
+ ```
121
+ 1 row affected
122
+ ```
123
+
124
+ **DDL**:
125
+ ```
126
+ DDL executed successfully
127
+ ```
128
+
129
+ ### --json 输出
130
+
131
+ **单条语句**:
132
+
133
+ SELECT — 直接输出查询结果的 JSON 数组:
134
+ ```json
135
+ [
136
+ {"title": "hello", "content": "world"}
137
+ ]
138
+ ```
139
+
140
+ DML — 输出影响行数:
141
+ ```json
142
+ {"affectedRows": 1}
143
+ ```
144
+
145
+ DDL — 输出成功标识:
146
+ ```json
147
+ {"status":"ok"}
148
+ ```
149
+
150
+ **多条语句**:输出带 index/type 的结构化数组:
151
+ ```json
152
+ [
153
+ {"index": 0, "type": "DDL", "status": "ok"},
154
+ {"index": 1, "type": "DML", "affectedRows": 1},
155
+ {"index": 2, "type": "SELECT", "rows": [{"id": "...", "name": "test"}], "rowCount": 1}
156
+ ]
157
+ ```
158
+
159
+ ### 返回值处理
160
+
161
+ - **DDL**:默认输出确认文本,`--json` 输出 `{"status":"ok"}`,退出码 0 即成功
162
+ - **SELECT**:默认输出表格,`--json` 直接输出数据 JSON 数组,可直接解析使用
163
+ - **DML**:默认输出影响行数文本,`--json` 输出 `{"affectedRows": N}`
164
+
165
+ ---
166
+
167
+ ## 命令:db schema
168
+
169
+ 查看数据库表结构。默认输出 DDL(CREATE TABLE 语句),`--json` 输出表结构 JSON。支持多表名。
170
+
171
+ ### 格式
172
+
173
+ ```bash
174
+ # 所有表 DDL
175
+ npx -y @lark-apaas/miaoda-data-cli db schema
176
+
177
+ # 指定表 DDL
178
+ npx -y @lark-apaas/miaoda-data-cli db schema <table_name>
179
+
180
+ # 多表 DDL
181
+ npx -y @lark-apaas/miaoda-data-cli db schema <table1> <table2>
182
+
183
+ # 表结构 JSON
184
+ npx -y @lark-apaas/miaoda-data-cli db schema --json
185
+ npx -y @lark-apaas/miaoda-data-cli db schema <table_name> --json
186
+ ```
187
+
188
+ ### 示例
189
+
190
+ ```bash
191
+ # 所有表 DDL
192
+ npx -y @lark-apaas/miaoda-data-cli db schema
193
+
194
+ # 查看 note 表 DDL
195
+ npx -y @lark-apaas/miaoda-data-cli db schema note
196
+
197
+ # 查看 note 表结构 JSON
198
+ npx -y @lark-apaas/miaoda-data-cli db schema note --json
199
+ ```
200
+
201
+ ### 默认输出(DDL)
202
+
203
+ ```sql
204
+ CREATE TABLE workspace_xxx.note (
205
+ id uuid NOT NULL DEFAULT gen_random_uuid(),
206
+ title character varying(255) NOT NULL,
207
+ content text NULL,
208
+ CONSTRAINT note_pkey PRIMARY KEY (id)
209
+ ) TABLESPACE pg_default;
210
+ COMMENT ON TABLE workspace_xxx.note IS 'note table';
211
+ ```
212
+
213
+ 多表时空行分隔,不存在的表输出 `-- table "xxx" not found`。
214
+
215
+ ### --json 输出
216
+
217
+ ```json
218
+ {
219
+ "tableName": "note",
220
+ "comment": "note table",
221
+ "type": "normal",
222
+ "fields": [
223
+ {
224
+ "fieldName": "id",
225
+ "type": "uuid",
226
+ "isNullable": false,
227
+ "defaultValue": "gen_random_uuid()",
228
+ "isPrimary": true,
229
+ "isUnique": false,
230
+ "isArray": false,
231
+ "isEnum": false
232
+ },
233
+ {
234
+ "fieldName": "title",
235
+ "type": "varchar",
236
+ "isNullable": false,
237
+ "defaultValue": null,
238
+ "isPrimary": false
239
+ }
240
+ ],
241
+ "indexes": [],
242
+ "relationships": []
243
+ }
244
+ ```