@fortressllm/sybil 0.0.3

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 (288) hide show
  1. package/.env copy +91 -0
  2. package/.env.example +139 -0
  3. package/BROWSER_CONTROL.md +354 -0
  4. package/CLI_CHAT_FEATURE.md +224 -0
  5. package/CLI_GUIDE.md +359 -0
  6. package/DYNAMIC_SKILLS.md +345 -0
  7. package/DockerFile.sandbox +14 -0
  8. package/PROGRESS.md +249 -0
  9. package/README.md +281 -0
  10. package/RENAME_LOG.md +62 -0
  11. package/SIMPLIFIED_TELEGRAM_UX.md +273 -0
  12. package/SYBIL_SUMMARY.md +360 -0
  13. package/TASK11_NETWORK.md +202 -0
  14. package/TASK14_CLI.md +432 -0
  15. package/TASK8_SAFETY.md +317 -0
  16. package/TASK9_COMPLETION.md +186 -0
  17. package/TASK9_SUMMARY.md +201 -0
  18. package/TELEGRAM_OTP_AUTH.md +359 -0
  19. package/VECTOR_MEMORY.md +163 -0
  20. package/assets/logo.png +0 -0
  21. package/cypfq_code_search.md +287 -0
  22. package/cypfq_driver_search.md +297 -0
  23. package/cypfq_github_search.md +297 -0
  24. package/cypfq_repo_search.md +370 -0
  25. package/dist/agents/autonomous-agent.d.ts +61 -0
  26. package/dist/agents/autonomous-agent.d.ts.map +1 -0
  27. package/dist/agents/autonomous-agent.js +536 -0
  28. package/dist/agents/autonomous-agent.js.map +1 -0
  29. package/dist/agents/network.d.ts +1006 -0
  30. package/dist/agents/network.d.ts.map +1 -0
  31. package/dist/agents/network.js +1266 -0
  32. package/dist/agents/network.js.map +1 -0
  33. package/dist/cli/commands/backup.d.ts +3 -0
  34. package/dist/cli/commands/backup.d.ts.map +1 -0
  35. package/dist/cli/commands/backup.js +63 -0
  36. package/dist/cli/commands/backup.js.map +1 -0
  37. package/dist/cli/commands/config.d.ts +3 -0
  38. package/dist/cli/commands/config.d.ts.map +1 -0
  39. package/dist/cli/commands/config.js +163 -0
  40. package/dist/cli/commands/config.js.map +1 -0
  41. package/dist/cli/commands/doctor.d.ts +3 -0
  42. package/dist/cli/commands/doctor.d.ts.map +1 -0
  43. package/dist/cli/commands/doctor.js +107 -0
  44. package/dist/cli/commands/doctor.js.map +1 -0
  45. package/dist/cli/commands/init.d.ts +3 -0
  46. package/dist/cli/commands/init.d.ts.map +1 -0
  47. package/dist/cli/commands/init.js +138 -0
  48. package/dist/cli/commands/init.js.map +1 -0
  49. package/dist/cli/commands/logs.d.ts +3 -0
  50. package/dist/cli/commands/logs.d.ts.map +1 -0
  51. package/dist/cli/commands/logs.js +81 -0
  52. package/dist/cli/commands/logs.js.map +1 -0
  53. package/dist/cli/commands/otp.d.ts +3 -0
  54. package/dist/cli/commands/otp.d.ts.map +1 -0
  55. package/dist/cli/commands/otp.js +142 -0
  56. package/dist/cli/commands/otp.js.map +1 -0
  57. package/dist/cli/commands/restore.d.ts +3 -0
  58. package/dist/cli/commands/restore.d.ts.map +1 -0
  59. package/dist/cli/commands/restore.js +99 -0
  60. package/dist/cli/commands/restore.js.map +1 -0
  61. package/dist/cli/commands/start.d.ts +3 -0
  62. package/dist/cli/commands/start.d.ts.map +1 -0
  63. package/dist/cli/commands/start.js +65 -0
  64. package/dist/cli/commands/start.js.map +1 -0
  65. package/dist/cli/commands/status.d.ts +3 -0
  66. package/dist/cli/commands/status.d.ts.map +1 -0
  67. package/dist/cli/commands/status.js +68 -0
  68. package/dist/cli/commands/status.js.map +1 -0
  69. package/dist/cli/commands/stop.d.ts +3 -0
  70. package/dist/cli/commands/stop.d.ts.map +1 -0
  71. package/dist/cli/commands/stop.js +62 -0
  72. package/dist/cli/commands/stop.js.map +1 -0
  73. package/dist/cli/commands/update.d.ts +3 -0
  74. package/dist/cli/commands/update.d.ts.map +1 -0
  75. package/dist/cli/commands/update.js +49 -0
  76. package/dist/cli/commands/update.js.map +1 -0
  77. package/dist/cli/commands/whatsapp.d.ts +3 -0
  78. package/dist/cli/commands/whatsapp.d.ts.map +1 -0
  79. package/dist/cli/commands/whatsapp.js +281 -0
  80. package/dist/cli/commands/whatsapp.js.map +1 -0
  81. package/dist/cli/index.d.ts +7 -0
  82. package/dist/cli/index.d.ts.map +1 -0
  83. package/dist/cli/index.js +58 -0
  84. package/dist/cli/index.js.map +1 -0
  85. package/dist/cli.d.ts +9 -0
  86. package/dist/cli.d.ts.map +1 -0
  87. package/dist/cli.js +750 -0
  88. package/dist/cli.js.map +1 -0
  89. package/dist/index.d.ts +2 -0
  90. package/dist/index.d.ts.map +1 -0
  91. package/dist/index.js +109 -0
  92. package/dist/index.js.map +1 -0
  93. package/dist/mastra/index.d.ts +4 -0
  94. package/dist/mastra/index.d.ts.map +1 -0
  95. package/dist/mastra/index.js +37 -0
  96. package/dist/mastra/index.js.map +1 -0
  97. package/dist/mastra/memory.d.ts +9 -0
  98. package/dist/mastra/memory.d.ts.map +1 -0
  99. package/dist/mastra/memory.js +92 -0
  100. package/dist/mastra/memory.js.map +1 -0
  101. package/dist/processors/index.d.ts +74 -0
  102. package/dist/processors/index.d.ts.map +1 -0
  103. package/dist/processors/index.js +153 -0
  104. package/dist/processors/index.js.map +1 -0
  105. package/dist/processors/semantic-recall.d.ts +63 -0
  106. package/dist/processors/semantic-recall.d.ts.map +1 -0
  107. package/dist/processors/semantic-recall.js +216 -0
  108. package/dist/processors/semantic-recall.js.map +1 -0
  109. package/dist/processors/tool-search.d.ts +26 -0
  110. package/dist/processors/tool-search.d.ts.map +1 -0
  111. package/dist/processors/tool-search.js +41 -0
  112. package/dist/processors/tool-search.js.map +1 -0
  113. package/dist/skills/dynamic/skill-generator.d.ts +169 -0
  114. package/dist/skills/dynamic/skill-generator.d.ts.map +1 -0
  115. package/dist/skills/dynamic/skill-generator.js +488 -0
  116. package/dist/skills/dynamic/skill-generator.js.map +1 -0
  117. package/dist/tools/agent-delegation-tools.d.ts +142 -0
  118. package/dist/tools/agent-delegation-tools.d.ts.map +1 -0
  119. package/dist/tools/agent-delegation-tools.js +263 -0
  120. package/dist/tools/agent-delegation-tools.js.map +1 -0
  121. package/dist/tools/browser-tools.d.ts +374 -0
  122. package/dist/tools/browser-tools.d.ts.map +1 -0
  123. package/dist/tools/browser-tools.js +752 -0
  124. package/dist/tools/browser-tools.js.map +1 -0
  125. package/dist/tools/dynamic/registry.d.ts +61 -0
  126. package/dist/tools/dynamic/registry.d.ts.map +1 -0
  127. package/dist/tools/dynamic/registry.js +121 -0
  128. package/dist/tools/dynamic/registry.js.map +1 -0
  129. package/dist/tools/dynamic/tool-generator.d.ts +99 -0
  130. package/dist/tools/dynamic/tool-generator.d.ts.map +1 -0
  131. package/dist/tools/dynamic/tool-generator.js +367 -0
  132. package/dist/tools/dynamic/tool-generator.js.map +1 -0
  133. package/dist/tools/extended-tools.d.ts +176 -0
  134. package/dist/tools/extended-tools.d.ts.map +1 -0
  135. package/dist/tools/extended-tools.js +464 -0
  136. package/dist/tools/extended-tools.js.map +1 -0
  137. package/dist/tools/library/calendar/index.d.ts +134 -0
  138. package/dist/tools/library/calendar/index.d.ts.map +1 -0
  139. package/dist/tools/library/calendar/index.js +160 -0
  140. package/dist/tools/library/calendar/index.js.map +1 -0
  141. package/dist/tools/podman-workspace-mcp-cli.d.ts +3 -0
  142. package/dist/tools/podman-workspace-mcp-cli.d.ts.map +1 -0
  143. package/dist/tools/podman-workspace-mcp-cli.js +12 -0
  144. package/dist/tools/podman-workspace-mcp-cli.js.map +1 -0
  145. package/dist/tools/podman-workspace-mcp.d.ts +247 -0
  146. package/dist/tools/podman-workspace-mcp.d.ts.map +1 -0
  147. package/dist/tools/podman-workspace-mcp.js +1093 -0
  148. package/dist/tools/podman-workspace-mcp.js.map +1 -0
  149. package/dist/tools/podman-workspace.d.ts +148 -0
  150. package/dist/tools/podman-workspace.d.ts.map +1 -0
  151. package/dist/tools/podman-workspace.js +682 -0
  152. package/dist/tools/podman-workspace.js.map +1 -0
  153. package/dist/tools/telegram-file-tools.d.ts +78 -0
  154. package/dist/tools/telegram-file-tools.d.ts.map +1 -0
  155. package/dist/tools/telegram-file-tools.js +294 -0
  156. package/dist/tools/telegram-file-tools.js.map +1 -0
  157. package/dist/tools/tool-registry.d.ts +467 -0
  158. package/dist/tools/tool-registry.d.ts.map +1 -0
  159. package/dist/tools/tool-registry.js +156 -0
  160. package/dist/tools/tool-registry.js.map +1 -0
  161. package/dist/tools/web-tools.d.ts +77 -0
  162. package/dist/tools/web-tools.d.ts.map +1 -0
  163. package/dist/tools/web-tools.js +416 -0
  164. package/dist/tools/web-tools.js.map +1 -0
  165. package/dist/tools/whatsapp-autoreply-tools.d.ts +118 -0
  166. package/dist/tools/whatsapp-autoreply-tools.d.ts.map +1 -0
  167. package/dist/tools/whatsapp-autoreply-tools.js +503 -0
  168. package/dist/tools/whatsapp-autoreply-tools.js.map +1 -0
  169. package/dist/tools/whatsapp-tools.d.ts +175 -0
  170. package/dist/tools/whatsapp-tools.d.ts.map +1 -0
  171. package/dist/tools/whatsapp-tools.js +566 -0
  172. package/dist/tools/whatsapp-tools.js.map +1 -0
  173. package/dist/utils/logger.d.ts +65 -0
  174. package/dist/utils/logger.d.ts.map +1 -0
  175. package/dist/utils/logger.js +307 -0
  176. package/dist/utils/logger.js.map +1 -0
  177. package/dist/utils/model-config.d.ts +73 -0
  178. package/dist/utils/model-config.d.ts.map +1 -0
  179. package/dist/utils/model-config.js +366 -0
  180. package/dist/utils/model-config.js.map +1 -0
  181. package/dist/utils/semantic-memory.d.ts +82 -0
  182. package/dist/utils/semantic-memory.d.ts.map +1 -0
  183. package/dist/utils/semantic-memory.js +189 -0
  184. package/dist/utils/semantic-memory.js.map +1 -0
  185. package/dist/utils/system.d.ts +2 -0
  186. package/dist/utils/system.d.ts.map +1 -0
  187. package/dist/utils/system.js +24 -0
  188. package/dist/utils/system.js.map +1 -0
  189. package/dist/utils/telegram-auth.d.ts +54 -0
  190. package/dist/utils/telegram-auth.d.ts.map +1 -0
  191. package/dist/utils/telegram-auth.js +146 -0
  192. package/dist/utils/telegram-auth.js.map +1 -0
  193. package/dist/utils/telegram.d.ts +7 -0
  194. package/dist/utils/telegram.d.ts.map +1 -0
  195. package/dist/utils/telegram.js +1494 -0
  196. package/dist/utils/telegram.js.map +1 -0
  197. package/dist/utils/whatsapp-client.d.ts +166 -0
  198. package/dist/utils/whatsapp-client.d.ts.map +1 -0
  199. package/dist/utils/whatsapp-client.js +722 -0
  200. package/dist/utils/whatsapp-client.js.map +1 -0
  201. package/dist/workflows/planner-workflow.d.ts +39 -0
  202. package/dist/workflows/planner-workflow.d.ts.map +1 -0
  203. package/dist/workflows/planner-workflow.js +165 -0
  204. package/dist/workflows/planner-workflow.js.map +1 -0
  205. package/dist/workflows/skill-builder-workflow.d.ts +16 -0
  206. package/dist/workflows/skill-builder-workflow.d.ts.map +1 -0
  207. package/dist/workflows/skill-builder-workflow.js +157 -0
  208. package/dist/workflows/skill-builder-workflow.js.map +1 -0
  209. package/dist/workspace/index.d.ts +23 -0
  210. package/dist/workspace/index.d.ts.map +1 -0
  211. package/dist/workspace/index.js +64 -0
  212. package/dist/workspace/index.js.map +1 -0
  213. package/docs/README.md +140 -0
  214. package/docs/api/agents.md +481 -0
  215. package/docs/api/browser-tools.md +469 -0
  216. package/docs/api/memory.md +629 -0
  217. package/docs/architecture/agent-networks.md +586 -0
  218. package/docs/architecture/memory.md +579 -0
  219. package/docs/architecture/overview.md +436 -0
  220. package/docs/architecture/tools.md +637 -0
  221. package/docs/cli-tui.md +367 -0
  222. package/docs/guides/environment-variables.md +502 -0
  223. package/docs/guides/troubleshooting.md +882 -0
  224. package/docs/tutorials/agent-networks.md +432 -0
  225. package/docs/tutorials/dynamic-tools.md +469 -0
  226. package/docs/tutorials/getting-started.md +263 -0
  227. package/docs/tutorials/skills.md +561 -0
  228. package/docs/tutorials/web-browsing.md +329 -0
  229. package/mastra.db-shm +0 -0
  230. package/mastra.db-wal +0 -0
  231. package/package.json +71 -0
  232. package/plan.md +601 -0
  233. package/skills/code-review/SKILL.md +48 -0
  234. package/skills/task-planning/SKILL.md +55 -0
  235. package/skills/web-research/SKILL.md +79 -0
  236. package/skills/whatsapp-management/SKILL.md +78 -0
  237. package/src/agents/autonomous-agent.ts +626 -0
  238. package/src/agents/network.ts +1307 -0
  239. package/src/cli/commands/backup.ts +78 -0
  240. package/src/cli/commands/config.ts +176 -0
  241. package/src/cli/commands/doctor.ts +111 -0
  242. package/src/cli/commands/init.ts +150 -0
  243. package/src/cli/commands/logs.ts +94 -0
  244. package/src/cli/commands/otp.ts +162 -0
  245. package/src/cli/commands/restore.ts +118 -0
  246. package/src/cli/commands/start.ts +76 -0
  247. package/src/cli/commands/status.ts +81 -0
  248. package/src/cli/commands/stop.ts +68 -0
  249. package/src/cli/commands/update.ts +61 -0
  250. package/src/cli/commands/whatsapp.ts +322 -0
  251. package/src/cli/index.ts +69 -0
  252. package/src/cli.ts +830 -0
  253. package/src/index.ts +124 -0
  254. package/src/mastra/index.ts +49 -0
  255. package/src/mastra/memory.ts +99 -0
  256. package/src/mastra/public/workspace/plan.md +115 -0
  257. package/src/mastra/public/workspace/research/react-tailwind/skill.md +47 -0
  258. package/src/processors/index.ts +170 -0
  259. package/src/processors/semantic-recall.ts +277 -0
  260. package/src/processors/tool-search.ts +46 -0
  261. package/src/skills/dynamic/skill-generator.ts +568 -0
  262. package/src/tools/agent-delegation-tools.ts +301 -0
  263. package/src/tools/browser-tools.ts +792 -0
  264. package/src/tools/dynamic/registry.ts +144 -0
  265. package/src/tools/dynamic/tool-generator.ts +406 -0
  266. package/src/tools/extended-tools.ts +498 -0
  267. package/src/tools/library/calendar/index.ts +172 -0
  268. package/src/tools/podman-workspace-mcp-cli.ts +14 -0
  269. package/src/tools/podman-workspace-mcp.ts +1290 -0
  270. package/src/tools/podman-workspace.ts +858 -0
  271. package/src/tools/telegram-file-tools.ts +320 -0
  272. package/src/tools/tool-registry.ts +233 -0
  273. package/src/tools/web-tools.ts +461 -0
  274. package/src/tools/whatsapp-autoreply-tools.ts +616 -0
  275. package/src/tools/whatsapp-tools.ts +602 -0
  276. package/src/utils/logger.ts +368 -0
  277. package/src/utils/model-config.ts +437 -0
  278. package/src/utils/semantic-memory.ts +230 -0
  279. package/src/utils/system.ts +25 -0
  280. package/src/utils/telegram-auth.ts +201 -0
  281. package/src/utils/telegram.ts +1847 -0
  282. package/src/utils/whatsapp-client.ts +808 -0
  283. package/src/workflows/planner-workflow.ts +178 -0
  284. package/src/workflows/skill-builder-workflow.ts +175 -0
  285. package/src/workspace/index.ts +69 -0
  286. package/tsconfig.json +22 -0
  287. package/view-logs.sh +116 -0
  288. package/whatsapp-session.sh +197 -0
