@qqbrowser/qbot-claw-launcher 0.10.4 → 0.10.6

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/build.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.IS_DEBUG_BUILD=exports.LAUNCHER_VERSION=void 0,exports.LAUNCHER_VERSION="0.10.4",exports.IS_DEBUG_BUILD=!1;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.IS_DEBUG_BUILD=exports.LAUNCHER_VERSION=void 0,exports.LAUNCHER_VERSION="0.10.6",exports.IS_DEBUG_BUILD=!1;
package/dist/installer.js CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";var O=exports&&exports.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.PYTHON_DIR=exports.isInstalling=exports.installState=void 0,exports.runQBotClaw=S,exports.configAndRunQBotClaw=y,exports.runInstall=v;const c=O(require("fs")),u=O(require("path")),I=require("child_process"),s=require("./config");Object.defineProperty(exports,"PYTHON_DIR",{enumerable:!0,get:function(){return s.PYTHON_DIR}});const m=require("./utils"),d=require("./state"),o=require("./reportLog"),E=require("./service"),A=require("./openai-proxy"),p=require("./report"),$=require("./qqbrowser-skill-installer");let w="qqbrowser-skill-control";function f(t,n,i,l){if(t&&t.writable){const e=n>0?Math.round(i/n*1e4)/100:0;try{t.write(JSON.stringify({status:"downloading",progress:e,totalSteps:n,currentStep:i,message:l})+`
2
2
  `)}catch{}}}exports.installState={status:"idle",message:"\u672A\u5F00\u59CB"},exports.isInstalling=!1;function S(t,n){return(0,o.log)(`[QBotClaw] \u6267\u884C: QBotClaw ${t.join(" ")}`),new Promise(i=>{const l=(0,d.readState)(),e=(0,I.spawn)(s.QBOTCLAW_BIN,t,{stdio:["ignore","pipe","pipe"],shell:process.platform==="win32",windowsHide:!0,env:{...process.platform==="win32"?process.env:{},PATH:`${s.NODE_BIN_DIR}${u.default.delimiter}${process.env.PATH||""}`,HOME:process.env.HOME||process.env.USERPROFILE,USERPROFILE:process.env.USERPROFILE,OPENCLAW_TELEMETRY_GALIELO_GUID:process.env.QB_GUID||"",OPENCLAW_TELEMETRY_GALIELO_QIEMI36:process.env.QB_QIMEI36||"",QBOTCLAW_LLM_BASE_URL:`http://127.0.0.1:${l.port}/v1`,QBOTCLAW_LLM_API_KEY:A.proxyApiKey}});(0,o.log)(`[QBotClaw] \u6267\u884C: QBotClaw ${t.join(" ")}`),e.stdout.on("data",a=>{const r=a.toString();if(n&&n.writable)try{n.write(r)}catch{}}),e.stderr.on("data",a=>{const r=a.toString();if(n&&n.writable)try{n.write(r)}catch{}}),e.on("close",a=>{(0,o.log)(`[QBotClaw] \u6267\u884C\u5B8C\u6210\uFF0C\u9000\u51FA\u7801: ${a}`),i()}),e.on("error",a=>{(0,o.log)(`[QBotClaw] \u542F\u52A8\u5931\u8D25: ${a.message}`),i()})})}function C(){c.default.existsSync(s.QBOT_CLAW_DIR)||c.default.mkdirSync(s.QBOT_CLAW_DIR,{recursive:!0})}function L(){const t=process.platform==="win32"?"pip.ini":"pip.conf",n=u.default.join(s.PYTHON_DIR,t);if(c.default.existsSync(n)){(0,o.log)(`${t} \u5DF2\u5B58\u5728\uFF0C\u8DF3\u8FC7`);return}const i=["[global]","index-url = https://mirrors.tencent.com/pypi/simple/",`cache-dir = ${u.default.join(s.PYTHON_DIR,".pip-cache")}`,"","[install]",`prefix = ${s.PYTHON_DIR}`,""].join(`
3
3
  `);c.default.writeFileSync(n,i,"utf-8"),(0,o.log)(`\u5DF2\u5199\u5165 ${t}: ${n}`)}function N(t,n){return new Promise((i,l)=>{const e=(0,I.spawn)(s.NPM_BIN,["--userconfig",s.NPM_RC,...t],{stdio:["ignore","pipe","pipe"],shell:process.platform==="win32",windowsHide:!0,env:{...process.env,PATH:`${u.default.dirname(s.NPM_BIN)}${u.default.delimiter}${process.env.PATH}`}});e.stdout.on("data",a=>{const r=`[npm] ${a.toString().trim()}`;(0,o.log)(r)}),e.stderr.on("data",a=>{const r=`[npm] ${a.toString().trim()}`;(0,o.log)(r)}),e.on("close",a=>{a===0?((0,o.log)(`${n} \u6210\u529F`),i()):l(new Error(`${n} \u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${a}`))}),e.on("error",l)})}function P(){const t=u.default.join(s.QBOT_CLAW_DIR,"node",".npm-cache","_logs");try{if(!c.default.existsSync(t)){(0,o.log)(`[dumpNpmLogs] npm \u65E5\u5FD7\u76EE\u5F55\u4E0D\u5B58\u5728: ${t}`);return}const n=c.default.readdirSync(t).filter(i=>c.default.statSync(u.default.join(t,i)).isFile()).sort((i,l)=>{const e=c.default.statSync(u.default.join(t,i));return c.default.statSync(u.default.join(t,l)).mtimeMs-e.mtimeMs}).slice(0,3);if(n.length===0){(0,o.log)(`[dumpNpmLogs] npm \u65E5\u5FD7\u76EE\u5F55\u4E3A\u7A7A: ${t}`);return}(0,o.log)(`[dumpNpmLogs] \u8BFB\u53D6\u6700\u65B0\u7684 ${n.length} \u4E2A npm \u65E5\u5FD7\u6587\u4EF6:`);for(const i of n){const l=u.default.join(t,i);try{const e=c.default.readFileSync(l,"utf-8");(0,o.log)(`[npm-log] ===== ${i} =====
