opencode-haimati 1.1.5 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,99 +1,99 @@
1
- # opencode-haimati
2
-
3
- 为 OpenCode 提供基于文件系统的长期记忆存储和检索功能。
4
-
5
- ## 功能特性
6
-
7
- - 类海马体记忆机制:模拟人脑记忆系统的分类存储
8
- - 树形索引结构 + 分组书页存储
9
- - 多模式搜索:序号精确查询 + 关键字模糊搜索
10
- - 完整 CRUD:读取、写入、更新、删除、移动
11
- - 版本并发控制:基于 version 的乐观锁
12
- - 自动增强首条提示词 + 会话空闲时自动提示记录
13
-
14
- ## 安装
15
-
16
- ```bash
17
- npm install -g opencode-haimati
18
- # 或
19
- bun add -g opencode-haimati
20
- ```
21
-
22
- ## 配置
23
-
24
- 在 `opencode.json` 中添加插件:
25
-
26
- ```json
27
- {
28
- "$schema": "https://opencode.ai/config.json",
29
- "plugin": ["opencode-haimati"]
30
- }
31
- ```
32
-
33
- 在项目根目录创建 `opencode-haimati.conf`(可选):
34
-
35
- ```ini
36
- haimati-path: .haimati
37
- ```
38
-
39
- ## 目录结构
40
-
41
- ```
42
- .haimati/
43
- ├── .lock # 文件锁(支持网络共享挂载多用户协调)
44
- ├── 索引.md # 树形索引
45
- ├── next-id.txt # 下一个序号
46
- └── 书页/ # 记忆内容(每50个序号一分组)
47
- ```
48
-
49
- ## 工具
50
-
51
- | 工具 | 说明 |
52
- |------|------|
53
- | `haimati_read` | 读取记忆(序号查询,支持分页) |
54
- | `haimati_write` | 写入记忆(不允许覆盖已存在) |
55
- | `haimati_search` | 搜索(标题/分类/内容,match必填) |
56
- | `haimati_edit` | 部分修改(需 version 并发控制) |
57
- | `haimati_move` | 修改分类路径 |
58
- | `haimati_delete` | 删除记忆 |
59
- | `haimati_list` | 列出索引 |
60
-
61
- ## 使用示例
62
-
63
- ```typescript
64
- // 写入(title 不能以 " - 序号" 结尾)
65
- haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "..." })
66
-
67
- // 读取
68
- haimati_read({ query: "086" })
69
-
70
- // 搜索
71
- haimati_search({ keyword: "WebSocket", match: "or" })
72
-
73
- // 修改(先 read 获取 version)
74
- haimati_edit({ query: "086", offsetBegin: 3, offsetEnd: 5, content: "新内容", version: 1 })
75
-
76
- // 移动
77
- haimati_move({ query: "086", newCategory: "xxx项目/客户端" })
78
-
79
- // 删除
80
- haimati_delete({ query: "086" })
81
-
82
- // 列出
83
- haimati_list({ category: "xxx项目", recursive: true })
84
- ```
85
-
86
- ## 海马体三大原则
87
-
88
- 1. **信息不丢失**: 完整保留所有有价值的信息
89
- 2. **错误信息修正**: 不再保留已被纠正的错误信息
90
- 3. **拒绝冗余**: 不要重复记录相同内容
91
-
92
- ## 日志
93
-
94
- 日志位于:`{系统临时目录}/haimati_logs/haimati.log`(按天覆盖)
95
-
96
- ## 依赖
97
-
98
- - OpenCode v0.15.0+
99
- - Node.js 或 Bun
1
+ # opencode-haimati
2
+
3
+ 为 OpenCode 提供基于文件系统的长期记忆存储和检索功能。
4
+
5
+ ## 功能特性
6
+
7
+ - 类海马体记忆机制:模拟人脑记忆系统的分类存储
8
+ - 树形索引结构 + 分组书页存储
9
+ - 多模式搜索:序号精确查询 + 关键字模糊搜索
10
+ - 完整 CRUD:读取、写入、更新、删除、移动
11
+ - 版本并发控制:基于 version 的乐观锁
12
+ - 自动增强首条提示词 + 会话空闲时自动提示记录
13
+
14
+ ## 安装
15
+
16
+ ```bash
17
+ npm install -g opencode-haimati
18
+ # 或
19
+ bun add -g opencode-haimati
20
+ ```
21
+
22
+ ## 配置
23
+
24
+ 在 `opencode.json` 中添加插件:
25
+
26
+ ```json
27
+ {
28
+ "$schema": "https://opencode.ai/config.json",
29
+ "plugin": ["opencode-haimati"]
30
+ }
31
+ ```
32
+
33
+ 在项目根目录创建 `opencode-haimati.conf`(可选):
34
+
35
+ ```ini
36
+ haimati-path: .haimati
37
+ ```
38
+
39
+ ## 目录结构
40
+
41
+ ```
42
+ .haimati/
43
+ ├── .lock # 文件锁(支持网络共享挂载多用户协调)
44
+ ├── 索引.md # 树形索引
45
+ ├── next-id.txt # 下一个序号
46
+ └── 书页/ # 记忆内容(每50个序号一分组)
47
+ ```
48
+
49
+ ## 工具
50
+
51
+ | 工具 | 说明 |
52
+ |------|------|
53
+ | `haimati_read` | 读取记忆(序号查询,支持分页) |
54
+ | `haimati_write` | 写入记忆(不允许覆盖已存在) |
55
+ | `haimati_search` | 搜索(标题/分类/内容,match必填) |
56
+ | `haimati_edit` | 部分修改(需 version 并发控制) |
57
+ | `haimati_move` | 修改分类路径 |
58
+ | `haimati_delete` | 删除记忆 |
59
+ | `haimati_list` | 列出索引 |
60
+
61
+ ## 使用示例
62
+
63
+ ```typescript
64
+ // 写入(title 不能以 " - 序号" 结尾)
65
+ haimati_write({ category: "xxx项目/签章", title: "签章服务WS通信机制", content: "..." })
66
+
67
+ // 读取
68
+ haimati_read({ query: "086" })
69
+
70
+ // 搜索
71
+ haimati_search({ keyword: "WebSocket", match: "or" })
72
+
73
+ // 修改(先 read 获取 version)
74
+ haimati_edit({ query: "086", offsetBegin: 3, offsetEnd: 5, content: "新内容", version: 1 })
75
+
76
+ // 移动
77
+ haimati_move({ query: "086", newCategory: "xxx项目/客户端" })
78
+
79
+ // 删除
80
+ haimati_delete({ query: "086" })
81
+
82
+ // 列出
83
+ haimati_list({ category: "xxx项目", recursive: true })
84
+ ```
85
+
86
+ ## 海马体三大原则
87
+
88
+ 1. **信息不丢失**: 完整保留所有有价值的信息
89
+ 2. **错误信息修正**: 不再保留已被纠正的错误信息
90
+ 3. **拒绝冗余**: 不要重复记录相同内容
91
+
92
+ ## 日志
93
+
94
+ 日志位于:`{系统临时目录}/haimati_logs/haimati.log`(按天覆盖)
95
+
96
+ ## 依赖
97
+
98
+ - OpenCode v0.15.0+
99
+ - Node.js 或 Bun
package/dist/index.js CHANGED
@@ -1,90 +1,90 @@
1
- import{tool as I}from"@opencode-ai/plugin";import _ from"path";import Dt from"os";import q from"fs";var z=".haimati",xt="\u7D22\u5F15.md";var It="next-id.txt",St="info.log",Et="error.log";var _t="log.conf";var Pt="opencode-haimati.conf",bt="haimati-path";var G="/start-work";var X="/record-memory";function ee(e){let i=_.join(e,Pt);if(!q.existsSync(i))return null;try{let c=q.readFileSync(i,"utf-8").split(`
2
- `);for(let t of c){let r=t.trim();if(!r||r.startsWith("#"))continue;let l=r.match(/^([^:]+):\s*(.+)$/);if(l){let o=l[1].trim(),a=l[2].trim();if(o===bt&&a){let u=a.match(/^\$\{(\w+)\}$/);if(u){let f=process.env[u[1]];return f?_.resolve(e,f):(console.warn(`[haimati] \u73AF\u5883\u53D8\u91CF ${u[1]} \u672A\u5B9A\u4E49\u6216\u503C\u4E3A\u7A7A`),null)}return _.resolve(e,a)}}}}catch(n){console.error("[haimati] \u8BFB\u53D6\u914D\u7F6E\u6587\u4EF6\u5931\u8D25:",n)}return null}function v(e){let i=ee(e);return i||_.join(e,z)}function L(e){return _.join(v(e),xt)}function Q(e){return _.join(v(e),It)}function ut(e){return _.join(v(e),".lock")}function gt(e){return _.join(v(e),"\u4E66\u9875")}function B(e,i){let n=parseInt(i,10),c=Math.floor((n-1)/50)*50+1,t=c+50-1,r=`${String(c).padStart(3,"0")}-${String(t).padStart(3,"0")}`;return _.join(gt(e),r)}function Z(e,i){let n=String(parseInt(i,10)).padStart(3,"0");return _.join(B(e,i),`${n}.md`)}function H(){let e=Dt.homedir();return _.join(e,".opencode-haimati","log")}function ne(){let e=Dt.homedir();return _.join(e,".opencode-haimati",_t)}function tt(){return _.join(H(),St)}function Lt(){return _.join(H(),Et)}function mt(){let e=ne(),i={level:"info",logRetentionDays:180};if(!q.existsSync(e))return i;try{let c=q.readFileSync(e,"utf-8").split(`
3
- `),t=i.level,r=i.logRetentionDays;for(let l of c){let o=l.trim();if(!o||o.startsWith("#"))continue;let a=o.match(/^([^:]+):\s*(.+)$/);if(a){let u=a[1].trim(),f=a[2].trim();if(u==="level")["debug","info","warn","error"].includes(f)&&(t=f);else if(u==="log_retention_days"){let d=parseInt(f,10);!isNaN(d)&&d>0&&(r=d)}}}return{level:t,logRetentionDays:r}}catch(n){return console.error("[haimati] \u8BFB\u53D6\u65E5\u5FD7\u914D\u7F6E\u5931\u8D25:",n),i}}function C(e){return q.promises.mkdir(e,{recursive:!0}).then(()=>{})}function y(e){return q.promises.access(e).then(()=>!0).catch(()=>!1)}import Mt from"fs";import ie from"path";import{promisify as Ct}from"util";var kt=Ct(Mt.readFile),re=Ct(Mt.writeFile);function et(e){let i=0,n=0,c=e.length;for(;n<c;)if(e[n]==="\u2502"&&n+3<c&&e.slice(n+1,n+4)===" ")i++,n+=4;else if(e.slice(n,n+4)===" ")i++,n+=4;else{if((e[n]==="\u251C"||e[n]==="\u2514")&&n+3<c&&e.slice(n+1,n+4)==="\u2500\u2500 ")break;break}return i}function nt(e){let n=e.trim().replace(/^[│├└─\s]+/,"").trim();return n==="/"?"/":!n.endsWith("/")||(n=n.slice(0,-1),!n)?null:n}function oe(e){let i=[],n=e.split(`
4
- `),c=[];for(let t of n){if(!t.trim())continue;let r=et(t),l=t.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(l){let o=l[1].trim(),a=String(parseInt(l[2],10)),f=c.slice(0,r).filter(d=>d!=="").join("/");i.push({id:a,category:f,title:o})}else{let o=nt(t);if(o)if(o==="/"){c[r]="";for(let a=r+1;a<c.length;a++)delete c[a]}else{c[r]=o;for(let a=r+1;a<c.length;a++)delete c[a]}}}return i}function Y(e,i){return e.find(n=>n.id===i)||null}function it(e,i,n){return e.find(c=>c.category===i&&c.title===n)||null}function vt(e,i){return e.filter(n=>n.id!==i)}function ht(e){if(e.length===0)return"";let i={name:"/",children:[],entry:null};for(let t of e){let r=t.category.split("/"),l=i;for(let a=0;a<r.length;a++){let u=r[a];if(!u)continue;let f=l.children.find(d=>d.name===u);f||(f={name:u,children:[],entry:null},l.children.push(f)),l=f}let o={name:t.id,children:[],entry:t};l.children.push(o)}function n(t){t.children.sort((r,l)=>r.name.localeCompare(l.name,void 0,{sensitivity:"base"}));for(let r of t.children)n(r)}n(i);function c(t,r,l){let o=[],a=r+(l?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "),u=t.name==="/"?"/":t.name+"/";o.push(`${a}${u}`),r=r+(l?" ":"\u2502 ");let f=t.children.filter(g=>g.entry===null),d=t.children.filter(g=>g.entry!==null),p=[...f,...d];for(let g=0;g<p.length;g++){let m=p[g],w=g===p.length-1;if(m.entry){let h=m.entry.id.padStart(3,"0"),S=r+(w?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ");o.push(`${S}${m.entry.title} - ${h}`)}else o.push(...c(m,r,w))}return o}return c(i,"",!0).join(`
5
- `)}async function M(e){let i=L(e);if(!await y(i))return[];let n=await kt(i,"utf-8");return oe(n)}async function J(e,i){let n=ie.join(e,z);await y(n)||await C(n);let c=ht(i),t=L(e);await re(t,c,"utf-8")}async function Tt(e){let i=L(e);return await y(i)?kt(i,"utf-8"):""}import rt from"fs";import{promisify as ot}from"util";var se=ot(rt.readFile),ae=ot(rt.writeFile),ce=ot(rt.unlink),Rt=ot(rt.mkdir);async function T(e,i){let n=Z(e,i);if(!await y(n))return null;let t=(await se(n,"utf-8")).split(`
6
- `);if(t.length<4)return null;let r="------system------",l=Math.max(0,t.length-5),o=-1;for(let g=t.length-1;g>=l;g--)if(t[g].trim()===r){o=g;break}if(o===-1){if(t.length>=3&&t[2].startsWith("version:")&&/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/.test(t[1])){let h=t[0],S=t[1],x=parseInt(t[2].substring(8).trim(),10)||1,D=t.slice(3).join(`
7
- `);return{title:h,createdAt:S,content:D,version:x}}let m=t[0],w=t.join(`
8
- `);return{title:m,createdAt:"",content:w,version:1}}if(o+3>=t.length)return null;let a=t.slice(0,o).join(`
9
- `),u=t[o+1],f=t[o+2],d=t[o+3],p=parseInt(d.substring(8).trim(),10)||1;return{title:u,createdAt:f,content:a,version:p}}async function U(e,i,n,c,t,r=1){let l=gt(e);await y(l)||await Rt(l,{recursive:!0});let o=B(e,i);await y(o)||await Rt(o,{recursive:!0});let a=Z(e,i),f=`------system------
1
+ import{tool as x}from"@opencode-ai/plugin";import E from"path";import It from"os";import F from"fs";var U=".haimati",ht="\u7D22\u5F15.md";var pt="next-id.txt",wt="info.log";var yt="log.conf";var $t="opencode-haimati.conf",xt="haimati-path";var O="/start-work";var K="/record-memory";function zt(t){let r=E.join(t,$t);if(!F.existsSync(r))return null;try{let a=F.readFileSync(r,"utf-8").split(`
2
+ `);for(let e of a){let i=e.trim();if(!i||i.startsWith("#"))continue;let l=i.match(/^([^:]+):\s*(.+)$/);if(l){let s=l[1].trim(),c=l[2].trim();if(s===xt&&c){let g=c.match(/^\$\{(\w+)\}$/);if(g){let d=process.env[g[1]];return d?E.resolve(t,d):(console.warn(`[haimati] \u73AF\u5883\u53D8\u91CF ${g[1]} \u672A\u5B9A\u4E49\u6216\u503C\u4E3A\u7A7A`),null)}return E.resolve(t,c)}}}}catch(n){console.error("[haimati] \u8BFB\u53D6\u914D\u7F6E\u6587\u4EF6\u5931\u8D25:",n)}return null}function C(t){let r=zt(t);return r||E.join(t,U)}function _(t){return E.join(C(t),ht)}function V(t){return E.join(C(t),pt)}function ct(t){return E.join(C(t),".lock")}function lt(t){return E.join(C(t),"\u4E66\u9875")}function R(t,r){let n=parseInt(r,10),a=Math.floor((n-1)/50)*50+1,e=a+50-1,i=`${String(a).padStart(3,"0")}-${String(e).padStart(3,"0")}`;return E.join(lt(t),i)}function z(t,r){let n=String(parseInt(r,10)).padStart(3,"0");return E.join(R(t,r),`${n}.md`)}function q(){let t=It.homedir();return E.join(t,".opencode-haimati","log")}function Xt(){let t=It.homedir();return E.join(t,".opencode-haimati",yt)}function X(){return E.join(q(),wt)}function dt(){let t=Xt(),r={level:"info",logRetentionDays:180};if(!F.existsSync(t))return r;try{let a=F.readFileSync(t,"utf-8").split(`
3
+ `),e=r.level,i=r.logRetentionDays;for(let l of a){let s=l.trim();if(!s||s.startsWith("#"))continue;let c=s.match(/^([^:]+):\s*(.+)$/);if(c){let g=c[1].trim(),d=c[2].trim();if(g==="level")["debug","info","warn","error"].includes(d)&&(e=d);else if(g==="log_retention_days"){let f=parseInt(d,10);!isNaN(f)&&f>0&&(i=f)}}}return{level:e,logRetentionDays:i}}catch(n){return console.error("[haimati] \u8BFB\u53D6\u65E5\u5FD7\u914D\u7F6E\u5931\u8D25:",n),r}}function L(t){return F.promises.mkdir(t,{recursive:!0}).then(()=>{})}function w(t){return F.promises.access(t).then(()=>!0).catch(()=>!1)}import bt from"fs";import Qt from"path";import{promisify as St}from"util";var Et=St(bt.readFile),Zt=St(bt.writeFile);function Q(t){let r=0,n=0,a=t.length;for(;n<a;)if(t[n]==="\u2502"&&n+3<a&&t.slice(n+1,n+4)===" ")r++,n+=4;else if(t.slice(n,n+4)===" ")r++,n+=4;else{if((t[n]==="\u251C"||t[n]==="\u2514")&&n+3<a&&t.slice(n+1,n+4)==="\u2500\u2500 ")break;break}return r}function Z(t){let n=t.trim().replace(/^[│├└─\s]+/,"").trim();return n==="/"?"/":!n.endsWith("/")||(n=n.slice(0,-1),!n)?null:n}function te(t){let r=[],n=t.split(`
4
+ `),a=[];for(let e of n){if(!e.trim())continue;let i=Q(e),l=e.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(l){let s=l[1].trim(),c=String(parseInt(l[2],10)),d=a.slice(0,i).filter(f=>f!=="").join("/");r.push({id:c,category:d,title:s})}else{let s=Z(e);if(s)if(s==="/"){a[i]="";for(let c=i+1;c<a.length;c++)delete a[c]}else{a[i]=s;for(let c=i+1;c<a.length;c++)delete a[c]}}}return r}function G(t,r){return t.find(n=>n.id===r)||null}function tt(t,r,n){return t.find(a=>a.category===r&&a.title===n)||null}function Pt(t,r){return t.filter(n=>n.id!==r)}function ft(t){if(t.length===0)return"";let r={name:"/",children:[],entry:null};for(let e of t){let i=e.category.split("/"),l=r;for(let c=0;c<i.length;c++){let g=i[c];if(!g)continue;let d=l.children.find(f=>f.name===g);d||(d={name:g,children:[],entry:null},l.children.push(d)),l=d}let s={name:e.id,children:[],entry:e};l.children.push(s)}function n(e){e.children.sort((i,l)=>i.name.localeCompare(l.name,void 0,{sensitivity:"base"}));for(let i of e.children)n(i)}n(r);function a(e,i,l){let s=[],c=i+(l?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "),g=e.name==="/"?"/":e.name+"/";s.push(`${c}${g}`),i=i+(l?" ":"\u2502 ");let d=e.children.filter(u=>u.entry===null),f=e.children.filter(u=>u.entry!==null),p=[...d,...f];for(let u=0;u<p.length;u++){let m=p[u],y=u===p.length-1;if(m.entry){let h=m.entry.id.padStart(3,"0"),b=i+(y?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 ");s.push(`${b}${m.entry.title} - ${h}`)}else s.push(...a(m,i,y))}return s}return a(r,"",!0).join(`
5
+ `)}async function D(t){let r=_(t);if(!await w(r))return[];let n=await Et(r,"utf-8");return te(n)}async function H(t,r){let n=Qt.join(t,U);await w(n)||await L(n);let a=ft(r),e=_(t);await Zt(e,a,"utf-8")}async function _t(t){let r=_(t);return await w(r)?Et(r,"utf-8"):""}import et from"fs";import{promisify as nt}from"util";var ee=nt(et.readFile),ne=nt(et.writeFile),re=nt(et.unlink),Dt=nt(et.mkdir);async function k(t,r){let n=z(t,r);if(!await w(n))return null;let e=(await ee(n,"utf-8")).split(`
6
+ `);if(e.length<4)return null;let i="------system------",l=Math.max(0,e.length-5),s=-1;for(let u=e.length-1;u>=l;u--)if(e[u].trim()===i){s=u;break}if(s===-1){if(e.length>=3&&e[2].startsWith("version:")&&/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/.test(e[1])){let h=e[0],b=e[1],$=parseInt(e[2].substring(8).trim(),10)||1,M=e.slice(3).join(`
7
+ `);return{title:h,createdAt:b,content:M,version:$}}let m=e[0],y=e.join(`
8
+ `);return{title:m,createdAt:"",content:y,version:1}}if(s+3>=e.length)return null;let c=e.slice(0,s).join(`
9
+ `),g=e[s+1],d=e[s+2],f=e[s+3],p=parseInt(f.substring(8).trim(),10)||1;return{title:g,createdAt:d,content:c,version:p}}async function B(t,r,n,a,e,i=1){let l=lt(t);await w(l)||await Dt(l,{recursive:!0});let s=R(t,r);await w(s)||await Dt(s,{recursive:!0});let c=z(t,r),d=`------system------
10
10
  ${n}
11
- ${c}
12
- version:${r}`,d=t?`${t}
13
- ${f}`:f;await ae(a,d,"utf-8")}async function Ot(e,i){let n=Z(e,i);return await y(n)?(await ce(n),!0):!1}async function st(e,i,n,c,t=!1){let r=i.toLowerCase().split(/\s+/).filter(o=>o.length>0);if(r.length===0)return[];let l=[];for(let o of e){let a=o.title.toLowerCase(),u=o.category.toLowerCase(),f=o.id.toLowerCase(),d=0,p=0;for(let m of r)(a.includes(m)||u.includes(m)||f.includes(m))&&d++;if(t&&c){let m=await T(c,o.id);if(m&&m.content){let w=m.content.toLowerCase();for(let h of r)w.includes(h)&&p++}}let g=d+p;n==="and"?g>=r.length&&l.push({entry:o,score:g}):(d>0||t&&p>0)&&l.push({entry:o,score:g})}return l.sort((o,a)=>a.score-o.score),l.map(o=>o.entry)}import Kt from"fs";import{promisify as Vt}from"util";import Nt from"fs";import{promisify as At}from"util";var fe=At(Nt.writeFile),de=At(Nt.unlink);async function Ft(e){let i=v(e);await y(i)||await C(i);let n=ut(e),c=Date.now(),t=50+Math.random()*20;for(;await y(n);){if(Date.now()-c>5e3)return!1;await new Promise(r=>setTimeout(r,t))}return await fe(n,String(process.pid),"utf-8"),!0}async function jt(e){let i=ut(e);await y(i)&&await de(i)}import N from"fs";import O from"path";import{promisify as A}from"util";var qt=A(N.appendFile),ue=A(N.readdir),Bt=A(N.unlink),wt=A(N.stat),ge=A(N.rename),Ht=A(N.readFile),me=A(N.writeFile),Wt={debug:0,info:1,warn:2,error:3},k="",he=".log_state";function Yt(){return O.join(H(),he)}async function yt(){let e=Yt();try{if(await y(e)){let n=(await Ht(e,"utf-8")).match(/lastCheckedDate=(\d{4}-\d{2}-\d{2})/);if(n)return n[1]}}catch(i){console.error("[haimati] \u8BFB\u53D6\u65E5\u5FD7\u72B6\u6001\u6587\u4EF6\u5931\u8D25:",i)}return""}async function K(e){let i=Yt();try{let n=O.dirname(i);await y(n)||await C(n),await me(i,`lastCheckedDate=${e}`,"utf-8")}catch(n){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u72B6\u6001\u6587\u4EF6\u5931\u8D25:",n)}}function $(e,i=5e3){if(e.length<=i)return e;let n=Math.floor((i-20)/2);return e.substring(0,n)+"...(\u7701\u7565"+(e.length-i)+"\u5B57\u7B26)..."+e.substring(e.length-n)}function V(e){let i=e.getFullYear(),n=String(e.getMonth()+1).padStart(2,"0"),c=String(e.getDate()).padStart(2,"0");return`${i}-${n}-${c}`}function pe(){let e=new Date;return e.setDate(e.getDate()-1),V(e)}function we(e){let i=e.getFullYear(),n=String(e.getMonth()+1).padStart(2,"0"),c=String(e.getDate()).padStart(2,"0"),t=String(e.getHours()).padStart(2,"0"),r=String(e.getMinutes()).padStart(2,"0"),l=String(e.getSeconds()).padStart(2,"0");return`${i}-${n}-${c} ${t}:${r}:${l}`}async function ye(e){try{let i=tt();if(!await y(i)||(await wt(i)).size===0)return;let c=O.join(H(),"history");await y(c)||await C(c);let t=O.join(c,`${e}.log`),r=await Ht(i,"utf-8");await qt(t,r,"utf-8"),await ge(i,i+".tmp"),await Bt(i+".tmp")}catch(i){console.error("[haimati] \u8F6E\u8F6C info.log \u5931\u8D25:",i)}}async function $e(){let e=V(new Date);if(await yt()===e){k=e;return}let n=pe();await ye(n),k=e,await K(e)}async function Gt(e,i){try{let n=O.dirname(e);await y(n)||await C(n),await qt(e,i+`
14
- `,"utf-8")}catch(n){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",n)}}async function Jt(){let e=new Date,i=V(e);if(await yt()===i){k=i;return}try{let c=mt(),t=O.join(H(),"history");if(!await y(t)){k=i,await K(i);return}let r=await ue(t),l=e.getTime()-c.logRetentionDays*24*60*60*1e3;for(let o of r){if(!o.match(/^\d{4}-\d{2}-\d{2}\.log$/))continue;let a=O.join(t,o);(await wt(a)).mtime.getTime()<l&&await Bt(a)}k=i,await K(i)}catch(c){console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",c)}}async function s(e,i,n){try{let t=mt().level;if(Wt[e]<Wt[t])return;let l=we(new Date),o=n?`[${n}] `:"",a=`[${l}] [${e.toUpperCase()}] ${o}${i}`,u=a.length>5e3?$(a):a;await $e(),e==="error"?await Gt(Lt(),u):await Gt(tt(),u),Jt().catch(f=>{console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",f)})}catch(c){console.error("[haimati] \u65E5\u5FD7\u8BB0\u5F55\u5931\u8D25:",c)}}async function Ut(){let e=V(new Date),i=tt();if(k=await yt(),k!==e){try{if(await y(i)){let n=await wt(i);if(V(n.mtime)===e){k=e,await K(e);return}}}catch(n){console.error("[haimati] \u68C0\u67E5 info.log \u72B6\u6001\u5931\u8D25:",n)}k=e,await K(e),await Jt()}}var xe=Vt(Kt.readFile),Ie=Vt(Kt.writeFile);async function Se(e){let i=Q(e);if(!await y(i))return 1;let c=(await xe(i,"utf-8")).trim(),t=parseInt(c,10);return!isNaN(t)&&t>0?t:1}async function Ee(e){let i=Q(e);if(await y(i))return;let n=await M(e),c=0;for(let t of n){let r=parseInt(t.id,10);r>c&&(c=r)}await zt(e,c+1)}async function zt(e,i){let n=v(e);await y(n)||await C(n);let c=Q(e);await Ie(c,String(i),"utf-8")}async function Xt(e,i,n,c,t,r=!1){if(/ - \d{3}$/.test(n))throw await s("warn",`[allocateIdWithLock] title \u683C\u5F0F\u4E0D\u5408\u89C4: "${n}", \u629B\u51FA\u9519\u8BEF`),new Error('\u6807\u9898\u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u683C\u5F0F\u7ED3\u5C3E\uFF0C\u5E8F\u53F7\u7531\u7CFB\u7EDF\u81EA\u52A8\u5206\u914D\uFF0C\u8BF7\u4FEE\u6539\u6807\u9898');if(await s("info",`[allocateIdWithLock] \u5F00\u59CB\u5206\u914D\u5E8F\u53F7: category="${i}", title="${n}"`),!await Ft(e))return await s("warn",`[allocateIdWithLock] \u83B7\u53D6\u9501\u5931\u8D25: category="${i}", title="${n}"`),null;await s("debug",`[allocateIdWithLock] \u83B7\u53D6\u9501\u6210\u529F: category="${i}", title="${n}"`);try{await Ee(e);let l=await M(e),o=l.find(d=>d.category===i&&d.title===n);if(o){if(!r)throw new Error(`\u8BB0\u5FC6\u5DF2\u5B58\u5728: ${i}/${n}\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`);let d=await T(e,o.id),p=d?d.createdAt:c,g=d?d.version+1:1;return await U(e,o.id,n,p,t,g),await s("info",`[allocateIdWithLock] \u66F4\u65B0\u5DF2\u6709\u6761\u76EE: #${o.id} ${i}/${n}, \u65B0\u7248\u672C: ${g}`),null}let a=await Se(e),u=String(a).padStart(3,"0");await U(e,u,n,c,t,1);let f={id:u,category:i,title:n};return l.push(f),await J(e,l),await zt(e,a+1),await s("info",`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u6210\u529F: #${u} ${i}/${n}`),u}catch(l){let o=l instanceof Error?l.message:String(l);if(await s("error",`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u5931\u8D25: ${o}`),o.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw l;return null}finally{await jt(e)}}function Qt(){return{haimati_read:I({description:"\u4ECE\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u8BFB\u53D6\u5185\u5BB9\u3002\u901A\u8FC7\u5E8F\u53F7\uFF08\u5982 '086'\uFF09\u6765\u5B9A\u4F4D\u5E76\u8BFB\u53D6\u8BB0\u5FC6\u5185\u5BB9\u3002\u652F\u6301\u5206\u9875\u8BFB\u53D6\uFF08offset/limit\uFF09\uFF0C\u8FD4\u56DE\u5185\u5BB9\u5E26\u884C\u53F7\u548C\u7248\u672C\u53F7\u3002",args:{query:I.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'"),offset:I.schema.number().optional().default(1).describe("\u8D77\u59CB\u884C\u53F7\uFF08\u9ED8\u8BA4 1\uFF09"),limit:I.schema.number().optional().default(2e3).describe("\u6700\u5927\u8BFB\u53D6\u884C\u6570\uFF08\u9ED8\u8BA4 2000\uFF09")},async execute(e,i){let{directory:n}=i,c=L(n);if(await s("info",`[haimati_read] \u5165\u53C2: query="${e.query}", offset=${e.offset||1}, limit=${e.limit||2e3}`),!await y(c)){let t=`\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728\u4E8E ${c}`;return await s("warn",`[haimati_read] \u51FA\u53C2:
15
- ${$(t)}`),t}try{let t=await M(n);await s("debug",`[haimati_read] \u8BFB\u53D6\u7D22\u5F15: \u5171 ${t.length} \u6761\u8BB0\u5F55`);let r=e.query.trim();if(!/^\d+$/.test(r)){let x="\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";return await s("warn",`[haimati_read] \u51FA\u53C2:
16
- ${$(x)}`),x}let l=String(parseInt(r,10)),o=Y(t,l);if(await s("debug",`[haimati_read] \u5E8F\u53F7\u67E5\u8BE2 #${r}: ${o?"\u627E\u5230":"\u672A\u627E\u5230"}`),!o){let x=`\u672A\u627E\u5230\u8BB0\u5FC6: ${e.query}`;return await s("info",`[haimati_read] \u51FA\u53C2:
17
- ${$(x)}`),x}let a=await T(n,o.id);if(!a){let x=`\u672A\u627E\u5230\u4E66\u9875: #${o.id.padStart(3,"0")}`;return await s("error",`[haimati_read] \u51FA\u53C2:
18
- ${$(x)}`),x}let u=B(n,o.id);await s("debug",`[haimati_read] \u8BFB\u53D6\u4E66\u9875: \u4E66\u9875/${u.split(/[\\/]/).pop()}/${o.id}.md, version=${a.version}`);let f=a.content.split(`
19
- `),d=e.offset||1,p=e.limit||2e3,g=f.length,m=Math.max(0,d-1),w=Math.min(g,m+p),h=[];for(let x=m;x<w;x++)h.push(`${x+1}|${f[x]}`);h.push("------system------"),h.push(`\u6807\u9898:${o.title}`),h.push(`\u521B\u5EFA\u65F6\u95F4:${a.createdAt}`),h.push(`version:${a.version}`);let S=h.join(`
20
- `);return await s("info",`[haimati_read] \u51FA\u53C2:
21
- ${$(S)}`),S}catch(t){let r=t instanceof Error?t.message:String(t),l=t instanceof Error?t.stack:"";return await s("error",`[haimati_read] \u51FA\u53C2: \u9519\u8BEF: ${r}
22
- \u5806\u6808: ${l}`),`\u9519\u8BEF: ${r}`}}}),haimati_write:I({description:"\u5C06\u65B0\u4FE1\u606F\u5199\u5165\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u3002\u9700\u8981\u63D0\u4F9B\u5206\u7C7B\u8DEF\u5F84\uFF08\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0'\uFF09\u3001\u6807\u9898\u548C\u5185\u5BB9\u3002\u5982\u679C\u76F8\u540C\u5206\u7C7B\u548C\u6807\u9898\u7684\u8BB0\u5FC6\u5DF2\u5B58\u5728\uFF0C\u5219\u4F1A\u62A5\u9519\u3002",args:{category:I.schema.string().describe("\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0' \u6216 '\u901A\u7528'"),title:I.schema.string().describe("\u8BB0\u5FC6\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'"),content:I.schema.string().describe("\u8981\u5199\u5165\u7684\u8BE6\u7EC6\u5185\u5BB9")},async execute(e,i){let{directory:n}=i;await s("info",`[haimati_write] \u5165\u53C2: category="${e.category}", title="${e.title}", content\u957F\u5EA6=${e.content.length}\u5B57\u7B26, content=
23
- ${$(e.content)}
24
- `);try{let c=new Date().toLocaleString("zh-CN",{hour12:!1}),t=null;for(let a=0;a<3;a++)try{if(t=await Xt(n,e.category,e.title,c,e.content,!1),t)break;await s("warn",`[haimati_write] \u9501\u83B7\u53D6\u5931\u8D25\uFF0C\u91CD\u8BD5\u7B2C ${a+1} \u6B21`)}catch(u){let f=u instanceof Error?u.message:String(u);if(f.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw u;await s("warn",`[haimati_write] \u83B7\u53D6\u9501\u5F02\u5E38: ${f}, \u91CD\u8BD5\u7B2C ${a+1} \u6B21`)}if(t){let a=B(n,t);await s("debug",`[haimati_write] \u5206\u914D\u65B0\u5E8F\u53F7: #${t}`),await s("debug",`[haimati_write] \u4E66\u9875\u548C\u7D22\u5F15\u5DF2\u66F4\u65B0: \u4E66\u9875/${a.split(/[\\/]/).pop()}/${t}.md`);let u=`\u5DF2\u5199\u5165\u6D77\u9A6C\u4F53 #${t}
25
- \u8DEF\u5F84: ${e.category}/${e.title}
26
- \u7248\u672C: 1`;return await s("info",`[haimati_write] \u51FA\u53C2:
27
- ${$(u)}`),u}let r=await M(n),l=it(r,e.category,e.title);if(l){let a=`\u9519\u8BEF\uFF1A\u8BB0\u5FC6\u5DF2\u5B58\u5728 #${l.id} (${e.category}/${e.title})\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`;return await s("error",`[haimati_write] \u51FA\u53C2:
28
- ${$(a)}`),a}let o="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await s("error",`[haimati_write] \u51FA\u53C2:
29
- ${$(o)}`),o}catch(c){let t=c instanceof Error?c.message:String(c),r=c instanceof Error?c.stack:"";return await s("error",`[haimati_write] \u51FA\u53C2: \u9519\u8BEF: ${t}
30
- \u5806\u6808: ${r}`),`\u9519\u8BEF: ${t}`}}}),haimati_search:I({description:"\u641C\u7D22\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09\u3002\u641C\u7D22\u8303\u56F4\u5305\u62EC\uFF1A\u6807\u9898\u3001\u5206\u7C7B\u3001\u5E8F\u53F7\u3001\u4E66\u9875\u5185\u5BB9\u3002\u8F93\u5165\u5173\u952E\u8BCD\uFF0C\u8FD4\u56DE\u5339\u914D\u7684\u6761\u76EE\u5217\u8868\u548C\u5185\u5BB9\u7247\u6BB5\uFF0C\u652F\u6301\u5206\u9875\uFF08limit/offset\uFF09\u3002",args:{keyword:I.schema.string().describe("\u641C\u7D22\u5173\u952E\u8BCD\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09"),match:I.schema.string().describe("\u5339\u914D\u6A21\u5F0F\uFF1Aand=\u6240\u6709\u5173\u952E\u5B57\u90FD\u5339\u914D\uFF0Cor=\u4EFB\u610F\u5173\u952E\u5B57\u5339\u914D"),limit:I.schema.number().default(10).describe("\u8FD4\u56DE\u7ED3\u679C\u6570\u91CF\u9650\u5236"),offset:I.schema.number().default(0).describe("\u5206\u9875\u504F\u79FB\u91CF\uFF0C\u7528\u4E8E\u83B7\u53D6\u540E\u7EED\u9875\u9762")},async execute(e,i){let{directory:n}=i,c=L(n);if(await s("info",`[haimati_search] \u5165\u53C2: keyword="${e.keyword}", match="${e.match}", limit=${e.limit||10}, offset=${e.offset||0}`),!await y(c)){let t="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s("warn",`[haimati_search] \u51FA\u53C2:
31
- ${$(t)}`),t}try{let t=await M(n),r=e.keyword.trim(),l=e.match,o=e.limit||10,a=e.offset||0,u=await st(t,r,l,n,!0),f=u.length,d=u.slice(a,a+o);if(d.length===0){let h=`\u672A\u627E\u5230\u5305\u542B '${r}' \u7684\u8BB0\u5FC6`;return await s("info",`[haimati_search] \u51FA\u53C2:
32
- ${$(h)}`),h}let p=[],g=a+d.length<f,m=g?`${a+1}-${a+d.length}/${f}`:`${a+1}-${a+d.length}/${f}`;p.push(`\u627E\u5230 ${m} \u6761\u5339\u914D\uFF1A
33
- `),g&&p.push(`\uFF08\u5982\u9700\u83B7\u53D6\u66F4\u591A\uFF0C\u8BF7\u4F7F\u7528 offset=${a+o} \u7EE7\u7EED\u7FFB\u9875\uFF09
34
- `);for(let h of d){let S=await T(n,h.id),x=`${h.category}/${h.title}`,D="";S&&(D=S.content.split(`
35
- `).filter(ct=>ct.trim()).slice(0,3).join(" | ").substring(0,150),D.length===150&&(D+="...")),p.push(`## ${x} [${h.id}]`),D&&p.push(`> ${D}`),p.push("")}let w=p.join(`
36
- `);return await s("info",`[haimati_search] \u51FA\u53C2:
37
- ${$(w)}`),w}catch(t){let r=t instanceof Error?t.message:String(t),l=t instanceof Error?t.stack:"";return await s("error",`[haimati_search] \u51FA\u53C2: \u9519\u8BEF: ${r}
38
- \u5806\u6808: ${l}`),`\u9519\u8BEF: ${r}`}}}),haimati_edit:I({description:"\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u90E8\u5206\u5185\u5BB9\u3002\u5C06\u6307\u5B9A\u884C\u53F7\u8303\u56F4 [offsetBegin, offsetEnd] \u7684\u5185\u5BB9\u66FF\u6362\u4E3A\u65B0 content\uFF0CoffsetEnd \u5305\u62EC\u6B64\u884C\u3002\u9700\u8981\u63D0\u4F9B read \u65F6\u8FD4\u56DE\u7684 version \u8FDB\u884C\u5E76\u53D1\u63A7\u5236\u3002",args:{query:I.schema.string().describe("\u5E8F\u53F7\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u66F4\u65B0\u7684\u8BB0\u5FC6"),offsetBegin:I.schema.number().describe("\u8D77\u59CB\u884C\u53F7\uFF08\u5305\u62EC\uFF09"),offsetEnd:I.schema.number().describe("\u7ED3\u675F\u884C\u53F7\uFF08\u5305\u62EC\u6B64\u884C\uFF09"),content:I.schema.string().describe("\u66FF\u6362\u5185\u5BB9"),version:I.schema.number().describe("read \u65F6\u8FD4\u56DE\u7684 version\uFF0C\u7528\u4E8E\u5E76\u53D1\u63A7\u5236")},async execute(e,i){let{directory:n}=i,c=L(n);if(await s("info",`[haimati_edit] \u5165\u53C2: query="${e.query}", offsetBegin=${e.offsetBegin}, offsetEnd=${e.offsetEnd}, content\u957F\u5EA6=${e.content.length}\u5B57\u7B26, version=${e.version}, content=
39
- ${$(e.content)}`),!await y(c)){let t="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s("warn",`[haimati_edit] \u51FA\u53C2:
40
- ${$(t)}`),t}try{let t=await M(n),r=e.query.trim();if(!/^\d+$/.test(r)){let E="\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";return await s("warn",`[haimati_edit] \u51FA\u53C2:
41
- ${$(E)}`),E}let l=String(parseInt(r,10)),o=Y(t,l);if(!o){let E=`\u672A\u627E\u5230\u4E0E '${r}' \u76F8\u5173\u7684\u8BB0\u5FC6`;return await s("info",`[haimati_edit] \u51FA\u53C2:
42
- ${$(E)}`),E}let a=await T(n,o.id);if(!a){let E=`\u672A\u627E\u5230\u4E66\u9875: #${o.id.padStart(3,"0")}`;return await s("error",`[haimati_edit] \u51FA\u53C2:
43
- ${$(E)}`),E}let u=e.offsetBegin,f=e.offsetEnd,d=a.content.split(`
44
- `).length;if(u<1||u>d||u>f||f>d){let E=`\u9519\u8BEF\uFF1Aoffset \u975E\u6CD5\uFF0CoffsetBegin=${u}, offsetEnd=${f}, \u6587\u4EF6\u603B\u884C\u6570=${d}\uFF0C\u6709\u6548\u8303\u56F4 offsetBegin=[1, ${d}], offsetEnd=[offsetBegin, ${d}]`;return await s("warn",`[haimati_edit] \u51FA\u53C2:
45
- ${$(E)}`),E}if(a.version!==e.version){let E=`\u9519\u8BEF\uFF1A\u7248\u672C\u51B2\u7A81\uFF0C\u5F53\u524D version=${a.version}\uFF0C\u4F20\u5165 version=${e.version}\uFF0C\u8BF7\u91CD\u65B0\u8BFB\u53D6\u540E\u518D\u64CD\u4F5C`;return await s("warn",`[haimati_edit] \u51FA\u53C2:
46
- ${$(E)}`),E}let p=(E,lt)=>{if(lt===0)return 0;let ft=1,W=0;for(;W<E.length;){if(E[W]===`
47
- `){if(ft===lt)return W+1;ft++}W++}return W},g=u===1?0:p(a.content,u-1),m=p(a.content,f),w=a.content.substring(0,Math.min(100,a.content.length));await s("debug",`[haimati_edit] content\u957F\u5EA6=${a.content.length}, content\u524D100\u5B57\u7B26: ${JSON.stringify(w)}, offsetBegin=${u}, offsetEnd=${f}, beforeEndIndex=${g}, afterStartIndex=${m}`);let S=(m<a.content.length?a.content.substring(m):"").startsWith(`
48
- `),x=m<a.content.length&&!e.content.endsWith(`
49
- `)&&!S,D=a.content.substring(0,g)+e.content+(x?`
50
- `:"")+a.content.substring(m),j=a.version+1;await U(n,o.id,o.title,a.createdAt,D,j);let ct=`${o.category}/${o.title}`,$t=`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${o.id.padStart(3,"0")}
51
- \u8DEF\u5F84: ${ct}
52
- \u65B0\u7248\u672C: ${j}`;return await s("info",`[haimati_edit] \u51FA\u53C2:
53
- ${$($t)}`),$t}catch(t){let r=t instanceof Error?t.message:String(t),l=t instanceof Error?t.stack:"";return await s("error",`[haimati_edit] \u51FA\u53C2: \u9519\u8BEF: ${r}
54
- \u5806\u6808: ${l}`),`\u9519\u8BEF: ${r}`}}}),haimati_delete:I({description:"\u5220\u9664\u6D77\u9A6C\u4F53\u4E2D\u7684\u8BB0\u5FC6\u3002\u901A\u8FC7\u5E8F\u53F7\uFF08\u5982 '086'\uFF09\u6216\u5B8C\u6574\u8DEF\u5F84\uFF08\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0/\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'\uFF09\u6765\u5B9A\u4F4D\u8981\u5220\u9664\u7684\u8BB0\u5FC6\u3002",args:{query:I.schema.string().describe("\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u5220\u9664\u7684\u8BB0\u5FC6")},async execute(e,i){let{directory:n}=i,c=L(n);if(await s("info",`[haimati_delete] \u5165\u53C2: query="${e.query}"`),!await y(c)){let t="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s("warn",`[haimati_delete] \u51FA\u53C2:
55
- ${$(t)}`),t}try{let t=await M(n),r=e.query.trim(),l=null;if(/^\d+$/.test(r))l=Y(t,String(parseInt(r,10)));else{let f=r.split("/").filter(Boolean);if(f.length>=2){let d=f.pop(),p=f.join("/");l=it(t,p,d)}else{let d=await st(t,r,"or",n);if(d.length===1)l=d[0];else if(d.length>1)return`\u627E\u5230\u591A\u6761\u5339\u914D\uFF0C\u8BF7\u4F7F\u7528\u5E8F\u53F7\u7CBE\u786E\u6307\u5B9A\uFF1A
56
- ${d.slice(0,10).map(g=>` - ${g.category}/${g.title} [${g.id.padStart(3,"0")}]`).join(`
57
- `)}`}}if(!l){let f=`\u672A\u627E\u5230\u4E0E '${r}' \u76F8\u5173\u7684\u8BB0\u5FC6`;return await s("info",`[haimati_delete] \u51FA\u53C2:
58
- ${$(f)}`),f}await Ot(n,l.id);let o=vt(t,l.id);await J(n,o);let a=`${l.category}/${l.title}`,u=`\u5DF2\u5220\u9664\u6D77\u9A6C\u4F53 #${l.id.padStart(3,"0")}
59
- \u8DEF\u5F84: ${a}`;return await s("info",`[haimati_delete] \u51FA\u53C2:
60
- ${$(u)}`),u}catch(t){let r=t instanceof Error?t.message:String(t),l=t instanceof Error?t.stack:"";return await s("error",`[haimati_delete] \u51FA\u53C2: \u9519\u8BEF: ${r}
61
- \u5806\u6808: ${l}`),`\u9519\u8BEF: ${r}`}}}),haimati_move:I({description:"\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u5206\u7C7B\u8DEF\u5F84\u3002\u901A\u8FC7\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\u5B9A\u4F4D\u8BB0\u5FC6\uFF0C\u7136\u540E\u5C06\u5176\u79FB\u52A8\u5230\u65B0\u7684\u5206\u7C7B\u3002",args:{query:I.schema.string().describe("\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u79FB\u52A8\u7684\u8BB0\u5FC6"),newCategory:I.schema.string().describe("\u65B0\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u5BA2\u6237\u7AEF' \u6216 '\u901A\u7528'")},async execute(e,i){let{directory:n}=i,c=L(n);if(await s("info",`[haimati_move] \u5165\u53C2: query="${e.query}", newCategory="${e.newCategory}"`),!await y(c)){let t="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s("warn",`[haimati_move] \u51FA\u53C2:
62
- ${$(t)}`),t}try{let t=await M(n),r=e.query.trim(),l=null;if(/^\d+$/.test(r))l=Y(t,String(parseInt(r,10)));else{let g=r.split("/").filter(Boolean);if(g.length>=2){let m=g.pop(),w=g.join("/");l=it(t,w,m)}else{let m=await st(t,r,"or",n);if(m.length===1)l=m[0];else if(m.length>1)return`\u627E\u5230\u591A\u6761\u5339\u914D\uFF0C\u8BF7\u4F7F\u7528\u5E8F\u53F7\u7CBE\u786E\u6307\u5B9A\uFF1A
11
+ ${a}
12
+ version:${i}`,f=e?`${e}
13
+ ${d}`:d;await ne(c,f,"utf-8")}async function Mt(t,r){let n=z(t,r);return await w(n)?(await re(n),!0):!1}function Lt(t,r){if(r===0)return 0;let n=1,a=0;for(;a<t.length;){if(t[a]===`
14
+ `){if(n===r)return a+1;n++}a++}return a}function vt(t,r,n,a){let e=r===1?0:Lt(t,r-1),i=Lt(t,n),s=(i<t.length?t.substring(i):"").startsWith(`
15
+ `),c=i<t.length&&!a.endsWith(`
16
+ `)&&!s;return t.substring(0,e)+a+(c?`
17
+ `:"")+t.substring(i)}async function rt(t,r,n,a,e=!1){let i=r.toLowerCase().split(/\s+/).filter(s=>s.length>0);if(i.length===0)return[];let l=[];for(let s of t){let c=s.title.toLowerCase(),g=s.category.toLowerCase(),d=s.id.toLowerCase(),f=0,p=0;for(let m of i)(c.includes(m)||g.includes(m)||d.includes(m))&&f++;if(e&&a){let m=await k(a,s.id);if(m&&m.content){let y=m.content.toLowerCase();for(let h of i)y.includes(h)&&p++}}let u=f+p;n==="and"?u>=i.length&&l.push({entry:s,score:u}):(f>0||e&&p>0)&&l.push({entry:s,score:u})}return l.sort((s,c)=>c.score-s.score),l.map(s=>s.entry)}import Gt from"fs";import{promisify as Ht}from"util";import Ct from"fs";import{promisify as kt}from"util";var se=kt(Ct.writeFile),oe=kt(Ct.unlink);async function Tt(t){let r=C(t);await w(r)||await L(r);let n=ct(t),a=Date.now(),e=50+Math.random()*20;for(;await w(n);){if(Date.now()-a>5e3)return!1;await new Promise(i=>setTimeout(i,e))}return await se(n,String(process.pid),"utf-8"),!0}async function Nt(t){let r=ct(t);await w(r)&&await oe(r)}import j from"fs";import N from"path";import{promisify as W}from"util";var Ot=W(j.appendFile),ae=W(j.readdir),ce=W(j.unlink),ut=W(j.stat),Ft=W(j.readFile),Rt=W(j.writeFile),At={debug:0,info:1,warn:2,error:3},v="",le=".log_state";function jt(){return N.join(q(),le)}async function mt(){let t=jt();try{if(await w(t)){let n=(await Ft(t,"utf-8")).match(/lastCheckedDate=(\d{4}-\d{2}-\d{2})/);if(n)return n[1]}}catch(r){console.error("[haimati] \u8BFB\u53D6\u65E5\u5FD7\u72B6\u6001\u6587\u4EF6\u5931\u8D25:",r)}return""}async function Y(t){let r=jt();try{let n=N.dirname(r);await w(n)||await L(n),await Rt(r,`lastCheckedDate=${t}`,"utf-8")}catch(n){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u72B6\u6001\u6587\u4EF6\u5931\u8D25:",n)}}function I(t,r=5e3){if(t.length<=r)return t;let n=Math.floor((r-20)/2);return t.substring(0,n)+"...(\u7701\u7565"+(t.length-r)+"\u5B57\u7B26)..."+t.substring(t.length-n)}function J(t){let r=t.getFullYear(),n=String(t.getMonth()+1).padStart(2,"0"),a=String(t.getDate()).padStart(2,"0");return`${r}-${n}-${a}`}function de(){let t=new Date;return t.setDate(t.getDate()-1),J(t)}function fe(t){let r=t.getFullYear(),n=String(t.getMonth()+1).padStart(2,"0"),a=String(t.getDate()).padStart(2,"0"),e=String(t.getHours()).padStart(2,"0"),i=String(t.getMinutes()).padStart(2,"0"),l=String(t.getSeconds()).padStart(2,"0");return`${r}-${n}-${a} ${e}:${i}:${l}`}async function ge(t){try{let r=X();if(!await w(r)||(await ut(r)).size===0)return;let a=N.join(q(),"history");await w(a)||await L(a);let e=N.join(a,`${t}.log`),i=await Ft(r,"utf-8");await Ot(e,i,"utf-8"),await Rt(r,"","utf-8")}catch(r){console.error("[haimati] \u8F6E\u8F6C info.log \u5931\u8D25:",r)}}async function ue(){let t=J(new Date);if(await mt()===t){v=t;return}let n=de();await ge(n),v=t,await Y(t)}async function me(t,r){try{let n=N.dirname(t);await w(n)||await L(n),await Ot(t,r+`
18
+ `,"utf-8")}catch(n){console.error("[haimati] \u5199\u5165\u65E5\u5FD7\u6587\u4EF6\u5931\u8D25:",n)}}async function Wt(){let t=new Date,r=J(t);if(await mt()===r){v=r;return}try{let a=dt(),e=N.join(q(),"history");if(!await w(e)){v=r,await Y(r);return}let i=await ae(e),l=t.getTime()-a.logRetentionDays*24*60*60*1e3;for(let s of i){if(!s.match(/^\d{4}-\d{2}-\d{2}\.log$/))continue;let c=N.join(e,s);(await ut(c)).mtime.getTime()<l&&await ce(c)}v=r,await Y(r)}catch(a){console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",a)}}async function it(t,r,n){try{let e=dt().level;if(At[t]<At[e])return;let l=fe(new Date),s=n?`[${n}] `:"",c=`[${l}] [${t.toUpperCase()}] ${s}${r}`,g=c.length>5e3?I(c):c;await ue(),await me(X(),g),Wt().catch(d=>{console.error("[haimati] \u6E05\u7406\u5386\u53F2\u65E5\u5FD7\u5931\u8D25:",d)})}catch(a){console.error("[haimati] \u65E5\u5FD7\u8BB0\u5F55\u5931\u8D25:",a)}}var o={debug(t,r){return it("debug",t,r)},info(t,r){return it("info",t,r)},warn(t,r){return it("warn",t,r)},error(t,r){return it("error",t,r)}};async function qt(){let t=J(new Date),r=X();if(v=await mt(),v!==t){try{if(await w(r)){let n=await ut(r);if(J(n.mtime)===t){v=t,await Y(t);return}}}catch(n){console.error("[haimati] \u68C0\u67E5 info.log \u72B6\u6001\u5931\u8D25:",n)}v=t,await Y(t),await Wt()}}var he=Ht(Gt.readFile),pe=Ht(Gt.writeFile);async function we(t){let r=V(t);if(!await w(r))return 1;let a=(await he(r,"utf-8")).trim(),e=parseInt(a,10);return!isNaN(e)&&e>0?e:1}async function ye(t){let r=V(t);if(await w(r))return;let n=await D(t),a=0;for(let e of n){let i=parseInt(e.id,10);i>a&&(a=i)}await Bt(t,a+1)}async function Bt(t,r){let n=C(t);await w(n)||await L(n);let a=V(t);await pe(a,String(r),"utf-8")}async function Yt(t,r,n,a,e,i=!1){if(/ - \d{3}$/.test(n))throw await o.warn(`[allocateIdWithLock] title \u683C\u5F0F\u4E0D\u5408\u89C4: "${n}", \u629B\u51FA\u9519\u8BEF`),new Error('\u6807\u9898\u4E0D\u80FD\u4EE5 " - \u5E8F\u53F7" \u683C\u5F0F\u7ED3\u5C3E\uFF0C\u5E8F\u53F7\u7531\u7CFB\u7EDF\u81EA\u52A8\u5206\u914D\uFF0C\u8BF7\u4FEE\u6539\u6807\u9898');if(await o.info(`[allocateIdWithLock] \u5F00\u59CB\u5206\u914D\u5E8F\u53F7: category="${r}", title="${n}"`),!await Tt(t))return await o.warn(`[allocateIdWithLock] \u83B7\u53D6\u9501\u5931\u8D25: category="${r}", title="${n}"`),null;await o.debug(`[allocateIdWithLock] \u83B7\u53D6\u9501\u6210\u529F: category="${r}", title="${n}"`);try{await ye(t);let l=await D(t),s=l.find(f=>f.category===r&&f.title===n);if(s){if(!i)throw new Error(`\u8BB0\u5FC6\u5DF2\u5B58\u5728: ${r}/${n}\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`);let f=await k(t,s.id),p=f?f.createdAt:a,u=f?f.version+1:1;return await B(t,s.id,n,p,e,u),await o.info(`[allocateIdWithLock] \u66F4\u65B0\u5DF2\u6709\u6761\u76EE: #${s.id} ${r}/${n}, \u65B0\u7248\u672C: ${u}`),null}let c=await we(t),g=String(c).padStart(3,"0");await B(t,g,n,a,e,1);let d={id:g,category:r,title:n};return l.push(d),await H(t,l),await Bt(t,c+1),await o.info(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u6210\u529F: #${g} ${r}/${n}`),g}catch(l){let s=l instanceof Error?l.message:String(l);if(await o.error(`[allocateIdWithLock] \u5206\u914D\u5E8F\u53F7\u5931\u8D25: ${s}`),s.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw l;return null}finally{await Nt(t)}}function Jt(){return{haimati_read:x({description:"\u4ECE\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u8BFB\u53D6\u5185\u5BB9\u3002\u901A\u8FC7\u5E8F\u53F7\uFF08\u5982 '086'\uFF09\u6765\u5B9A\u4F4D\u5E76\u8BFB\u53D6\u8BB0\u5FC6\u5185\u5BB9\u3002\u652F\u6301\u5206\u9875\u8BFB\u53D6\uFF08offset/limit\uFF09\uFF0C\u8FD4\u56DE\u5185\u5BB9\u5E26\u884C\u53F7\u548C\u7248\u672C\u53F7\u3002",args:{query:x.schema.string().describe("\u5E8F\u53F7\u3002\u4F8B\u5982\uFF1A'086'"),offset:x.schema.number().optional().default(1).describe("\u8D77\u59CB\u884C\u53F7\uFF08\u9ED8\u8BA4 1\uFF09"),limit:x.schema.number().optional().default(2e3).describe("\u6700\u5927\u8BFB\u53D6\u884C\u6570\uFF08\u9ED8\u8BA4 2000\uFF09")},async execute(t,r){let{directory:n}=r,a=_(n);if(await o.debug(`[haimati_read] \u5165\u53C2: query="${t.query}", offset=${t.offset||1}, limit=${t.limit||2e3}`),!await w(a)){let e=`\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728\u4E8E ${a}`;return await o.warn(`[haimati_read] \u51FA\u53C2:
19
+ ${I(e)}`),e}try{let e=await D(n);await o.debug(`[haimati_read] \u8BFB\u53D6\u7D22\u5F15: \u5171 ${e.length} \u6761\u8BB0\u5F55`);let i=t.query.trim();if(!/^\d+$/.test(i)){let $="\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";return await o.warn(`[haimati_read] \u51FA\u53C2:
20
+ ${I($)}`),$}let l=String(parseInt(i,10)),s=G(e,l);if(await o.debug(`[haimati_read] \u5E8F\u53F7\u67E5\u8BE2 #${i}: ${s?"\u627E\u5230":"\u672A\u627E\u5230"}`),!s){let $=`\u672A\u627E\u5230\u8BB0\u5FC6: ${t.query}`;return await o.debug(`[haimati_read] \u51FA\u53C2:
21
+ ${I($)}`),$}let c=await k(n,s.id);if(!c){let $=`\u672A\u627E\u5230\u4E66\u9875: #${s.id.padStart(3,"0")}`;return await o.error(`[haimati_read] \u51FA\u53C2:
22
+ ${I($)}`),$}let g=R(n,s.id);await o.debug(`[haimati_read] \u8BFB\u53D6\u4E66\u9875: \u4E66\u9875/${g.split(/[\\/]/).pop()}/${s.id}.md, version=${c.version}`);let d=c.content.split(`
23
+ `),f=t.offset||1,p=t.limit||2e3,u=d.length,m=Math.max(0,f-1),y=Math.min(u,m+p),h=[];for(let $=m;$<y;$++)h.push(`${$+1}|${d[$]}`);h.push("------system------"),h.push(`\u6807\u9898:${s.title}`),h.push(`\u521B\u5EFA\u65F6\u95F4:${c.createdAt}`),h.push(`version:${c.version}`);let b=h.join(`
24
+ `);return await o.debug(`[haimati_read] \u51FA\u53C2:
25
+ ${I(b)}`),b}catch(e){let i=e instanceof Error?e.message:String(e),l=e instanceof Error?e.stack:"";return await o.error(`[haimati_read] \u51FA\u53C2: \u9519\u8BEF: ${i}
26
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${i}`}}}),haimati_write:x({description:"\u5C06\u65B0\u4FE1\u606F\u5199\u5165\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u3002\u9700\u8981\u63D0\u4F9B\u5206\u7C7B\u8DEF\u5F84\uFF08\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0'\uFF09\u3001\u6807\u9898\u548C\u5185\u5BB9\u3002\u5982\u679C\u76F8\u540C\u5206\u7C7B\u548C\u6807\u9898\u7684\u8BB0\u5FC6\u5DF2\u5B58\u5728\uFF0C\u5219\u4F1A\u62A5\u9519\u3002",args:{category:x.schema.string().describe("\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0' \u6216 '\u901A\u7528'"),title:x.schema.string().describe("\u8BB0\u5FC6\u6807\u9898\uFF0C\u5982 '\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'"),content:x.schema.string().describe("\u8981\u5199\u5165\u7684\u8BE6\u7EC6\u5185\u5BB9")},async execute(t,r){let{directory:n}=r;await o.debug(`[haimati_write] \u5165\u53C2: category="${t.category}", title="${t.title}", content\u957F\u5EA6=${t.content.length}\u5B57\u7B26, content=
27
+ ${I(t.content)}
28
+ `);try{let a=new Date().toLocaleString("zh-CN",{hour12:!1}),e=null;for(let c=0;c<3;c++)try{if(e=await Yt(n,t.category,t.title,a,t.content,!1),e)break;await o.warn(`[haimati_write] \u9501\u83B7\u53D6\u5931\u8D25\uFF0C\u91CD\u8BD5\u7B2C ${c+1} \u6B21`)}catch(g){let d=g instanceof Error?g.message:String(g);if(d.includes("\u8BB0\u5FC6\u5DF2\u5B58\u5728"))throw g;await o.warn(`[haimati_write] \u83B7\u53D6\u9501\u5F02\u5E38: ${d}, \u91CD\u8BD5\u7B2C ${c+1} \u6B21`)}if(e){let c=R(n,e);await o.debug(`[haimati_write] \u5206\u914D\u65B0\u5E8F\u53F7: #${e}`),await o.debug(`[haimati_write] \u4E66\u9875\u548C\u7D22\u5F15\u5DF2\u66F4\u65B0: \u4E66\u9875/${c.split(/[\\/]/).pop()}/${e}.md`);let g=`\u5DF2\u5199\u5165\u6D77\u9A6C\u4F53 #${e}
29
+ \u8DEF\u5F84: ${t.category}/${t.title}
30
+ \u7248\u672C: 1`;return await o.debug(`[haimati_write] \u51FA\u53C2:
31
+ ${I(g)}`),g}let i=await D(n),l=tt(i,t.category,t.title);if(l){let c=`\u9519\u8BEF\uFF1A\u8BB0\u5FC6\u5DF2\u5B58\u5728 #${l.id} (${t.category}/${t.title})\uFF0C\u5982\u9700\u66F4\u65B0\u8BF7\u4F7F\u7528 haimati_edit \u5DE5\u5177`;return await o.error(`[haimati_write] \u51FA\u53C2:
32
+ ${I(c)}`),c}let s="\u9519\u8BEF\uFF1A\u65E0\u6CD5\u5206\u914D\u5E8F\u53F7\uFF08\u9501\u7B49\u5F85\u8D85\u65F6\uFF09";return await o.error(`[haimati_write] \u51FA\u53C2:
33
+ ${I(s)}`),s}catch(a){let e=a instanceof Error?a.message:String(a),i=a instanceof Error?a.stack:"";return await o.error(`[haimati_write] \u51FA\u53C2: \u9519\u8BEF: ${e}
34
+ \u5806\u6808: ${i}`),`\u9519\u8BEF: ${e}`}}}),haimati_search:x({description:"\u641C\u7D22\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09\u3002\u641C\u7D22\u8303\u56F4\u5305\u62EC\uFF1A\u6807\u9898\u3001\u5206\u7C7B\u3001\u5E8F\u53F7\u3001\u4E66\u9875\u5185\u5BB9\u3002\u8F93\u5165\u5173\u952E\u8BCD\uFF0C\u8FD4\u56DE\u5339\u914D\u7684\u6761\u76EE\u5217\u8868\u548C\u5185\u5BB9\u7247\u6BB5\uFF0C\u652F\u6301\u5206\u9875\uFF08limit/offset\uFF09\u3002",args:{keyword:x.schema.string().describe("\u641C\u7D22\u5173\u952E\u8BCD\uFF08\u652F\u6301\u591A\u5173\u952E\u5B57\uFF0C\u7528\u7A7A\u683C\u5206\u9694\uFF09"),match:x.schema.string().describe("\u5339\u914D\u6A21\u5F0F\uFF1Aand=\u6240\u6709\u5173\u952E\u5B57\u90FD\u5339\u914D\uFF0Cor=\u4EFB\u610F\u5173\u952E\u5B57\u5339\u914D"),limit:x.schema.number().default(10).describe("\u8FD4\u56DE\u7ED3\u679C\u6570\u91CF\u9650\u5236"),offset:x.schema.number().default(0).describe("\u5206\u9875\u504F\u79FB\u91CF\uFF0C\u7528\u4E8E\u83B7\u53D6\u540E\u7EED\u9875\u9762")},async execute(t,r){let{directory:n}=r,a=_(n);if(await o.debug(`[haimati_search] \u5165\u53C2: keyword="${t.keyword}", match="${t.match}", limit=${t.limit||10}, offset=${t.offset||0}`),!await w(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await o.warn(`[haimati_search] \u51FA\u53C2:
35
+ ${I(e)}`),e}try{let e=await D(n),i=t.keyword.trim(),l=t.match,s=t.limit||10,c=t.offset||0,g=await rt(e,i,l,n,!0),d=g.length,f=g.slice(c,c+s);if(f.length===0){let h=`\u672A\u627E\u5230\u5305\u542B '${i}' \u7684\u8BB0\u5FC6`;return await o.debug(`[haimati_search] \u51FA\u53C2:
36
+ ${I(h)}`),h}let p=[],u=c+f.length<d,m=u?`${c+1}-${c+f.length}/${d}`:`${c+1}-${c+f.length}/${d}`;p.push(`\u627E\u5230 ${m} \u6761\u5339\u914D\uFF1A
37
+ `),u&&p.push(`\uFF08\u5982\u9700\u83B7\u53D6\u66F4\u591A\uFF0C\u8BF7\u4F7F\u7528 offset=${c+s} \u7EE7\u7EED\u7FFB\u9875\uFF09
38
+ `);for(let h of f){let b=await k(n,h.id),$=`${h.category}/${h.title}`,M="";b&&(M=b.content.split(`
39
+ `).filter(Kt=>Kt.trim()).slice(0,3).join(" | ").substring(0,150),M.length===150&&(M+="...")),p.push(`## ${$} [${h.id}]`),M&&p.push(`> ${M}`),p.push("")}let y=p.join(`
40
+ `);return await o.debug(`[haimati_search] \u51FA\u53C2:
41
+ ${I(y)}`),y}catch(e){let i=e instanceof Error?e.message:String(e),l=e instanceof Error?e.stack:"";return await o.error(`[haimati_search] \u51FA\u53C2: \u9519\u8BEF: ${i}
42
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${i}`}}}),haimati_edit:x({description:"\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u90E8\u5206\u5185\u5BB9\u3002\u5C06\u6307\u5B9A\u884C\u53F7\u8303\u56F4 [offsetBegin, offsetEnd] \u7684\u5185\u5BB9\u66FF\u6362\u4E3A\u65B0 content\uFF0CoffsetEnd \u5305\u62EC\u6B64\u884C\u3002\u9700\u8981\u63D0\u4F9B read \u65F6\u8FD4\u56DE\u7684 version \u8FDB\u884C\u5E76\u53D1\u63A7\u5236\u3002",args:{query:x.schema.string().describe("\u5E8F\u53F7\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u66F4\u65B0\u7684\u8BB0\u5FC6"),offsetBegin:x.schema.number().describe("\u8D77\u59CB\u884C\u53F7\uFF08\u5305\u62EC\uFF09"),offsetEnd:x.schema.number().describe("\u7ED3\u675F\u884C\u53F7\uFF08\u5305\u62EC\u6B64\u884C\uFF09"),content:x.schema.string().describe("\u66FF\u6362\u5185\u5BB9"),version:x.schema.number().describe("read \u65F6\u8FD4\u56DE\u7684 version\uFF0C\u7528\u4E8E\u5E76\u53D1\u63A7\u5236")},async execute(t,r){let{directory:n}=r,a=_(n);if(await o.debug(`[haimati_edit] \u5165\u53C2: query="${t.query}", offsetBegin=${t.offsetBegin}, offsetEnd=${t.offsetEnd}, content\u957F\u5EA6=${t.content.length}\u5B57\u7B26, version=${t.version}`),!await w(a))return await o.warn(`[haimati_edit] \u51FA\u53C2:
43
+ \u7D22\u5F15\u6587\u4EF6\u4E0D\u5B58\u5728`),"\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";try{let e=await D(n),i=t.query.trim();if(!/^\d+$/.test(i))return await o.warn(`[haimati_edit] \u51FA\u53C2:
44
+ query\u65E0\u6548`),"\u9519\u8BEF\uFF1Aquery \u5FC5\u987B\u662F\u5E8F\u53F7\uFF0C\u53EA\u652F\u6301\u5E8F\u53F7\u67E5\u8BE2";let l=String(parseInt(i,10)),s=G(e,l);if(!s)return await o.debug(`[haimati_edit] \u51FA\u53C2:
45
+ \u672A\u627E\u5230`),`\u672A\u627E\u5230\u4E0E '${i}' \u76F8\u5173\u7684\u8BB0\u5FC6`;let c=await k(n,s.id);if(!c)return await o.error(`[haimati_edit] \u51FA\u53C2:
46
+ \u4E66\u9875\u4E0D\u5B58\u5728`),`\u672A\u627E\u5230\u4E66\u9875: #${s.id.padStart(3,"0")}`;if(c.version!==t.version)return await o.warn(`[haimati_edit] \u51FA\u53C2:
47
+ \u7248\u672C\u51B2\u7A81`),`\u9519\u8BEF\uFF1A\u7248\u672C\u51B2\u7A81\uFF0C\u5F53\u524D version=${c.version}\uFF0C\u4F20\u5165 version=${t.version}\uFF0C\u8BF7\u91CD\u65B0\u8BFB\u53D6\u540E\u518D\u64CD\u4F5C`;let g=c.content.split(`
48
+ `).length,{offsetBegin:d,offsetEnd:f}=t;if(d<1||d>g||d>f||f>g)return await o.warn(`[haimati_edit] \u51FA\u53C2:
49
+ offset\u975E\u6CD5`),`\u9519\u8BEF\uFF1Aoffset \u975E\u6CD5\uFF0CoffsetBegin=${d}, offsetEnd=${f}, \u6587\u4EF6\u603B\u884C\u6570=${g}\uFF0C\u6709\u6548\u8303\u56F4 offsetBegin=[1, ${g}], offsetEnd=[offsetBegin, ${g}]`;let p=vt(c.content,d,f,t.content);await B(n,s.id,s.title,c.createdAt,p,c.version+1);let u=`${s.category}/${s.title}`,m=`\u5DF2\u66F4\u65B0\u6D77\u9A6C\u4F53 #${s.id.padStart(3,"0")}
50
+ \u8DEF\u5F84: ${u}
51
+ \u65B0\u7248\u672C: ${c.version+1}`;return await o.debug(`[haimati_edit] \u51FA\u53C2:
52
+ ${I(m)}`),m}catch(e){let i=e instanceof Error?e.message:String(e),l=e instanceof Error?e.stack:"";return await o.error(`[haimati_edit] \u51FA\u53C2:
53
+ ${i}
54
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${i}`}}}),haimati_delete:x({description:"\u5220\u9664\u6D77\u9A6C\u4F53\u4E2D\u7684\u8BB0\u5FC6\u3002\u901A\u8FC7\u5E8F\u53F7\uFF08\u5982 '086'\uFF09\u6216\u5B8C\u6574\u8DEF\u5F84\uFF08\u5982 'xxx\u9879\u76EE/\u7B7E\u7AE0/\u7B7E\u7AE0\u670D\u52A1WS\u901A\u4FE1\u673A\u5236'\uFF09\u6765\u5B9A\u4F4D\u8981\u5220\u9664\u7684\u8BB0\u5FC6\u3002",args:{query:x.schema.string().describe("\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u5220\u9664\u7684\u8BB0\u5FC6")},async execute(t,r){let{directory:n}=r,a=_(n);if(await o.debug(`[haimati_delete] \u5165\u53C2: query="${t.query}"`),!await w(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await o.warn(`[haimati_delete] \u51FA\u53C2:
55
+ ${I(e)}`),e}try{let e=await D(n),i=t.query.trim(),l=null;if(/^\d+$/.test(i))l=G(e,String(parseInt(i,10)));else{let d=i.split("/").filter(Boolean);if(d.length>=2){let f=d.pop(),p=d.join("/");l=tt(e,p,f)}else{let f=await rt(e,i,"or",n);if(f.length===1)l=f[0];else if(f.length>1)return`\u627E\u5230\u591A\u6761\u5339\u914D\uFF0C\u8BF7\u4F7F\u7528\u5E8F\u53F7\u7CBE\u786E\u6307\u5B9A\uFF1A
56
+ ${f.slice(0,10).map(u=>` - ${u.category}/${u.title} [${u.id.padStart(3,"0")}]`).join(`
57
+ `)}`}}if(!l){let d=`\u672A\u627E\u5230\u4E0E '${i}' \u76F8\u5173\u7684\u8BB0\u5FC6`;return await o.debug(`[haimati_delete] \u51FA\u53C2:
58
+ ${I(d)}`),d}await Mt(n,l.id);let s=Pt(e,l.id);await H(n,s);let c=`${l.category}/${l.title}`,g=`\u5DF2\u5220\u9664\u6D77\u9A6C\u4F53 #${l.id.padStart(3,"0")}
59
+ \u8DEF\u5F84: ${c}`;return await o.debug(`[haimati_delete] \u51FA\u53C2:
60
+ ${I(g)}`),g}catch(e){let i=e instanceof Error?e.message:String(e),l=e instanceof Error?e.stack:"";return await o.error(`[haimati_delete] \u51FA\u53C2: \u9519\u8BEF: ${i}
61
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${i}`}}}),haimati_move:x({description:"\u4FEE\u6539\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7684\u5206\u7C7B\u8DEF\u5F84\u3002\u901A\u8FC7\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\u5B9A\u4F4D\u8BB0\u5FC6\uFF0C\u7136\u540E\u5C06\u5176\u79FB\u52A8\u5230\u65B0\u7684\u5206\u7C7B\u3002",args:{query:x.schema.string().describe("\u5E8F\u53F7\u6216\u5B8C\u6574\u8DEF\u5F84\uFF0C\u7528\u4E8E\u5B9A\u4F4D\u8981\u79FB\u52A8\u7684\u8BB0\u5FC6"),newCategory:x.schema.string().describe("\u65B0\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5982 'xxx\u9879\u76EE/\u5BA2\u6237\u7AEF' \u6216 '\u901A\u7528'")},async execute(t,r){let{directory:n}=r,a=_(n);if(await o.debug(`[haimati_move] \u5165\u53C2: query="${t.query}", newCategory="${t.newCategory}"`),!await w(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await o.warn(`[haimati_move] \u51FA\u53C2:
62
+ ${I(e)}`),e}try{let e=await D(n),i=t.query.trim(),l=null;if(/^\d+$/.test(i))l=G(e,String(parseInt(i,10)));else{let u=i.split("/").filter(Boolean);if(u.length>=2){let m=u.pop(),y=u.join("/");l=tt(e,y,m)}else{let m=await rt(e,i,"or",n);if(m.length===1)l=m[0];else if(m.length>1)return`\u627E\u5230\u591A\u6761\u5339\u914D\uFF0C\u8BF7\u4F7F\u7528\u5E8F\u53F7\u7CBE\u786E\u6307\u5B9A\uFF1A
63
63
  ${m.slice(0,10).map(h=>` - ${h.category}/${h.title} [${h.id.padStart(3,"0")}]`).join(`
64
- `)}`}}if(!l){let g=`\u672A\u627E\u5230\u4E0E '${r}' \u76F8\u5173\u7684\u8BB0\u5FC6`;return await s("info",`[haimati_move] \u51FA\u53C2:
65
- ${$(g)}`),g}let a=`${l.category}/${l.title}`,u=e.newCategory,f=`${u}/${l.title}`,d=t.map(g=>g.id===l.id?{...g,category:u}:g);await J(n,d);let p=`\u5DF2\u79FB\u52A8\u6D77\u9A6C\u4F53 #${l.id}
66
- \u65E7\u8DEF\u5F84: ${a}
67
- \u65B0\u8DEF\u5F84: ${f}`;return await s("info",`[haimati_move] \u51FA\u53C2:
68
- ${$(p)}`),p}catch(t){let r=t instanceof Error?t.message:String(t),l=t instanceof Error?t.stack:"";return await s("error",`[haimati_move] \u51FA\u53C2: \u9519\u8BEF: ${r}
69
- \u5806\u6808: ${l}`),`\u9519\u8BEF: ${r}`}}}),haimati_list:I({description:"\u5217\u51FA\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u7684\u5B8C\u6574\u7D22\u5F15\u7ED3\u6784\u3002",args:{category:I.schema.string().optional().describe("\u53EF\u9009\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5217\u51FA\u8BE5\u5206\u7C7B\u4E0B\u7684\u6761\u76EE"),recursive:I.schema.boolean().optional().default(!1).describe("\u662F\u5426\u9012\u5F52\u904D\u5386\u5B50\u5206\u7C7B\uFF0C\u9ED8\u8BA4false")},async execute(e,i){let{directory:n}=i,c=L(n);if(await s("info",`[haimati_list] \u5165\u53C2: category="${e.category||"(\u65E0)"}, recursive=${e.recursive}"`),!await y(c)){let t="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await s("warn",`[haimati_list] \u51FA\u53C2:
70
- ${$(t)}`),t}try{let t=await M(n);if(e.category){let a=(await Tt(n)).split(`
71
- `),u=0,f=[];for(let m of a){if(!m.trim())continue;let w=et(m);if(m.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/))continue;let S=nt(m);if(S&&(S==="/"?f[w]="":f[w]=S,f=f.slice(0,w+1),f.filter(Boolean).join("/")===e.category)){u=w;break}}let d=[],p=[];f=[];for(let m of a){if(!m.trim())continue;let w=et(m),h=m.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(h){let x=h[1].trim(),D=h[2];if(w===u+1){let j=f.slice(1,w).filter(Boolean).join("/");j===e.category&&p.push({category:j,title:x,id:D})}continue}let S=nt(m);S&&(S==="/"?f[w]="":f[w]=S,f=f.slice(0,w+1),w===u+1&&f.filter(Boolean).join("/")===e.category&&d.push(S))}let g=`## ${e.category}
64
+ `)}`}}if(!l){let u=`\u672A\u627E\u5230\u4E0E '${i}' \u76F8\u5173\u7684\u8BB0\u5FC6`;return await o.debug(`[haimati_move] \u51FA\u53C2:
65
+ ${I(u)}`),u}let c=`${l.category}/${l.title}`,g=t.newCategory,d=`${g}/${l.title}`,f=e.map(u=>u.id===l.id?{...u,category:g}:u);await H(n,f);let p=`\u5DF2\u79FB\u52A8\u6D77\u9A6C\u4F53 #${l.id}
66
+ \u65E7\u8DEF\u5F84: ${c}
67
+ \u65B0\u8DEF\u5F84: ${d}`;return await o.debug(`[haimati_move] \u51FA\u53C2:
68
+ ${I(p)}`),p}catch(e){let i=e instanceof Error?e.message:String(e),l=e instanceof Error?e.stack:"";return await o.error(`[haimati_move] \u51FA\u53C2: \u9519\u8BEF: ${i}
69
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${i}`}}}),haimati_list:x({description:"\u5217\u51FA\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u7684\u5B8C\u6574\u7D22\u5F15\u7ED3\u6784\u3002",args:{category:x.schema.string().optional().describe("\u53EF\u9009\u7684\u5206\u7C7B\u8DEF\u5F84\uFF0C\u5217\u51FA\u8BE5\u5206\u7C7B\u4E0B\u7684\u6761\u76EE"),recursive:x.schema.boolean().optional().default(!1).describe("\u662F\u5426\u9012\u5F52\u904D\u5386\u5B50\u5206\u7C7B\uFF0C\u9ED8\u8BA4false")},async execute(t,r){let{directory:n}=r,a=_(n);if(await o.debug(`[haimati_list] \u5165\u53C2: category="${t.category||"(\u65E0)"}, recursive=${t.recursive}"`),!await w(a)){let e="\u9519\u8BEF\uFF1A\u6D77\u9A6C\u4F53\u7D22\u5F15\u4E0D\u5B58\u5728";return await o.warn(`[haimati_list] \u51FA\u53C2:
70
+ ${I(e)}`),e}try{let e=await D(n);if(t.category){let c=(await _t(n)).split(`
71
+ `),g=0,d=[];for(let m of c){if(!m.trim())continue;let y=Q(m);if(m.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/))continue;let b=Z(m);if(b&&(b==="/"?d[y]="":d[y]=b,d=d.slice(0,y+1),d.filter(Boolean).join("/")===t.category)){g=y;break}}let f=[],p=[];d=[];for(let m of c){if(!m.trim())continue;let y=Q(m),h=m.match(/^\s*[│├└─\s]*(.+?)\s*-\s*(\d+)\s*$/);if(h){let $=h[1].trim(),M=h[2];if(y===g+1){let ot=d.slice(1,y).filter(Boolean).join("/");ot===t.category&&p.push({category:ot,title:$,id:M})}continue}let b=Z(m);b&&(b==="/"?d[y]="":d[y]=b,d=d.slice(0,y+1),y===g+1&&d.filter(Boolean).join("/")===t.category&&f.push(b))}let u=`## ${t.category}
72
72
 
73
- `;if(e.recursive){let m=t.filter(h=>h.category===e.category||h.category.startsWith(e.category+"/")),w=new Map;for(let h of m){let x=h.category.slice(e.category.length+1).split("/")[0]||"(\u76F4\u63A5)";w.has(x)||w.set(x,[]),w.get(x).push(h)}for(let[h,S]of w)g+=`### ${h}/
74
- `,g+=S.map(x=>`- ${x.title} - ${x.id.padStart(3,"0")}`).join(`
73
+ `;if(t.recursive){let m=e.filter(h=>h.category===t.category||h.category.startsWith(t.category+"/")),y=new Map;for(let h of m){let $=h.category.slice(t.category.length+1).split("/")[0]||"(\u76F4\u63A5)";y.has($)||y.set($,[]),y.get($).push(h)}for(let[h,b]of y)u+=`### ${h}/
74
+ `,u+=b.map($=>`- ${$.title} - ${$.id.padStart(3,"0")}`).join(`
75
75
  `)+`
76
76
 
77
- `}else d.length>0&&(g+=`**\u5B50\u5206\u7C7B\uFF1A**
78
- `+d.map(m=>`- ${m}/`).join(`
77
+ `}else f.length>0&&(u+=`**\u5B50\u5206\u7C7B\uFF1A**
78
+ `+f.map(m=>`- ${m}/`).join(`
79
79
  `)+`
80
80
 
81
- `),p.length>0&&(g+=`**\u76F4\u63A5\u6761\u76EE\uFF1A**
81
+ `),p.length>0&&(u+=`**\u76F4\u63A5\u6761\u76EE\uFF1A**
82
82
  `+p.map(m=>`- ${m.title} - ${m.id.padStart(3,"0")}`).join(`
83
- `));return await s("info",`[haimati_list] \u51FA\u53C2:
84
- ${$(g)}`),g}let l=`## \u6D77\u9A6C\u4F53\u7D22\u5F15
83
+ `));return await o.debug(`[haimati_list] \u51FA\u53C2:
84
+ ${I(u)}`),u}let l=`## \u6D77\u9A6C\u4F53\u7D22\u5F15
85
85
 
86
- ${ht(t)||"(\u7A7A)"}`;return await s("info",`[haimati_list] \u51FA\u53C2:
87
- ${$(l)}`),l}catch(t){let r=t instanceof Error?t.message:String(t),l=t instanceof Error?t.stack:"";return await s("error",`[haimati_list] \u51FA\u53C2: \u9519\u8BEF: ${r}
88
- \u5806\u6808: ${l}`),`\u9519\u8BEF: ${r}`}}})}}var R=new Map,at=new Map,F=new Set,P=new Set,b=new Set,Zt=new Map,bn=async e=>{await Ut(),await s("info","\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u63D2\u4EF6(\u6587\u4EF6\u7248)debug\u7248\u672C04091402\u5DF2\u52A0\u8F7D");let{client:i}=e;return{tool:Qt(),"chat.message":async(c,t)=>{let{message:r,parts:l}=t,o=r.sessionID,a=r.id;if(await s("debug","[chat.message] ====== \u5F00\u59CB\u5904\u7406 ======"),await s("debug",`[chat.message] sessionId=${o}, messageId=${a}`),await s("debug",`[chat.message] enhancedSessions: ${JSON.stringify([...R.entries()])}`),R.get(o)===a){await s("debug",`[chat.message] \u4F1A\u8BDD ${o} \u7684\u6D88\u606F ${a} \u5DF2\u589E\u5F3A\u8FC7\uFF0C\u8DF3\u8FC7`);return}let u=l.some(d=>d.type==="text"&&d.text);if(await s("debug",`[chat.message] hasUserContent=${u}`),!u){await s("debug",`[chat.message] \u6D88\u606F ${a} \u4E0D\u5305\u542B\u7528\u6237\u5185\u5BB9\uFF0C\u8DF3\u8FC7`);return}if(R.has(o)){await s("debug",`[chat.message] \u4F1A\u8BDD ${o} \u5DF2\u589E\u5F3A\u8FC7\uFF0C\u4E0D\u662F\u9996\u6761\u7528\u6237\u6D88\u606F\uFF0C\u8DF3\u8FC7 | enhancedSessions.get=${R.get(o)}`);return}let f=null;try{let d=await i.command.list({});if(d.data){let g=d.data.find(m=>m.name===G.replace(/^\//,""));g&&g.template?(f=g.template,await s("info",`[chat.message] \u627E\u5230 ${G} \u547D\u4EE4\u7684 template`)):await s("warn",`[chat.message] \u672A\u627E\u5230 ${G} \u547D\u4EE4\u7684 template`)}}catch(d){let p=d instanceof Error?d.message:String(d);await s("error",`[chat.message] \u67E5\u8BE2 ${G} \u547D\u4EE4 template \u5931\u8D25: ${p}`)}if(f===null){await s("info",`[chat.message] \u4F1A\u8BDD ${o} \u672A\u627E\u5230 ${G} \u547D\u4EE4\u7684 template\uFF0C\u6807\u8BB0\u5E76\u8DF3\u8FC7`),R.set(o,a),await s("debug",`[chat.message] \u6807\u8BB0\u540E enhancedSessions: ${JSON.stringify([...R.entries()])}`);return}await s("info",`[chat.message] \u589E\u5F3A\u4F1A\u8BDD ${o} \u7684\u9996\u6761\u7528\u6237\u6D88\u606F ${a}`);for(let d of l)d.type==="text"&&(d.text=f+`
86
+ ${ft(e)||"(\u7A7A)"}`;return await o.debug(`[haimati_list] \u51FA\u53C2:
87
+ ${I(l)}`),l}catch(e){let i=e instanceof Error?e.message:String(e),l=e instanceof Error?e.stack:"";return await o.error(`[haimati_list] \u51FA\u53C2: \u9519\u8BEF: ${i}
88
+ \u5806\u6808: ${l}`),`\u9519\u8BEF: ${i}`}}})}}var T=new Map,st=new Map,A=new Set,S=new Set,P=new Set,Ut=new Map,In=async t=>{await qt(),await o.debug("\u6D77\u9A6C\u4F53\u8BB0\u5FC6\u7CFB\u7EDF\u63D2\u4EF6(\u6587\u4EF6\u7248)debug\u7248\u672C04091402\u5DF2\u52A0\u8F7D");let{client:r}=t;return{tool:Jt(),"chat.message":async(a,e)=>{let{message:i,parts:l}=e,s=i.sessionID,c=i.id;if(await o.debug("[chat.message] ====== \u5F00\u59CB\u5904\u7406 ======"),await o.debug(`[chat.message] sessionId=${s}, messageId=${c}`),await o.debug(`[chat.message] enhancedSessions: ${JSON.stringify([...T.entries()])}`),T.get(s)===c){await o.debug(`[chat.message] \u4F1A\u8BDD ${s} \u7684\u6D88\u606F ${c} \u5DF2\u589E\u5F3A\u8FC7\uFF0C\u8DF3\u8FC7`);return}let g=l.some(f=>f.type==="text"&&f.text);if(await o.debug(`[chat.message] hasUserContent=${g}`),!g){await o.debug(`[chat.message] \u6D88\u606F ${c} \u4E0D\u5305\u542B\u7528\u6237\u5185\u5BB9\uFF0C\u8DF3\u8FC7`);return}if(T.has(s)){await o.debug(`[chat.message] \u4F1A\u8BDD ${s} \u5DF2\u589E\u5F3A\u8FC7\uFF0C\u4E0D\u662F\u9996\u6761\u7528\u6237\u6D88\u606F\uFF0C\u8DF3\u8FC7 | enhancedSessions.get=${T.get(s)}`);return}let d=null;try{let f=await r.command.list({});if(f.data){let u=f.data.find(m=>m.name===O.replace(/^\//,""));u&&u.template?(d=u.template,await o.debug(`[chat.message] \u627E\u5230 ${O} \u547D\u4EE4\u7684 template`)):await o.warn(`[chat.message] \u672A\u627E\u5230 ${O} \u547D\u4EE4\u7684 template`)}}catch(f){let p=f instanceof Error?f.message:String(f);await o.error(`[chat.message] \u67E5\u8BE2 ${O} \u547D\u4EE4 template \u5931\u8D25: ${p}`)}if(d===null){await o.debug(`[chat.message] \u4F1A\u8BDD ${s} \u672A\u627E\u5230 ${O} \u547D\u4EE4\u7684 template\uFF0C\u6807\u8BB0\u5E76\u8DF3\u8FC7`),T.set(s,c),await o.debug(`[chat.message] \u6807\u8BB0\u540E enhancedSessions: ${JSON.stringify([...T.entries()])}`);return}await o.debug(`[chat.message] \u589E\u5F3A\u4F1A\u8BDD ${s} \u7684\u9996\u6761\u7528\u6237\u6D88\u606F ${c}`);for(let f of l)f.type==="text"&&(f.text=d+`
89
89
 
90
- `+d.text,await s("debug",`[chat.message] \u5DF2\u589E\u5F3A part ${d.id}\uFF0Ctemplate \u957F\u5EA6=${f.length}`));R.set(o,a),await s("info",`[chat.message] \u5B8C\u6210\u9996\u6761\u6D88\u606F\u589E\u5F3A (sessionID: ${o}, messageID: ${a})`),await s("debug",`[chat.message] \u6807\u8BB0\u540E enhancedSessions: ${JSON.stringify([...R.entries()])}`),await s("debug","[chat.message] ====== \u5904\u7406\u5B8C\u6210 ======")},event:async({event:c})=>{try{if(c.type==="session.created"){await s("debug",`[session.created] \u4E8B\u4EF6\u5C5E\u6027: ${JSON.stringify(c.properties)}`);let t=c.properties?.info?.id,r=c.properties?.info?.directory;if(await s("debug",`[session.created] \u5C1D\u8BD5\u4FDD\u5B58\u4F1A\u8BDD\u76EE\u5F55: (evt.properties as any).sessionID=${c.properties?.sessionID}, info.id=${t}, directory=${r}`),await s("debug",`[session.created] sessionDirectories.size=${at.size}, \u73B0\u6709key: ${Array.from(at.keys()).join(",")}`),r&&(at.set(t,r),await s("debug",`[session.created] \u4FDD\u5B58\u4F1A\u8BDD\u76EE\u5F55\u5B8C\u6210: sessionID=${t}, directory=${r}`)),!t){await s("warn","[session.created] \u65E0\u6CD5\u83B7\u53D6 sessionID\uFF0C\u8DF3\u8FC7");return}return}if(c.type==="session.error"){let t=c.properties?.sessionID,r=c.properties?.error;await s("debug",`[session.error] \u4E8B\u4EF6\u5C5E\u6027: ${JSON.stringify(c.properties)}, sessionID=${t}, error=${JSON.stringify(r)}`),r&&r.name==="MessageAbortedError"&&t&&(b.add(t),await s("info",`[session.error] \u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\u4F1A\u8BDD ${t}`));return}if(c.type==="session.idle"){let t=c.properties?.sessionID,r=(Zt.get(t)||0)+1;if(Zt.set(t,r),r===1&&await s("info",`[session.idle] \u7B2C1\u6B21\u89E6\u53D1 | \u72B6\u6001: userStopped=${b.has(t)}, injected=${F.has(t)}, injecting=${P.has(t)}`),r>1&&(P.has(t)||F.has(t))){await s("debug",`[session.idle] \u7B2C${r}\u6B21\u89E6\u53D1\u91CD\u590D\uFF0C\u8DF3\u8FC7 | sessionId=${t}`);return}if(!t){await s("warn","[session.idle] \u65E0\u6CD5\u83B7\u53D6 sessionID\uFF0C\u8DF3\u8FC7");return}if(r===1&&await s("debug",`[session.idle] \u8BE6\u7EC6\u72B6\u6001: userStoppedSessions=${JSON.stringify([...b])}, injectedSessions=${JSON.stringify([...F])}, injectingSessions=${JSON.stringify([...P])}`),F.has(t)){await s("debug",`[session.idle] \u4F1A\u8BDD ${t} \u5DF2\u6CE8\u5165\u8FC7\u63D0\u793A\u8BCD\uFF0C\u8DF3\u8FC7`);return}if(P.has(t)){if(await s("debug",`[session.idle] \u4F1A\u8BDD ${t} \u6B63\u5728\u6CE8\u5165\u4E2D\uFF0C\u7B49\u5F85...`),await new Promise(o=>setTimeout(o,1e3)),b.has(t)){await s("info",`[session.idle] \u7B49\u5F85\u540E\u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F | sessionId=${t}`),b.delete(t),P.delete(t);return}if(F.has(t)){await s("debug",`[session.idle] \u7B49\u5F85\u540E\u786E\u8BA4\u5DF2\u6CE8\u5165\uFF0C\u8DF3\u8FC7 | sessionId=${t}`);return}if(!b.has(t)){await s("debug",`[session.idle] \u7B49\u5F85\u540E\u672A\u68C0\u6D4B\u5230\u7528\u6237\u505C\u6B62\uFF0C\u7531\u9996\u6B21\u89E6\u53D1\u5904\u7406 | sessionId=${t}`),P.delete(t);return}await s("warn",`[session.idle] \u4F1A\u8BDD ${t} \u7B49\u5F85\u540E\u4ECD\u672A\u6CE8\u5165\u4F46\u4ECD\u5728\u6CE8\u5165\u4E2D\uFF0C\u8DF3\u8FC7`);return}if(P.add(t),await s("debug",`[session.idle] \u4F1A\u8BDD ${t} \u5F00\u59CB\u6CE8\u5165\uFF0C\u6807\u8BB0\u4E3A\u6B63\u5728\u6CE8\u5165`),await new Promise(o=>setTimeout(o,500)),await s("debug",`[session.idle] \u7B49\u5F85500ms\u540E\u68C0\u67E5: userStopped=${b.has(t)}, sessionId=${t}`),b.has(t)){await s("info",`[session.idle] \u7B49\u5F85\u540E\u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F | sessionId=${t}`),b.delete(t),P.delete(t);return}let l=null;try{let o=await i.command.list({});if(o.data){let u=o.data.find(f=>f.name===X.replace(/^\//,""));u&&u.template?(l=u.template,await s("info",`[session.idle] \u627E\u5230 ${X} \u547D\u4EE4\u7684 template`)):await s("warn",`[session.idle] \u672A\u627E\u5230 ${X} \u547D\u4EE4\u7684 template`)}}catch(o){let a=o instanceof Error?o.message:String(o);await s("error",`[session.idle] \u67E5\u8BE2\u547D\u4EE4 template \u5931\u8D25: ${a}`)}if(l===null){await s("info",`[session.idle] \u4F1A\u8BDD ${t} \u672A\u627E\u5230 /record-memory \u547D\u4EE4\u7684 template\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F`),P.delete(t);return}if(b.has(t)){await s("info",`[session.idle] \u6CE8\u5165\u524D\u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F | sessionId=${t}`),b.delete(t),P.delete(t);return}await s("info",`[session.idle] \u5F00\u59CB\u6CE8\u5165\u63D0\u793A\u8BCD | sessionId=${t}, promptText=${l.substring(0,50)}...`);try{await i.session.prompt({path:{id:t},body:{parts:[{type:"text",text:l}],noReply:!1}}),await s("info",`[session.idle] \u2705 \u6210\u529F\u6CE8\u5165\u63D0\u793A\u8BCD\u5230\u4F1A\u8BDD ${t}`),F.add(t),P.delete(t),await s("debug",`[session.idle] \u6CE8\u5165\u5B8C\u6210\uFF0C\u6E05\u7406\u72B6\u6001: injectedSessions=${JSON.stringify([...F])}, injectingSessions=${JSON.stringify([...P])}, userStoppedSessions=${JSON.stringify([...b])}`),at.delete(t)}catch(o){let a=o instanceof Error?o.message:String(o);await s("error",`[session.idle] \u274C \u6CE8\u5165\u63D0\u793A\u8BCD\u5931\u8D25: ${a}`),P.delete(t),await s("debug",`[session.idle] \u6CE8\u5165\u5931\u8D25\uFF0C\u6E05\u7406\u72B6\u6001: injectingSessions=${JSON.stringify([...P])}, userStoppedSessions=${JSON.stringify([...b])}`)}return}}catch(t){let r=t instanceof Error?t.message:String(t);await s("error",`[event] \u5904\u7406\u4E8B\u4EF6 ${c.type} \u5931\u8D25: ${r}`)}}}};export{bn as HaimatiPlugin};
90
+ `+f.text,await o.debug(`[chat.message] \u5DF2\u589E\u5F3A part ${f.id}\uFF0Ctemplate \u957F\u5EA6=${d.length}`));T.set(s,c),await o.debug(`[chat.message] \u5B8C\u6210\u9996\u6761\u6D88\u606F\u589E\u5F3A (sessionID: ${s}, messageID: ${c})`),await o.debug(`[chat.message] \u6807\u8BB0\u540E enhancedSessions: ${JSON.stringify([...T.entries()])}`),await o.debug("[chat.message] ====== \u5904\u7406\u5B8C\u6210 ======")},event:async({event:a})=>{try{if(a.type==="session.created"){await o.debug(`[session.created] \u4E8B\u4EF6\u5C5E\u6027: ${JSON.stringify(a.properties)}`);let e=a.properties?.info?.id,i=a.properties?.info?.directory;if(await o.debug(`[session.created] \u5C1D\u8BD5\u4FDD\u5B58\u4F1A\u8BDD\u76EE\u5F55: (evt.properties as any).sessionID=${a.properties?.sessionID}, info.id=${e}, directory=${i}`),await o.debug(`[session.created] sessionDirectories.size=${st.size}, \u73B0\u6709key: ${Array.from(st.keys()).join(",")}`),i&&(st.set(e,i),await o.debug(`[session.created] \u4FDD\u5B58\u4F1A\u8BDD\u76EE\u5F55\u5B8C\u6210: sessionID=${e}, directory=${i}`)),!e){await o.warn("[session.created] \u65E0\u6CD5\u83B7\u53D6 sessionID\uFF0C\u8DF3\u8FC7");return}return}if(a.type==="session.error"){let e=a.properties?.sessionID,i=a.properties?.error;await o.debug(`[session.error] \u4E8B\u4EF6\u5C5E\u6027: ${JSON.stringify(a.properties)}, sessionID=${e}, error=${JSON.stringify(i)}`),i&&i.name==="MessageAbortedError"&&e&&(P.add(e),await o.debug(`[session.error] \u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\u4F1A\u8BDD ${e}`));return}if(a.type==="session.idle"){let e=a.properties?.sessionID,i=(Ut.get(e)||0)+1;if(Ut.set(e,i),i===1&&await o.debug(`[session.idle] \u7B2C1\u6B21\u89E6\u53D1 | \u72B6\u6001: userStopped=${P.has(e)}, injected=${A.has(e)}, injecting=${S.has(e)}`),i>1&&(S.has(e)||A.has(e))){await o.debug(`[session.idle] \u7B2C${i}\u6B21\u89E6\u53D1\u91CD\u590D\uFF0C\u8DF3\u8FC7 | sessionId=${e}`);return}if(!e){await o.warn("[session.idle] \u65E0\u6CD5\u83B7\u53D6 sessionID\uFF0C\u8DF3\u8FC7");return}if(i===1&&await o.debug(`[session.idle] \u8BE6\u7EC6\u72B6\u6001: userStoppedSessions=${JSON.stringify([...P])}, injectedSessions=${JSON.stringify([...A])}, injectingSessions=${JSON.stringify([...S])}`),A.has(e)){await o.debug(`[session.idle] \u4F1A\u8BDD ${e} \u5DF2\u6CE8\u5165\u8FC7\u63D0\u793A\u8BCD\uFF0C\u8DF3\u8FC7`);return}if(S.has(e)){if(await o.debug(`[session.idle] \u4F1A\u8BDD ${e} \u6B63\u5728\u6CE8\u5165\u4E2D\uFF0C\u7B49\u5F85...`),await new Promise(s=>setTimeout(s,1e3)),P.has(e)){await o.debug(`[session.idle] \u7B49\u5F85\u540E\u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F | sessionId=${e}`),P.delete(e),S.delete(e);return}if(A.has(e)){await o.debug(`[session.idle] \u7B49\u5F85\u540E\u786E\u8BA4\u5DF2\u6CE8\u5165\uFF0C\u8DF3\u8FC7 | sessionId=${e}`);return}if(!P.has(e)){await o.debug(`[session.idle] \u7B49\u5F85\u540E\u672A\u68C0\u6D4B\u5230\u7528\u6237\u505C\u6B62\uFF0C\u7531\u9996\u6B21\u89E6\u53D1\u5904\u7406 | sessionId=${e}`),S.delete(e);return}await o.warn(`[session.idle] \u4F1A\u8BDD ${e} \u7B49\u5F85\u540E\u4ECD\u672A\u6CE8\u5165\u4F46\u4ECD\u5728\u6CE8\u5165\u4E2D\uFF0C\u8DF3\u8FC7`);return}if(S.add(e),await o.debug(`[session.idle] \u4F1A\u8BDD ${e} \u5F00\u59CB\u6CE8\u5165\uFF0C\u6807\u8BB0\u4E3A\u6B63\u5728\u6CE8\u5165`),await new Promise(s=>setTimeout(s,500)),await o.debug(`[session.idle] \u7B49\u5F85500ms\u540E\u68C0\u67E5: userStopped=${P.has(e)}, sessionId=${e}`),P.has(e)){await o.debug(`[session.idle] \u7B49\u5F85\u540E\u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F | sessionId=${e}`),P.delete(e),S.delete(e);return}let l=null;try{let s=await r.command.list({});if(s.data){let g=s.data.find(d=>d.name===K.replace(/^\//,""));g&&g.template?(l=g.template,await o.debug(`[session.idle] \u627E\u5230 ${K} \u547D\u4EE4\u7684 template`)):await o.warn(`[session.idle] \u672A\u627E\u5230 ${K} \u547D\u4EE4\u7684 template`)}}catch(s){let c=s instanceof Error?s.message:String(s);await o.error(`[session.idle] \u67E5\u8BE2\u547D\u4EE4 template \u5931\u8D25: ${c}`)}if(l===null){await o.debug(`[session.idle] \u4F1A\u8BDD ${e} \u672A\u627E\u5230 /record-memory \u547D\u4EE4\u7684 template\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F`),S.delete(e);return}if(P.has(e)){await o.debug(`[session.idle] \u6CE8\u5165\u524D\u68C0\u6D4B\u5230\u7528\u6237\u4E3B\u52A8\u505C\u6B62\uFF0C\u6E05\u7406\u5E76\u7ED3\u675F | sessionId=${e}`),P.delete(e),S.delete(e);return}await o.debug(`[session.idle] \u5F00\u59CB\u6CE8\u5165\u63D0\u793A\u8BCD | sessionId=${e}, promptText=${l.substring(0,50)}...`);try{await r.session.prompt({path:{id:e},body:{parts:[{type:"text",text:l}],noReply:!1}}),await o.debug(`[session.idle] \u2705 \u6210\u529F\u6CE8\u5165\u63D0\u793A\u8BCD\u5230\u4F1A\u8BDD ${e}`),A.add(e),S.delete(e),await o.debug(`[session.idle] \u6CE8\u5165\u5B8C\u6210\uFF0C\u6E05\u7406\u72B6\u6001: injectedSessions=${JSON.stringify([...A])}, injectingSessions=${JSON.stringify([...S])}, userStoppedSessions=${JSON.stringify([...P])}`),st.delete(e)}catch(s){let c=s instanceof Error?s.message:String(s);await o.error(`[session.idle] \u274C \u6CE8\u5165\u63D0\u793A\u8BCD\u5931\u8D25: ${c}`),S.delete(e),await o.debug(`[session.idle] \u6CE8\u5165\u5931\u8D25\uFF0C\u6E05\u7406\u72B6\u6001: injectingSessions=${JSON.stringify([...S])}, userStoppedSessions=${JSON.stringify([...P])}`)}return}}catch(e){let i=e instanceof Error?e.message:String(e);await o.error(`[event] \u5904\u7406\u4E8B\u4EF6 ${a.type} \u5931\u8D25: ${i}`)}}}};export{In as HaimatiPlugin};
package/dist/package.json CHANGED
@@ -1,27 +1,27 @@
1
- {
2
- "name": "opencode-haimati",
3
- "version": "1.1.5",
4
- "description": "OpenCode plugin for a file-based memory system inspired by the hippocampus, providing long-term memory storage and retrieval across sessions.",
5
- "main": "./dist/index.js",
6
- "type": "module",
7
- "license": "MIT",
8
- "files": [
9
- "dist"
10
- ],
11
- "scripts": {
12
- "build": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify && cp package.json dist/",
13
- "build:uncompressed": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin && cp package.json dist/",
14
- "typecheck": "tsc --noEmit",
15
- "prepublishOnly": "npm run build",
16
- "test": "npx tsx test/index.ts"
17
- },
18
- "peerDependencies": {
19
- "@opencode-ai/plugin": ">=0.15.0",
20
- "typescript": ">=5.0.0"
21
- },
22
- "devDependencies": {
23
- "@opencode-ai/plugin": "^0.15.0",
24
- "@types/bun": "^1.3.1",
25
- "typescript": "^5.9.3"
26
- }
27
- }
1
+ {
2
+ "name": "opencode-haimati",
3
+ "version": "1.2.0",
4
+ "description": "OpenCode plugin for a file-based memory system inspired by the hippocampus, providing long-term memory storage and retrieval across sessions.",
5
+ "main": "./dist/index.js",
6
+ "type": "module",
7
+ "license": "MIT",
8
+ "files": [
9
+ "dist"
10
+ ],
11
+ "scripts": {
12
+ "build": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify && cp package.json dist/",
13
+ "build:uncompressed": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin && cp package.json dist/",
14
+ "typecheck": "tsc --noEmit",
15
+ "prepublishOnly": "npm run build",
16
+ "test": "npx tsx test/index.ts"
17
+ },
18
+ "peerDependencies": {
19
+ "@opencode-ai/plugin": ">=0.15.0",
20
+ "typescript": ">=5.0.0"
21
+ },
22
+ "devDependencies": {
23
+ "@opencode-ai/plugin": "^0.15.0",
24
+ "@types/bun": "^1.3.1",
25
+ "typescript": "^5.9.3"
26
+ }
27
+ }
package/package.json CHANGED
@@ -1,27 +1,27 @@
1
- {
2
- "name": "opencode-haimati",
3
- "version": "1.1.5",
4
- "description": "OpenCode plugin for a file-based memory system inspired by the hippocampus, providing long-term memory storage and retrieval across sessions.",
5
- "main": "./dist/index.js",
6
- "type": "module",
7
- "license": "MIT",
8
- "files": [
9
- "dist"
10
- ],
11
- "scripts": {
12
- "build": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify && cp package.json dist/",
13
- "build:uncompressed": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin && cp package.json dist/",
14
- "typecheck": "tsc --noEmit",
15
- "prepublishOnly": "npm run build",
16
- "test": "npx tsx test/index.ts"
17
- },
18
- "peerDependencies": {
19
- "@opencode-ai/plugin": ">=0.15.0",
20
- "typescript": ">=5.0.0"
21
- },
22
- "devDependencies": {
23
- "@opencode-ai/plugin": "^0.15.0",
24
- "@types/bun": "^1.3.1",
25
- "typescript": "^5.9.3"
26
- }
27
- }
1
+ {
2
+ "name": "opencode-haimati",
3
+ "version": "1.2.0",
4
+ "description": "OpenCode plugin for a file-based memory system inspired by the hippocampus, providing long-term memory storage and retrieval across sessions.",
5
+ "main": "./dist/index.js",
6
+ "type": "module",
7
+ "license": "MIT",
8
+ "files": [
9
+ "dist"
10
+ ],
11
+ "scripts": {
12
+ "build": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin --minify && cp package.json dist/",
13
+ "build:uncompressed": "rm -rf dist && npx esbuild src/index.ts --bundle --platform=node --outdir=dist --format=esm --external:@opencode-ai/plugin && cp package.json dist/",
14
+ "typecheck": "tsc --noEmit",
15
+ "prepublishOnly": "npm run build",
16
+ "test": "npx tsx test/index.ts"
17
+ },
18
+ "peerDependencies": {
19
+ "@opencode-ai/plugin": ">=0.15.0",
20
+ "typescript": ">=5.0.0"
21
+ },
22
+ "devDependencies": {
23
+ "@opencode-ai/plugin": "^0.15.0",
24
+ "@types/bun": "^1.3.1",
25
+ "typescript": "^5.9.3"
26
+ }
27
+ }