@@ -0,0 +1,368 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+ import { fileURLToPath } from "url";
4
+
5
+ const __filename = fileURLToPath(import.meta.url);
6
+ const __dirname = path.dirname(__filename);
7
+
8
+ export enum LogLevel {
9
+ DEBUG = 0,
10
+ INFO = 1,
11
+ WARN = 2,
12
+ ERROR = 3,
13
+ }
14
+
15
+ export interface LogEntry {
16
+ timestamp: string;
17
+ level: LogLevel;
18
+ category: string;
19
+ message: string;
20
+ data?: any;
21
+ sessionId?: string;
22
+ userId?: number;
23
+ }
24
+
25
+ export interface LoggerConfig {
26
+ level: LogLevel;
27
+ logFile: string;
28
+ enableConsole: boolean;
29
+ enableFile: boolean;
30
+ maxFileSize: number; // in bytes
31
+ maxFiles: number;
32
+ }
33
+
34
+ const defaultConfig: LoggerConfig = {
35
+ level: LogLevel.DEBUG,
36
+ logFile: "./logs/sybil.log",
37
+ enableConsole: true,
38
+ enableFile: true,
39
+ maxFileSize: 10 * 1024 * 1024, // 10MB
40
+ maxFiles: 5,
41
+ };
42
+
43
+ class Logger {
44
+ private config: LoggerConfig;
45
+ private logDir: string;
46
+ private logBuffer: LogEntry[] = [];
47
+ private bufferFlushInterval: NodeJS.Timeout | null = null;
48
+
49
+ constructor(config: Partial<LoggerConfig> = {}) {
50
+ this.config = { ...defaultConfig, ...config };
51
+ this.logDir = path.dirname(this.config.logFile);
52
+ this.init();
53
+ }
54
+
55
+ private init(): void {
56
+ if (this.config.enableFile) {
57
+ try {
58
+ if (!fs.existsSync(this.logDir)) {
59
+ fs.mkdirSync(this.logDir, { recursive: true });
60
+ }
61
+ this.rotateLogs();
62
+ } catch (error) {
63
+ console.error("Failed to initialize log directory:", error);
64
+ this.config.enableFile = false;
65
+ }
66
+ }
67
+ this.bufferFlushInterval = setInterval(() => this.flush(), 5000);
68
+ }
69
+
70
+ private rotateLogs(): void {
71
+ try {
72
+ if (!fs.existsSync(this.logDir)) return;
73
+
74
+ const files = fs.readdirSync(this.logDir)
75
+ .filter(f => f.startsWith("sybil") && f.endsWith(".log"))
76
+ .map(f => ({
77
+ name: f,
78
+ path: path.join(this.logDir, f),
79
+ stats: fs.statSync(path.join(this.logDir, f)),
80
+ }))
81
+ .sort((a, b) => b.stats.mtimeMs - a.stats.mtimeMs);
82
+
83
+ if (files.length >= this.config.maxFiles) {
84
+ const toDelete = files.slice(this.config.maxFiles - 1);
85
+ for (const file of toDelete) {
86
+ try {
87
+ fs.unlinkSync(file.path);
88
+ } catch (e) {
89
+ // Ignore deletion errors
90
+ }
91
+ }
92
+ }
93
+ } catch (error) {
94
+ // Ignore rotation errors
95
+ }
96
+ }
97
+
98
+ private formatTimestamp(): string {
99
+ return new Date().toISOString();
100
+ }
101
+
102
+ private formatLevel(level: LogLevel): string {
103
+ return ["DEBUG", "INFO ", "WARN ", "ERROR"][level];
104
+ }
105
+
106
+ private formatCategory(category: string): string {
107
+ return category.length > 12 ? category.substring(0, 11) + ":" : category.padEnd(12);
108
+ }
109
+
110
+ private colorize(level: LogLevel, text: string): string {
111
+ const colors: Record<LogLevel, string> = {
112
+ [LogLevel.DEBUG]: "\x1b[90m", // Gray
113
+ [LogLevel.INFO]: "\x1b[32m", // Green
114
+ [LogLevel.WARN]: "\x1b[33m", // Yellow
115
+ [LogLevel.ERROR]: "\x1b[31m", // Red
116
+ };
117
+ return `${colors[level]}${text}\x1b[0m`;
118
+ }
119
+
120
+ private formatMessage(entry: LogEntry): string {
121
+ let msg = `[${entry.timestamp}] [${this.formatLevel(entry.level)}] [${this.formatCategory(entry.category)}]`;
122
+ if (entry.userId) msg += ` [User:${entry.userId}]`;
123
+ if (entry.sessionId) msg += ` [Session:${entry.sessionId}]`;
124
+ msg += ` ${entry.message}`;
125
+ return msg;
126
+ }
127
+
128
+ private writeToFile(entry: LogEntry): void {
129
+ if (!this.config.enableFile) return;
130
+
131
+ try {
132
+ const logPath = this.config.logFile;
133
+ if (fs.existsSync(logPath)) {
134
+ const stats = fs.statSync(logPath);
135
+ if (stats.size > this.config.maxFileSize) {
136
+ this.rotateLogs();
137
+ }
138
+ }
139
+
140
+ const line = JSON.stringify(entry) + "\n";
141
+ fs.appendFileSync(logPath, line);
142
+ } catch (error) {
143
+ // Silently fail for file writing errors
144
+ }
145
+ }
146
+
147
+ log(
148
+ level: LogLevel,
149
+ category: string,
150
+ message: string,
151
+ data?: any,
152
+ sessionId?: string,
153
+ userId?: number
154
+ ): void {
155
+ if (level < this.config.level) return;
156
+
157
+ const entry: LogEntry = {
158
+ timestamp: this.formatTimestamp(),
159
+ level,
160
+ category,
161
+ message,
162
+ data: data !== undefined ? this.sanitizeData(data) : undefined,
163
+ sessionId,
164
+ userId,
165
+ };
166
+
167
+ this.logBuffer.push(entry);
168
+
169
+ if (this.config.enableConsole) {
170
+ const formatted = this.formatMessage(entry);
171
+ const colored = this.colorize(level, formatted);
172
+
173
+ if (entry.data) {
174
+ console.log(colored);
175
+ console.log(this.colorize(level, ` Data: ${JSON.stringify(entry.data, null, 2)}`));
176
+ } else {
177
+ console.log(colored);
178
+ }
179
+ }
180
+
181
+ this.writeToFile(entry);
182
+ }
183
+
184
+ private sanitizeData(data: any): any {
185
+ if (data === null || data === undefined) return data;
186
+ if (typeof data !== "object") return data;
187
+
188
+ const sanitized: any = Array.isArray(data) ? [] : {};
189
+ const seen = new Set();
190
+
191
+ const sanitize = (obj: any, depth: number = 0): any => {
192
+ if (depth > 5) return "[MAX_DEPTH]";
193
+ if (seen.has(obj)) return "[CIRCULAR]";
194
+ if (typeof obj !== "object" || obj === null) return obj;
195
+
196
+ seen.add(obj);
197
+
198
+ if (Array.isArray(obj)) {
199
+ return obj.map(item => sanitize(item, depth + 1));
200
+ }
201
+
202
+ const result: any = {};
203
+ for (const [key, value] of Object.entries(obj)) {
204
+ if (typeof value === "string" && value.length > 1000) {
205
+ result[key] = value.substring(0, 1000) + "...[TRUNCATED]";
206
+ } else if (typeof value === "object" && value !== null) {
207
+ result[key] = sanitize(value, depth + 1);
208
+ } else {
209
+ result[key] = value;
210
+ }
211
+ }
212
+ return result;
213
+ };
214
+
215
+ return sanitize(data);
216
+ }
217
+
218
+ debug(category: string, message: string, data?: any, sessionId?: string, userId?: number): void {
219
+ this.log(LogLevel.DEBUG, category, message, data, sessionId, userId);
220
+ }
221
+
222
+ info(category: string, message: string, data?: any, sessionId?: string, userId?: number): void {
223
+ this.log(LogLevel.INFO, category, message, data, sessionId, userId);
224
+ }
225
+
226
+ warn(category: string, message: string, data?: any, sessionId?: string, userId?: number): void {
227
+ this.log(LogLevel.WARN, category, message, data, sessionId, userId);
228
+ }
229
+
230
+ error(category: string, message: string, data?: any, sessionId?: string, userId?: number): void {
231
+ this.log(LogLevel.ERROR, category, message, data, sessionId, userId);
232
+ }
233
+
234
+ toolCall(toolName: string, params: any, sessionId?: string, userId?: number): void {
235
+ this.info("TOOL_CALL", `Tool called: ${toolName}`, {
236
+ parameters: params,
237
+ }, sessionId, userId);
238
+ }
239
+
240
+ toolResult(toolName: string, success: boolean, result: any, duration: number, sessionId?: string, userId?: number): void {
241
+ const level = success ? LogLevel.INFO : LogLevel.ERROR;
242
+ this.log(level, "TOOL_RESULT", `Tool ${toolName} ${success ? "succeeded" : "failed"}`, {
243
+ success,
244
+ duration: `${duration}ms`,
245
+ result: result,
246
+ }, sessionId, userId);
247
+ }
248
+
249
+ agentDecision(decision: string, reasoning: string, sessionId?: string, userId?: number): void {
250
+ this.info("AGENT", `Decision: ${decision}`, {
251
+ reasoning,
252
+ }, sessionId, userId);
253
+ }
254
+
255
+ memoryOperation(operation: string, details: any, sessionId?: string): void {
256
+ this.debug("MEMORY", `Operation: ${operation}`, details, sessionId);
257
+ }
258
+
259
+ messageReceived(source: string, userId: number, messagePreview: string): void {
260
+ this.info("MESSAGE", `[${source}] Message from user ${userId}`, {
261
+ preview: messagePreview.substring(0, 100),
262
+ }, undefined, userId);
263
+ }
264
+
265
+ messageSent(destination: string, recipientId: number, messagePreview: string): void {
266
+ this.info("MESSAGE", `Sent to [${destination}] user ${recipientId}`, {
267
+ preview: messagePreview.substring(0, 100),
268
+ }, undefined, recipientId);
269
+ }
270
+
271
+ workflowStart(workflowName: string, input: any, sessionId?: string): void {
272
+ this.info("WORKFLOW", `Started: ${workflowName}`, { input }, sessionId);
273
+ }
274
+
275
+ workflowStep(workflowName: string, step: string, details: any, sessionId?: string): void {
276
+ this.debug("WORKFLOW", `[${workflowName}] Step: ${step}`, details, sessionId);
277
+ }
278
+
279
+ workflowComplete(workflowName: string, result: any, duration: number, sessionId?: string): void {
280
+ this.info("WORKFLOW", `Completed: ${workflowName}`, {
281
+ duration: `${duration}ms`,
282
+ result,
283
+ }, sessionId);
284
+ }
285
+
286
+ whatsappEvent(event: string, details: any): void {
287
+ this.info("WHATSAPP", `Event: ${event}`, details);
288
+ }
289
+
290
+ autoReplyEvent(event: string, details: any): void {
291
+ this.info("AUTO_REPLY", `Event: ${event}`, details);
292
+ }
293
+
294
+ flush(): void {
295
+ // Empty buffer for file writing if needed
296
+ this.logBuffer = [];
297
+ }
298
+
299
+ shutdown(): void {
300
+ if (this.bufferFlushInterval) {
301
+ clearInterval(this.bufferFlushInterval);
302
+ }
303
+ this.flush();
304
+ }
305
+
306
+ getRecentLogs(count: number = 100): LogEntry[] {
307
+ if (!this.config.enableFile) return [];
308
+
309
+ try {
310
+ const logPath = this.config.logFile;
311
+ if (!fs.existsSync(logPath)) return [];
312
+
313
+ const content = fs.readFileSync(logPath, "utf-8");
314
+ const lines = content.trim().split("\n").filter(Boolean);
315
+ return lines.slice(-count).map(line => JSON.parse(line));
316
+ } catch (error) {
317
+ return [];
318
+ }
319
+ }
320
+
321
+ getLogsByCategory(category: string, count: number = 100): LogEntry[] {
322
+ const logs = this.getRecentLogs(1000);
323
+ return logs.filter(log => log.category.startsWith(category)).slice(-count);
324
+ }
325
+
326
+ getLogsByUser(userId: number, count: number = 100): LogEntry[] {
327
+ const logs = this.getRecentLogs(1000);
328
+ return logs.filter(log => log.userId === userId).slice(-count);
329
+ }
330
+
331
+ searchLogs(query: string): LogEntry[] {
332
+ const logs = this.getRecentLogs(1000);
333
+ const lowerQuery = query.toLowerCase();
334
+ return logs.filter(log =>
335
+ log.message.toLowerCase().includes(lowerQuery) ||
336
+ log.category.toLowerCase().includes(lowerQuery)
337
+ );
338
+ }
339
+ }
340
+
341
+ export const logger = new Logger();
342
+
343
+ export function createSessionLogger(sessionId: string, userId?: number): Logger {
344
+ return {
345
+ debug: (category, message, data) => logger.debug(category, message, data, sessionId, userId),
346
+ info: (category, message, data) => logger.info(category, message, data, sessionId, userId),
347
+ warn: (category, message, data) => logger.warn(category, message, data, sessionId, userId),
348
+ error: (category, message, data) => logger.error(category, message, data, sessionId, userId),
349
+ toolCall: (toolName, params) => logger.toolCall(toolName, params, sessionId, userId),
350
+ toolResult: (toolName, success, result, duration) => logger.toolResult(toolName, success, result, duration, sessionId, userId),
351
+ agentDecision: (decision, reasoning) => logger.agentDecision(decision, reasoning, sessionId, userId),
352
+ memoryOperation: (operation, details) => logger.memoryOperation(operation, details, sessionId),
353
+ messageReceived: (source, uid, msg) => logger.messageReceived(source, uid, msg),
354
+ messageSent: (dest, rid, msg) => logger.messageSent(dest, rid, msg),
355
+ workflowStart: (name, input) => logger.workflowStart(name, input, sessionId),
356
+ workflowStep: (name, step, details) => logger.workflowStep(name, step, details, sessionId),
357
+ workflowComplete: (name, result, duration) => logger.workflowComplete(name, result, duration, sessionId),
358
+ whatsappEvent: (event, details) => logger.whatsappEvent(event, details),
359
+ autoReplyEvent: (event, details) => logger.autoReplyEvent(event, details),
360
+ log: (level, category, message, data) => logger.log(level, category, message, data, sessionId, userId),
361
+ flush: () => logger.flush(),
362
+ shutdown: () => logger.shutdown(),
363
+ getRecentLogs: (count) => logger.getRecentLogs(count),
364
+ getLogsByCategory: (cat, count) => logger.getLogsByCategory(cat, count),
365
+ getLogsByUser: (uid, count) => logger.getLogsByUser(uid, count),
366
+ searchLogs: (query) => logger.searchLogs(query),
367
+ } as Logger;
368
+ }