feique 1.1.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.
Files changed (227) hide show
  1. package/LICENSE +21 -0
  2. package/README.en.md +220 -0
  3. package/README.md +265 -0
  4. package/dist/backend/claude.d.ts +36 -0
  5. package/dist/backend/claude.js +358 -0
  6. package/dist/backend/claude.js.map +1 -0
  7. package/dist/backend/codex.d.ts +31 -0
  8. package/dist/backend/codex.js +100 -0
  9. package/dist/backend/codex.js.map +1 -0
  10. package/dist/backend/factory.d.ts +9 -0
  11. package/dist/backend/factory.js +56 -0
  12. package/dist/backend/factory.js.map +1 -0
  13. package/dist/backend/types.d.ts +54 -0
  14. package/dist/backend/types.js +2 -0
  15. package/dist/backend/types.js.map +1 -0
  16. package/dist/bridge/commands.d.ts +135 -0
  17. package/dist/bridge/commands.js +860 -0
  18. package/dist/bridge/commands.js.map +1 -0
  19. package/dist/bridge/service.d.ts +160 -0
  20. package/dist/bridge/service.js +3785 -0
  21. package/dist/bridge/service.js.map +1 -0
  22. package/dist/bridge/task-queue.d.ts +14 -0
  23. package/dist/bridge/task-queue.js +81 -0
  24. package/dist/bridge/task-queue.js.map +1 -0
  25. package/dist/bridge/types.d.ts +39 -0
  26. package/dist/bridge/types.js +2 -0
  27. package/dist/bridge/types.js.map +1 -0
  28. package/dist/cli.d.ts +2 -0
  29. package/dist/cli.js +1199 -0
  30. package/dist/cli.js.map +1 -0
  31. package/dist/codex/capabilities.d.ts +20 -0
  32. package/dist/codex/capabilities.js +41 -0
  33. package/dist/codex/capabilities.js.map +1 -0
  34. package/dist/codex/runner.d.ts +47 -0
  35. package/dist/codex/runner.js +294 -0
  36. package/dist/codex/runner.js.map +1 -0
  37. package/dist/codex/session-index.d.ts +22 -0
  38. package/dist/codex/session-index.js +205 -0
  39. package/dist/codex/session-index.js.map +1 -0
  40. package/dist/collaboration/awareness.d.ts +36 -0
  41. package/dist/collaboration/awareness.js +107 -0
  42. package/dist/collaboration/awareness.js.map +1 -0
  43. package/dist/collaboration/digest.d.ts +65 -0
  44. package/dist/collaboration/digest.js +178 -0
  45. package/dist/collaboration/digest.js.map +1 -0
  46. package/dist/collaboration/handoff.d.ts +66 -0
  47. package/dist/collaboration/handoff.js +94 -0
  48. package/dist/collaboration/handoff.js.map +1 -0
  49. package/dist/collaboration/insights.d.ts +24 -0
  50. package/dist/collaboration/insights.js +243 -0
  51. package/dist/collaboration/insights.js.map +1 -0
  52. package/dist/collaboration/knowledge.d.ts +26 -0
  53. package/dist/collaboration/knowledge.js +105 -0
  54. package/dist/collaboration/knowledge.js.map +1 -0
  55. package/dist/collaboration/timeline.d.ts +31 -0
  56. package/dist/collaboration/timeline.js +150 -0
  57. package/dist/collaboration/timeline.js.map +1 -0
  58. package/dist/collaboration/trust.d.ts +49 -0
  59. package/dist/collaboration/trust.js +176 -0
  60. package/dist/collaboration/trust.js.map +1 -0
  61. package/dist/config/codex-skill.d.ts +7 -0
  62. package/dist/config/codex-skill.js +44 -0
  63. package/dist/config/codex-skill.js.map +1 -0
  64. package/dist/config/doctor.d.ts +12 -0
  65. package/dist/config/doctor.js +314 -0
  66. package/dist/config/doctor.js.map +1 -0
  67. package/dist/config/init.d.ts +3 -0
  68. package/dist/config/init.js +123 -0
  69. package/dist/config/init.js.map +1 -0
  70. package/dist/config/load.d.ts +33 -0
  71. package/dist/config/load.js +252 -0
  72. package/dist/config/load.js.map +1 -0
  73. package/dist/config/mutate.d.ts +21 -0
  74. package/dist/config/mutate.js +86 -0
  75. package/dist/config/mutate.js.map +1 -0
  76. package/dist/config/paths.d.ts +3 -0
  77. package/dist/config/paths.js +33 -0
  78. package/dist/config/paths.js.map +1 -0
  79. package/dist/config/schema.d.ts +308 -0
  80. package/dist/config/schema.js +250 -0
  81. package/dist/config/schema.js.map +1 -0
  82. package/dist/control-plane/project-session.d.ts +67 -0
  83. package/dist/control-plane/project-session.js +234 -0
  84. package/dist/control-plane/project-session.js.map +1 -0
  85. package/dist/feishu/base.d.ts +19 -0
  86. package/dist/feishu/base.js +93 -0
  87. package/dist/feishu/base.js.map +1 -0
  88. package/dist/feishu/cards.d.ts +22 -0
  89. package/dist/feishu/cards.js +144 -0
  90. package/dist/feishu/cards.js.map +1 -0
  91. package/dist/feishu/client.d.ts +61 -0
  92. package/dist/feishu/client.js +315 -0
  93. package/dist/feishu/client.js.map +1 -0
  94. package/dist/feishu/diagnostics.d.ts +42 -0
  95. package/dist/feishu/diagnostics.js +194 -0
  96. package/dist/feishu/diagnostics.js.map +1 -0
  97. package/dist/feishu/doc.d.ts +13 -0
  98. package/dist/feishu/doc.js +59 -0
  99. package/dist/feishu/doc.js.map +1 -0
  100. package/dist/feishu/extractors.d.ts +7 -0
  101. package/dist/feishu/extractors.js +215 -0
  102. package/dist/feishu/extractors.js.map +1 -0
  103. package/dist/feishu/long-connection.d.ts +12 -0
  104. package/dist/feishu/long-connection.js +41 -0
  105. package/dist/feishu/long-connection.js.map +1 -0
  106. package/dist/feishu/message-resource.d.ts +14 -0
  107. package/dist/feishu/message-resource.js +309 -0
  108. package/dist/feishu/message-resource.js.map +1 -0
  109. package/dist/feishu/replay.d.ts +37 -0
  110. package/dist/feishu/replay.js +114 -0
  111. package/dist/feishu/replay.js.map +1 -0
  112. package/dist/feishu/task.d.ts +18 -0
  113. package/dist/feishu/task.js +86 -0
  114. package/dist/feishu/task.js.map +1 -0
  115. package/dist/feishu/text.d.ts +23 -0
  116. package/dist/feishu/text.js +155 -0
  117. package/dist/feishu/text.js.map +1 -0
  118. package/dist/feishu/webhook.d.ts +23 -0
  119. package/dist/feishu/webhook.js +130 -0
  120. package/dist/feishu/webhook.js.map +1 -0
  121. package/dist/feishu/wiki.d.ts +52 -0
  122. package/dist/feishu/wiki.js +300 -0
  123. package/dist/feishu/wiki.js.map +1 -0
  124. package/dist/index.d.ts +9 -0
  125. package/dist/index.js +9 -0
  126. package/dist/index.js.map +1 -0
  127. package/dist/knowledge/search.d.ts +11 -0
  128. package/dist/knowledge/search.js +83 -0
  129. package/dist/knowledge/search.js.map +1 -0
  130. package/dist/logging.d.ts +3 -0
  131. package/dist/logging.js +40 -0
  132. package/dist/logging.js.map +1 -0
  133. package/dist/mcp/server.d.ts +34 -0
  134. package/dist/mcp/server.js +1196 -0
  135. package/dist/mcp/server.js.map +1 -0
  136. package/dist/memory/embedding-factory.d.ts +6 -0
  137. package/dist/memory/embedding-factory.js +20 -0
  138. package/dist/memory/embedding-factory.js.map +1 -0
  139. package/dist/memory/embeddings.d.ts +40 -0
  140. package/dist/memory/embeddings.js +150 -0
  141. package/dist/memory/embeddings.js.map +1 -0
  142. package/dist/memory/ollama-embeddings.d.ts +63 -0
  143. package/dist/memory/ollama-embeddings.js +215 -0
  144. package/dist/memory/ollama-embeddings.js.map +1 -0
  145. package/dist/memory/retrieve.d.ts +17 -0
  146. package/dist/memory/retrieve.js +29 -0
  147. package/dist/memory/retrieve.js.map +1 -0
  148. package/dist/memory/summarize.d.ts +13 -0
  149. package/dist/memory/summarize.js +58 -0
  150. package/dist/memory/summarize.js.map +1 -0
  151. package/dist/observability/cost.d.ts +12 -0
  152. package/dist/observability/cost.js +22 -0
  153. package/dist/observability/cost.js.map +1 -0
  154. package/dist/observability/dashboard-html.d.ts +5 -0
  155. package/dist/observability/dashboard-html.js +304 -0
  156. package/dist/observability/dashboard-html.js.map +1 -0
  157. package/dist/observability/metrics.d.ts +36 -0
  158. package/dist/observability/metrics.js +230 -0
  159. package/dist/observability/metrics.js.map +1 -0
  160. package/dist/observability/readiness.d.ts +31 -0
  161. package/dist/observability/readiness.js +57 -0
  162. package/dist/observability/readiness.js.map +1 -0
  163. package/dist/observability/server.d.ts +84 -0
  164. package/dist/observability/server.js +181 -0
  165. package/dist/observability/server.js.map +1 -0
  166. package/dist/projects/paths.d.ts +9 -0
  167. package/dist/projects/paths.js +30 -0
  168. package/dist/projects/paths.js.map +1 -0
  169. package/dist/runtime/instance-lock.d.ts +12 -0
  170. package/dist/runtime/instance-lock.js +99 -0
  171. package/dist/runtime/instance-lock.js.map +1 -0
  172. package/dist/runtime/process.d.ts +2 -0
  173. package/dist/runtime/process.js +43 -0
  174. package/dist/runtime/process.js.map +1 -0
  175. package/dist/runtime/shutdown.d.ts +11 -0
  176. package/dist/runtime/shutdown.js +38 -0
  177. package/dist/runtime/shutdown.js.map +1 -0
  178. package/dist/security/access.d.ts +13 -0
  179. package/dist/security/access.js +160 -0
  180. package/dist/security/access.js.map +1 -0
  181. package/dist/service/install.d.ts +19 -0
  182. package/dist/service/install.js +35 -0
  183. package/dist/service/install.js.map +1 -0
  184. package/dist/service/templates.d.ts +22 -0
  185. package/dist/service/templates.js +118 -0
  186. package/dist/service/templates.js.map +1 -0
  187. package/dist/state/audit-log.d.ts +33 -0
  188. package/dist/state/audit-log.js +116 -0
  189. package/dist/state/audit-log.js.map +1 -0
  190. package/dist/state/config-history-store.d.ts +27 -0
  191. package/dist/state/config-history-store.js +65 -0
  192. package/dist/state/config-history-store.js.map +1 -0
  193. package/dist/state/handoff-store.d.ts +20 -0
  194. package/dist/state/handoff-store.js +97 -0
  195. package/dist/state/handoff-store.js.map +1 -0
  196. package/dist/state/idempotency-store.d.ts +19 -0
  197. package/dist/state/idempotency-store.js +84 -0
  198. package/dist/state/idempotency-store.js.map +1 -0
  199. package/dist/state/memory-store.d.ts +137 -0
  200. package/dist/state/memory-store.js +713 -0
  201. package/dist/state/memory-store.js.map +1 -0
  202. package/dist/state/pending-command-store.d.ts +30 -0
  203. package/dist/state/pending-command-store.js +108 -0
  204. package/dist/state/pending-command-store.js.map +1 -0
  205. package/dist/state/run-state-store.d.ts +58 -0
  206. package/dist/state/run-state-store.js +269 -0
  207. package/dist/state/run-state-store.js.map +1 -0
  208. package/dist/state/session-store.d.ts +56 -0
  209. package/dist/state/session-store.js +275 -0
  210. package/dist/state/session-store.js.map +1 -0
  211. package/dist/state/trust-store.d.ts +15 -0
  212. package/dist/state/trust-store.js +53 -0
  213. package/dist/state/trust-store.js.map +1 -0
  214. package/dist/utils/fs.d.ts +4 -0
  215. package/dist/utils/fs.js +26 -0
  216. package/dist/utils/fs.js.map +1 -0
  217. package/dist/utils/json.d.ts +1 -0
  218. package/dist/utils/json.js +9 -0
  219. package/dist/utils/json.js.map +1 -0
  220. package/dist/utils/path.d.ts +3 -0
  221. package/dist/utils/path.js +22 -0
  222. package/dist/utils/path.js.map +1 -0
  223. package/dist/utils/serial-executor.d.ts +5 -0
  224. package/dist/utils/serial-executor.js +12 -0
  225. package/dist/utils/serial-executor.js.map +1 -0
  226. package/package.json +71 -0
  227. package/skills/feique-session/SKILL.md +27 -0