4
- ${e}`)}catch(e){(0,o.log)(`[npm-log] \u8BFB\u53D6\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25 ${i}: ${e.message}`)}}}catch(n){(0,o.log)(`[dumpNpmLogs] \u8BFB\u53D6 npm \u65E5\u5FD7\u76EE\u5F55\u5931\u8D25: ${n.message}`)}}async function B(t){const n=`${s.NPM_PACKAGE_NAME}@${t}`,i=`${n} \u4E0B\u8F7D\u89E3\u538B`;(0,o.log)(`\u5F00\u59CB\u5B89\u88C5 ${n}\uFF08--ignore-scripts\uFF0C\u4EC5\u4E0B\u8F7D\u89E3\u538B\uFF09...`);let l;for(let e=0;e<s.NPM_REGISTRIES.length;e++){const a=s.NPM_REGISTRIES[e];try{(0,o.log)(`[${i}] \u5C1D\u8BD5\u4F7F\u7528\u6E90 (${e+1}/${s.NPM_REGISTRIES.length}): ${a}`),await N(["install","-g","--ignore-scripts","--registry",a,n],i);return}catch(r){l=r,(0,o.log)(`[${i}] \u6E90 ${a} \u5931\u8D25: ${r.message}`),e<s.NPM_REGISTRIES.length-1&&(0,o.log)(`[${i}] \u5C06\u5C1D\u8BD5\u4E0B\u4E00\u4E2A\u6E90...`)}}throw(0,o.log)(`\u5B89\u88C5 ${n} \u6240\u6709\u6E90\u5747\u5931\u8D25`),P(),l}async function T(t){const n=`${s.NPM_PACKAGE_NAME}@${t}`;(0,o.log)("\u5F00\u59CB npm rebuild\uFF08\u6267\u884C postinstall \u811A\u672C\uFF09..."),await N(["rebuild","-g",s.NPM_PACKAGE_NAME],`${n} rebuild`),(0,o.log)(`${n} \u5B89\u88C5\u6210\u529F`)}async function Q(t,n,i,l){try{const r=process.platform==="win32"?`"${s.QBOTCLAW_BIN}" config validate --json`:`"${s.NODE_BIN}" "${s.QBOTCLAW_BIN}" config validate --json`,g=await(0,m.execCommand)(r);(0,o.log)(`[config validate] \u8F93\u51FA: ${g}`);const _=JSON.parse(g);_.valid!==!0?((0,o.log)(`[config validate] \u914D\u7F6E\u6821\u9A8C\u672A\u901A\u8FC7\uFF08valid=${_.valid}\uFF09\uFF0C\u5F3A\u5236\u8986\u76D6\u914D\u7F6E`),l=!0):(0,o.log)("[config validate] \u914D\u7F6E\u6821\u9A8C\u901A\u8FC7")}catch(r){(0,o.log)(`[config validate] \u6267\u884C\u5931\u8D25: ${r.message}\uFF0C\u5F3A\u5236\u8986\u76D6\u914D\u7F6E`),l=!0}let e;if((0,o.log)(`\u8986\u76D6\u7528\u6237\u5DF2\u6709\u914D\u7F6E: ${l}`),!l&&c.default.existsSync(s.QBOT_CLAW_CONFIG_PATH))e=s.QBOT_CLAW_CONFIG_PATH,(0,o.log)(`\u4F7F\u7528\u5DF2\u6709\u914D\u7F6E\u6587\u4EF6: ${e}`);else{const r=u.default.join(s.NPM_GLOBAL_MODULES,s.NPM_PACKAGE_NAME,"preset-config.json");if(!c.default.existsSync(r)){(0,o.log)(`npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165: ${r}`);return}e=r,(0,o.log)(`\u4F7F\u7528 npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E: ${e}`)}let a;try{a=JSON.parse(c.default.readFileSync(e,"utf-8")),(0,o.log)(`\u5DF2\u8BFB\u53D6\u914D\u7F6E: ${e}`)}catch(r){(0,o.log)(`\u8BFB\u53D6\u914D\u7F6E\u5931\u8D25: ${e}\uFF0C${r.message}\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165`);return}a.gateway={...a.gateway??{},port:t},a.gateway.auth={...a.gateway.auth??{},token:n},(0,o.log)(`\u5DF2\u5199\u5165 gateway.port=${t}, gateway.token=${n}`),a.plugins=a.plugins??{},a.plugins.entries=a.plugins.entries??{},a.plugins.entries[w]=a.plugins.entries[w]??{},a.plugins.entries[w].config={...a.plugins.entries[w].config??{},wsPort:i},(0,o.log)(`\u5DF2\u5C06 ${w} wsPort=${i} \u5199\u5165\u914D\u7F6E`),c.default.writeFileSync(s.QBOT_CLAW_CONFIG_PATH,JSON.stringify(a,null,2),"utf-8"),(0,o.log)(`\u914D\u7F6E\u6587\u4EF6\u5DF2\u5199\u5165: ${s.QBOT_CLAW_CONFIG_PATH}`)}function h(){try{if(!c.default.existsSync(s.GALILEO_CONFIG_PATH)){(0,o.log)(`[galileo] \u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7: ${s.GALILEO_CONFIG_PATH}`);return}const t=c.default.readFileSync(s.GALILEO_CONFIG_PATH,"utf-8"),n=JSON.parse(t),i=n.galileo;if(!i){(0,o.log)("[galileo] \u914D\u7F6E\u6587\u4EF6\u4E2D\u7F3A\u5C11 galileo \u5B57\u6BB5\uFF0C\u8DF3\u8FC7");return}const l=process.env.QB_QIMEI36||"";i.userId==="userid"&&l?(i.userId=l,i.customAttributes={qimei36:l,guid:process.env.QB_GUID||""},c.default.writeFileSync(s.GALILEO_CONFIG_PATH,JSON.stringify(n,null,2),"utf-8"),(0,o.log)(`[galileo] \u5DF2\u5C06 userId \u66F4\u65B0\u4E3A ${l}\uFF0CcustomAttributes \u5DF2\u5199\u5165`)):(0,o.log)(`[galileo] \u65E0\u9700\u66F4\u65B0\uFF08userId=${i.userId}, QB_QIMEI36=${l||"\u7A7A"})`)}catch(t){(0,o.log)(`[galileo] \u8BFB\u53D6/\u5199\u5165\u914D\u7F6E\u5931\u8D25: ${t.message}`)}}async function y(t){const n=Date.now(),i=await(0,m.getQBotClawVersion)()??"unknown";try{h();const l=(0,d.readState)();let e;l.gatewayPort&&!await(0,d.isPortAvailable)(l.gatewayPort)?(e=l.gatewayPort,(0,o.log)(`\u68C0\u6D4B\u5230 QBotClaw gateway \u5DF2\u5728\u7AEF\u53E3 ${e} \u8FD0\u884C\uFF0C\u590D\u7528\u539F\u7AEF\u53E3`)):e=await(0,m.findAvailablePort)(),(0,o.log)(`\u540E\u53F0\u542F\u52A8 QBotClaw gateway run --port ${e} --force`);const a=await(0,m.findAvailablePort)(),r=(0,E.getOrCreateGatewayToken)();await Q(e,r,a,t),R(r);const g=(0,I.spawn)(s.QBOTCLAW_BIN,["gateway","run","--port",String(e),"--force"],{stdio:"ignore",shell:process.platform==="win32",windowsHide:!0,env:{...process.platform==="win32"?process.env:{},HOME:process.env.HOME||process.env.USERPROFILE,USERPROFILE:process.env.USERPROFILE,OPENCLAW_NO_RESPAWN:"true",VENUS_API_KEY:"E9isWWfAr4VIFuIa5RbJaPxD@2040",OPENCLAW_TELEMETRY_GALIELO_GUID:process.env.QB_GUID||"",OPENCLAW_TELEMETRY_GALIELO_QIEMI36:process.env.QB_QIMEI36||"",QBOTCLAW_LLM_BASE_URL:`http://127.0.0.1:${l.port}/v1`,QBOTCLAW_LLM_API_KEY:A.proxyApiKey}});g.unref();const _=g.pid;(0,o.log)(`QBotClaw gateway \u5DF2\u5728\u540E\u53F0\u542F\u52A8\uFF0CPID: ${_}\uFF0C\u7AEF\u53E3: ${e}, token ${(0,E.getOrCreateGatewayToken)()}`),(0,d.writeState)({...(0,d.readState)(),gatewayPid:_,gatewayPort:e,mcpWsPort:a}),(0,p.report)({event_name:"qbot_claw_started",version:i,result:"1",cost_ms:String(Date.now()-n)})}catch(l){throw(0,p.report)({event_name:"qbot_claw_started",version:i,result:"0",cost_ms:String(Date.now()-n),error:l.message}),l}}function R(t){const n=u.default.join(s.QBOT_CLAW_DIR,".env"),i=`OPENCLAW_GATEWAY_TOKEN=${t}
4
+ ${e}`)}catch(e){(0,o.log)(`[npm-log] \u8BFB\u53D6\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25 ${i}: ${e.message}`)}}}catch(n){(0,o.log)(`[dumpNpmLogs] \u8BFB\u53D6 npm \u65E5\u5FD7\u76EE\u5F55\u5931\u8D25: ${n.message}`)}}async function B(t){const n=`${s.NPM_PACKAGE_NAME}@${t}`,i=`${n} \u4E0B\u8F7D\u89E3\u538B`;(0,o.log)(`\u5F00\u59CB\u5B89\u88C5 ${n}\uFF08--ignore-scripts\uFF0C\u4EC5\u4E0B\u8F7D\u89E3\u538B\uFF09...`);let l;for(let e=0;e<s.NPM_REGISTRIES.length;e++){const a=s.NPM_REGISTRIES[e];try{(0,o.log)(`[${i}] \u5C1D\u8BD5\u4F7F\u7528\u6E90 (${e+1}/${s.NPM_REGISTRIES.length}): ${a}`),await N(["install","-g","--ignore-scripts","--registry",a,n],i);return}catch(r){l=r,(0,o.log)(`[${i}] \u6E90 ${a} \u5931\u8D25: ${r.message}`),e<s.NPM_REGISTRIES.length-1&&(0,o.log)(`[${i}] \u5C06\u5C1D\u8BD5\u4E0B\u4E00\u4E2A\u6E90...`)}}throw(0,o.log)(`\u5B89\u88C5 ${n} \u6240\u6709\u6E90\u5747\u5931\u8D25`),P(),l}async function T(t){const n=`${s.NPM_PACKAGE_NAME}@${t}`;(0,o.log)("\u5F00\u59CB npm rebuild\uFF08\u6267\u884C postinstall \u811A\u672C\uFF09..."),await N(["rebuild","-g",s.NPM_PACKAGE_NAME],`${n} rebuild`),(0,o.log)(`${n} \u5B89\u88C5\u6210\u529F`)}async function Q(t,n,i,l){try{const r=process.platform==="win32"?`"${s.QBOTCLAW_BIN}" config validate --json`:`"${s.NODE_BIN}" "${s.QBOTCLAW_BIN}" config validate --json`,g=await(0,m.execCommand)(r);(0,o.log)(`[config validate] \u8F93\u51FA: ${g}`);const _=JSON.parse(g);_.valid!==!0?((0,o.log)(`[config validate] \u914D\u7F6E\u6821\u9A8C\u672A\u901A\u8FC7\uFF08valid=${_.valid}\uFF09\uFF0C\u5F3A\u5236\u8986\u76D6\u914D\u7F6E`),l=!0):(0,o.log)("[config validate] \u914D\u7F6E\u6821\u9A8C\u901A\u8FC7")}catch(r){(0,o.log)(`[config validate] \u6267\u884C\u5931\u8D25: ${r.message}\uFF0C\u5F3A\u5236\u8986\u76D6\u914D\u7F6E`),l=!0}let e;if((0,o.log)(`\u8986\u76D6\u7528\u6237\u5DF2\u6709\u914D\u7F6E: ${l}`),!l&&c.default.existsSync(s.QBOT_CLAW_CONFIG_PATH))e=s.QBOT_CLAW_CONFIG_PATH,(0,o.log)(`\u4F7F\u7528\u5DF2\u6709\u914D\u7F6E\u6587\u4EF6: ${e}`);else{const r=u.default.join(s.NPM_GLOBAL_MODULES,s.NPM_PACKAGE_NAME,"preset-config.json");if(!c.default.existsSync(r)){(0,o.log)(`npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165: ${r}`);return}e=r,(0,o.log)(`\u4F7F\u7528 npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E: ${e}`)}let a;try{a=JSON.parse(c.default.readFileSync(e,"utf-8")),(0,o.log)(`\u5DF2\u8BFB\u53D6\u914D\u7F6E: ${e}`)}catch(r){(0,o.log)(`\u8BFB\u53D6\u914D\u7F6E\u5931\u8D25: ${e}\uFF0C${r.message}\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165`);return}a.gateway={...a.gateway??{},port:t},a.gateway.auth={...a.gateway.auth??{},token:n},(0,o.log)(`\u5DF2\u5199\u5165 gateway.port=${t}, gateway.token=${n}`),a.plugins=a.plugins??{},a.plugins.entries=a.plugins.entries??{},a.plugins.entries[w]=a.plugins.entries[w]??{},a.plugins.entries[w].config={...a.plugins.entries[w].config??{},wsPort:i},(0,o.log)(`\u5DF2\u5C06 ${w} wsPort=${i} \u5199\u5165\u914D\u7F6E`),c.default.writeFileSync(s.QBOT_CLAW_CONFIG_PATH,JSON.stringify(a,null,2),"utf-8"),(0,o.log)(`\u914D\u7F6E\u6587\u4EF6\u5DF2\u5199\u5165: ${s.QBOT_CLAW_CONFIG_PATH}`)}function h(){try{if(!c.default.existsSync(s.GALILEO_CONFIG_PATH)){(0,o.log)(`[galileo] \u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7: ${s.GALILEO_CONFIG_PATH}`);return}const t=c.default.readFileSync(s.GALILEO_CONFIG_PATH,"utf-8"),n=JSON.parse(t),i=n.galileo;if(!i){(0,o.log)("[galileo] \u914D\u7F6E\u6587\u4EF6\u4E2D\u7F3A\u5C11 galileo \u5B57\u6BB5\uFF0C\u8DF3\u8FC7");return}const l=process.env.QB_QIMEI36||"";i.userId==="userid"&&l?(i.userId=l,i.customAttributes={qimei36:l,guid:process.env.QB_GUID||""},c.default.writeFileSync(s.GALILEO_CONFIG_PATH,JSON.stringify(n,null,2),"utf-8"),(0,o.log)(`[galileo] \u5DF2\u5C06 userId \u66F4\u65B0\u4E3A ${l}\uFF0CcustomAttributes \u5DF2\u5199\u5165`)):(0,o.log)(`[galileo] \u65E0\u9700\u66F4\u65B0\uFF08userId=${i.userId}, QB_QIMEI36=${l||"\u7A7A"})`)}catch(t){(0,o.log)(`[galileo] \u8BFB\u53D6/\u5199\u5165\u914D\u7F6E\u5931\u8D25: ${t.message}`)}}async function y(t){const n=Date.now(),i=await(0,m.getQBotClawVersion)()??"unknown";try{h();const l=(0,d.readState)();let e;l.gatewayPort&&!await(0,d.isPortAvailable)(l.gatewayPort)?(e=l.gatewayPort,(0,o.log)(`\u68C0\u6D4B\u5230 QBotClaw gateway \u5DF2\u5728\u7AEF\u53E3 ${e} \u8FD0\u884C\uFF0C\u590D\u7528\u539F\u7AEF\u53E3`)):e=await(0,m.findAvailablePort)(),(0,o.log)(`\u540E\u53F0\u542F\u52A8 QBotClaw gateway run --port ${e} --force`);const a=await(0,m.findAvailablePort)(),r=(0,E.getOrCreateGatewayToken)();await Q(e,r,a,t),R(r);const g=(0,I.spawn)(s.QBOTCLAW_BIN,["gateway","run","--port",String(e),"--force"],{stdio:"ignore",shell:process.platform==="win32",windowsHide:!0,env:{...process.platform==="win32"?process.env:{PATH:s.NODE_BIN_DIR},HOME:process.env.HOME||process.env.USERPROFILE,USERPROFILE:process.env.USERPROFILE,OPENCLAW_NO_RESPAWN:"true",VENUS_API_KEY:"E9isWWfAr4VIFuIa5RbJaPxD@2040",OPENCLAW_TELEMETRY_GALIELO_GUID:process.env.QB_GUID||"",OPENCLAW_TELEMETRY_GALIELO_QIEMI36:process.env.QB_QIMEI36||"",QBOTCLAW_LLM_BASE_URL:`http://127.0.0.1:${l.port}/v1`,QBOTCLAW_LLM_API_KEY:A.proxyApiKey}});g.unref();const _=g.pid;(0,o.log)(`QBotClaw gateway \u5DF2\u5728\u540E\u53F0\u542F\u52A8\uFF0CPID: ${_}\uFF0C\u7AEF\u53E3: ${e}, token ${(0,E.getOrCreateGatewayToken)()}`),(0,d.writeState)({...(0,d.readState)(),gatewayPid:_,gatewayPort:e,mcpWsPort:a}),(0,p.report)({event_name:"qbot_claw_started",version:i,result:"1",cost_ms:String(Date.now()-n)})}catch(l){throw(0,p.report)({event_name:"qbot_claw_started",version:i,result:"0",cost_ms:String(Date.now()-n),error:l.message}),l}}function R(t){const n=u.default.join(s.QBOT_CLAW_DIR,".env"),i=`OPENCLAW_GATEWAY_TOKEN=${t}
5
5
  `;try{if(c.default.existsSync(n)){const a=c.default.readFileSync(n,"utf-8").split(`
