@qqbrowser/qbot-claw-launcher 0.9.60 → 0.9.62

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.verifyServiceToken=u,exports.verifyOrigin=s,exports.authenticateRequest=o;const i=["https://quickstart.imtt.qq.com","https://quickstarttest.imtt.qq.com","https://browser.qq.com"];function u(t,e){return!0}function s(t){let e=t.headers.origin;if(!e){const r=t.headers.referer;if(r)try{e=new URL(r).origin}catch{}}if(!e||e.startsWith("chrome-extension://")||e.startsWith("moz-extension://"))return!0;try{const r=new URL(e).origin;return i.some(n=>{try{return new URL(n).origin===r}catch{return!1}})}catch{return!1}}function o(t,e){return u(t,e)?s(t)?{ok:!0,statusCode:200,message:""}:{ok:!1,statusCode:403,message:"\u8BF7\u6C42\u6765\u6E90\u4E0D\u5728\u5141\u8BB8\u5217\u8868\u4E2D"}:{ok:!1,statusCode:401,message:"\u672A\u6388\u6743\u8BBF\u95EE\uFF1A\u7F3A\u5C11\u6709\u6548\u7684 ServiceToken"}}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.verifyServiceToken=s,exports.verifyOrigin=n,exports.authenticateRequest=u;const o=["https://quickstart.imtt.qq.com","https://quickstarttest.imtt.qq.com","https://browser.qq.com"];function s(t,e){return!0}function n(t){let e=t.headers.origin;if(!e){const r=t.headers.referer;if(r)try{e=new URL(r).origin}catch{}}if(!e||e.startsWith("chrome-extension://")||e.startsWith("moz-extension://"))return!0;try{const r=new URL(e).origin;return o.some(i=>{try{return new URL(i).origin===r}catch{return!1}})}catch{return!1}}function u(t,e){return s(t,e)?n(t)?{ok:!0,statusCode:200,message:""}:{ok:!1,statusCode:403,message:"\u8BF7\u6C42\u6765\u6E90\u4E0D\u5728\u5141\u8BB8\u5217\u8868\u4E2D"}:{ok:!1,statusCode:401,message:"\u672A\u6388\u6743\u8BBF\u95EE\uFF1A\u7F3A\u5C11\u6709\u6548\u7684 ServiceToken"}}
package/dist/config.js CHANGED
@@ -1 +1 @@
1
- "use strict";var n=exports&&exports.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.DEFAULT_MCP_HTTP_PORT=exports.SESSIONS_FILE=exports.STATE_FILE=exports.MCPORTER_BIN=exports.OPENCLAW_BIN=exports.QBOTCLAW_BIN=exports.NPM_GLOBAL_MODULES=exports.NPM_PACKAGE_NAME=exports.QBOT_CLAW_LOG_PATH=exports.QBOT_CLAW_CONFIG_PATH=exports.NODE_BIN_DIR=exports.NPM_RC=exports.NPM_BIN=exports.PYTHON_BIN=exports.NODE_BIN=exports.QBOT_CLAW_DIR=void 0;const _=n(require("path")),o=n(require("os"));exports.QBOT_CLAW_DIR=_.default.join(o.default.homedir(),".qbotclaw"),exports.NODE_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","node"),exports.PYTHON_BIN=_.default.join(exports.QBOT_CLAW_DIR,"python","bin","python3"),exports.NPM_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","npm"),exports.NPM_RC=_.default.join(exports.QBOT_CLAW_DIR,"node",".npmrc"),exports.NODE_BIN_DIR=_.default.dirname(exports.NODE_BIN),exports.QBOT_CLAW_CONFIG_PATH=_.default.join(exports.QBOT_CLAW_DIR,".openclaw-qbot.json"),exports.QBOT_CLAW_LOG_PATH=_.default.join(exports.QBOT_CLAW_DIR,"launcher.log"),exports.NPM_PACKAGE_NAME="@qqbrowser/openclaw-qbot",exports.NPM_GLOBAL_MODULES=_.default.join(exports.QBOT_CLAW_DIR,"node","lib","node_modules"),exports.QBOTCLAW_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","qb-qbot-claw"),exports.OPENCLAW_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","openclaw"),exports.MCPORTER_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","mcporter"),exports.STATE_FILE=_.default.join(exports.QBOT_CLAW_DIR,"launcher.json"),exports.SESSIONS_FILE=_.default.join(exports.QBOT_CLAW_DIR,"agents","main","sessions","sessions.json"),exports.DEFAULT_MCP_HTTP_PORT=38789;
1
+ "use strict";var n=exports&&exports.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.DEFAULT_MCP_HTTP_PORT=exports.SESSIONS_FILE=exports.STATE_FILE=exports.MCPORTER_BIN=exports.OPENCLAW_BIN=exports.QBOTCLAW_BIN=exports.NPM_GLOBAL_MODULES=exports.NPM_PACKAGE_NAME=exports.QBOT_CLAW_CONFIG_PATH=exports.NODE_BIN_DIR=exports.NPM_RC=exports.NPM_BIN=exports.PYTHON_BIN=exports.NODE_BIN=exports.QBOT_CLAW_DIR=void 0;const _=n(require("path")),o=n(require("os"));exports.QBOT_CLAW_DIR=_.default.join(o.default.homedir(),".qbotclaw"),exports.NODE_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","node"),exports.PYTHON_BIN=_.default.join(exports.QBOT_CLAW_DIR,"python","bin","python3"),exports.NPM_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","npm"),exports.NPM_RC=_.default.join(exports.QBOT_CLAW_DIR,"node",".npmrc"),exports.NODE_BIN_DIR=_.default.dirname(exports.NODE_BIN),exports.QBOT_CLAW_CONFIG_PATH=_.default.join(exports.QBOT_CLAW_DIR,".openclaw-qbot.json"),exports.NPM_PACKAGE_NAME="@qqbrowser/openclaw-qbot",exports.NPM_GLOBAL_MODULES=_.default.join(exports.QBOT_CLAW_DIR,"node","lib","node_modules"),exports.QBOTCLAW_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","qb-qbot-claw"),exports.OPENCLAW_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","openclaw"),exports.MCPORTER_BIN=_.default.join(exports.QBOT_CLAW_DIR,"node","bin","mcporter"),exports.STATE_FILE=_.default.join(exports.QBOT_CLAW_DIR,"launcher.json"),exports.SESSIONS_FILE=_.default.join(exports.QBOT_CLAW_DIR,"agents","main","sessions","sessions.json"),exports.DEFAULT_MCP_HTTP_PORT=38789;
@@ -1,33 +1,33 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.isFilePickerBusy=$,exports.showFilePicker=B;const f=require("child_process"),E=6e4;let d=!1;function $(){return d}async function B(r={}){if(d)throw new Error("\u5DF2\u6709\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u6B63\u5728\u663E\u793A");d=!0;try{const l=process.platform;switch(l){case"darwin":return await y(r);case"win32":return await x(r);case"linux":return await O(r);default:throw new Error(`\u4E0D\u652F\u6301\u7684\u64CD\u4F5C\u7CFB\u7EDF\u5E73\u53F0: ${l}`)}}finally{d=!1}}function y(r){const{extensions:l=[],multiple:o=!1,title:c="\u9009\u62E9\u6587\u4EF6",allowDirectory:F=!1}=r;let t;if(F)t=`choose folder with prompt "${h(c)}"`,o&&(t+=" with multiple selections allowed");else if(t=`choose file with prompt "${h(c)}"`,o&&(t+=" with multiple selections allowed"),l.length>0){const u=l.map(e=>`"${e.replace(/^\./,"")}"`).join(", ");t+=` of type {${u}}`}const i=o?`set selectedItems to (${t})
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.isFilePickerBusy=P,exports.showFilePicker=O;const w=require("child_process"),d=3e5;let h=!1;function P(){return h}async function O(s={}){if(h)throw new Error("\u5DF2\u6709\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u6B63\u5728\u663E\u793A");h=!0;try{const n=process.platform;switch(n){case"darwin":return await k(s);case"win32":return await S(s);case"linux":return await E(s);default:throw new Error(`\u4E0D\u652F\u6301\u7684\u64CD\u4F5C\u7CFB\u7EDF\u5E73\u53F0: ${n}`)}}finally{h=!1}}function k(s){const{extensions:n=[],multiple:a=!1,title:p="\u9009\u62E9\u6587\u4EF6",allowDirectory:f=!1}=s;let e;if(f)e=`choose folder with prompt "${$(p)}"`,a&&(e+=" with multiple selections allowed");else if(e=`choose file with prompt "${$(p)}"`,a&&(e+=" with multiple selections allowed"),n.length>0){const l=n.map(t=>`"${t.replace(/^\./,"")}"`).join(", ");e+=` of type {${l}}`}const i=a?`set selectedItems to (${e})
2
2
  set posixPaths to ""
3
3
  repeat with anItem in selectedItems
4
4
  set posixPaths to posixPaths & POSIX path of anItem & linefeed
5
5
  end repeat
6
- return posixPaths`:`set selectedItem to (${t})
7
- return POSIX path of selectedItem`;return new Promise((u,e)=>{const p=(0,f.execFile)("osascript",["-e",i],{timeout:E},(s,a,n)=>{if(s){if(s.killed){e(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}if(n&&n.includes("User canceled")){u(null);return}if(s.code===1){u(null);return}e(new Error(`macOS \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${n||s.message}`));return}const m=a.trim().split(`
8
- `).map(g=>g.trim()).filter(Boolean);u(m.length>0?m:null)})})}function h(r){return r.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}function x(r){const{extensions:l=[],multiple:o=!1,title:c="\u9009\u62E9\u6587\u4EF6",allowDirectory:F=!1}=r;let t;if(F)t=`
6
+ return posixPaths`:`set selectedItem to (${e})
7
+ return POSIX path of selectedItem`;return new Promise((l,t)=>{const o=(0,w.execFile)("osascript",["-e",i],{timeout:d},(u,c,r)=>{if(u){if(u.killed){t(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}if(r&&r.includes("User canceled")){l(null);return}if(u.code===1){l(null);return}t(new Error(`macOS \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${r||u.message}`));return}const m=c.trim().split(`
8
+ `).map(F=>F.trim()).filter(Boolean);l(m.length>0?m:null)})})}function $(s){return s.replace(/\\/g,"\\\\").replace(/"/g,'\\"')}function S(s){const{extensions:n=[],multiple:a=!1,title:p="\u9009\u62E9\u6587\u4EF6",allowDirectory:f=!1}=s;let e;if(f)e=`
9
9
  Add-Type -AssemblyName System.Windows.Forms
10
10
  $dialog = New-Object System.Windows.Forms.FolderBrowserDialog
11
- $dialog.Description = '${w(c)}'
11
+ $dialog.Description = '${g(p)}'
12
12
  $dialog.ShowNewFolderButton = $true
13
13
  $result = $dialog.ShowDialog()
14
14
  if ($result -eq [System.Windows.Forms.DialogResult]::OK) {
15
15
  Write-Output $dialog.SelectedPath
16
16
  } else {
17
17
  Write-Output ''
18
- }`;else{let i="\u6240\u6709\u6587\u4EF6 (*.*)|*.*";if(l.length>0){const u=l.map(e=>`*${e.startsWith(".")?e:"."+e}`).join(";");i=`\u5141\u8BB8\u7684\u6587\u4EF6\u7C7B\u578B (${l.map(e=>e.startsWith(".")?e:"."+e).join(", ")})|${u}|\u6240\u6709\u6587\u4EF6 (*.*)|*.*`}t=`
18
+ }`;else{let i="\u6240\u6709\u6587\u4EF6 (*.*)|*.*";if(n.length>0){const l=n.map(o=>`*${o.startsWith(".")?o:"."+o}`).join(";");i=`\u5141\u8BB8\u7684\u6587\u4EF6\u7C7B\u578B (${n.map(o=>o.startsWith(".")?o:"."+o).join(", ")})|${l}|\u6240\u6709\u6587\u4EF6 (*.*)|*.*`}e=`
19
19
  Add-Type -AssemblyName System.Windows.Forms
20
20
  $dialog = New-Object System.Windows.Forms.OpenFileDialog
21
- $dialog.Title = '${w(c)}'
22
- $dialog.Filter = '${w(i)}'
23
- $dialog.Multiselect = $${o?"true":"false"}
21
+ $dialog.Title = '${g(p)}'
22
+ $dialog.Filter = '${g(i)}'
23
+ $dialog.Multiselect = $${a?"true":"false"}
24
24
  $result = $dialog.ShowDialog()