@@ -0,0 +1,205 @@
1
+ import fs from 'node:fs/promises';
2
+ import os from 'node:os';
3
+ import path from 'node:path';
4
+ const FUZZY_SUFFIX_TOKENS = new Set(['bridge', 'repo', 'project', 'workspace']);
5
+ export class CodexSessionIndex {
6
+ codexHomeDir;
7
+ constructor(codexHomeDir = resolveCodexHomeDir()) {
8
+ this.codexHomeDir = codexHomeDir;
9
+ }
10
+ async listProjectSessions(projectRoot, limit = 10) {
11
+ const sessions = await this.listSessions();
12
+ const matches = [];
13
+ for (const session of sessions) {
14
+ const match = scoreSessionProjectMatch(projectRoot, session.cwd);
15
+ if (!match) {
16
+ continue;
17
+ }
18
+ matches.push({
19
+ ...session,
20
+ matchKind: match.kind,
21
+ matchScore: match.score,
22
+ });
23
+ }
24
+ return matches.sort(compareIndexedSessions).slice(0, limit);
25
+ }
26
+ async findLatestProjectSession(projectRoot) {
27
+ const [session] = await this.listProjectSessions(projectRoot, 1);
28
+ return session ?? null;
29
+ }
30
+ async findProjectSessionById(projectRoot, threadId) {
31
+ const sessions = await this.listSessions();
32
+ const candidate = sessions.find((session) => session.threadId === threadId);
33
+ if (!candidate) {
34
+ return null;
35
+ }
36
+ const match = scoreSessionProjectMatch(projectRoot, candidate.cwd);
37
+ if (!match) {
38
+ return null;
39
+ }
40
+ return {
41
+ ...candidate,
42
+ matchKind: match.kind,
43
+ matchScore: match.score,
44
+ };
45
+ }
46
+ async listSessions() {
47
+ const roots = [
48
+ { root: path.join(this.codexHomeDir, 'sessions'), source: 'sessions' },
49
+ { root: path.join(this.codexHomeDir, 'archived_sessions'), source: 'archived' },
50
+ ];
51
+ const sessions = new Map();
52
+ for (const entry of roots) {
53
+ const filePaths = await walkJsonlFiles(entry.root);
54
+ for (const filePath of filePaths) {
55
+ const session = await readIndexedSession(filePath, entry.source);
56
+ if (!session) {
57
+ continue;
58
+ }
59
+ const previous = sessions.get(session.threadId);
60
+ if (!previous || previous.updatedAt < session.updatedAt) {
61
+ sessions.set(session.threadId, session);
62
+ }
63
+ }
64
+ }
65
+ return [...sessions.values()].sort((left, right) => right.updatedAt.localeCompare(left.updatedAt));
66
+ }
67
+ }
68
+ export function resolveCodexHomeDir() {
69
+ const configured = process.env.CODEX_HOME?.trim();
70
+ if (!configured) {
71
+ return path.join(os.homedir(), '.codex');
72
+ }
73
+ if (configured === '~') {
74
+ return os.homedir();
75
+ }
76
+ if (configured.startsWith('~/')) {
77
+ return path.join(os.homedir(), configured.slice(2));
78
+ }
79
+ return path.resolve(configured);
80
+ }
81
+ export function renderSessionMatchLabel(session) {
82
+ switch (session.matchKind) {
83
+ case 'exact-root':
84
+ return 'exact-root';
85
+ case 'basename':
86
+ return 'basename';
87
+ case 'normalized-name':
88
+ return 'normalized-name';
89
+ case 'basename-contains':
90
+ return 'basename-contains';
91
+ default:
92
+ return 'unknown';
93
+ }
94
+ }
95
+ async function walkJsonlFiles(root) {
96
+ let entries;
97
+ try {
98
+ entries = await fs.readdir(root, { withFileTypes: true });
99
+ }
100
+ catch (error) {
101
+ if (isMissingPathError(error)) {
102
+ return [];
103
+ }
104
+ throw error;
105
+ }
106
+ const filePaths = [];
107
+ for (const entry of entries) {
108
+ const filePath = path.join(root, entry.name);
109
+ if (entry.isDirectory()) {
110
+ filePaths.push(...(await walkJsonlFiles(filePath)));
111
+ continue;
112
+ }
113
+ if (entry.isFile() && filePath.endsWith('.jsonl')) {
114
+ filePaths.push(filePath);
115
+ }
116
+ }
117
+ return filePaths;
118
+ }
119
+ async function readIndexedSession(filePath, source) {
120
+ let content;
121
+ let stat;
122
+ try {
123
+ [content, stat] = await Promise.all([fs.readFile(filePath, 'utf8'), fs.stat(filePath)]);
124
+ }
125
+ catch (error) {
126
+ if (isMissingPathError(error)) {
127
+ return null;
128
+ }
129
+ throw error;
130
+ }
131
+ const firstLine = content.split(/\r?\n/, 1)[0]?.trim();
132
+ if (!firstLine) {
133
+ return null;
134
+ }
135
+ try {
136
+ const parsed = JSON.parse(firstLine);
137
+ const threadId = parsed.payload?.id;
138
+ const cwd = parsed.payload?.cwd;
139
+ if (parsed.type !== 'session_meta' || !threadId || !cwd) {
140
+ return null;
141
+ }
142
+ const createdAt = parsed.payload?.timestamp;
143
+ const updatedAtCandidate = createdAt ? Date.parse(createdAt) : Number.NaN;
144
+ const updatedAt = new Date(Number.isFinite(updatedAtCandidate) ? Math.max(updatedAtCandidate, stat.mtimeMs) : stat.mtimeMs).toISOString();
145
+ return {
146
+ threadId,
147
+ cwd,
148
+ updatedAt,
149
+ createdAt,
150
+ filePath,
151
+ source,
152
+ };
153
+ }
154
+ catch {
155
+ return null;
156
+ }
157
+ }
158
+ function scoreSessionProjectMatch(projectRoot, sessionCwd) {
159
+ const normalizedProjectRoot = normalizePath(projectRoot);
160
+ const normalizedSessionRoot = normalizePath(sessionCwd);
161
+ if (normalizedProjectRoot === normalizedSessionRoot) {
162
+ return { kind: 'exact-root', score: 100 };
163
+ }
164
+ const projectBase = path.basename(normalizedProjectRoot);
165
+ const sessionBase = path.basename(normalizedSessionRoot);
166
+ if (projectBase === sessionBase) {
167
+ return { kind: 'basename', score: 80 };
168
+ }
169
+ const normalizedProjectName = normalizeProjectName(projectBase);
170
+ const normalizedSessionName = normalizeProjectName(sessionBase);
171
+ if (normalizedProjectName && normalizedProjectName === normalizedSessionName) {
172
+ return { kind: 'normalized-name', score: 60 };
173
+ }
174
+ if (normalizedProjectName.length >= 5 && normalizedSessionName.includes(normalizedProjectName)) {
175
+ return { kind: 'basename-contains', score: 40 };
176
+ }
177
+ return null;
178
+ }
179
+ function normalizePath(input) {
180
+ return path.resolve(input).replace(/\/+$/, '').toLowerCase();
181
+ }
182
+ function normalizeProjectName(input) {
183
+ const tokens = input
184
+ .toLowerCase()
185
+ .replace(/\.git$/, '')
186
+ .split(/[^a-z0-9]+/)
187
+ .filter(Boolean);
188
+ const filtered = tokens.filter((token) => !FUZZY_SUFFIX_TOKENS.has(token));
189
+ return (filtered.length > 0 ? filtered : tokens).join('-');
190
+ }
191
+ function compareIndexedSessions(left, right) {
192
+ const scoreDelta = (right.matchScore ?? 0) - (left.matchScore ?? 0);
193
+ if (scoreDelta !== 0) {
194
+ return scoreDelta;
195
+ }
196
+ const updatedAtDelta = right.updatedAt.localeCompare(left.updatedAt);
197
+ if (updatedAtDelta !== 0) {
198
+ return updatedAtDelta;
199
+ }
200
+ return left.threadId.localeCompare(right.threadId);
201
+ }
202
+ function isMissingPathError(error) {
203
+ return error instanceof Error && 'code' in error && error.code === 'ENOENT';
204
+ }
205
+ //# sourceMappingURL=session-index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-index.js","sourceRoot":"","sources":["../../src/codex/session-index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ /**
2
+ * Direction 1: 协作态势感知 — Team Activity Awareness
3
+ *
4
+ * Aggregates run states into a team-level view and detects
5
+ * overlapping work across team members.
6
+ */
7
+ import type { RunState } from '../state/run-state-store.js';
8
+ export interface TeamMemberActivity {
9
+ actor_id: string;
10
+ actor_name?: string;
11
+ chat_id: string;
12
+ project_alias: string;
13
+ project_root?: string;
14
+ backend?: string;
15
+ status: 'running' | 'queued';
16
+ run_id: string;
17
+ started_at: string;
18
+ updated_at: string;
19
+ prompt_excerpt?: string;
20
+ }
21
+ export interface OverlapAlert {
22
+ kind: 'same_project' | 'same_root';
23
+ existing_actor_id?: string;
24
+ existing_run_id: string;
25
+ project_alias: string;
26
+ project_root?: string;
27
+ detail: string;
28
+ }
29
+ export declare function buildTeamActivityView(runs: RunState[]): TeamMemberActivity[];
30
+ export declare function detectOverlaps(incoming: {
31
+ actor_id?: string;
32
+ project_alias: string;
33
+ project_root?: string;
34
+ }, activeRuns: RunState[]): OverlapAlert[];
35
+ export declare function formatTeamView(activities: TeamMemberActivity[]): string;
36
+ export declare function formatOverlapAlerts(alerts: OverlapAlert[]): string;
@@ -0,0 +1,107 @@
1
+ /**
2
+ * Direction 1: 协作态势感知 — Team Activity Awareness
3
+ *
4
+ * Aggregates run states into a team-level view and detects
5
+ * overlapping work across team members.
6
+ */
7
+ const ACTIVE_STATUSES = new Set(['running', 'queued']);
8
+ export function buildTeamActivityView(runs) {
9
+ return runs
10
+ .filter((r) => ACTIVE_STATUSES.has(r.status))
11
+ .map((r) => ({
12
+ actor_id: r.actor_id ?? 'unknown',
13
+ chat_id: r.chat_id,
14
+ project_alias: r.project_alias,
15
+ project_root: r.project_root,
16
+ status: r.status,
17
+ run_id: r.run_id,
18
+ started_at: r.started_at,
19
+ updated_at: r.updated_at,
20
+ prompt_excerpt: r.prompt_excerpt,
21
+ }))
22
+ .sort((a, b) => b.updated_at.localeCompare(a.updated_at));
23
+ }
24
+ export function detectOverlaps(incoming, activeRuns) {
25
+ const alerts = [];
26
+ for (const run of activeRuns) {
27
+ if (!ACTIVE_STATUSES.has(run.status))
28
+ continue;
29
+ if (run.actor_id === incoming.actor_id)
30
+ continue;
31
+ if (run.project_alias === incoming.project_alias) {
32
+ alerts.push({
33
+ kind: 'same_project',
34
+ existing_actor_id: run.actor_id,
35
+ existing_run_id: run.run_id,
36
+ project_alias: run.project_alias,
37
+ project_root: run.project_root,
38
+ detail: `${run.actor_id ?? '其他成员'} 正在项目 ${run.project_alias} 上工作`,
39
+ });
40
+ }
41
+ else if (incoming.project_root &&
42
+ run.project_root &&
43
+ run.project_root === incoming.project_root) {
44
+ alerts.push({
45
+ kind: 'same_root',
46
+ existing_actor_id: run.actor_id,
47
+ existing_run_id: run.run_id,
48
+ project_alias: run.project_alias,
49
+ project_root: run.project_root,
50
+ detail: `${run.actor_id ?? '其他成员'} 正在操作同一仓库 (${run.project_alias})`,
51
+ });
52
+ }
53
+ }
54
+ return alerts;
55
+ }
56
+ export function formatTeamView(activities) {
57
+ if (activities.length === 0) {
58
+ return '当前没有活跃的团队成员在使用 AI 工具。';
59
+ }
60
+ const lines = ['📡 团队 AI 协作态势\n'];
61
+ const running = activities.filter((a) => a.status === 'running');
62
+ const queued = activities.filter((a) => a.status === 'queued');
63
+ if (running.length > 0) {
64
+ lines.push(`🟢 执行中 (${running.length})`);
65
+ for (const a of running) {
66
+ const actor = a.actor_id;
67
+ const elapsed = formatElapsed(a.started_at);
68
+ lines.push(` • ${actor} → ${a.project_alias} (${elapsed})`);
69
+ if (a.prompt_excerpt) {
70
+ lines.push(` "${truncate(a.prompt_excerpt, 60)}"`);
71
+ }
72
+ }
73
+ }
74
+ if (queued.length > 0) {
75
+ lines.push(`\n⏳ 排队中 (${queued.length})`);
76
+ for (const a of queued) {
77
+ lines.push(` • ${a.actor_id} → ${a.project_alias}`);
78
+ }
79
+ }
80
+ return lines.join('\n');
81
+ }
82
+ export function formatOverlapAlerts(alerts) {
83
+ if (alerts.length === 0)
84
+ return '';
85
+ const lines = ['⚠️ 协作提醒:'];
86
+ for (const alert of alerts) {
87
+ lines.push(` • ${alert.detail}`);
88
+ }
89
+ lines.push('建议先确认是否需要协调,避免冲突。');
90
+ return lines.join('\n');
91
+ }
92
+ function formatElapsed(isoStart) {
93
+ const ms = Date.now() - new Date(isoStart).getTime();
94
+ const minutes = Math.floor(ms / 60_000);
95
+ if (minutes < 1)
96
+ return '<1 分钟';
97
+ if (minutes < 60)
98
+ return `${minutes} 分钟`;
99
+ const hours = Math.floor(minutes / 60);
100
+ return `${hours} 小时 ${minutes % 60} 分钟`;
101
+ }
102
+ function truncate(text, maxLength) {
103
+ if (text.length <= maxLength)
104
+ return text;
105
+ return text.slice(0, maxLength - 1) + '…';
106
+ }
107
+ //# sourceMappingURL=awareness.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"awareness.js","sourceRoot":"","sources":["../../src/collaboration/awareness.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,65 @@
1
+ /**
2
+ * Team AI Collaboration Digest
3
+ *
4
+ * Generates periodic (daily/weekly) summaries of team AI activity,
5
+ * knowledge accumulation, bottlenecks, and collaboration health.
6
+ * Pushed to designated Feishu group chats.
7
+ */
8
+ import type { RunState } from '../state/run-state-store.js';
9
+ import type { MemoryRecord } from '../state/memory-store.js';
10
+ import type { TeamInsight } from './insights.js';
11
+ export interface DigestPeriod {
12
+ from: Date;
13
+ to: Date;
14
+ label: string;
15
+ }
16
+ export interface TeamDigest {
17
+ period: DigestPeriod;
18
+ summary: DigestSummary;
19
+ topProjects: ProjectDigest[];
20
+ topContributors: ContributorDigest[];
21
+ insights: TeamInsight[];
22
+ knowledgeAdded: number;
23
+ handoffsCompleted: number;
24
+ }
25
+ interface DigestSummary {
26
+ total_runs: number;
27
+ successful_runs: number;
28
+ failed_runs: number;
29
+ cancelled_runs: number;
30
+ unique_actors: number;
31
+ unique_projects: number;
32
+ avg_duration_ms: number;
33
+ total_input_tokens: number;
34
+ total_output_tokens: number;
35
+ total_cost_usd: number;
36
+ }
37
+ interface ProjectDigest {
38
+ alias: string;
39
+ runs: number;
40
+ success_rate: number;
41
+ actors: string[];
42
+ }
43
+ interface ContributorDigest {
44
+ actor_id: string;
45
+ runs: number;
46
+ success_rate: number;
47
+ projects: string[];
48
+ }
49
+ /**
50
+ * Build a team digest for a given time period.
51
+ */
52
+ export declare function buildTeamDigest(runs: RunState[], memories: MemoryRecord[], auditEvents: Array<{
53
+ type: string;
54
+ at: string;
55
+ [key: string]: unknown;
56
+ }>, period: DigestPeriod): TeamDigest;
57
+ /**
58
+ * Format digest as readable text for Feishu.
59
+ */
60
+ export declare function formatTeamDigest(digest: TeamDigest): string;
61
+ /**
62
+ * Create a DigestPeriod for the last N hours (default: 24 = daily).
63
+ */
64
+ export declare function createDigestPeriod(hours?: number): DigestPeriod;
65
+ export {};
@@ -0,0 +1,178 @@
1
+ /**
2
+ * Team AI Collaboration Digest
3
+ *
4
+ * Generates periodic (daily/weekly) summaries of team AI activity,
5
+ * knowledge accumulation, bottlenecks, and collaboration health.
6
+ * Pushed to designated Feishu group chats.
7
+ */
8
+ import { analyzeTeamHealth } from './insights.js';
9
+ /**
10
+ * Build a team digest for a given time period.
11
+ */
12
+ export function buildTeamDigest(runs, memories, auditEvents, period) {
13
+ const periodRuns = runs.filter((r) => {
14
+ const t = new Date(r.started_at);
15
+ return t >= period.from && t <= period.to;
16
+ });
17
+ const successful = periodRuns.filter((r) => r.status === 'success');
18
+ const failed = periodRuns.filter((r) => r.status === 'failure');
19
+ const cancelled = periodRuns.filter((r) => r.status === 'cancelled');
20
+ const actors = new Set(periodRuns.map((r) => r.actor_id).filter(Boolean));
21
+ const projects = new Set(periodRuns.map((r) => r.project_alias));
22
+ const durations = periodRuns
23
+ .filter((r) => r.finished_at && r.started_at)
24
+ .map((r) => new Date(r.finished_at).getTime() - new Date(r.started_at).getTime())
25
+ .filter((d) => d > 0);
26
+ const avgDuration = durations.length > 0
27
+ ? durations.reduce((a, b) => a + b, 0) / durations.length
28
+ : 0;
29
+ // Token / cost totals
30
+ const totalInputTokens = periodRuns.reduce((sum, r) => sum + (r.input_tokens ?? 0), 0);
31
+ const totalOutputTokens = periodRuns.reduce((sum, r) => sum + (r.output_tokens ?? 0), 0);
32
+ const totalCostUsd = periodRuns.reduce((sum, r) => sum + (r.estimated_cost_usd ?? 0), 0);
33
+ // Per-project breakdown
34
+ const projectMap = new Map();
35
+ for (const run of periodRuns) {
36
+ const list = projectMap.get(run.project_alias) ?? [];
37
+ list.push(run);
38
+ projectMap.set(run.project_alias, list);
39
+ }
40
+ const topProjects = [...projectMap.entries()]
41
+ .map(([alias, projectRuns]) => ({
42
+ alias,
43
+ runs: projectRuns.length,
44
+ success_rate: projectRuns.length > 0
45
+ ? projectRuns.filter((r) => r.status === 'success').length / projectRuns.length
46
+ : 0,
47
+ actors: [...new Set(projectRuns.map((r) => r.actor_id).filter(Boolean))],
48
+ }))
49
+ .sort((a, b) => b.runs - a.runs)
50
+ .slice(0, 5);
51
+ // Per-contributor breakdown
52
+ const actorMap = new Map();
53
+ for (const run of periodRuns) {
54
+ if (!run.actor_id)
55
+ continue;
56
+ const list = actorMap.get(run.actor_id) ?? [];
57
+ list.push(run);
58
+ actorMap.set(run.actor_id, list);
59
+ }
60
+ const topContributors = [...actorMap.entries()]
61
+ .map(([actor_id, actorRuns]) => ({
62
+ actor_id,
63
+ runs: actorRuns.length,
64
+ success_rate: actorRuns.length > 0
65
+ ? actorRuns.filter((r) => r.status === 'success').length / actorRuns.length
66
+ : 0,
67
+ projects: [...new Set(actorRuns.map((r) => r.project_alias))],
68
+ }))
69
+ .sort((a, b) => b.runs - a.runs)
70
+ .slice(0, 5);
71
+ // Knowledge added in period
72
+ const knowledgeAdded = memories.filter((m) => {
73
+ const t = new Date(m.created_at);
74
+ return t >= period.from && t <= period.to && !m.archived_at;
75
+ }).length;
76
+ // Handoffs completed in period
77
+ const handoffsCompleted = auditEvents.filter((e) => {
78
+ const t = new Date(e.at);
79
+ return e.type === 'collaboration.handoff.accepted' && t >= period.from && t <= period.to;
80
+ }).length;
81
+ const insights = analyzeTeamHealth(periodRuns, auditEvents);
82
+ return {
83
+ period,
84
+ summary: {
85
+ total_runs: periodRuns.length,
86
+ successful_runs: successful.length,
87
+ failed_runs: failed.length,
88
+ cancelled_runs: cancelled.length,
89
+ unique_actors: actors.size,
90
+ unique_projects: projects.size,
91
+ avg_duration_ms: avgDuration,
92
+ total_input_tokens: totalInputTokens,
93
+ total_output_tokens: totalOutputTokens,
94
+ total_cost_usd: totalCostUsd,
95
+ },
96
+ topProjects,
97
+ topContributors,
98
+ insights,
99
+ knowledgeAdded,
100
+ handoffsCompleted,
101
+ };
102
+ }
103
+ /**
104
+ * Format digest as readable text for Feishu.
105
+ */
106
+ export function formatTeamDigest(digest) {
107
+ const { period, summary } = digest;
108
+ const lines = [];
109
+ lines.push(`📊 团队 AI 协作日报 (${period.label})`);
110
+ lines.push('');
111
+ // Overview
112
+ const successRate = summary.total_runs > 0
113
+ ? Math.round((summary.successful_runs / summary.total_runs) * 100)
114
+ : 0;
115
+ const avgMin = Math.round(summary.avg_duration_ms / 60_000);
116
+ lines.push('📈 总览');
117
+ lines.push(` 运行: ${summary.total_runs} 次 (成功 ${successRate}%)`);
118
+ lines.push(` 成员: ${summary.unique_actors} 人 / 项目: ${summary.unique_projects} 个`);
119
+ if (avgMin > 0) {
120
+ lines.push(` 平均耗时: ${avgMin} 分钟`);
121
+ }
122
+ if (digest.knowledgeAdded > 0) {
123
+ lines.push(` 知识沉淀: ${digest.knowledgeAdded} 条`);
124
+ }
125
+ if (digest.handoffsCompleted > 0) {
126
+ lines.push(` 会话交接: ${digest.handoffsCompleted} 次`);
127
+ }
128
+ if (summary.total_input_tokens > 0 || summary.total_output_tokens > 0) {
129
+ const fmtTokens = (n) => n >= 1_000_000 ? `${(n / 1_000_000).toFixed(1)}M` : n >= 1_000 ? `${Math.round(n / 1_000)}K` : `${n}`;
130
+ const costCny = (summary.total_cost_usd * 7.2).toFixed(2);
131
+ lines.push(` Token 用量: ${fmtTokens(summary.total_input_tokens)} 输入 / ${fmtTokens(summary.total_output_tokens)} 输出, 预估 ¥${costCny}`);
132
+ }
133
+ // Top projects
134
+ if (digest.topProjects.length > 0) {
135
+ lines.push('');
136
+ lines.push('🏗️ 活跃项目');
137
+ for (const p of digest.topProjects) {
138
+ const rate = Math.round(p.success_rate * 100);
139
+ lines.push(` ${p.alias}: ${p.runs} 次运行, ${rate}% 成功, ${p.actors.length} 人参与`);
140
+ }
141
+ }
142
+ // Top contributors
143
+ if (digest.topContributors.length > 0) {
144
+ lines.push('');
145
+ lines.push('👥 活跃成员');
146
+ for (const c of digest.topContributors) {
147
+ const rate = Math.round(c.success_rate * 100);
148
+ lines.push(` ${c.actor_id}: ${c.runs} 次运行, ${rate}% 成功, ${c.projects.length} 个项目`);
149
+ }
150
+ }
151
+ // Insights (only warnings and above)
152
+ const actionable = digest.insights.filter((i) => i.severity !== 'info');
153
+ if (actionable.length > 0) {
154
+ lines.push('');
155
+ lines.push('⚠️ 需要关注');
156
+ for (const insight of actionable.slice(0, 3)) {
157
+ const icon = insight.severity === 'critical' ? '🔴' : '🟡';
158
+ lines.push(` ${icon} ${insight.title}`);
159
+ lines.push(` 💡 ${insight.suggestion}`);
160
+ }
161
+ }
162
+ return lines.join('\n');
163
+ }
164
+ /**
165
+ * Create a DigestPeriod for the last N hours (default: 24 = daily).
166
+ */
167
+ export function createDigestPeriod(hours = 24) {
168
+ const to = new Date();
169
+ const from = new Date(to.getTime() - hours * 3600_000);
170
+ const fmtDate = (d) => d.toLocaleDateString('zh-CN');
171
+ const fmtTime = (d) => d.toLocaleTimeString('zh-CN', { hour: '2-digit', minute: '2-digit' });
172
+ const sameDay = from.toDateString() === to.toDateString();
173
+ const label = sameDay
174
+ ? `${fmtDate(from)} ${fmtTime(from)} — ${fmtTime(to)}`
175
+ : `${fmtDate(from)} ${fmtTime(from)} — ${fmtDate(to)} ${fmtTime(to)}`;
176
+ return { from, to, label };
177
+ }
178
+ //# sourceMappingURL=digest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"digest.js","sourceRoot":"","sources":["../../src/collaboration/digest.ts"],"names":[],"mappings":"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"}