6
6
  `).filter(r=>!r.startsWith("OPENCLAW_GATEWAY_TOKEN=")).filter(r=>r!=="").join(`
7
7
  `)+`
@@ -1,2 +1,2 @@
1
1
  "use strict";var k=exports&&exports.__importDefault||function(r){return r&&r.__esModule?r:{default:r}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.installQQBrowserSkill=d;const m=k(require("fs")),f=require("child_process"),q=require("./config"),t=require("./reportLog"),_=require("./report"),g="https://test.pypi.org/simple/",$="https://mirrors.tencent.com/pypi/simple/",p=!1,b=p?g:$,u=p?"test.pypi.org":"mirrors.tencent.com";function w(r,l,e){return new Promise(s=>{let n="";const a=(0,f.spawn)(r,l,{stdio:["ignore","pipe","pipe"],windowsHide:!0});a.stdout.on("data",o=>{const i=o.toString().trim();i&&((0,t.log)(`[qqbrowser-skill] ${i}`),e(`[qqbrowser-skill] ${i}`))}),a.stderr.on("data",o=>{const i=o.toString().trim();i&&(n+=i+`
2
- `,(0,t.log)(`[qqbrowser-skill] ${i}`),e(`[qqbrowser-skill] ${i}`))}),a.on("close",o=>{s({code:o??1,stderr:n})}),a.on("error",o=>{(0,t.log)(`[qqbrowser-skill] \u547D\u4EE4\u6267\u884C\u5931\u8D25: ${o.message}`),s({code:1,stderr:o.message})})})}const c="qqbrowser-skill";async function d(r){const l=Date.now();try{if((0,t.log)("[qqbrowser-skill] \u5F00\u59CB\u5B89\u88C5 support-trusted-host & force-reinstall"),r("[qqbrowser-skill] \u5F00\u59CB\u5B89\u88C5..."),process.platform==="darwin"){if(!m.default.existsSync(q.PYTHON_BIN)){(0,t.log)(`[qqbrowser-skill] \u5185\u7F6E Python \u4E0D\u5B58\u5728: ${q.PYTHON_BIN}\uFF0C\u8DF3\u8FC7\u5B89\u88C5`),r("[qqbrowser-skill] \u5185\u7F6E Python \u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7\u5B89\u88C5"),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:"\u5185\u7F6E Python \u4E0D\u5B58\u5728"});return}(0,t.log)(`[qqbrowser-skill] \u4F7F\u7528 pip \u5B89\u88C5/\u5347\u7EA7: ${c}`),r("[qqbrowser-skill] \u6B63\u5728\u901A\u8FC7 pip \u5B89\u88C5/\u5347\u7EA7...");const{code:e,stderr:s}=await w(q.PYTHON_BIN,["-m","pip","install","--force-reinstall","-i",b,"--trusted-host",u,"--prefix",q.PYTHON_DIR,c],r);if(e!==0){(0,t.log)(`[qqbrowser-skill] pip install \u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${e}\uFF0Cstderr: ${s}`),r(`[qqbrowser-skill] \u5B89\u88C5\u5931\u8D25\uFF08\u9000\u51FA\u7801: ${e}\uFF09`),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:s});return}try{(0,t.log)(`[qqbrowser-skill] \u6E05\u9664 Python \u76EE\u5F55\u9694\u79BB\u5C5E\u6027: ${q.PYTHON_DIR}`),r("[qqbrowser-skill] \u6B63\u5728\u6E05\u9664\u9694\u79BB\u5C5E\u6027...");const{code:n,stderr:a}=await w("/usr/bin/xattr",["-rd","com.apple.quarantine",q.PYTHON_DIR],r);n!==0?(0,t.log)(`[qqbrowser-skill] xattr \u6E05\u9664\u9694\u79BB\u5C5E\u6027\u5931\u8D25\uFF08\u9000\u51FA\u7801: ${n}\uFF09\uFF0Cstderr: ${a}`):(0,t.log)("[qqbrowser-skill] \u9694\u79BB\u5C5E\u6027\u6E05\u9664\u5B8C\u6210")}catch(n){(0,t.log)(`[qqbrowser-skill] xattr \u6267\u884C\u5F02\u5E38: ${n.message}`)}}else if(process.platform==="win32"){(0,t.log)(`[qqbrowser-skill] \u4F7F\u7528 pip \u5B89\u88C5/\u5347\u7EA7: ${c}`),r("[qqbrowser-skill] \u6B63\u5728\u901A\u8FC7 pip \u5B89\u88C5/\u5347\u7EA7...");const{code:e,stderr:s}=await w("pip",["install","--force-reinstall","-i",b,"--trusted-host",u,"--prefix",q.PYTHON_DIR,c],r);if(e!==0){(0,t.log)(`[qqbrowser-skill] pip install \u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${e}\uFF0Cstderr: ${s}`),r(`[qqbrowser-skill] \u5B89\u88C5\u5931\u8D25\uFF08\u9000\u51FA\u7801: ${e}\uFF09`),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:s});return}}else{(0,t.log)(`[qqbrowser-skill] \u4E0D\u652F\u6301\u7684\u5E73\u53F0: ${process.platform}\uFF0C\u8DF3\u8FC7\u5B89\u88C5`),r("[qqbrowser-skill] \u4E0D\u652F\u6301\u7684\u5E73\u53F0\uFF0C\u8DF3\u8FC7\u5B89\u88C5"),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:`\u4E0D\u652F\u6301\u7684\u5E73\u53F0: ${process.platform}`});return}(0,t.log)("[qqbrowser-skill] \u5B89\u88C5\u5B8C\u6210"),r("[qqbrowser-skill] \u5B89\u88C5\u5B8C\u6210"),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"1",cost_ms:String(Date.now()-l)})}catch(e){(0,t.log)(`[qqbrowser-skill] \u5B89\u88C5\u8FC7\u7A0B\u4E2D\u53D1\u751F\u5F02\u5E38: ${e.message}`),r(`[qqbrowser-skill] \u5B89\u88C5\u5F02\u5E38: ${e.message}`),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:e.message})}}
2
+ `,(0,t.log)(`[qqbrowser-skill] ${i}`),e(`[qqbrowser-skill] ${i}`))}),a.on("close",o=>{s({code:o??1,stderr:n})}),a.on("error",o=>{(0,t.log)(`[qqbrowser-skill] \u547D\u4EE4\u6267\u884C\u5931\u8D25: ${o.message}`),s({code:1,stderr:o.message})})})}const c="qqbrowser-skill";async function d(r){const l=Date.now();try{if((0,t.log)("[qqbrowser-skill] \u5F00\u59CB\u5B89\u88C5 support-trusted-host & force-reinstall"),r("[qqbrowser-skill] \u5F00\u59CB\u5B89\u88C5..."),process.platform==="darwin"){if(!m.default.existsSync(q.PYTHON_BIN)){(0,t.log)(`[qqbrowser-skill] \u5185\u7F6E Python \u4E0D\u5B58\u5728: ${q.PYTHON_BIN}\uFF0C\u8DF3\u8FC7\u5B89\u88C5`),r("[qqbrowser-skill] \u5185\u7F6E Python \u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7\u5B89\u88C5"),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:"\u5185\u7F6E Python \u4E0D\u5B58\u5728"});return}(0,t.log)(`[qqbrowser-skill] \u4F7F\u7528 pip \u5B89\u88C5/\u5347\u7EA7: ${c}`),r("[qqbrowser-skill] \u6B63\u5728\u901A\u8FC7 pip \u5B89\u88C5/\u5347\u7EA7...");const{code:e,stderr:s}=await w(q.PYTHON_BIN,["-m","pip","install","--force-reinstall","-i",b,"--trusted-host",u,"--prefix",q.PYTHON_DIR,c],r);if(e!==0){(0,t.log)(`[qqbrowser-skill] pip install \u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${e}\uFF0Cstderr: ${s}`),r(`[qqbrowser-skill] \u5B89\u88C5\u5931\u8D25\uFF08\u9000\u51FA\u7801: ${e}\uFF09`),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:s});return}try{(0,t.log)(`[qqbrowser-skill] \u6E05\u9664 Python \u76EE\u5F55\u9694\u79BB\u5C5E\u6027: ${q.PYTHON_DIR}`),r("[qqbrowser-skill] \u6B63\u5728\u6E05\u9664\u9694\u79BB\u5C5E\u6027...");const{code:n,stderr:a}=await w("/usr/bin/xattr",["-rd","com.apple.quarantine",q.PYTHON_DIR],r);n!==0?(0,t.log)(`[qqbrowser-skill] xattr \u6E05\u9664\u9694\u79BB\u5C5E\u6027\u5931\u8D25\uFF08\u9000\u51FA\u7801: ${n}\uFF09\uFF0Cstderr: ${a}`):(0,t.log)("[qqbrowser-skill] \u9694\u79BB\u5C5E\u6027\u6E05\u9664\u5B8C\u6210")}catch(n){(0,t.log)(`[qqbrowser-skill] xattr \u6267\u884C\u5F02\u5E38: ${n.message}`)}}else if(process.platform==="win32"){(0,t.log)(`[qqbrowser-skill] \u4F7F\u7528 pip \u5B89\u88C5/\u5347\u7EA7: ${c}`),r("[qqbrowser-skill] \u6B63\u5728\u901A\u8FC7 pip \u5B89\u88C5/\u5347\u7EA7...");const{code:e,stderr:s}=await w("pip",["install","--force-reinstall","-i",b,"--trusted-host",u,"--target",q.PYTHON_DIR,c],r);if(e!==0){(0,t.log)(`[qqbrowser-skill] pip install \u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${e}\uFF0Cstderr: ${s}`),r(`[qqbrowser-skill] \u5B89\u88C5\u5931\u8D25\uFF08\u9000\u51FA\u7801: ${e}\uFF09`),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:s});return}}else{(0,t.log)(`[qqbrowser-skill] \u4E0D\u652F\u6301\u7684\u5E73\u53F0: ${process.platform}\uFF0C\u8DF3\u8FC7\u5B89\u88C5`),r("[qqbrowser-skill] \u4E0D\u652F\u6301\u7684\u5E73\u53F0\uFF0C\u8DF3\u8FC7\u5B89\u88C5"),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:`\u4E0D\u652F\u6301\u7684\u5E73\u53F0: ${process.platform}`});return}(0,t.log)("[qqbrowser-skill] \u5B89\u88C5\u5B8C\u6210"),r("[qqbrowser-skill] \u5B89\u88C5\u5B8C\u6210"),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"1",cost_ms:String(Date.now()-l)})}catch(e){(0,t.log)(`[qqbrowser-skill] \u5B89\u88C5\u8FC7\u7A0B\u4E2D\u53D1\u751F\u5F02\u5E38: ${e.message}`),r(`[qqbrowser-skill] \u5B89\u88C5\u5F02\u5E38: ${e.message}`),(0,_.report)({event_name:"qbot_claw_qqbrowser_skill_install",result:"0",cost_ms:String(Date.now()-l),error:e.message})}}
package/dist/service.js CHANGED
@@ -1,6 +1,3 @@
1
- "use strict";var S=exports&&exports.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.readCurrentGatewayToken=f,exports.getOrCreateGatewayToken=v,exports.startService=$,exports.stopService=b;const w=S(require("fs")),k=require("crypto"),y=require("./server"),t=require("./state"),p=require("./config"),d=require("./build"),q=require("./installer"),O=require("./utils"),r=require("./reportLog"),n=require("./report");let _,i;const g="0526bec85002fe65ef10d33df0a8dfbe76917cd125f5a4ad";function f(){try{if(!w.default.existsSync(p.QBOT_CLAW_CONFIG_PATH))return(0,r.log)(`[service] \u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728: ${p.QBOT_CLAW_CONFIG_PATH}`),g;const e=w.default.readFileSync(p.QBOT_CLAW_CONFIG_PATH,"utf-8");return JSON.parse(e)?.gateway?.auth?.token||g}catch(e){return(0,r.log)(`[service] \u8BFB\u53D6\u914D\u7F6E\u6587\u4EF6 gateway.auth.token \u5931\u8D25: ${e.message}`),g}}function v(){return i||(i=require("crypto").randomBytes(24).toString("hex"),(0,r.log)(`[service] \u751F\u6210\u65B0\u7684 gateway token: ${i}`),i||f())}async function T(){const e=(0,t.readState)();if(!e.pid||!e.port)return null;try{process.kill(e.pid,0)}catch{return(0,t.clearState)(),null}if(await(0,t.isPortAvailable)(e.port))return(0,r.log)("\u7AEF\u53E3\u672A\u88AB\u5360\u7528\uFF0C\u8BF4\u660E\u72B6\u6001\u6587\u4EF6\u8FC7\u671F"),(0,t.clearState)(),null;const a=e.launcherVersion??null;if((0,r.log)(`[service] \u68C0\u6D4B\u5230\u6B63\u5728\u8FD0\u884C\u7684\u670D\u52A1\u7248\u672C: ${a??"unknown"}\uFF0C\u5F53\u524D\u7248\u672C: ${d.LAUNCHER_VERSION}`),a===d.LAUNCHER_VERSION)return(0,r.log)(`[service] \u7248\u672C\u4E00\u81F4\uFF0C\u590D\u7528\u5DF2\u6709\u670D\u52A1 (pid: ${e.pid}, port: ${e.port})`),!1;(0,r.log)(`[service] \u7248\u672C\u4E0D\u4E00\u81F4 (\u8FD0\u884C\u4E2D: ${a??"unknown"}, \u5F53\u524D: ${d.LAUNCHER_VERSION})\uFF0C\u6740\u6389\u65E7\u8FDB\u7A0B pid: ${e.pid}\uFF0C\u91CD\u65B0\u542F\u52A8`);try{process.kill(e.pid,"SIGTERM")}catch{}return(0,t.clearState)(),!0}async function $(e,o){if(await T()===!1){const s=(0,t.readState)();process.stdout.write(JSON.stringify({state:"success",pid:s.pid,port:s.port,gatewayToken:f()})+`
2
- `),process.stdout.uncork(),(0,r.log)(`[service] \u7248\u672C\u4E00\u81F4\uFF0C\u590D\u7528\u5DF2\u6709\u670D\u52A1 (pid: ${s.pid}, port: ${s.port})`);return}const c=await(0,t.findAvailablePort)();y.server.listen(c,"127.0.0.1",async()=>{_=(0,k.randomUUID)(),(0,t.writeState)({pid:process.pid,port:c,token:_,launcherVersion:d.LAUNCHER_VERSION,...e?{ppid:e}:{}}),(0,y.watchParentProcess)(e),(0,n.report)({event_name:"qbot_claw_try_start"});let s;if(w.default.existsSync(p.QBOTCLAW_BIN))try{const l=await(0,O.getQBotClawVersion)(),u=(0,t.readState)();l!==o?((0,r.log)(`[service] qbotclaw \u672C\u5730\u7248\u672C (${l??"unknown"}) \u4E0E\u671F\u671B\u7248\u672C (${o}) \u4E0D\u4E00\u81F4\uFF0C\u505C\u6B62\u5F53\u524D qbotclaw \u8FDB\u7A0B`),(0,n.report)({event_name:"qbot_claw_need_update"}),(0,t.stopGateway)()):u.gatewayPid&&u.gatewayPort?((0,r.log)(`[service] qbotclaw \u5DF2\u5728\u8FD0\u884C\uFF0Cpid: ${u.gatewayPid}, port: ${u.gatewayPort}`),s=f(),(0,n.report)({event_name:"qbot_claw_version_match"}),(0,n.report)({event_name:"qbot_claw_reuse"})):((0,r.log)("[service] \u68C0\u6D4B\u5230 qbotclaw\uFF0C\u7248\u672C\u5339\u914D\uFF0C\u81EA\u52A8\u542F\u52A8 gateway..."),(0,n.report)({event_name:"qbot_claw_version_match"}),await(0,q.configAndRunQBotClaw)(),s=v())}catch(l){(0,r.log)(`[service] \u81EA\u52A8\u542F\u52A8 gateway \u5931\u8D25: ${l.message}`)}else(0,r.log)("[service] qbotclaw \u672A\u5B89\u88C5\uFF0C\u4E0D\u81EA\u52A8\u542F\u52A8"),(0,n.report)({event_name:"qbot_claw_need_install"});(0,r.log)(`[service] \u670D\u52A1\u542F\u52A8\u6210\u529F\uFF0Cpid: ${process.pid}, port: ${c}, token: ${_}`),process.stdout.write(JSON.stringify({state:"success",pid:process.pid,port:c,token:_,gatewayToken:s})+`
3
- `),process.stdout.uncork()}),process.on("SIGTERM",()=>{(0,t.stopGateway)(),(0,t.clearState)(),(0,r.flushLogs)().finally(()=>{process.exit(0)})})}function b(){const e=(0,t.readState)();if(!e.pid){process.stdout.write(JSON.stringify({state:"err",pid:0,port:0})+`
4
- `),process.stdout.uncork();return}try{process.kill(e.pid,"SIGTERM");const o=e.pid,a=e.port??0;(0,t.clearState)(),process.stdout.write(JSON.stringify({state:"success",pid:o,port:a})+`
5
- `),process.stdout.uncork()}catch(o){o.code==="ESRCH"&&(0,t.clearState)(),process.stdout.write(JSON.stringify({state:"err",pid:0,port:0})+`
6
- `),process.stdout.uncork()}}
1
+ "use strict";var S=exports&&exports.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.readCurrentGatewayToken=w,exports.getOrCreateGatewayToken=v,exports.startService=b,exports.stopService=O;const f=S(require("fs")),k=require("crypto"),y=require("./server"),t=require("./state"),p=require("./config"),_=require("./build"),q=require("./installer"),T=require("./utils"),r=require("./reportLog"),o=require("./report");let d,s;const g="0526bec85002fe65ef10d33df0a8dfbe76917cd125f5a4ad";function w(){try{if(!f.default.existsSync(p.QBOT_CLAW_CONFIG_PATH))return(0,r.log)(`[service] \u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728: ${p.QBOT_CLAW_CONFIG_PATH}`),g;const e=f.default.readFileSync(p.QBOT_CLAW_CONFIG_PATH,"utf-8");return JSON.parse(e)?.gateway?.auth?.token||g}catch(e){return(0,r.log)(`[service] \u8BFB\u53D6\u914D\u7F6E\u6587\u4EF6 gateway.auth.token \u5931\u8D25: ${e.message}`),g}}function v(){return s||(s=require("crypto").randomBytes(24).toString("hex"),(0,r.log)(`[service] \u751F\u6210\u65B0\u7684 gateway token: ${s}`),s||w())}async function $(){const e=(0,t.readState)();if(!e.pid||!e.port)return null;try{process.kill(e.pid,0)}catch{return(0,t.clearState)(),null}if(await(0,t.isPortAvailable)(e.port))return(0,r.log)("\u7AEF\u53E3\u672A\u88AB\u5360\u7528\uFF0C\u8BF4\u660E\u72B6\u6001\u6587\u4EF6\u8FC7\u671F"),(0,t.clearState)(),null;const i=e.launcherVersion??null;if((0,r.log)(`[service] \u68C0\u6D4B\u5230\u6B63\u5728\u8FD0\u884C\u7684\u670D\u52A1\u7248\u672C: ${i??"unknown"}\uFF0C\u5F53\u524D\u7248\u672C: ${_.LAUNCHER_VERSION}`),i===_.LAUNCHER_VERSION)return(0,r.log)(`[service] \u7248\u672C\u4E00\u81F4\uFF0C\u590D\u7528\u5DF2\u6709\u670D\u52A1 (pid: ${e.pid}, port: ${e.port})`),!1;(0,r.log)(`[service] \u7248\u672C\u4E0D\u4E00\u81F4 (\u8FD0\u884C\u4E2D: ${i??"unknown"}, \u5F53\u524D: ${_.LAUNCHER_VERSION})\uFF0C\u6740\u6389\u65E7\u8FDB\u7A0B pid: ${e.pid}\uFF0C\u91CD\u65B0\u542F\u52A8`);try{process.kill(e.pid,"SIGTERM")}catch{}return(0,t.clearState)(),!0}async function b(e,n){if(await $()===!1){const a=(0,t.readState)();process.stdout.write(JSON.stringify({state:"success",pid:a.pid,port:a.port,gatewayToken:w()})+`
2
+ `),process.stdout.uncork(),(0,r.log)(`[service] \u7248\u672C\u4E00\u81F4\uFF0C\u590D\u7528\u5DF2\u6709\u670D\u52A1 (pid: ${a.pid}, port: ${a.port})`);return}const c=await(0,t.findAvailablePort)();y.server.listen(c,"127.0.0.1",async()=>{d=(0,k.randomUUID)(),(0,t.writeState)({pid:process.pid,port:c,token:d,launcherVersion:_.LAUNCHER_VERSION,...e?{ppid:e}:{}}),(0,y.watchParentProcess)(e),(0,o.report)({event_name:"qbot_claw_try_start"});let a;if(f.default.existsSync(p.QBOTCLAW_BIN))try{const l=await(0,T.getQBotClawVersion)(),u=(0,t.readState)();l!==n?((0,r.log)(`[service] qbotclaw \u672C\u5730\u7248\u672C (${l??"unknown"}) \u4E0E\u671F\u671B\u7248\u672C (${n}) \u4E0D\u4E00\u81F4\uFF0C\u505C\u6B62\u5F53\u524D qbotclaw \u8FDB\u7A0B`),(0,o.report)({event_name:"qbot_claw_need_update"}),(0,t.stopGateway)()):u.gatewayPid&&u.gatewayPort?((0,r.log)(`[service] qbotclaw \u5DF2\u5728\u8FD0\u884C\uFF0Cpid: ${u.gatewayPid}, port: ${u.gatewayPort}`),a=w(),(0,o.report)({event_name:"qbot_claw_version_match"}),(0,o.report)({event_name:"qbot_claw_reuse"})):((0,r.log)("[service] \u68C0\u6D4B\u5230 qbotclaw\uFF0C\u7248\u672C\u5339\u914D\uFF0C\u81EA\u52A8\u542F\u52A8 gateway..."),(0,o.report)({event_name:"qbot_claw_version_match"}),await(0,q.configAndRunQBotClaw)(),a=v())}catch(l){(0,r.log)(`[service] \u81EA\u52A8\u542F\u52A8 gateway \u5931\u8D25: ${l.message}`)}else(0,r.log)("[service] qbotclaw \u672A\u5B89\u88C5\uFF0C\u4E0D\u81EA\u52A8\u542F\u52A8"),(0,o.report)({event_name:"qbot_claw_need_install"});(0,r.log)(`[service] \u670D\u52A1\u542F\u52A8\u6210\u529F\uFF0Cpid: ${process.pid}, port: ${c}, token: ${d}`),process.stdout.write(JSON.stringify({state:"success",pid:process.pid,port:c,token:d,gatewayToken:a})+`
3
+ `),process.stdout.uncork()}),process.on("SIGTERM",()=>{(0,t.stopGateway)(),(0,t.clearState)(),(0,r.flushLogs)().finally(()=>{process.exit(0)})})}function O(){(0,t.stopGateway)();const e=(0,t.readState)();if(!e.pid){(0,t.clearState)();return}try{process.kill(e.pid,"SIGTERM")}catch{}(0,t.clearState)()}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@qqbrowser/qbot-claw-launcher",
3
- "version": "0.10.4",
3
+ "version": "0.10.6",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "bin": {