25
25
  if ($result -eq [System.Windows.Forms.DialogResult]::OK) {
26
26
  $dialog.FileNames | ForEach-Object { Write-Output $_ }
27
27
  } else {
28
28
  Write-Output ''
29
- }`}return new Promise((i,u)=>{(0,f.execFile)("powershell.exe",["-NoProfile","-NonInteractive","-Command",t],{timeout:E},(e,p,s)=>{if(e){if(e.killed){u(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}u(new Error(`Windows \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${s||e.message}`));return}const a=p.trim();if(!a){i(null);return}const n=a.split(`
30
- `).map(m=>m.trim()).filter(Boolean);i(n.length>0?n:null)})})}function w(r){return r.replace(/'/g,"''")}async function O(r){if(await D("zenity"))return P(r);if(await D("kdialog"))return W(r);throw new Error("Linux \u7CFB\u7EDF\u672A\u5B89\u88C5 zenity \u6216 kdialog\uFF0C\u65E0\u6CD5\u5F39\u51FA\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u3002\u8BF7\u5B89\u88C5\u5176\u4E2D\u4E4B\u4E00\uFF1Asudo apt install zenity \u6216 sudo apt install kdialog")}function D(r){return new Promise(l=>{(0,f.execFile)("which",[r],o=>{l(!o)})})}function P(r){const{extensions:l=[],multiple:o=!1,title:c="\u9009\u62E9\u6587\u4EF6",allowDirectory:F=!1}=r,t=["--file-selection",`--title=${c}`];if(F&&t.push("--directory"),o&&t.push("--multiple",`--separator=
31
- `),!F&&l.length>0){const i=l.map(u=>`*${u.startsWith(".")?u:"."+u}`).join(" ");t.push(`--file-filter=\u5141\u8BB8\u7684\u6587\u4EF6\u7C7B\u578B | ${i}`),t.push("--file-filter=\u6240\u6709\u6587\u4EF6 | *")}return new Promise((i,u)=>{(0,f.execFile)("zenity",t,{timeout:E},(e,p,s)=>{if(e){if(e.killed){u(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}if(e.code===1){i(null);return}u(new Error(`zenity \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${s||e.message}`));return}const a=p.trim();if(!a){i(null);return}const n=a.split(`
32
- `).map(m=>m.trim()).filter(Boolean);i(n.length>0?n:null)})})}function W(r){const{extensions:l=[],multiple:o=!1,title:c="\u9009\u62E9\u6587\u4EF6",allowDirectory:F=!1}=r;let t;if(F)t=["--getexistingdirectory",process.env.HOME||"/"];else{let i="";l.length>0&&(i=`${l.map(u=>`*${u.startsWith(".")?u:"."+u}`).join(" ")} | \u5141\u8BB8\u7684\u6587\u4EF6\u7C7B\u578B`),o?t=["--getopenfilename",process.env.HOME||"/",i,"--multiple","--separate-output"]:t=["--getopenfilename",process.env.HOME||"/",i]}return t.push("--title",c),new Promise((i,u)=>{(0,f.execFile)("kdialog",t,{timeout:E},(e,p,s)=>{if(e){if(e.killed){u(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}if(e.code===1){i(null);return}u(new Error(`kdialog \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${s||e.message}`));return}const a=p.trim();if(!a){i(null);return}const n=a.split(`
33
- `).map(m=>m.trim()).filter(Boolean);i(n.length>0?n:null)})})}
29
+ }`}return new Promise((i,l)=>{(0,w.execFile)("powershell.exe",["-NoProfile","-NonInteractive","-Command",e],{timeout:d},(t,o,u)=>{if(t){if(t.killed){l(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}l(new Error(`Windows \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${u||t.message}`));return}const c=o.trim();if(!c){i(null);return}const r=c.split(`
30
+ `).map(m=>m.trim()).filter(Boolean);i(r.length>0?r:null)})})}function g(s){return s.replace(/'/g,"''")}async function E(s){if(await y("zenity"))return W(s);if(await y("kdialog"))return D(s);throw new Error("Linux \u7CFB\u7EDF\u672A\u5B89\u88C5 zenity \u6216 kdialog\uFF0C\u65E0\u6CD5\u5F39\u51FA\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u3002\u8BF7\u5B89\u88C5\u5176\u4E2D\u4E4B\u4E00\uFF1Asudo apt install zenity \u6216 sudo apt install kdialog")}function y(s){return new Promise(n=>{(0,w.execFile)("which",[s],a=>{n(!a)})})}function W(s){const{extensions:n=[],multiple:a=!1,title:p="\u9009\u62E9\u6587\u4EF6",allowDirectory:f=!1}=s,e=["--file-selection",`--title=${p}`];if(f&&e.push("--directory"),a&&e.push("--multiple",`--separator=
31
+ `),!f&&n.length>0){const i=n.map(l=>`*${l.startsWith(".")?l:"."+l}`).join(" ");e.push(`--file-filter=\u5141\u8BB8\u7684\u6587\u4EF6\u7C7B\u578B | ${i}`),e.push("--file-filter=\u6240\u6709\u6587\u4EF6 | *")}return new Promise((i,l)=>{(0,w.execFile)("zenity",e,{timeout:d},(t,o,u)=>{if(t){if(t.killed){l(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}if(t.code===1){i(null);return}l(new Error(`zenity \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${u||t.message}`));return}const c=o.trim();if(!c){i(null);return}const r=c.split(`
32
+ `).map(m=>m.trim()).filter(Boolean);i(r.length>0?r:null)})})}function D(s){const{extensions:n=[],multiple:a=!1,title:p="\u9009\u62E9\u6587\u4EF6",allowDirectory:f=!1}=s;let e;if(f)e=["--getexistingdirectory",process.env.HOME||"/"];else{let i="";n.length>0&&(i=`${n.map(t=>`*${t.startsWith(".")?t:"."+t}`).join(" ")} | \u5141\u8BB8\u7684\u6587\u4EF6\u7C7B\u578B`),a?e=["--getopenfilename",process.env.HOME||"/",i,"--multiple","--separate-output"]:e=["--getopenfilename",process.env.HOME||"/",i]}return e.push("--title",p),new Promise((i,l)=>{(0,w.execFile)("kdialog",e,{timeout:d},(t,o,u)=>{if(t){if(t.killed){l(new Error("\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u8D85\u65F6\uFF0860\u79D2\uFF09"));return}if(t.code===1){i(null);return}l(new Error(`kdialog \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${u||t.message}`));return}const c=o.trim();if(!c){i(null);return}const r=c.split(`
33
+ `).map(m=>m.trim()).filter(Boolean);i(r.length>0?r:null)})})}
@@ -1 +1 @@
1
- "use strict";var r=exports&&exports.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.BLOCKED_DIRS=void 0,exports.getMimeType=s,exports.validateFilePath=p,exports.readFileInfo=m,exports.readFileAsBase64=g;const n=r(require("fs")),o=r(require("path")),v=require("./config");exports.BLOCKED_DIRS=process.platform==="win32"?["C:\\Windows","C:\\Program Files","C:\\Program Files (x86)","C:\\ProgramData"]:["/etc","/var","/usr","/bin","/sbin","/boot","/root","/sys","/proc","/dev","/lib","/lib64"];const x=o.default.basename(v.QBOT_CLAW_DIR),E={".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".txt":"text/plain",".csv":"text/csv",".rtf":"application/rtf",".md":"text/markdown",".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".bmp":"image/bmp",".svg":"image/svg+xml",".webp":"image/webp",".ico":"image/x-icon",".tiff":"image/tiff",".tif":"image/tiff",".mp3":"audio/mpeg",".wav":"audio/wav",".ogg":"audio/ogg",".flac":"audio/flac",".aac":"audio/aac",".mp4":"video/mp4",".avi":"video/x-msvideo",".mov":"video/quicktime",".wmv":"video/x-ms-wmv",".webm":"video/webm",".mkv":"video/x-matroska",".zip":"application/zip",".rar":"application/vnd.rar",".7z":"application/x-7z-compressed",".tar":"application/x-tar",".gz":"application/gzip",".bz2":"application/x-bzip2",".json":"application/json",".xml":"application/xml",".html":"text/html",".htm":"text/html",".css":"text/css",".js":"application/javascript",".ts":"application/typescript",".py":"text/x-python",".java":"text/x-java-source",".c":"text/x-c",".cpp":"text/x-c++src",".h":"text/x-c",".sh":"application/x-sh",".yaml":"text/yaml",".yml":"text/yaml",".toml":"application/toml",".ini":"text/plain",".log":"text/plain",".wasm":"application/wasm",".exe":"application/x-msdownload",".dmg":"application/x-apple-diskimage",".iso":"application/x-iso9660-image"};function s(t){const a=o.default.extname(t).toLowerCase();return E[a]||"application/octet-stream"}function p(t){if(t.includes("\0"))return{valid:!1,reason:"\u8DEF\u5F84\u5305\u542B\u975E\u6CD5\u5B57\u7B26"};const a=o.default.resolve(t),e=l(a);if(!e.valid)return e;const i=c(a);if(!i.valid)return i;if(!n.default.existsSync(a))return{valid:!1,reason:`\u6587\u4EF6\u6216\u76EE\u5F55\u4E0D\u5B58\u5728: ${a}`};let u;try{u=n.default.realpathSync(a)}catch{return{valid:!1,reason:"\u65E0\u6CD5\u89E3\u6790\u6587\u4EF6\u771F\u5B9E\u8DEF\u5F84"}}if(u!==a){if(!l(u).valid)return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55"};if(!c(u).valid)return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u9690\u85CF\u6587\u4EF6\u6216\u76EE\u5F55"}}return{valid:!0}}function l(t){const a=t.toLowerCase();for(const e of exports.BLOCKED_DIRS)if(a===e.toLowerCase()||a.startsWith(e.toLowerCase()+o.default.sep))return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55"};return{valid:!0}}function c(t){const a=t.split(o.default.sep);for(const e of a)if(e.startsWith(".")&&e!=="."&&e!==".."&&e!==x)return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u9690\u85CF\u6587\u4EF6\u6216\u76EE\u5F55"};return{valid:!0}}function m(t,a){const e=p(t);if(!e.valid)return{ok:!1,path:t,reason:e.reason};const i=o.default.resolve(t);let u;try{u=n.default.statSync(i)}catch{return{ok:!1,path:t,reason:"\u65E0\u6CD5\u8BFB\u53D6\u6587\u4EF6\u4FE1\u606F"}}if(u.isDirectory())return{ok:!1,path:t,reason:"\u8DEF\u5F84\u6307\u5411\u4E00\u4E2A\u76EE\u5F55\uFF0C\u4E0D\u662F\u6587\u4EF6"};if(u.size>a){const f=(u.size/1024/1024).toFixed(2),F=(a/1024/1024).toFixed(2);return{ok:!1,path:t,reason:`\u6587\u4EF6\u5927\u5C0F (${f}MB) \u8D85\u8FC7\u9650\u5236 (${F}MB)`}}const d=s(i);return{ok:!0,name:o.default.basename(i),path:i,size:u.size,mimeType:d}}function g(t,a){const e=m(t,a);if(!e.ok)return e;try{const i=n.default.readFileSync(e.path);return{...e,content:i.toString("base64")}}catch(i){return{ok:!1,path:t,reason:`\u6587\u4EF6\u8BFB\u53D6\u5931\u8D25: ${i.message}`}}}
1
+ "use strict";var c=exports&&exports.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.BLOCKED_DIRS=void 0,exports.getMimeType=p,exports.validateFilePath=d,exports.readFileInfo=u,exports.readFileAsBase64=k;const s=c(require("fs")),n=c(require("path")),x=require("./config");exports.BLOCKED_DIRS=process.platform==="win32"?["C:\\Windows","C:\\Program Files","C:\\Program Files (x86)","C:\\ProgramData"]:["/etc","/var","/usr","/bin","/sbin","/boot","/root","/sys","/proc","/dev","/lib","/lib64"];const g=n.default.basename(x.QBOT_CLAW_DIR),h={".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".txt":"text/plain",".csv":"text/csv",".rtf":"application/rtf",".md":"text/markdown",".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".bmp":"image/bmp",".svg":"image/svg+xml",".webp":"image/webp",".ico":"image/x-icon",".tiff":"image/tiff",".tif":"image/tiff",".mp3":"audio/mpeg",".wav":"audio/wav",".ogg":"audio/ogg",".flac":"audio/flac",".aac":"audio/aac",".mp4":"video/mp4",".avi":"video/x-msvideo",".mov":"video/quicktime",".wmv":"video/x-ms-wmv",".webm":"video/webm",".mkv":"video/x-matroska",".zip":"application/zip",".rar":"application/vnd.rar",".7z":"application/x-7z-compressed",".tar":"application/x-tar",".gz":"application/gzip",".bz2":"application/x-bzip2",".json":"application/json",".xml":"application/xml",".html":"text/html",".htm":"text/html",".css":"text/css",".js":"application/javascript",".ts":"application/typescript",".py":"text/x-python",".java":"text/x-java-source",".c":"text/x-c",".cpp":"text/x-c++src",".h":"text/x-c",".sh":"application/x-sh",".yaml":"text/yaml",".yml":"text/yaml",".toml":"application/toml",".ini":"text/plain",".log":"text/plain",".wasm":"application/wasm",".exe":"application/x-msdownload",".dmg":"application/x-apple-diskimage",".iso":"application/x-iso9660-image"};function p(e){const t=n.default.extname(e).toLowerCase();return h[t]||"application/octet-stream"}function d(e){if(e.includes("\0"))return{valid:!1,reason:"\u8DEF\u5F84\u5305\u542B\u975E\u6CD5\u5B57\u7B26"};const t=n.default.resolve(e),a=m(t);if(!a.valid)return a;const i=f(t);if(!i.valid)return i;if(!s.default.existsSync(t))return{valid:!1,reason:`\u6587\u4EF6\u6216\u76EE\u5F55\u4E0D\u5B58\u5728: ${t}`};let o;try{o=s.default.realpathSync(t)}catch{return{valid:!1,reason:"\u65E0\u6CD5\u89E3\u6790\u6587\u4EF6\u771F\u5B9E\u8DEF\u5F84"}}if(o!==t){if(!m(o).valid)return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55"};if(!f(o).valid)return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u9690\u85CF\u6587\u4EF6\u6216\u76EE\u5F55"}}return{valid:!0}}function m(e){const t=e.toLowerCase();for(const a of exports.BLOCKED_DIRS)if(t===a.toLowerCase()||t.startsWith(a.toLowerCase()+n.default.sep))return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55"};return{valid:!0}}function f(e){const t=e.split(n.default.sep);for(const a of t)if(a.startsWith(".")&&a!=="."&&a!==".."&&a!==g)return{valid:!1,reason:"\u7981\u6B62\u8BBF\u95EE\u9690\u85CF\u6587\u4EF6\u6216\u76EE\u5F55"};return{valid:!0}}function u(e,t){const a=d(e);if(!a.valid)return{ok:!1,path:e,reason:a.reason};const i=n.default.resolve(e);let o;try{o=s.default.statSync(i)}catch{return{ok:!1,path:e,reason:"\u65E0\u6CD5\u8BFB\u53D6\u6587\u4EF6\u4FE1\u606F"}}if(o.isDirectory())return{ok:!1,path:e,reason:"\u8DEF\u5F84\u6307\u5411\u4E00\u4E2A\u76EE\u5F55\uFF0C\u4E0D\u662F\u6587\u4EF6"};if(o.size>t){const l=(o.size/1024/1024).toFixed(2),v=(t/1024/1024).toFixed(2);return{ok:!1,path:e,reason:`\u6587\u4EF6\u5927\u5C0F (${l}MB) \u8D85\u8FC7\u9650\u5236 (${v}MB)`}}const r=p(i);return{ok:!0,name:n.default.basename(i),path:i,size:o.size,mimeType:r}}function k(e,t){const a=u(e,t);if(!a.ok)return a;try{const i=s.default.readFileSync(a.path);return{...a,content:i.toString("base64")}}catch(i){return{ok:!1,path:e,reason:`\u6587\u4EF6\u8BFB\u53D6\u5931\u8D25: ${i.message}`}}}
package/dist/installer.js CHANGED
@@ -1,6 +1,6 @@
1
- "use strict";var d=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=C,exports.configAndRunQBotClaw=N,exports.runInstall=B;const c=d(require("fs")),u=d(require("path")),_=require("child_process"),r=require("./config"),w=require("./utils"),p=require("./state"),f=require("./quarantine"),a=require("./reportLog"),P=require("./service");function g(t,o,s,i){if(t&&t.writable){const e=o>0?Math.round(s/o*1e4)/100:0;try{t.write(JSON.stringify({status:"downloading",progress:e,totalSteps:o,currentStep:s,message:i})+`
2
- `)}catch{}}}exports.installState={status:"idle",message:"\u672A\u5F00\u59CB"},exports.isInstalling=!1,exports.PYTHON_DIR=u.default.join(r.QBOT_CLAW_DIR,"python");function C(t,o){return new Promise(s=>{const i=(0,_.spawn)(r.QBOTCLAW_BIN,t,{stdio:["ignore","pipe","pipe"],env:{PATH:r.NODE_BIN_DIR,HOME:process.env.HOME,OPENCLAW_TELEMETRY_GALIELO_GUID:process.env.QB_GUID||"",OPENCLAW_TELEMETRY_GALIELO_QIEMI36:process.env.QB_QIMEI36||""}});(0,a.log)(`[QBotClaw] \u6267\u884C: QBotClaw ${t.join(" ")}`),i.stdout.on("data",e=>{const n=e.toString();if(o&&o.writable)try{o.write(n)}catch{}}),i.stderr.on("data",e=>{const n=e.toString();if(o&&o.writable)try{o.write(n)}catch{}}),i.on("close",e=>{(0,a.log)(`[QBotClaw] \u6267\u884C\u5B8C\u6210\uFF0C\u9000\u51FA\u7801: ${e}`),s()}),i.on("error",e=>{(0,a.log)(`[QBotClaw] \u542F\u52A8\u5931\u8D25: ${e.message}`),s()})})}function I(){c.default.existsSync(r.QBOT_CLAW_DIR)||c.default.mkdirSync(r.QBOT_CLAW_DIR,{recursive:!0})}function m(){const t=u.default.join(exports.PYTHON_DIR,"pip.conf");if(c.default.existsSync(t)){(0,a.log)("pip.conf \u5DF2\u5B58\u5728\uFF0C\u8DF3\u8FC7");return}const o=["[global]","index-url = https://mirrors.tencent.com/pypi/simple/",`cache-dir = ${u.default.join(exports.PYTHON_DIR,".pip-cache")}`,"","[install]",`prefix = ${exports.PYTHON_DIR}`,""].join(`
3
- `);c.default.writeFileSync(t,o,"utf-8"),(0,a.log)(`\u5DF2\u5199\u5165 pip.conf: ${t}`)}async function O(t){if(c.default.existsSync(r.MCPORTER_BIN)){(0,a.log)("mcporter \u5DF2\u5B89\u88C5\uFF0C\u8DF3\u8FC7");return}(0,a.log)("\u5F00\u59CB\u5B89\u88C5 mcporter..."),await new Promise((o,s)=>{const i=(0,_.spawn)(r.NPM_BIN,["--userconfig",r.NPM_RC,"install","-g","mcporter"],{stdio:["ignore","pipe","pipe"],env:{...process.env,PATH:`${u.default.dirname(r.NPM_BIN)}:${process.env.PATH}`}});i.stdout.on("data",e=>{const n=`[mcporter] ${e.toString().trim()}`;(0,a.log)(n),g(t,0,0,n)}),i.stderr.on("data",e=>{const n=`[mcporter] ${e.toString().trim()}`;(0,a.log)(n),g(t,0,0,n)}),i.on("close",e=>{e===0?((0,a.log)("mcporter \u5B89\u88C5\u6210\u529F"),o()):s(new Error(`mcporter \u5B89\u88C5\u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${e}`))}),i.on("error",s)})}function A(t,o){return new Promise((s,i)=>{const e=(0,_.spawn)(r.NPM_BIN,["--userconfig",r.NPM_RC,...t],{stdio:["ignore","pipe","pipe"],env:{...process.env,PATH:`${u.default.dirname(r.NPM_BIN)}:${process.env.PATH}`}});e.stdout.on("data",n=>{const l=`[npm] ${n.toString().trim()}`;(0,a.log)(l)}),e.stderr.on("data",n=>{const l=`[npm] ${n.toString().trim()}`;(0,a.log)(l)}),e.on("close",n=>{n===0?((0,a.log)(`${o} \u6210\u529F`),s()):i(new Error(`${o} \u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${n}`))}),e.on("error",i)})}async function E(t){const o=`${r.NPM_PACKAGE_NAME}@${t}`;(0,a.log)(`\u5F00\u59CB\u5B89\u88C5 ${o}\uFF08--ignore-scripts\uFF0C\u4EC5\u4E0B\u8F7D\u89E3\u538B\uFF09...`),await A(["install","-g","--ignore-scripts",o],`${o} \u4E0B\u8F7D\u89E3\u538B`)}async function y(t){const o=`${r.NPM_PACKAGE_NAME}@${t}`;(0,a.log)("\u5F00\u59CB npm rebuild\uFF08\u6267\u884C postinstall \u811A\u672C\uFF09..."),await A(["rebuild","-g",r.NPM_PACKAGE_NAME],`${o} rebuild`),(0,a.log)(`${o} \u5B89\u88C5\u6210\u529F`)}async function $(t,o,s,i){let e;if((0,a.log)(`\u8986\u76D6\u7528\u6237\u5DF2\u6709\u914D\u7F6E: ${i}`),!i&&c.default.existsSync(r.QBOT_CLAW_CONFIG_PATH))e=r.QBOT_CLAW_CONFIG_PATH,(0,a.log)(`\u4F7F\u7528\u5DF2\u6709\u914D\u7F6E\u6587\u4EF6: ${e}`);else{const l=u.default.join(r.NPM_GLOBAL_MODULES,r.NPM_PACKAGE_NAME,"preset-config.json");if(!c.default.existsSync(l)){(0,a.log)(`npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165: ${l}`);return}e=l,(0,a.log)(`\u4F7F\u7528 npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E: ${e}`)}let n;try{n=JSON.parse(c.default.readFileSync(e,"utf-8")),(0,a.log)(`\u5DF2\u8BFB\u53D6\u914D\u7F6E: ${e}`)}catch(l){(0,a.log)(`\u8BFB\u53D6\u914D\u7F6E\u5931\u8D25: ${e}\uFF0C${l.message}\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165`);return}t!==void 0&&(n.gateway={...n.gateway??{},port:t},(0,a.log)(`\u5DF2\u5C06 gateway.port=${t} \u5199\u5165\u914D\u7F6E`)),n.plugins=n.plugins??{},n.plugins.entries=n.plugins.entries??{},n.plugins.entries["x5use-browser-control"]=n.plugins.entries["x5use-browser-control"]??{},n.plugins.entries["x5use-browser-control"].config={...n.plugins.entries["x5use-browser-control"].config??{},wsPort:s,httpPort:o},(0,a.log)(`\u5DF2\u5C06 x5use-browser-control wsPort=${s}, httpPort=${o} \u5199\u5165\u914D\u7F6E`),c.default.writeFileSync(r.QBOT_CLAW_CONFIG_PATH,JSON.stringify(n,null,2),"utf-8"),(0,a.log)(`\u914D\u7F6E\u6587\u4EF6\u5DF2\u5199\u5165: ${r.QBOT_CLAW_CONFIG_PATH}`)}async function N(t){const o=(0,p.readState)();let s;o.gatewayPort&&!await(0,p.isPortAvailable)(o.gatewayPort)?(s=o.gatewayPort,(0,a.log)(`\u68C0\u6D4B\u5230 QBotClaw gateway \u5DF2\u5728\u7AEF\u53E3 ${s} \u8FD0\u884C\uFF0C\u590D\u7528\u539F\u7AEF\u53E3`)):s=await(0,w.findAvailablePort)(),(0,a.log)(`\u540E\u53F0\u542F\u52A8 QBotClaw gateway run --port ${s} --force`);const i=await(0,w.findAvailablePort)(r.DEFAULT_MCP_HTTP_PORT),e=await(0,w.findAvailablePort)();await $(s,i,e,t);const n=(0,_.spawn)(r.QBOTCLAW_BIN,["gateway","run","--port",String(s),"--force"],{stdio:"ignore",env:{PATH:r.NODE_BIN_DIR,HOME:process.env.HOME,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||"",OPENCLAW_GATEWAY_TOKEN:(0,P.getOrCreateGatewayToken)()}});n.unref();const l=n.pid;(0,a.log)(`QBotClaw gateway \u5DF2\u5728\u540E\u53F0\u542F\u52A8\uFF0CPID: ${l}\uFF0C\u7AEF\u53E3: ${s}, token ${(0,P.getOrCreateGatewayToken)()}`),(0,p.writeState)({...(0,p.readState)(),gatewayPid:l,gatewayPort:s,mcpHttpPort:i,mcpWsPort:e})}function B(t,o,s){if(exports.isInstalling){if((0,a.log)("[runInstall] \u5B89\u88C5\u6B63\u5728\u8FDB\u884C\u4E2D\uFF0C\u62D2\u7EDD\u91CD\u590D\u6267\u884C"),t&&t.writable)try{t.end(JSON.stringify({status:"failed",progress:0,message:"\u5B89\u88C5\u6B63\u5728\u8FDB\u884C\u4E2D\uFF0C\u8BF7\u52FF\u91CD\u590D\u64CD\u4F5C"})+`
4
- `)}catch{}return}exports.isInstalling=!0,exports.installState={status:"downloading",message:"\u6B63\u5728\u5B89\u88C5...",startTime:new Date().toISOString()},(0,a.log)(`\u5F00\u59CB\u5B89\u88C5 ${r.NPM_PACKAGE_NAME}@${o}`),(async()=>{try{(0,p.stopGateway)(),I(),m();const i=5;let e=0;g(t,i,e,"\u5F00\u59CB\u5B89\u88C5 mcporter..."),await O(t),e++,g(t,i,e,"\u5F00\u59CB\u4E0B\u8F7D\u89E3\u538B QBotClaw..."),await E(o),e++,g(t,i,e,"npmDownloadQBotClaw \u5B8C\u6210"),await(0,f.fullScanClearQuarantine)("npm install --ignore-scripts \u5B8C\u6210\u540E\uFF0Crebuild \u524D"),e++,await(0,f.watchWorkspaceQuarantine)().catch(n=>{(0,a.log)(`[quarantine] watchWorkspaceQuarantine \u542F\u52A8\u5F02\u5E38: ${n.message}`)}),g(t,i,e,"\u5F00\u59CB npm rebuild..."),await y(o),e++,g(t,i,e,"npmRebuildQBotClaw \u5B8C\u6210");try{c.default.existsSync(r.OPENCLAW_BIN)||(c.default.symlinkSync(r.QBOTCLAW_BIN,r.OPENCLAW_BIN),(0,a.log)(`\u5DF2\u521B\u5EFA\u8F6F\u94FE\u63A5: ${r.OPENCLAW_BIN} -> ${r.QBOTCLAW_BIN}`))}catch(n){(0,a.log)(`\u521B\u5EFA openclaw \u8F6F\u94FE\u63A5\u5931\u8D25: ${n.message}`)}if(await(0,f.stopWatchWorkspaceQuarantine)().catch(n=>{(0,a.log)(`[quarantine] stopWatchWorkspaceQuarantine \u5F02\u5E38: ${n.message}`)}),exports.installState={status:"success",message:"\u5B89\u88C5\u6210\u529F",endTime:new Date().toISOString()},(0,a.log)("\u5B89\u88C5\u6210\u529F"),(0,a.refreshClawVersion)(o),g(t,i,e,"\u5F00\u59CB\u914D\u7F6E\u5E76\u542F\u52A8 QBotClaw gateway..."),await N(s),e++,t.writable)try{t.end(JSON.stringify({status:"done",progress:100,message:"\u5B89\u88C5\u6210\u529F"})+`
1
+ "use strict";var d=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=A,exports.configAndRunQBotClaw=N,exports.runInstall=$;const c=d(require("fs")),u=d(require("path")),_=require("child_process"),s=require("./config"),w=require("./utils"),p=require("./state"),f=require("./quarantine"),a=require("./reportLog");function g(t,o,r,i){if(t&&t.writable){const e=o>0?Math.round(r/o*1e4)/100:0;try{t.write(JSON.stringify({status:"downloading",progress:e,totalSteps:o,currentStep:r,message:i})+`
2
+ `)}catch{}}}exports.installState={status:"idle",message:"\u672A\u5F00\u59CB"},exports.isInstalling=!1,exports.PYTHON_DIR=u.default.join(s.QBOT_CLAW_DIR,"python");function A(t,o){return new Promise(r=>{const i=(0,_.spawn)(s.QBOTCLAW_BIN,t,{stdio:["ignore","pipe","pipe"],env:{PATH:s.NODE_BIN_DIR,HOME:process.env.HOME,OPENCLAW_TELEMETRY_GALIELO_GUID:process.env.QB_GUID||"",OPENCLAW_TELEMETRY_GALIELO_QIEMI36:process.env.QB_QIMEI36||""}});(0,a.log)(`[QBotClaw] \u6267\u884C: QBotClaw ${t.join(" ")}`),i.stdout.on("data",e=>{const n=e.toString();if(o&&o.writable)try{o.write(n)}catch{}}),i.stderr.on("data",e=>{const n=e.toString();if(o&&o.writable)try{o.write(n)}catch{}}),i.on("close",e=>{(0,a.log)(`[QBotClaw] \u6267\u884C\u5B8C\u6210\uFF0C\u9000\u51FA\u7801: ${e}`),r()}),i.on("error",e=>{(0,a.log)(`[QBotClaw] \u542F\u52A8\u5931\u8D25: ${e.message}`),r()})})}function I(){c.default.existsSync(s.QBOT_CLAW_DIR)||c.default.mkdirSync(s.QBOT_CLAW_DIR,{recursive:!0})}function m(){const t=u.default.join(exports.PYTHON_DIR,"pip.conf");if(c.default.existsSync(t)){(0,a.log)("pip.conf \u5DF2\u5B58\u5728\uFF0C\u8DF3\u8FC7");return}const o=["[global]","index-url = https://mirrors.tencent.com/pypi/simple/",`cache-dir = ${u.default.join(exports.PYTHON_DIR,".pip-cache")}`,"","[install]",`prefix = ${exports.PYTHON_DIR}`,""].join(`
3
+ `);c.default.writeFileSync(t,o,"utf-8"),(0,a.log)(`\u5DF2\u5199\u5165 pip.conf: ${t}`)}async function C(t){if(c.default.existsSync(s.MCPORTER_BIN)){(0,a.log)("mcporter \u5DF2\u5B89\u88C5\uFF0C\u8DF3\u8FC7");return}(0,a.log)("\u5F00\u59CB\u5B89\u88C5 mcporter..."),await new Promise((o,r)=>{const i=(0,_.spawn)(s.NPM_BIN,["--userconfig",s.NPM_RC,"install","-g","mcporter"],{stdio:["ignore","pipe","pipe"],env:{...process.env,PATH:`${u.default.dirname(s.NPM_BIN)}:${process.env.PATH}`}});i.stdout.on("data",e=>{const n=`[mcporter] ${e.toString().trim()}`;(0,a.log)(n),g(t,0,0,n)}),i.stderr.on("data",e=>{const n=`[mcporter] ${e.toString().trim()}`;(0,a.log)(n),g(t,0,0,n)}),i.on("close",e=>{e===0?((0,a.log)("mcporter \u5B89\u88C5\u6210\u529F"),o()):r(new Error(`mcporter \u5B89\u88C5\u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${e}`))}),i.on("error",r)})}function P(t,o){return new Promise((r,i)=>{const e=(0,_.spawn)(s.NPM_BIN,["--userconfig",s.NPM_RC,...t],{stdio:["ignore","pipe","pipe"],env:{...process.env,PATH:`${u.default.dirname(s.NPM_BIN)}:${process.env.PATH}`}});e.stdout.on("data",n=>{const l=`[npm] ${n.toString().trim()}`;(0,a.log)(l)}),e.stderr.on("data",n=>{const l=`[npm] ${n.toString().trim()}`;(0,a.log)(l)}),e.on("close",n=>{n===0?((0,a.log)(`${o} \u6210\u529F`),r()):i(new Error(`${o} \u5931\u8D25\uFF0C\u9000\u51FA\u7801: ${n}`))}),e.on("error",i)})}async function E(t){const o=`${s.NPM_PACKAGE_NAME}@${t}`;(0,a.log)(`\u5F00\u59CB\u5B89\u88C5 ${o}\uFF08--ignore-scripts\uFF0C\u4EC5\u4E0B\u8F7D\u89E3\u538B\uFF09...`),await P(["install","-g","--ignore-scripts",o],`${o} \u4E0B\u8F7D\u89E3\u538B`)}async function O(t){const o=`${s.NPM_PACKAGE_NAME}@${t}`;(0,a.log)("\u5F00\u59CB npm rebuild\uFF08\u6267\u884C postinstall \u811A\u672C\uFF09..."),await P(["rebuild","-g",s.NPM_PACKAGE_NAME],`${o} rebuild`),(0,a.log)(`${o} \u5B89\u88C5\u6210\u529F`)}async function y(t,o,r,i){let e;if((0,a.log)(`\u8986\u76D6\u7528\u6237\u5DF2\u6709\u914D\u7F6E: ${i}`),!i&&c.default.existsSync(s.QBOT_CLAW_CONFIG_PATH))e=s.QBOT_CLAW_CONFIG_PATH,(0,a.log)(`\u4F7F\u7528\u5DF2\u6709\u914D\u7F6E\u6587\u4EF6: ${e}`);else{const l=u.default.join(s.NPM_GLOBAL_MODULES,s.NPM_PACKAGE_NAME,"preset-config.json");if(!c.default.existsSync(l)){(0,a.log)(`npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E\u6587\u4EF6\u4E0D\u5B58\u5728\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165: ${l}`);return}e=l,(0,a.log)(`\u4F7F\u7528 npm \u5168\u5C40\u5B89\u88C5\u76EE\u5F55\u4E2D\u7684\u914D\u7F6E: ${e}`)}let n;try{n=JSON.parse(c.default.readFileSync(e,"utf-8")),(0,a.log)(`\u5DF2\u8BFB\u53D6\u914D\u7F6E: ${e}`)}catch(l){(0,a.log)(`\u8BFB\u53D6\u914D\u7F6E\u5931\u8D25: ${e}\uFF0C${l.message}\uFF0C\u8DF3\u8FC7\u914D\u7F6E\u5199\u5165`);return}t!==void 0&&(n.gateway={...n.gateway??{},port:t},(0,a.log)(`\u5DF2\u5C06 gateway.port=${t} \u5199\u5165\u914D\u7F6E`)),n.plugins=n.plugins??{},n.plugins.entries=n.plugins.entries??{},n.plugins.entries["x5use-browser-control"]=n.plugins.entries["x5use-browser-control"]??{},n.plugins.entries["x5use-browser-control"].config={...n.plugins.entries["x5use-browser-control"].config??{},wsPort:r,httpPort:o},(0,a.log)(`\u5DF2\u5C06 x5use-browser-control wsPort=${r}, httpPort=${o} \u5199\u5165\u914D\u7F6E`),c.default.writeFileSync(s.QBOT_CLAW_CONFIG_PATH,JSON.stringify(n,null,2),"utf-8"),(0,a.log)(`\u914D\u7F6E\u6587\u4EF6\u5DF2\u5199\u5165: ${s.QBOT_CLAW_CONFIG_PATH}`)}async function N(t){const o=(0,p.readState)();let r;o.gatewayPort&&!await(0,p.isPortAvailable)(o.gatewayPort)?(r=o.gatewayPort,(0,a.log)(`\u68C0\u6D4B\u5230 QBotClaw gateway \u5DF2\u5728\u7AEF\u53E3 ${r} \u8FD0\u884C\uFF0C\u590D\u7528\u539F\u7AEF\u53E3`)):r=await(0,w.findAvailablePort)(),(0,a.log)(`\u540E\u53F0\u542F\u52A8 QBotClaw gateway run --port ${r} --force`);const i=await(0,w.findAvailablePort)(s.DEFAULT_MCP_HTTP_PORT),e=await(0,w.findAvailablePort)();await y(r,i,e,t);const n=(0,_.spawn)(s.QBOTCLAW_BIN,["gateway","run","--port",String(r),"--force"],{stdio:"ignore",env:{PATH:s.NODE_BIN_DIR,HOME:process.env.HOME,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||""}});n.unref();const l=n.pid;(0,a.log)(`QBotClaw gateway \u5DF2\u5728\u540E\u53F0\u542F\u52A8\uFF0CPID: ${l}\uFF0C\u7AEF\u53E3: ${r}`),(0,p.writeState)({...(0,p.readState)(),gatewayPid:l,gatewayPort:r,mcpHttpPort:i,mcpWsPort:e})}function $(t,o,r){if(exports.isInstalling){if((0,a.log)("[runInstall] \u5B89\u88C5\u6B63\u5728\u8FDB\u884C\u4E2D\uFF0C\u62D2\u7EDD\u91CD\u590D\u6267\u884C"),t&&t.writable)try{t.end(JSON.stringify({status:"failed",progress:0,message:"\u5B89\u88C5\u6B63\u5728\u8FDB\u884C\u4E2D\uFF0C\u8BF7\u52FF\u91CD\u590D\u64CD\u4F5C"})+`
4
+ `)}catch{}return}exports.isInstalling=!0,exports.installState={status:"downloading",message:"\u6B63\u5728\u5B89\u88C5...",startTime:new Date().toISOString()},(0,a.log)(`\u5F00\u59CB\u5B89\u88C5 ${s.NPM_PACKAGE_NAME}@${o}`),(async()=>{try{(0,p.stopGateway)(),I(),m();const i=5;let e=0;g(t,i,e,"\u5F00\u59CB\u5B89\u88C5 mcporter..."),await C(t),e++,g(t,i,e,"\u5F00\u59CB\u4E0B\u8F7D\u89E3\u538B QBotClaw..."),await E(o),e++,g(t,i,e,"npmDownloadQBotClaw \u5B8C\u6210"),await(0,f.fullScanClearQuarantine)("npm install --ignore-scripts \u5B8C\u6210\u540E\uFF0Crebuild \u524D"),e++,await(0,f.watchWorkspaceQuarantine)().catch(n=>{(0,a.log)(`[quarantine] watchWorkspaceQuarantine \u542F\u52A8\u5F02\u5E38: ${n.message}`)}),g(t,i,e,"\u5F00\u59CB npm rebuild..."),await O(o),e++,g(t,i,e,"npmRebuildQBotClaw \u5B8C\u6210");try{c.default.existsSync(s.OPENCLAW_BIN)||(c.default.symlinkSync(s.QBOTCLAW_BIN,s.OPENCLAW_BIN),(0,a.log)(`\u5DF2\u521B\u5EFA\u8F6F\u94FE\u63A5: ${s.OPENCLAW_BIN} -> ${s.QBOTCLAW_BIN}`))}catch(n){(0,a.log)(`\u521B\u5EFA openclaw \u8F6F\u94FE\u63A5\u5931\u8D25: ${n.message}`)}if(await(0,f.stopWatchWorkspaceQuarantine)().catch(n=>{(0,a.log)(`[quarantine] stopWatchWorkspaceQuarantine \u5F02\u5E38: ${n.message}`)}),exports.installState={status:"success",message:"\u5B89\u88C5\u6210\u529F",endTime:new Date().toISOString()},(0,a.log)("\u5B89\u88C5\u6210\u529F"),(0,a.refreshClawVersion)(o),g(t,i,e,"\u5F00\u59CB\u914D\u7F6E\u5E76\u542F\u52A8 QBotClaw gateway..."),await N(r),e++,t.writable)try{t.end(JSON.stringify({status:"done",progress:100,message:"\u5B89\u88C5\u6210\u529F"})+`
5
5
  `)}catch{}}catch(i){if(await(0,f.stopWatchWorkspaceQuarantine)().catch(()=>{}),exports.installState={status:"failed",message:i.message,endTime:new Date().toISOString()},(0,a.log)(`\u5B89\u88C5\u5931\u8D25: ${i.message}`),t&&t.writable)try{t.end(JSON.stringify({status:"failed",progress:0,message:i.message})+`
6
6
  `)}catch{}}finally{exports.isInstalling=!1}})()}
package/dist/reportLog.js CHANGED
@@ -1,2 +1 @@
1
- "use strict";var l=exports&&exports.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.flushLogs=N,exports.log=B,exports.refreshClawVersion=I,exports.initLog=M;const T=l(require("https")),E=require("crypto"),d=l(require("fs")),P=l(require("path")),u=require("./config"),O=require("./version"),r=[];let v=0,o=null,a=!1;const h=500;let y="guidxxx",m="qimei36",p="unknown",c="unknown";function b(){return(0,E.randomUUID)().replace(/-/g,"")}function q(){return Date.now()*1e6}function k(e){if(e.length===0)return Promise.resolve();const n=e.map(i=>({trace_id:i.trace_id,body:{string_value:i.body},time_unix_nano:i.time_unix_nano,severity_number:"SEVERITY_NUMBER_INFO",severity_text:"INFO",flags:1,attributes:[{key:"guid",value:{string_value:y}},{key:"qimei36",value:{string_value:m}},{key:"launcher_version",value:{string_value:p}},{key:"claw_version",value:{string_value:c}}]})),g=JSON.stringify({resource_logs:[{instrumentation_library_logs:[{instrumentation_library:{name:"qbot-launcher-log"},log_records:n}],resource:{attributes:[{key:"telemetry.sdk.language",value:{string_value:"go"}},{key:"telemetry.sdk.name",value:{string_value:"galileo"}},{key:"telemetry.sdk.version",value:{string_value:"0.0.1"}},{key:"target",value:{string_value:"RPC.QBotClaw.Launcher"}},{key:"namespace",value:{string_value:"Production"}},{key:"env",value:{string_value:"formal"}},{key:"server",value:{string_value:"QBotClaw.Launcher"}}]}}]});return new Promise((i,_)=>{const C={hostname:"galileotelemetry.tencent.com",port:443,path:"/v1/logs",method:"POST",headers:{"Content-Type":"application/json","Content-Length":Buffer.byteLength(g)}},s=T.default.request(C,t=>{let f="";t.on("data",S=>{f+=S.toString()}),t.on("end",()=>{t.statusCode&&t.statusCode>=200&&t.statusCode<300?i():_(new Error(`\u65E5\u5FD7\u4E0A\u62A5\u5931\u8D25\uFF0C\u72B6\u6001\u7801: ${t.statusCode}\uFF0C\u54CD\u5E94: ${f}`))})});s.on("error",t=>{_(new Error(`\u65E5\u5FD7\u4E0A\u62A5\u8BF7\u6C42\u5F02\u5E38: ${t.message}`))}),s.write(g),s.end()})}function w(){if(a||r.length===0)return;const n=Date.now()-v;n>=h?L():o===null&&(o=setTimeout(()=>{o=null,L()},h-n))}function L(){if(a||r.length===0)return;const e=r.splice(0);a=!0,k(e).catch(()=>{}).finally(()=>{v=Date.now(),a=!1,r.length>0&&w()})}async function N(){if(o!==null&&(clearTimeout(o),o=null),r.length===0)return Promise.resolve();const e=r.splice(0);try{return await k(e)}catch{}}function B(e){r.push({trace_id:b(),body:e,time_unix_nano:q()}),w();try{const n=new Date().toLocaleString("sv-SE",{timeZone:"Asia/Shanghai"});d.default.appendFileSync(u.QBOT_CLAW_LOG_PATH,`[${n}] ${e}
2
- `)}catch{}}function D(){try{const e=P.default.join(u.NPM_GLOBAL_MODULES,u.NPM_PACKAGE_NAME,"package.json");return JSON.parse(d.default.readFileSync(e,"utf-8")).version||"unknown"}catch{return"unknown"}}function I(e){c=e}function M(){const e=process.env.QB_GUID,n=process.env.QB_QIMEI36;e&&(y=e),n&&(m=n),p=O.LAUNCHER_VERSION,c=D()}
1
+ "use strict";var l=exports&&exports.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.flushLogs=O,exports.log=I,exports.refreshClawVersion=B,exports.initLog=D;const b=l(require("https")),E=require("crypto"),P=l(require("fs")),T=l(require("path")),f=require("./config"),q=require("./version"),r=[];let d=0,o=null,a=!1;const v=500;let y="guidxxx",h="qimei36",m="unknown",u="unknown";function N(){return(0,E.randomUUID)().replace(/-/g,"")}function S(){return Date.now()*1e6}function p(e){if(e.length===0)return Promise.resolve();const n=e.map(i=>({trace_id:i.trace_id,body:{string_value:i.body},time_unix_nano:i.time_unix_nano,severity_number:"SEVERITY_NUMBER_INFO",severity_text:"INFO",flags:1,attributes:[{key:"guid",value:{string_value:y}},{key:"qimei36",value:{string_value:h}},{key:"launcher_version",value:{string_value:m}},{key:"claw_version",value:{string_value:u}}]})),c=JSON.stringify({resource_logs:[{instrumentation_library_logs:[{instrumentation_library:{name:"qbot-launcher-log"},log_records:n}],resource:{attributes:[{key:"telemetry.sdk.language",value:{string_value:"go"}},{key:"telemetry.sdk.name",value:{string_value:"galileo"}},{key:"telemetry.sdk.version",value:{string_value:"0.0.1"}},{key:"target",value:{string_value:"RPC.QBotClaw.Launcher"}},{key:"namespace",value:{string_value:"Production"}},{key:"env",value:{string_value:"formal"}},{key:"server",value:{string_value:"QBotClaw.Launcher"}}]}}]});return new Promise((i,g)=>{const C={hostname:"galileotelemetry.tencent.com",port:443,path:"/v1/logs",method:"POST",headers:{"Content-Type":"application/json","Content-Length":Buffer.byteLength(c)}},s=b.default.request(C,t=>{let _="";t.on("data",L=>{_+=L.toString()}),t.on("end",()=>{t.statusCode&&t.statusCode>=200&&t.statusCode<300?i():g(new Error(`\u65E5\u5FD7\u4E0A\u62A5\u5931\u8D25\uFF0C\u72B6\u6001\u7801: ${t.statusCode}\uFF0C\u54CD\u5E94: ${_}`))})});s.on("error",t=>{g(new Error(`\u65E5\u5FD7\u4E0A\u62A5\u8BF7\u6C42\u5F02\u5E38: ${t.message}`))}),s.write(c),s.end()})}function k(){if(a||r.length===0)return;const n=Date.now()-d;n>=v?w():o===null&&(o=setTimeout(()=>{o=null,w()},v-n))}function w(){if(a||r.length===0)return;const e=r.splice(0);a=!0,p(e).catch(()=>{}).finally(()=>{d=Date.now(),a=!1,r.length>0&&k()})}async function O(){if(o!==null&&(clearTimeout(o),o=null),r.length===0)return Promise.resolve();const e=r.splice(0);try{return await p(e)}catch{}}function I(e){r.push({trace_id:N(),body:e,time_unix_nano:S()}),k()}function M(){try{const e=T.default.join(f.NPM_GLOBAL_MODULES,f.NPM_PACKAGE_NAME,"package.json");return JSON.parse(P.default.readFileSync(e,"utf-8")).version||"unknown"}catch{return"unknown"}}function B(e){u=e}function D(){const e=process.env.QB_GUID,n=process.env.QB_QIMEI36;e&&(y=e),n&&(h=n),m=q.LAUNCHER_VERSION,u=M()}
package/dist/server.js CHANGED
@@ -1,6 +1,6 @@
1
- "use strict";var I=exports&&exports.__importDefault||function(p){return p&&p.__esModule?p:{default:p}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.server=void 0,exports.watchParentProcess=W;const R=I(require("http")),h=I(require("fs")),y=I(require("path")),l=require("./config"),n=require("./utils"),a=require("./reportLog"),_=require("./installer"),J=require("./version"),P=require("./state"),A=require("child_process"),N={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type, Authorization, X-Requested-With","Access-Control-Max-Age":"86400"};function b(p){for(const[t,d]of Object.entries(N))p.setHeader(t,d)}exports.server=R.default.createServer(async(p,t)=>{const d=p.url||"";if(b(t),p.method==="OPTIONS"){t.writeHead(204,N),t.end();return}if(d==="/api/version"){let r="unknown";try{r=(await(0,n.execCommand)(`"${l.NODE_BIN}" -v`)).trim(),(0,a.log)(`[version] node \u7248\u672C: ${r}`)}catch(i){(0,a.log)(`[version] \u83B7\u53D6 node \u7248\u672C\u5931\u8D25: ${i.message}`),r=`error: ${i.message}`}const o=await(0,n.getQBotClawVersion)()??"0.0.0";(0,a.log)(`[version] qbotclaw \u7248\u672C: ${o}`);let e="0.0.0";if(h.default.existsSync(l.MCPORTER_BIN))try{e=(await(0,n.execCommand)(`"${l.NODE_BIN}" "${l.MCPORTER_BIN}" --version`)).trim(),(0,a.log)(`[version] mcporter \u7248\u672C: ${e}`)}catch(i){(0,a.log)(`[version] \u83B7\u53D6 mcporter \u7248\u672C\u5931\u8D25: ${i.message}`),e=`error: ${i.message}`}let s="0.0.0";if(h.default.existsSync(l.PYTHON_BIN))try{s=(await(0,n.execCommand)(`"${l.PYTHON_BIN}" --version`)).trim(),(0,a.log)(`[version] python \u7248\u672C: ${s}`)}catch(i){(0,a.log)(`[version] \u83B7\u53D6 python \u7248\u672C\u5931\u8D25: ${i.message}`),s=`error: ${i.message}`}(0,n.sendJSON)(t,200,{status:"\u6210\u529F",launcher:J.LAUNCHER_VERSION,node:r,qbotclaw:o,mcporter:e,python:s});return}if(d==="/api/port"){const r=exports.server.address(),o=r&&typeof r=="object"?r.port:null,e=(0,P.readState)();(0,n.sendJSON)(t,200,{status:"\u6210\u529F",launcher:o,qbotclaw:e.gatewayPort??2e3,mcpHttp:e.mcpHttpPort??l.DEFAULT_MCP_HTTP_PORT,mcpWs:e.mcpWsPort??8765});return}if(d==="/api/status"){const r=(0,P.readState)(),o=[];if(r.gatewayPid)try{process.kill(r.gatewayPid,0)}catch{o.push(`gateway \u8FDB\u7A0B (pid: ${r.gatewayPid}) \u5DF2\u9000\u51FA`)}else o.push("gateway \u8FDB\u7A0B\u672A\u542F\u52A8\uFF08\u72B6\u6001\u4E2D\u65E0 gatewayPid\uFF09");const e=[{name:"gateway",port:r.gatewayPort},{name:"mcpHttp",port:r.mcpHttpPort},{name:"mcpWs",port:r.mcpWsPort}];for(const{name:s,port:i}of e){if(!i){o.push(`${s} \u7AEF\u53E3\u672A\u914D\u7F6E\uFF08\u72B6\u6001\u4E2D\u65E0\u5BF9\u5E94\u7AEF\u53E3\u53F7\uFF09`);continue}await(0,P.isPortAvailable)(i)&&o.push(`${s} \u7AEF\u53E3 (${i}) \u65E0\u670D\u52A1\u76D1\u542C`)}o.length===0?(0,n.sendJSON)(t,200,{ok:!0,message:"\u6240\u6709\u670D\u52A1\u8FD0\u884C\u6B63\u5E38"}):(0,n.sendJSON)(t,200,{ok:!1,message:o.join("\uFF1B")});return}if(d==="/api/restart"){try{const r=(0,P.readState)();if(r.gatewayPid)try{process.kill(r.gatewayPid,"SIGTERM"),(0,a.log)(`[restart] \u5DF2\u53D1\u9001 SIGTERM \u7ED9\u65E7 gateway \u8FDB\u7A0B pid: ${r.gatewayPid}`)}catch{(0,a.log)(`[restart] \u65E7 gateway \u8FDB\u7A0B ${r.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA\uFF0C\u5FFD\u7565`)}const{gatewayPid:o,gatewayPort:e,mcpHttpPort:s,mcpWsPort:i,...f}=r;(0,P.writeState)(f),(0,a.log)("[restart] \u5DF2\u6E05\u9664 gatewayPid, gatewayPort, mcpHttpPort, mcpWsPort"),await(0,_.configAndRunQBotClaw)(),(0,a.log)("[restart] QBotClaw gateway \u91CD\u542F\u5B8C\u6210");const g=(0,P.readState)(),c=exports.server.address(),u=c&&typeof c=="object"?c.port:null;(0,n.sendJSON)(t,200,{ok:!0,message:"QBotClaw gateway \u91CD\u542F\u6210\u529F",launcher:u,qbotclaw:g.gatewayPort??2e3,mcpHttp:g.mcpHttpPort??l.DEFAULT_MCP_HTTP_PORT,mcpWs:g.mcpWsPort??8765})}catch(r){(0,a.log)(`[restart] \u91CD\u542F\u5931\u8D25: ${r.message}`),(0,n.sendJSON)(t,500,{ok:!1,message:`\u91CD\u542F\u5931\u8D25: ${r.message}`})}return}if(d==="/api/wechat/history"){try{if(!h.default.existsSync(l.SESSIONS_FILE)){(0,n.sendJSON)(t,404,{ok:!1,sessionKey:"",message:"\u672A\u627E\u5230\u4F1A\u8BDD\u6587\u4EF6"});return}const r=JSON.parse(h.default.readFileSync(l.SESSIONS_FILE,"utf-8"));let o=null,e=0;for(const[f,g]of Object.entries(r))if(f.includes("openclaw-weixin")){const u=g.updatedAt??0;u>e&&(e=u,o=f)}if(!o){(0,n.sendJSON)(t,404,{ok:!1,sessionKey:"",message:"\u672A\u627E\u5230\u5FAE\u4FE1\u4F1A\u8BDD"});return}const i=o.split(":").slice(4).join(":");(0,n.sendJSON)(t,200,{ok:!0,sessionKey:i,message:"\u83B7\u53D6\u6210\u529F"})}catch(r){(0,a.log)(`[wechat/history] \u8BFB\u53D6\u5FAE\u4FE1\u4F1A\u8BDD\u5931\u8D25: ${r.message}`),(0,n.sendJSON)(t,500,{ok:!1,sessionKey:"",message:`\u8BFB\u53D6\u5FAE\u4FE1\u4F1A\u8BDD\u5931\u8D25: ${r.message}`})}return}if(d==="/api/installing"){(0,n.sendJSON)(t,200,{installing:_.isInstalling});return}if(d==="/api/install"||d.startsWith("/api/install?")){if(_.installState.status==="downloading"){(0,n.sendJSON)(t,200,{ok:"downloading",message:"\u6B63\u5728\u5B89\u88C5\u4E2D..."});return}const r=new URL(d,"http://localhost"),o=r.searchParams.get("version")||void 0,e=r.searchParams.get("overrideConfig")==="true";if(!o){(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"\u7F3A\u5C11\u5FC5\u8981\u53C2\u6570 version\uFF0C\u7528\u6CD5: GET /api/install?version=x.x.x"});return}t.writeHead(200,{...N,"Content-Type":"text/plain; charset=utf-8","Transfer-Encoding":"chunked","Cache-Control":"no-cache"}),(0,_.runInstall)(t,o,e);return}if(d.startsWith("/api/watch")){const o=new URL(d,"http://localhost").searchParams.get("ppid");if(!o||isNaN(Number(o))){(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"\u7F3A\u5C11\u6709\u6548\u7684 ppid \u53C2\u6570\uFF0C\u7528\u6CD5: GET /api/watch?ppid=12345"});return}const e=parseInt(o,10);try{process.kill(e,0)}catch{(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:`\u8FDB\u7A0B ${e} \u4E0D\u5B58\u5728`});return}const s=(0,P.readState)();(0,P.writeState)({...s,ppid:e}),W(e),(0,n.sendJSON)(t,200,{status:"\u6210\u529F",message:`\u5DF2\u5F00\u59CB\u76D1\u63A7\u7236\u8FDB\u7A0B ppid: ${e}`});return}if(d==="/api/qbotclaw"&&p.method==="POST"){let r="";p.on("data",o=>{r+=o.toString()}),p.on("end",()=>{let o;try{const e=JSON.parse(r);if(!Array.isArray(e.args)||e.args.length===0){(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"\u53C2\u6570 args \u5FC5\u987B\u662F\u975E\u7A7A\u6570\u7EC4"});return}o=e.args.map(s=>String(s))}catch{(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"\u8BF7\u6C42\u4F53\u5FC5\u987B\u662F\u5408\u6CD5\u7684 JSON"});return}if(!h.default.existsSync(l.QBOTCLAW_BIN)){(0,n.sendJSON)(t,404,{status:"\u5931\u8D25",message:`qbotclaw \u53EF\u6267\u884C\u6587\u4EF6\u4E0D\u5B58\u5728: ${l.QBOTCLAW_BIN}`});return}t.writeHead(200,{...N,"Content-Type":"text/plain; charset=utf-8","Transfer-Encoding":"chunked","Cache-Control":"no-cache"}),(0,_.runQBotClaw)(o,t).then(()=>{t.end(`
1
+ "use strict";var E=exports&&exports.__importDefault||function(f){return f&&f.__esModule?f:{default:f}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.server=void 0,exports.watchParentProcess=L;const D=E(require("http")),h=E(require("fs")),_=E(require("path")),u=require("./config"),a=require("./utils"),o=require("./reportLog"),T=require("./installer"),F=require("./version"),w=require("./state"),v=require("child_process"),k=require("./filePicker"),J=require("./fileSecurityCheck"),W="\u9009\u62E9\u6587\u4EF6",x=10485760,B=10,R=!1,C={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type, Authorization, X-Requested-With","Access-Control-Max-Age":"86400"};function b(f){for(const[s,m]of Object.entries(C))f.setHeader(s,m)}exports.server=D.default.createServer(async(f,s)=>{const m=f.url||"";if(b(s),f.method==="OPTIONS"){s.writeHead(204,C),s.end();return}if(m==="/api/version"){let n="unknown";try{n=(await(0,a.execCommand)(`"${u.NODE_BIN}" -v`)).trim(),(0,o.log)(`[version] node \u7248\u672C: ${n}`)}catch(c){(0,o.log)(`[version] \u83B7\u53D6 node \u7248\u672C\u5931\u8D25: ${c.message}`),n=`error: ${c.message}`}const r=await(0,a.getQBotClawVersion)()??"0.0.0";(0,o.log)(`[version] qbotclaw \u7248\u672C: ${r}`);let t="0.0.0";if(h.default.existsSync(u.MCPORTER_BIN))try{t=(await(0,a.execCommand)(`"${u.NODE_BIN}" "${u.MCPORTER_BIN}" --version`)).trim(),(0,o.log)(`[version] mcporter \u7248\u672C: ${t}`)}catch(c){(0,o.log)(`[version] \u83B7\u53D6 mcporter \u7248\u672C\u5931\u8D25: ${c.message}`),t=`error: ${c.message}`}let l="0.0.0";if(h.default.existsSync(u.PYTHON_BIN))try{l=(await(0,a.execCommand)(`"${u.PYTHON_BIN}" --version`)).trim(),(0,o.log)(`[version] python \u7248\u672C: ${l}`)}catch(c){(0,o.log)(`[version] \u83B7\u53D6 python \u7248\u672C\u5931\u8D25: ${c.message}`),l=`error: ${c.message}`}(0,a.sendJSON)(s,200,{status:"\u6210\u529F",launcher:F.LAUNCHER_VERSION,node:n,qbotclaw:r,mcporter:t,python:l});return}if(m==="/api/port"){const n=exports.server.address(),r=n&&typeof n=="object"?n.port:null,t=(0,w.readState)();(0,a.sendJSON)(s,200,{status:"\u6210\u529F",launcher:r,qbotclaw:t.gatewayPort??2e3,mcpHttp:t.mcpHttpPort??u.DEFAULT_MCP_HTTP_PORT,mcpWs:t.mcpWsPort??8765});return}if(m==="/api/status"){const n=(0,w.readState)(),r=[];if(n.gatewayPid)try{process.kill(n.gatewayPid,0)}catch{r.push(`gateway \u8FDB\u7A0B (pid: ${n.gatewayPid}) \u5DF2\u9000\u51FA`)}else r.push("gateway \u8FDB\u7A0B\u672A\u542F\u52A8\uFF08\u72B6\u6001\u4E2D\u65E0 gatewayPid\uFF09");const t=[{name:"gateway",port:n.gatewayPort},{name:"mcpHttp",port:n.mcpHttpPort},{name:"mcpWs",port:n.mcpWsPort}];for(const{name:l,port:c}of t){if(!c){r.push(`${l} \u7AEF\u53E3\u672A\u914D\u7F6E\uFF08\u72B6\u6001\u4E2D\u65E0\u5BF9\u5E94\u7AEF\u53E3\u53F7\uFF09`);continue}await(0,w.isPortAvailable)(c)&&r.push(`${l} \u7AEF\u53E3 (${c}) \u65E0\u670D\u52A1\u76D1\u542C`)}r.length===0?(0,a.sendJSON)(s,200,{ok:!0,message:"\u6240\u6709\u670D\u52A1\u8FD0\u884C\u6B63\u5E38"}):(0,a.sendJSON)(s,200,{ok:!1,message:r.join("\uFF1B")});return}if(m==="/api/restart"){try{const n=(0,w.readState)();if(n.gatewayPid)try{process.kill(n.gatewayPid,"SIGTERM"),(0,o.log)(`[restart] \u5DF2\u53D1\u9001 SIGTERM \u7ED9\u65E7 gateway \u8FDB\u7A0B pid: ${n.gatewayPid}`)}catch{(0,o.log)(`[restart] \u65E7 gateway \u8FDB\u7A0B ${n.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA\uFF0C\u5FFD\u7565`)}const{gatewayPid:r,gatewayPort:t,mcpHttpPort:l,mcpWsPort:c,...g}=n;(0,w.writeState)(g),(0,o.log)("[restart] \u5DF2\u6E05\u9664 gatewayPid, gatewayPort, mcpHttpPort, mcpWsPort"),await(0,T.configAndRunQBotClaw)(),(0,o.log)("[restart] QBotClaw gateway \u91CD\u542F\u5B8C\u6210");const d=(0,w.readState)(),e=exports.server.address(),i=e&&typeof e=="object"?e.port:null;(0,a.sendJSON)(s,200,{ok:!0,message:"QBotClaw gateway \u91CD\u542F\u6210\u529F",launcher:i,qbotclaw:d.gatewayPort??2e3,mcpHttp:d.mcpHttpPort??u.DEFAULT_MCP_HTTP_PORT,mcpWs:d.mcpWsPort??8765})}catch(n){(0,o.log)(`[restart] \u91CD\u542F\u5931\u8D25: ${n.message}`),(0,a.sendJSON)(s,500,{ok:!1,message:`\u91CD\u542F\u5931\u8D25: ${n.message}`})}return}if(m==="/api/wechat/history"){try{if(!h.default.existsSync(u.SESSIONS_FILE)){(0,a.sendJSON)(s,404,{ok:!1,sessionKey:"",message:"\u672A\u627E\u5230\u4F1A\u8BDD\u6587\u4EF6"});return}const n=JSON.parse(h.default.readFileSync(u.SESSIONS_FILE,"utf-8"));let r=null,t=0;for(const[g,d]of Object.entries(n))if(g.includes("openclaw-weixin")){const i=d.updatedAt??0;i>t&&(t=i,r=g)}if(!r){(0,a.sendJSON)(s,404,{ok:!1,sessionKey:"",message:"\u672A\u627E\u5230\u5FAE\u4FE1\u4F1A\u8BDD"});return}const c=r.split(":").slice(4).join(":");(0,a.sendJSON)(s,200,{ok:!0,sessionKey:c,message:"\u83B7\u53D6\u6210\u529F"})}catch(n){(0,o.log)(`[wechat/history] \u8BFB\u53D6\u5FAE\u4FE1\u4F1A\u8BDD\u5931\u8D25: ${n.message}`),(0,a.sendJSON)(s,500,{ok:!1,sessionKey:"",message:`\u8BFB\u53D6\u5FAE\u4FE1\u4F1A\u8BDD\u5931\u8D25: ${n.message}`})}return}if(m==="/api/installing"){(0,a.sendJSON)(s,200,{installing:T.isInstalling});return}if(m==="/api/install"||m.startsWith("/api/install?")){if(T.installState.status==="downloading"){(0,a.sendJSON)(s,200,{ok:"downloading",message:"\u6B63\u5728\u5B89\u88C5\u4E2D..."});return}const n=new URL(m,"http://localhost"),r=n.searchParams.get("version")||void 0,t=n.searchParams.get("overrideConfig")==="true";if(!r){(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:"\u7F3A\u5C11\u5FC5\u8981\u53C2\u6570 version\uFF0C\u7528\u6CD5: GET /api/install?version=x.x.x"});return}s.writeHead(200,{...C,"Content-Type":"text/plain; charset=utf-8","Transfer-Encoding":"chunked","Cache-Control":"no-cache"}),(0,T.runInstall)(s,r,t);return}if(m.startsWith("/api/watch")){const r=new URL(m,"http://localhost").searchParams.get("ppid");if(!r||isNaN(Number(r))){(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:"\u7F3A\u5C11\u6709\u6548\u7684 ppid \u53C2\u6570\uFF0C\u7528\u6CD5: GET /api/watch?ppid=12345"});return}const t=parseInt(r,10);try{process.kill(t,0)}catch{(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:`\u8FDB\u7A0B ${t} \u4E0D\u5B58\u5728`});return}const l=(0,w.readState)();(0,w.writeState)({...l,ppid:t}),L(t),(0,a.sendJSON)(s,200,{status:"\u6210\u529F",message:`\u5DF2\u5F00\u59CB\u76D1\u63A7\u7236\u8FDB\u7A0B ppid: ${t}`});return}if(m==="/api/qbotclaw"&&f.method==="POST"){let n="";f.on("data",r=>{n+=r.toString()}),f.on("end",()=>{let r;try{const t=JSON.parse(n);if(!Array.isArray(t.args)||t.args.length===0){(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:"\u53C2\u6570 args \u5FC5\u987B\u662F\u975E\u7A7A\u6570\u7EC4"});return}r=t.args.map(l=>String(l))}catch{(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:"\u8BF7\u6C42\u4F53\u5FC5\u987B\u662F\u5408\u6CD5\u7684 JSON"});return}if(!h.default.existsSync(u.QBOTCLAW_BIN)){(0,a.sendJSON)(s,404,{status:"\u5931\u8D25",message:`qbotclaw \u53EF\u6267\u884C\u6587\u4EF6\u4E0D\u5B58\u5728: ${u.QBOTCLAW_BIN}`});return}s.writeHead(200,{...C,"Content-Type":"text/plain; charset=utf-8","Transfer-Encoding":"chunked","Cache-Control":"no-cache"}),(0,T.runQBotClaw)(r,s).then(()=>{s.end(`
2
2
  [\u6267\u884C\u6210\u529F]
3
- `)}).catch(e=>{t.end(`
4
- [\u542F\u52A8\u5931\u8D25: ${e.message}]
5
- `)})});return}if(d.startsWith("/api/uninstall")){const o=new URL(d,"http://localhost").searchParams.get("keepWorkspace")==="true";t.writeHead(200,{...N,"Content-Type":"text/plain; charset=utf-8","Transfer-Encoding":"chunked","Cache-Control":"no-cache"});const e=(s,i,f)=>{if(t.writable)try{t.write(JSON.stringify({status:s,file:i,msg:f})+`
6
- `)}catch{}};try{e("\u6210\u529F","","\u6B63\u5728\u505C\u6B62 QBotClaw...");const s=(0,P.readState)();if(s.gatewayPid)try{process.kill(s.gatewayPid,"SIGTERM"),(0,a.log)(`[uninstall] \u5DF2\u505C\u6B62 QBotClaw gateway \u8FDB\u7A0B pid: ${s.gatewayPid}`),e("\u6210\u529F","",`\u5DF2\u505C\u6B62 QBotClaw gateway \u8FDB\u7A0B pid: ${s.gatewayPid}`)}catch{(0,a.log)(`[uninstall] QBotClaw gateway \u8FDB\u7A0B ${s.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA`),e("\u6210\u529F","",`QBotClaw gateway \u8FDB\u7A0B ${s.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA`)}else e("\u6210\u529F","","QBotClaw \u672A\u5728\u8FD0\u884C");e("\u6210\u529F","",`\u6B63\u5728\u6267\u884C npm uninstall -g ${l.NPM_PACKAGE_NAME}...`);try{await new Promise((f,g)=>{const c=(0,A.spawn)(l.NPM_BIN,["--userconfig",l.NPM_RC,"uninstall","-g",l.NPM_PACKAGE_NAME],{env:{...process.env,PATH:`${l.NODE_BIN_DIR}:${process.env.PATH}`}});c.stdout?.on("data",u=>{(0,a.log)(`[uninstall] npm: ${u.toString().trim()}`)}),c.stderr?.on("data",u=>{(0,a.log)(`[uninstall] npm stderr: ${u.toString().trim()}`)}),c.on("close",u=>{u===0?f():g(new Error(`npm uninstall \u9000\u51FA\u7801: ${u}`))}),c.on("error",u=>g(u))}),(0,a.log)(`[uninstall] npm uninstall -g ${l.NPM_PACKAGE_NAME} \u6210\u529F`),e("\u6210\u529F","",`npm uninstall -g ${l.NPM_PACKAGE_NAME} \u6210\u529F`)}catch(f){(0,a.log)(`[uninstall] npm uninstall \u5931\u8D25: ${f.message}`),e("\u5931\u8D25","",`npm uninstall \u5931\u8D25: ${f.message}`)}e("\u6210\u529F","",`\u6B63\u5728\u6E05\u7406\u76EE\u5F55 ${l.QBOT_CLAW_DIR}...`);const i=[];if(h.default.existsSync(l.QBOT_CLAW_DIR)){const f=h.default.readdirSync(l.QBOT_CLAW_DIR);for(const g of f){const c=y.default.join(l.QBOT_CLAW_DIR,g);if(o&&g==="workspace"){e("\u6210\u529F",c,"\u4FDD\u7559 workspace \u76EE\u5F55");continue}try{h.default.statSync(c).isDirectory()?h.default.rmSync(c,{recursive:!0,force:!0}):h.default.unlinkSync(c),e("\u6210\u529F",c,"\u5DF2\u5220\u9664")}catch(u){(0,a.log)(`[uninstall] \u5220\u9664\u5931\u8D25: ${c} - ${u.message}`),e("\u5931\u8D25",c,`\u5220\u9664\u5931\u8D25: ${u.message}`),i.push(c)}}if(i.length>0){e("\u6210\u529F","",`${i.length} \u4E2A\u9879\u76EE\u5220\u9664\u5931\u8D25\uFF0C\u4F7F\u7528 rm \u547D\u4EE4\u91CD\u8BD5...`);for(const g of i)try{(0,A.execSync)(`rm -rf "${g}"`),(0,a.log)(`[uninstall] rm -rf \u91CD\u8BD5\u6210\u529F: ${g}`),e("\u6210\u529F",g,"rm \u91CD\u8BD5\u5220\u9664\u6210\u529F")}catch(c){(0,a.log)(`[uninstall] rm -rf \u91CD\u8BD5\u4E5F\u5931\u8D25: ${g} - ${c.message}`),e("\u5931\u8D25",g,`rm \u91CD\u8BD5\u4E5F\u5931\u8D25: ${c.message}`)}}if(o)e("\u6210\u529F",l.QBOT_CLAW_DIR,"\u4FDD\u7559\u6839\u76EE\u5F55\uFF08workspace \u6A21\u5F0F\uFF09");else try{h.default.rmSync(l.QBOT_CLAW_DIR,{recursive:!0,force:!0}),e("\u6210\u529F",l.QBOT_CLAW_DIR,"\u5DF2\u5220\u9664\u6839\u76EE\u5F55")}catch(g){(0,a.log)(`[uninstall] \u5220\u9664\u6839\u76EE\u5F55\u5931\u8D25: ${g.message}`);try{(0,A.execSync)(`rm -rf "${l.QBOT_CLAW_DIR}"`),e("\u6210\u529F",l.QBOT_CLAW_DIR,"rm \u91CD\u8BD5\u5220\u9664\u6839\u76EE\u5F55\u6210\u529F")}catch(c){e("\u5931\u8D25",l.QBOT_CLAW_DIR,`\u5220\u9664\u6839\u76EE\u5F55\u5931\u8D25: ${c.message}`)}}}else e("\u6210\u529F",l.QBOT_CLAW_DIR,"\u76EE\u5F55\u4E0D\u5B58\u5728\uFF0C\u65E0\u9700\u6E05\u7406");e("\u6210\u529F","","\u5378\u8F7D\u5B8C\u6210")}catch(s){(0,a.log)(`[uninstall] \u5378\u8F7D\u8FC7\u7A0B\u5F02\u5E38: ${s.message}`),e("\u5931\u8D25","",`\u5378\u8F7D\u8FC7\u7A0B\u5F02\u5E38: ${s.message}`)}t.end(),setTimeout(()=>{(0,a.log)("[uninstall] \u5378\u8F7D\u6D41\u7A0B\u7ED3\u675F\uFF0Clauncher \u8FDB\u7A0B\u9000\u51FA"),process.exit(0)},500);return}if(d.startsWith("/api/reveal")){const o=new URL(d,"http://localhost").searchParams.get("path");if(!o){(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"\u7F3A\u5C11\u5FC5\u8981\u53C2\u6570 path\uFF08\u9700 Base64 \u7F16\u7801\uFF09\uFF0C\u7528\u6CD5: GET /api/reveal?path=<base64\u7F16\u7801\u7684\u6587\u4EF6\u7EDD\u5BF9\u8DEF\u5F84>"});return}let e;try{e=Buffer.from(o,"base64").toString("utf-8")}catch{(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"path \u53C2\u6570 Base64 \u89E3\u7801\u5931\u8D25\uFF0C\u8BF7\u786E\u4FDD\u4F20\u5165\u5408\u6CD5\u7684 Base64 \u7F16\u7801\u5B57\u7B26\u4E32"});return}if(!e||e.trim()===""){(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"Base64 \u89E3\u7801\u540E\u8DEF\u5F84\u4E3A\u7A7A"});return}if(e.includes("\0")){(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"\u8DEF\u5F84\u5305\u542B\u975E\u6CD5\u5B57\u7B26"});return}const s=y.default.resolve(e),i=process.platform==="win32"?["C:\\Windows","C:\\Program Files","C:\\Program Files (x86)","C:\\ProgramData"]:["/etc","/var","/usr","/bin","/sbin","/boot","/root","/sys","/proc","/dev","/lib","/lib64"],f=s.toLowerCase();for(const m of i)if(f===m.toLowerCase()||f.startsWith(m.toLowerCase()+y.default.sep)){(0,a.log)(`[reveal] \u8BBF\u95EE\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55\u88AB\u62D2\u7EDD: ${s}`),(0,n.sendJSON)(t,403,{status:"\u5931\u8D25",message:"\u7981\u6B62\u8BBF\u95EE\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55"});return}const g=y.default.basename(l.QBOT_CLAW_DIR),c=s.split(y.default.sep);for(const m of c)if(m.startsWith(".")&&m!=="."&&m!==".."&&m!==g){(0,a.log)(`[reveal] \u8BBF\u95EE\u9690\u85CF\u6587\u4EF6/\u76EE\u5F55\u88AB\u62D2\u7EDD: ${s}\uFF08\u5339\u914D\u6BB5: ${m}\uFF09`),(0,n.sendJSON)(t,403,{status:"\u5931\u8D25",message:"\u7981\u6B62\u8BBF\u95EE\u9690\u85CF\u6587\u4EF6\u6216\u76EE\u5F55"});return}if(!h.default.existsSync(s)){(0,n.sendJSON)(t,404,{status:"\u5931\u8D25",message:`\u6587\u4EF6\u6216\u76EE\u5F55\u4E0D\u5B58\u5728: ${s}`});return}let u;try{u=h.default.realpathSync(s)}catch{(0,n.sendJSON)(t,400,{status:"\u5931\u8D25",message:"\u65E0\u6CD5\u89E3\u6790\u6587\u4EF6\u771F\u5B9E\u8DEF\u5F84"});return}if(u!==s){const m=u.toLowerCase();for(const w of i)if(m===w.toLowerCase()||m.startsWith(w.toLowerCase()+y.default.sep)){(0,a.log)(`[reveal] \u7B26\u53F7\u94FE\u63A5\u6307\u5411\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55\u88AB\u62D2\u7EDD: ${s} -> ${u}`),(0,n.sendJSON)(t,403,{status:"\u5931\u8D25",message:"\u7981\u6B62\u8BBF\u95EE\u7CFB\u7EDF\u654F\u611F\u76EE\u5F55"});return}const $=u.split(y.default.sep);for(const w of $)if(w.startsWith(".")&&w!=="."&&w!==".."&&w!==g){(0,a.log)(`[reveal] \u7B26\u53F7\u94FE\u63A5\u6307\u5411\u9690\u85CF\u6587\u4EF6/\u76EE\u5F55\u88AB\u62D2\u7EDD: ${s} -> ${u}\uFF08\u5339\u914D\u6BB5: ${w}\uFF09`),(0,n.sendJSON)(t,403,{status:"\u5931\u8D25",message:"\u7981\u6B62\u8BBF\u95EE\u9690\u85CF\u6587\u4EF6\u6216\u76EE\u5F55"});return}}const E=process.platform;let T,v;E==="darwin"?(T="open",v=["-R",s]):E==="win32"?(T="explorer",v=[`/select,${s}`]):(T="xdg-open",v=[y.default.dirname(s)]);try{await new Promise((m,$)=>{const w=(0,A.spawn)(T,v,{stdio:"ignore"}),B=setTimeout(()=>{w.kill(),$(new Error("\u6253\u5F00\u6587\u4EF6\u7BA1\u7406\u5668\u8D85\u65F6\uFF085\u79D2\uFF09"))},5e3);w.on("close",O=>{clearTimeout(B),O===0||O===1?m():$(new Error(`\u8FDB\u7A0B\u9000\u51FA\u7801: ${O}`))}),w.on("error",O=>{clearTimeout(B),$(O)})}),(0,a.log)(`[reveal] \u5DF2\u5728\u6587\u4EF6\u7BA1\u7406\u5668\u4E2D\u663E\u793A: ${s}`),(0,n.sendJSON)(t,200,{status:"\u6210\u529F",message:`\u5DF2\u5728\u6587\u4EF6\u7BA1\u7406\u5668\u4E2D\u663E\u793A: ${s}`})}catch(m){(0,a.log)(`[reveal] \u6253\u5F00\u6587\u4EF6\u7BA1\u7406\u5668\u5931\u8D25: ${m.message}`),(0,n.sendJSON)(t,500,{status:"\u5931\u8D25",message:`\u6253\u5F00\u6587\u4EF6\u7BA1\u7406\u5668\u5931\u8D25: ${m.message}`})}return}(0,n.sendJSON)(t,404,{status:"\u5931\u8D25",message:"\u63A5\u53E3\u4E0D\u5B58\u5728"})});let S=null,C=null;function W(p){if(!p)return;if(S&&C===p){(0,a.log)(`[watchParentProcess] \u5DF2\u5728\u76D1\u63A7\u7236\u8FDB\u7A0B ppid: ${p}\uFF0C\u8DF3\u8FC7\u91CD\u590D\u76D1\u542C`);return}S?((0,a.log)(`[watchParentProcess] \u5DF2\u6709\u76D1\u63A7\uFF08ppid: ${C}\uFF09\uFF0C\u505C\u6B62\u65E7\u7684\u76D1\u63A7\uFF0C\u91CD\u65B0\u76D1\u63A7 ppid: ${p}`),clearInterval(S),S=null,C=null):(0,a.log)(`[watchParentProcess] \u5F00\u59CB\u76D1\u63A7\u7236\u8FDB\u7A0B ppid: ${p}`);const t=setInterval(()=>{try{process.kill(p,0)}catch{(0,a.log)(`[watchParentProcess] \u7236\u8FDB\u7A0B ${p} \u5DF2\u9000\u51FA\uFF0C\u5F00\u59CB\u6E05\u7406\u5E76\u9000\u51FA`),clearInterval(t),S=null,C=null;const d=(0,P.readState)();if(d.gatewayPid)try{process.kill(d.gatewayPid,"SIGTERM"),(0,a.log)(`[watchParentProcess] \u5DF2\u53D1\u9001 SIGTERM \u7ED9 qbotclaw \u8FDB\u7A0B pid: ${d.gatewayPid}`)}catch{(0,a.log)(`[watchParentProcess] qbotclaw \u8FDB\u7A0B ${d.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA\uFF0C\u5FFD\u7565`)}(0,P.clearState)(),(0,a.log)("[watchParentProcess] \u72B6\u6001\u5DF2\u6E05\u7406\uFF0C\u5173\u95ED server \u5E76\u9000\u51FA"),exports.server.close(()=>{(0,a.log)("[watchParentProcess] server \u5DF2\u5173\u95ED\uFF0C\u8FDB\u7A0B\u9000\u51FA"),process.exit(0)}),setTimeout(()=>{(0,a.log)("[watchParentProcess] server.close \u8D85\u65F6\uFF0C\u5F3A\u5236\u9000\u51FA"),process.exit(0)},3e3).unref()}},3e3);t.unref(),S=t,C=p}
3
+ `)}).catch(t=>{s.end(`
4
+ [\u542F\u52A8\u5931\u8D25: ${t.message}]
5
+ `)})});return}if(m.startsWith("/api/uninstall")){const r=new URL(m,"http://localhost").searchParams.get("keepWorkspace")==="true";s.writeHead(200,{...C,"Content-Type":"text/plain; charset=utf-8","Transfer-Encoding":"chunked","Cache-Control":"no-cache"});const t=(l,c,g)=>{if(s.writable)try{s.write(JSON.stringify({status:l,file:c,msg:g})+`
6
+ `)}catch{}};try{t("\u6210\u529F","","\u6B63\u5728\u505C\u6B62 QBotClaw...");const l=(0,w.readState)();if(l.gatewayPid)try{process.kill(l.gatewayPid,"SIGTERM"),(0,o.log)(`[uninstall] \u5DF2\u505C\u6B62 QBotClaw gateway \u8FDB\u7A0B pid: ${l.gatewayPid}`),t("\u6210\u529F","",`\u5DF2\u505C\u6B62 QBotClaw gateway \u8FDB\u7A0B pid: ${l.gatewayPid}`)}catch{(0,o.log)(`[uninstall] QBotClaw gateway \u8FDB\u7A0B ${l.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA`),t("\u6210\u529F","",`QBotClaw gateway \u8FDB\u7A0B ${l.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA`)}else t("\u6210\u529F","","QBotClaw \u672A\u5728\u8FD0\u884C");t("\u6210\u529F","",`\u6B63\u5728\u6267\u884C npm uninstall -g ${u.NPM_PACKAGE_NAME}...`);try{await new Promise((g,d)=>{const e=(0,v.spawn)(u.NPM_BIN,["--userconfig",u.NPM_RC,"uninstall","-g",u.NPM_PACKAGE_NAME],{env:{...process.env,PATH:`${u.NODE_BIN_DIR}:${process.env.PATH}`}});e.stdout?.on("data",i=>{(0,o.log)(`[uninstall] npm: ${i.toString().trim()}`)}),e.stderr?.on("data",i=>{(0,o.log)(`[uninstall] npm stderr: ${i.toString().trim()}`)}),e.on("close",i=>{i===0?g():d(new Error(`npm uninstall \u9000\u51FA\u7801: ${i}`))}),e.on("error",i=>d(i))}),(0,o.log)(`[uninstall] npm uninstall -g ${u.NPM_PACKAGE_NAME} \u6210\u529F`),t("\u6210\u529F","",`npm uninstall -g ${u.NPM_PACKAGE_NAME} \u6210\u529F`)}catch(g){(0,o.log)(`[uninstall] npm uninstall \u5931\u8D25: ${g.message}`),t("\u5931\u8D25","",`npm uninstall \u5931\u8D25: ${g.message}`)}t("\u6210\u529F","",`\u6B63\u5728\u6E05\u7406\u76EE\u5F55 ${u.QBOT_CLAW_DIR}...`);const c=[];if(h.default.existsSync(u.QBOT_CLAW_DIR)){const g=h.default.readdirSync(u.QBOT_CLAW_DIR);for(const d of g){const e=_.default.join(u.QBOT_CLAW_DIR,d);if(r&&d==="workspace"){t("\u6210\u529F",e,"\u4FDD\u7559 workspace \u76EE\u5F55");continue}try{h.default.statSync(e).isDirectory()?h.default.rmSync(e,{recursive:!0,force:!0}):h.default.unlinkSync(e),t("\u6210\u529F",e,"\u5DF2\u5220\u9664")}catch(i){(0,o.log)(`[uninstall] \u5220\u9664\u5931\u8D25: ${e} - ${i.message}`),t("\u5931\u8D25",e,`\u5220\u9664\u5931\u8D25: ${i.message}`),c.push(e)}}if(c.length>0){t("\u6210\u529F","",`${c.length} \u4E2A\u9879\u76EE\u5220\u9664\u5931\u8D25\uFF0C\u4F7F\u7528 rm \u547D\u4EE4\u91CD\u8BD5...`);for(const d of c)try{(0,v.execSync)(`rm -rf "${d}"`),(0,o.log)(`[uninstall] rm -rf \u91CD\u8BD5\u6210\u529F: ${d}`),t("\u6210\u529F",d,"rm \u91CD\u8BD5\u5220\u9664\u6210\u529F")}catch(e){(0,o.log)(`[uninstall] rm -rf \u91CD\u8BD5\u4E5F\u5931\u8D25: ${d} - ${e.message}`),t("\u5931\u8D25",d,`rm \u91CD\u8BD5\u4E5F\u5931\u8D25: ${e.message}`)}}if(r)t("\u6210\u529F",u.QBOT_CLAW_DIR,"\u4FDD\u7559\u6839\u76EE\u5F55\uFF08workspace \u6A21\u5F0F\uFF09");else try{h.default.rmSync(u.QBOT_CLAW_DIR,{recursive:!0,force:!0}),t("\u6210\u529F",u.QBOT_CLAW_DIR,"\u5DF2\u5220\u9664\u6839\u76EE\u5F55")}catch(d){(0,o.log)(`[uninstall] \u5220\u9664\u6839\u76EE\u5F55\u5931\u8D25: ${d.message}`);try{(0,v.execSync)(`rm -rf "${u.QBOT_CLAW_DIR}"`),t("\u6210\u529F",u.QBOT_CLAW_DIR,"rm \u91CD\u8BD5\u5220\u9664\u6839\u76EE\u5F55\u6210\u529F")}catch(e){t("\u5931\u8D25",u.QBOT_CLAW_DIR,`\u5220\u9664\u6839\u76EE\u5F55\u5931\u8D25: ${e.message}`)}}}else t("\u6210\u529F",u.QBOT_CLAW_DIR,"\u76EE\u5F55\u4E0D\u5B58\u5728\uFF0C\u65E0\u9700\u6E05\u7406");t("\u6210\u529F","","\u5378\u8F7D\u5B8C\u6210")}catch(l){(0,o.log)(`[uninstall] \u5378\u8F7D\u8FC7\u7A0B\u5F02\u5E38: ${l.message}`),t("\u5931\u8D25","",`\u5378\u8F7D\u8FC7\u7A0B\u5F02\u5E38: ${l.message}`)}s.end(),setTimeout(()=>{(0,o.log)("[uninstall] \u5378\u8F7D\u6D41\u7A0B\u7ED3\u675F\uFF0Clauncher \u8FDB\u7A0B\u9000\u51FA"),process.exit(0)},500);return}if(m==="/api/file-picker"&&f.method==="POST"){if((0,k.isFilePickerBusy)()){(0,a.sendJSON)(s,409,{ok:!1,files:[],message:"\u5DF2\u6709\u6587\u4EF6\u9009\u62E9\u5BF9\u8BDD\u6846\u6B63\u5728\u663E\u793A\uFF0C\u8BF7\u7B49\u5F85\u5F53\u524D\u5BF9\u8BDD\u6846\u5173\u95ED\u540E\u91CD\u8BD5"});return}let n="";f.on("data",r=>{n+=r.toString()}),f.on("end",async()=>{let r=[],t=!1,l=W,c=x,g=B,d=R;if(n){let e;try{e=JSON.parse(n)}catch{(0,a.sendJSON)(s,400,{ok:!1,files:[],message:"\u8BF7\u6C42\u4F53\u5FC5\u987B\u662F\u5408\u6CD5\u7684 JSON"});return}if(e.extensions!==void 0){if(!Array.isArray(e.extensions)||!e.extensions.every(i=>typeof i=="string")){(0,a.sendJSON)(s,400,{ok:!1,files:[],message:"\u53C2\u6570 extensions \u5FC5\u987B\u662F\u5B57\u7B26\u4E32\u6570\u7EC4"});return}r=e.extensions}if(e.multiple!==void 0){if(typeof e.multiple!="boolean"){(0,a.sendJSON)(s,400,{ok:!1,files:[],message:"\u53C2\u6570 multiple \u5FC5\u987B\u662F\u5E03\u5C14\u503C"});return}t=e.multiple}if(e.title!==void 0){if(typeof e.title!="string"||e.title.length>200){(0,a.sendJSON)(s,400,{ok:!1,files:[],message:"\u53C2\u6570 title \u5FC5\u987B\u662F\u5B57\u7B26\u4E32\u4E14\u957F\u5EA6\u4E0D\u8D85\u8FC7 200"});return}l=e.title}if(e.maxFileSize!==void 0){if(typeof e.maxFileSize!="number"||e.maxFileSize<=0||!Number.isFinite(e.maxFileSize)){(0,a.sendJSON)(s,400,{ok:!1,files:[],message:"\u53C2\u6570 maxFileSize \u5FC5\u987B\u662F\u6B63\u6570"});return}c=Math.min(e.maxFileSize,x)}if(e.maxFileCount!==void 0){if(typeof e.maxFileCount!="number"||e.maxFileCount<=0||!Number.isInteger(e.maxFileCount)){(0,a.sendJSON)(s,400,{ok:!1,files:[],message:"\u53C2\u6570 maxFileCount \u5FC5\u987B\u662F\u6B63\u6574\u6570"});return}g=Math.min(e.maxFileCount,B)}if(R&&e.allowDirectory!==void 0){if(typeof e.allowDirectory!="boolean"){(0,a.sendJSON)(s,400,{ok:!1,files:[],message:"\u53C2\u6570 allowDirectory \u5FC5\u987B\u662F\u5E03\u5C14\u503C"});return}d=e.allowDirectory}}t||(g=1);try{const e=await(0,k.showFilePicker)({extensions:r,multiple:t,title:l,allowDirectory:d});if(!e||e.length===0){(0,a.sendJSON)(s,200,{ok:!0,files:[],message:"\u7528\u6237\u53D6\u6D88\u4E86\u6587\u4EF6\u9009\u62E9"});return}if(d){const O=e.slice(0,g).map(I=>({name:_.default.basename(I),path:I,size:0,mimeType:"inode/directory"})),p=e.length>g;(0,a.sendJSON)(s,200,{ok:!0,files:O,message:p?`\u5DF2\u9009\u62E9 ${O.length} \u4E2A\u76EE\u5F55\uFF08\u5171\u9009\u62E9 ${e.length} \u4E2A\uFF0C\u8D85\u51FA\u4E0A\u9650 ${g} \u4E2A\u5DF2\u622A\u65AD\uFF09`:`\u5DF2\u9009\u62E9 ${O.length} \u4E2A\u76EE\u5F55`});return}let i=!1,N=e;e.length>g&&(N=e.slice(0,g),i=!0);const S=[],P=[];for(const O of N){const p=(0,J.readFileInfo)(O,c);p.ok?S.push({name:p.name,path:p.path,size:p.size,mimeType:p.mimeType}):P.push({path:p.path,reason:p.reason})}const y=[];if(S.length>0&&y.push(`\u6210\u529F\u8BFB\u53D6 ${S.length} \u4E2A\u6587\u4EF6`),P.length>0){const O=P.map(p=>`${_.default.basename(p.path)}: ${p.reason}`).join("\uFF1B");y.push(`${P.length} \u4E2A\u6587\u4EF6\u8BFB\u53D6\u5931\u8D25\uFF08${O}\uFF09`)}i&&y.push(`\u5171\u9009\u62E9 ${e.length} \u4E2A\u6587\u4EF6\uFF0C\u8D85\u51FA\u4E0A\u9650 ${g} \u4E2A\u5DF2\u622A\u65AD`),(0,a.sendJSON)(s,200,{ok:!0,files:S,message:y.join("\uFF1B")||"\u6587\u4EF6\u9009\u62E9\u6210\u529F"})}catch(e){(0,o.log)(`[file-picker] \u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${e.message}`),(0,a.sendJSON)(s,500,{ok:!1,files:[],message:`\u6587\u4EF6\u9009\u62E9\u5931\u8D25: ${e.message}`})}});return}if(m.startsWith("/api/reveal")){const r=new URL(m,"http://localhost").searchParams.get("path");if(!r){(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:"\u7F3A\u5C11\u5FC5\u8981\u53C2\u6570 path\uFF08\u9700 Base64 \u7F16\u7801\uFF09\uFF0C\u7528\u6CD5: GET /api/reveal?path=<base64\u7F16\u7801\u7684\u6587\u4EF6\u7EDD\u5BF9\u8DEF\u5F84>"});return}let t;try{t=Buffer.from(r,"base64").toString("utf-8")}catch{(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:"path \u53C2\u6570 Base64 \u89E3\u7801\u5931\u8D25\uFF0C\u8BF7\u786E\u4FDD\u4F20\u5165\u5408\u6CD5\u7684 Base64 \u7F16\u7801\u5B57\u7B26\u4E32"});return}if(!t||t.trim()===""){(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:"Base64 \u89E3\u7801\u540E\u8DEF\u5F84\u4E3A\u7A7A"});return}const l=(0,J.validateFilePath)(t);if(!l.valid){const i=l.reason;i.includes("\u975E\u6CD5\u5B57\u7B26")?(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:i}):i.includes("\u4E0D\u5B58\u5728")?(0,a.sendJSON)(s,404,{status:"\u5931\u8D25",message:i}):i.includes("\u65E0\u6CD5\u89E3\u6790")?(0,a.sendJSON)(s,400,{status:"\u5931\u8D25",message:i}):((0,o.log)(`[reveal] \u5B89\u5168\u68C0\u67E5\u88AB\u62D2\u7EDD: ${t}\uFF0C\u539F\u56E0: ${i}`),(0,a.sendJSON)(s,403,{status:"\u5931\u8D25",message:i}));return}const c=_.default.resolve(t),g=process.platform;let d,e;g==="darwin"?(d="open",e=["-R",c]):g==="win32"?(d="explorer",e=[`/select,${c}`]):(d="xdg-open",e=[_.default.dirname(c)]);try{await new Promise((i,N)=>{const S=(0,v.spawn)(d,e,{stdio:"ignore"}),P=setTimeout(()=>{S.kill(),N(new Error("\u6253\u5F00\u6587\u4EF6\u7BA1\u7406\u5668\u8D85\u65F6\uFF085\u79D2\uFF09"))},5e3);S.on("close",y=>{clearTimeout(P),y===0||y===1?i():N(new Error(`\u8FDB\u7A0B\u9000\u51FA\u7801: ${y}`))}),S.on("error",y=>{clearTimeout(P),N(y)})}),(0,o.log)(`[reveal] \u5DF2\u5728\u6587\u4EF6\u7BA1\u7406\u5668\u4E2D\u663E\u793A: ${c}`),(0,a.sendJSON)(s,200,{status:"\u6210\u529F",message:`\u5DF2\u5728\u6587\u4EF6\u7BA1\u7406\u5668\u4E2D\u663E\u793A: ${c}`})}catch(i){(0,o.log)(`[reveal] \u6253\u5F00\u6587\u4EF6\u7BA1\u7406\u5668\u5931\u8D25: ${i.message}`),(0,a.sendJSON)(s,500,{status:"\u5931\u8D25",message:`\u6253\u5F00\u6587\u4EF6\u7BA1\u7406\u5668\u5931\u8D25: ${i.message}`})}return}(0,a.sendJSON)(s,404,{status:"\u5931\u8D25",message:"\u63A5\u53E3\u4E0D\u5B58\u5728"})});let $=null,A=null;function L(f){if(!f)return;if($&&A===f){(0,o.log)(`[watchParentProcess] \u5DF2\u5728\u76D1\u63A7\u7236\u8FDB\u7A0B ppid: ${f}\uFF0C\u8DF3\u8FC7\u91CD\u590D\u76D1\u542C`);return}$?((0,o.log)(`[watchParentProcess] \u5DF2\u6709\u76D1\u63A7\uFF08ppid: ${A}\uFF09\uFF0C\u505C\u6B62\u65E7\u7684\u76D1\u63A7\uFF0C\u91CD\u65B0\u76D1\u63A7 ppid: ${f}`),clearInterval($),$=null,A=null):(0,o.log)(`[watchParentProcess] \u5F00\u59CB\u76D1\u63A7\u7236\u8FDB\u7A0B ppid: ${f}`);const s=setInterval(()=>{try{process.kill(f,0)}catch{(0,o.log)(`[watchParentProcess] \u7236\u8FDB\u7A0B ${f} \u5DF2\u9000\u51FA\uFF0C\u5F00\u59CB\u6E05\u7406\u5E76\u9000\u51FA`),clearInterval(s),$=null,A=null;const m=(0,w.readState)();if(m.gatewayPid)try{process.kill(m.gatewayPid,"SIGTERM"),(0,o.log)(`[watchParentProcess] \u5DF2\u53D1\u9001 SIGTERM \u7ED9 qbotclaw \u8FDB\u7A0B pid: ${m.gatewayPid}`)}catch{(0,o.log)(`[watchParentProcess] qbotclaw \u8FDB\u7A0B ${m.gatewayPid} \u53EF\u80FD\u5DF2\u9000\u51FA\uFF0C\u5FFD\u7565`)}(0,w.clearState)(),(0,o.log)("[watchParentProcess] \u72B6\u6001\u5DF2\u6E05\u7406\uFF0C\u5173\u95ED server \u5E76\u9000\u51FA"),exports.server.close(()=>{(0,o.log)("[watchParentProcess] server \u5DF2\u5173\u95ED\uFF0C\u8FDB\u7A0B\u9000\u51FA"),process.exit(0)}),setTimeout(()=>{(0,o.log)("[watchParentProcess] server.close \u8D85\u65F6\uFF0C\u5F3A\u5236\u9000\u51FA"),process.exit(0)},3e3).unref()}},3e3);s.unref(),$=s,A=f}
package/dist/service.js CHANGED
@@ -1,6 +1,6 @@
1
- "use strict";var d=exports&&exports.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.getOrCreateGatewayToken=g,exports.startService=O,exports.stopService=R;const S=d(require("fs")),y=d(require("http")),_=require("crypto"),f=require("./server"),e=require("./state"),v=require("./config"),l=require("./version"),k=require("./installer"),q=require("./utils"),s=require("./reportLog");let p,u;function g(){return u||(u=require("crypto").randomBytes(24).toString("hex"),u||"0526bec85002fe65ef10d33df0a8dfbe76917cd125f5a4ad")}function h(t){return new Promise(r=>{const o=y.default.get(`http://127.0.0.1:${t}/api/version`,a=>{let n="";a.on("data",i=>{n+=i.toString()}),a.on("end",()=>{try{const i=JSON.parse(n);r(i.launcher??null)}catch{r(null)}})});o.on("error",()=>r(null)),o.setTimeout(3e3,()=>{o.destroy(),r(null)})})}async function $(){const t=(0,e.readState)();if(!t.pid||!t.port)return null;try{process.kill(t.pid,0)}catch{return(0,e.clearState)(),null}if(await(0,e.isPortAvailable)(t.port))return(0,s.log)("\u7AEF\u53E3\u672A\u88AB\u5360\u7528\uFF0C\u8BF4\u660E\u72B6\u6001\u6587\u4EF6\u8FC7\u671F"),(0,e.clearState)(),null;const o=await h(t.port);if((0,s.log)(`[service] \u68C0\u6D4B\u5230\u6B63\u5728\u8FD0\u884C\u7684\u670D\u52A1\u7248\u672C: ${o??"unknown"}\uFF0C\u5F53\u524D\u7248\u672C: ${l.LAUNCHER_VERSION}`),o===l.LAUNCHER_VERSION)return(0,s.log)(`[service] \u7248\u672C\u4E00\u81F4\uFF0C\u590D\u7528\u5DF2\u6709\u670D\u52A1 (pid: ${t.pid}, port: ${t.port})`),!1;(0,s.log)(`[service] \u7248\u672C\u4E0D\u4E00\u81F4 (\u8FD0\u884C\u4E2D: ${o??"unknown"}, \u5F53\u524D: ${l.LAUNCHER_VERSION})\uFF0C\u6740\u6389\u65E7\u8FDB\u7A0B pid: ${t.pid}\uFF0C\u91CD\u65B0\u542F\u52A8`);try{process.kill(t.pid,"SIGTERM")}catch{}return(0,e.clearState)(),!0}async function O(t,r){if(await $()===!1){const n=(0,e.readState)();process.stdout.write(JSON.stringify({state:"success",pid:n.pid,port:n.port})+`
2
- `),process.stdout.uncork(),(0,s.log)(`[service] \u7248\u672C\u4E00\u81F4\uFF0C\u590D\u7528\u5DF2\u6709\u670D\u52A1 (pid: ${n.pid}, port: ${n.port})`);return}const a=await(0,e.findAvailablePort)();f.server.listen(a,"127.0.0.1",()=>{p=(0,_.randomUUID)();const n=g();if((0,e.writeState)({pid:process.pid,port:a,token:p,...t?{ppid:t}:{}}),process.stdout.write(JSON.stringify({state:"success",pid:process.pid,port:a,token:p,gatewayToken:n})+`
3
- `),process.stdout.uncork(),(0,f.watchParentProcess)(t),!S.default.existsSync(v.QBOTCLAW_BIN)){(0,s.log)("[service] qbotclaw \u672A\u5B89\u88C5\uFF0C\u4E0D\u81EA\u52A8\u542F\u52A8");return}(0,q.getQBotClawVersion)().then(i=>{const c=(0,e.readState)();if(i!==r){(0,s.log)(`[service] qbotclaw \u672C\u5730\u7248\u672C (${i??"unknown"}) \u4E0E\u671F\u671B\u7248\u672C (${r}) \u4E0D\u4E00\u81F4\uFF0C\u505C\u6B62\u5F53\u524D qbotclaw \u8FDB\u7A0B`),(0,e.stopGateway)();return}else c.gatewayPid&&c.gatewayPort?(0,s.log)(`[service] qbotclaw \u5DF2\u5728\u8FD0\u884C\uFF0Cpid: ${c.gatewayPid}, port: ${c.gatewayPort}`):((0,s.log)("[service] \u68C0\u6D4B\u5230 qbotclaw\uFF0C\u7248\u672C\u5339\u914D\uFF0C\u81EA\u52A8\u542F\u52A8 gateway..."),(0,k.configAndRunQBotClaw)().catch(w=>{(0,s.log)(`[service] \u81EA\u52A8\u542F\u52A8 gateway \u5931\u8D25: ${w.message}`)}))})}),process.on("SIGTERM",()=>{(0,e.stopGateway)(),(0,e.clearState)(),(0,s.flushLogs)().finally(()=>{process.exit(0)})})}function R(){const t=(0,e.readState)();if(!t.pid){process.stdout.write(JSON.stringify({state:"err",pid:0,port:0})+`
4
- `),process.stdout.uncork();return}try{process.kill(t.pid,"SIGTERM");const r=t.pid,o=t.port??0;(0,e.clearState)(),process.stdout.write(JSON.stringify({state:"success",pid:r,port:o})+`
1
+ "use strict";var l=exports&&exports.__importDefault||function(t){return t&&t.__esModule?t:{default:t}};Object.defineProperty(exports,"__esModule",{value:!0}),exports.getServiceToken=_,exports.startService=h,exports.stopService=R;const f=l(require("fs")),S=l(require("http")),g=require("crypto"),p=require("./server"),e=require("./state"),w=require("./config"),u=require("./version"),y=require("./installer"),v=require("./utils"),o=require("./reportLog");let c=null;function _(){return c}function k(t){return new Promise(r=>{const s=S.default.get(`http://127.0.0.1:${t}/api/version`,a=>{let n="";a.on("data",i=>{n+=i.toString()}),a.on("end",()=>{try{const i=JSON.parse(n);r(i.launcher??null)}catch{r(null)}})});s.on("error",()=>r(null)),s.setTimeout(3e3,()=>{s.destroy(),r(null)})})}async function q(){const t=(0,e.readState)();if(!t.pid||!t.port)return null;try{process.kill(t.pid,0)}catch{return(0,e.clearState)(),null}if(await(0,e.isPortAvailable)(t.port))return(0,o.log)("\u7AEF\u53E3\u672A\u88AB\u5360\u7528\uFF0C\u8BF4\u660E\u72B6\u6001\u6587\u4EF6\u8FC7\u671F"),(0,e.clearState)(),null;const s=await k(t.port);if((0,o.log)(`[service] \u68C0\u6D4B\u5230\u6B63\u5728\u8FD0\u884C\u7684\u670D\u52A1\u7248\u672C: ${s??"unknown"}\uFF0C\u5F53\u524D\u7248\u672C: ${u.LAUNCHER_VERSION}`),s===u.LAUNCHER_VERSION)return(0,o.log)(`[service] \u7248\u672C\u4E00\u81F4\uFF0C\u590D\u7528\u5DF2\u6709\u670D\u52A1 (pid: ${t.pid}, port: ${t.port})`),!1;(0,o.log)(`[service] \u7248\u672C\u4E0D\u4E00\u81F4 (\u8FD0\u884C\u4E2D: ${s??"unknown"}, \u5F53\u524D: ${u.LAUNCHER_VERSION})\uFF0C\u6740\u6389\u65E7\u8FDB\u7A0B pid: ${t.pid}\uFF0C\u91CD\u65B0\u542F\u52A8`);try{process.kill(t.pid,"SIGTERM")}catch{}return(0,e.clearState)(),!0}async function h(t,r){if(await q()===!1){const n=(0,e.readState)();c=n.token??null,process.stdout.write(JSON.stringify({state:"success",pid:n.pid,port:n.port,token:c})+`
2
+ `),process.stdout.uncork();return}const a=await(0,e.findAvailablePort)();c=(0,g.randomUUID)(),p.server.listen(a,"127.0.0.1",()=>{if((0,e.writeState)({pid:process.pid,port:a,token:c,...t?{ppid:t}:{}}),process.stdout.write(JSON.stringify({state:"success",pid:process.pid,port:a,token:c})+`
3
+ `),process.stdout.uncork(),(0,p.watchParentProcess)(t),!f.default.existsSync(w.QBOTCLAW_BIN)){(0,o.log)("[service] qbotclaw \u672A\u5B89\u88C5\uFF0C\u4E0D\u81EA\u52A8\u542F\u52A8");return}(0,v.getQBotClawVersion)().then(n=>{const i=(0,e.readState)();if(n!==r){(0,o.log)(`[service] qbotclaw \u672C\u5730\u7248\u672C (${n??"unknown"}) \u4E0E\u671F\u671B\u7248\u672C (${r}) \u4E0D\u4E00\u81F4\uFF0C\u505C\u6B62\u5F53\u524D qbotclaw \u8FDB\u7A0B`),(0,e.stopGateway)();return}else i.gatewayPid&&i.gatewayPort?(0,o.log)(`[service] qbotclaw \u5DF2\u5728\u8FD0\u884C\uFF0Cpid: ${i.gatewayPid}, port: ${i.gatewayPort}`):((0,o.log)("[service] \u68C0\u6D4B\u5230 qbotclaw\uFF0C\u7248\u672C\u5339\u914D\uFF0C\u81EA\u52A8\u542F\u52A8 gateway..."),(0,y.configAndRunQBotClaw)().catch(d=>{(0,o.log)(`[service] \u81EA\u52A8\u542F\u52A8 gateway \u5931\u8D25: ${d.message}`)}))})}),process.on("SIGTERM",()=>{(0,e.stopGateway)(),(0,e.clearState)(),(0,o.flushLogs)().finally(()=>{process.exit(0)})})}function R(){const t=(0,e.readState)();if(!t.pid){process.stdout.write(JSON.stringify({state:"err",pid:0,port:0})+`
4
+ `),process.stdout.uncork();return}try{process.kill(t.pid,"SIGTERM");const r=t.pid,s=t.port??0;(0,e.clearState)(),process.stdout.write(JSON.stringify({state:"success",pid:r,port:s})+`
5
5
  `),process.stdout.uncork()}catch(r){r.code==="ESRCH"&&(0,e.clearState)(),process.stdout.write(JSON.stringify({state:"err",pid:0,port:0})+`
6
6
  `),process.stdout.uncork()}}
package/dist/version.js CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LAUNCHER_VERSION=void 0,exports.LAUNCHER_VERSION="0.9.60";
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.LAUNCHER_VERSION=void 0,exports.LAUNCHER_VERSION="0.9.62";
@@ -1,11 +1,11 @@
1
1
  const {createWrapper} = require('./wrapper');
2
2
 
3
- // 直接加载预编译的 Universal Binary (.node 文件)
3
+ // 直接加载本地编译的 Universal Binary (.node 文件)
4
4
  let binding;
5
5
  try {
6
6
  binding = require('./build/Release/watcher.node');
7
7
  } catch (err) {
8
- throw new Error(`No prebuild of @parcel/watcher found. Please run the build scripts to compile the native module. Error: ${err.message}`);
8
+ throw new Error(`No local build of @parcel/watcher found. Please run "bash scripts/build-parcel-watcher.sh" to compile the native module. Error: ${err.message}`);
9
9
  }
10
10
 
11
11
  const wrapper = createWrapper(binding);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@qqbrowser/qbot-claw-launcher",
3
- "version": "0.9.60",
3
+ "version": "0.9.62",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "bin": {
@@ -16,11 +16,10 @@
16
16
  ],
17
17
  "scripts": {
18
18
  "build": "node scripts/inject-version.js && tsc && node scripts/obfuscate.js && chmod +x dist/index.js",
19
- "prepare": "test -d prebuilds && mkdir -p fs-xattr/build/Release parcel-watcher/build/Release && cp prebuilds/xattr.node fs-xattr/build/Release/ && cp prebuilds/watcher.node parcel-watcher/build/Release/ && echo '✅ prebuilds copied' || true",
20
- "prepack": "rm -rf node_modules/fs-xattr && cp -r fs-xattr node_modules/fs-xattr && rm -rf node_modules/@parcel/watcher && mkdir -p node_modules/@parcel && cp -r parcel-watcher node_modules/@parcel/watcher && mkdir -p node_modules/fs-xattr/build/Release && cp prebuilds/xattr.node node_modules/fs-xattr/build/Release/ && mkdir -p node_modules/@parcel/watcher/build/Release && cp prebuilds/watcher.node node_modules/@parcel/watcher/build/Release/ && bash scripts/clean-native-sources.sh && bash scripts/verify-universal-binary.sh",
19
+ "prepack": "bash scripts/build-fs-xattr.sh && bash scripts/build-parcel-watcher.sh && rm -rf node_modules/fs-xattr && cp -r fs-xattr node_modules/fs-xattr && rm -rf node_modules/@parcel/watcher && mkdir -p node_modules/@parcel && cp -r parcel-watcher node_modules/@parcel/watcher && bash scripts/clean-native-sources.sh && bash scripts/verify-universal-binary.sh",
21
20
  "start": "node dist/index.js",
22
21
  "dev": "ts-node src/index.ts",
23
- "test": "echo \"Error: no test specified\" && exit 1"
22
+ "test": "jest --verbose"
24
23
  },
25
24
  "publishConfig": {
26
25
  "registry": "https://registry.npmjs.org"
@@ -29,13 +28,20 @@
29
28
  "author": "",
30
29
  "license": "ISC",
31
30
  "devDependencies": {
31
+ "@types/jest": "^30.0.0",
32
32
  "@types/node": "^20.0.0",
33
33
  "esbuild": "0.25.10",
34
+ "jest": "^30.3.0",
35
+ "ts-jest": "^29.4.6",
34
36
  "ts-node": "10.9.2",
35
37
  "typescript": "5.9.3"
36
38
  },
37
39
  "dependencies": {
38
40
  "@parcel/watcher": "file:./parcel-watcher",
39
41
  "fs-xattr": "file:./fs-xattr"
40
- }
42
+ },
43
+ "bundleDependencies": [
44
+ "fs-xattr",
45
+ "@parcel/watcher"
46
+ ]
41
47
  }