seclaw-agent 0.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 (219) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +668 -0
  3. package/SECURITY.md +253 -0
  4. package/assets/logo.png +0 -0
  5. package/dist/agent/context.d.ts +37 -0
  6. package/dist/agent/context.d.ts.map +1 -0
  7. package/dist/agent/context.js +211 -0
  8. package/dist/agent/context.js.map +1 -0
  9. package/dist/agent/docker_sandbox.d.ts +41 -0
  10. package/dist/agent/docker_sandbox.d.ts.map +1 -0
  11. package/dist/agent/docker_sandbox.js +239 -0
  12. package/dist/agent/docker_sandbox.js.map +1 -0
  13. package/dist/agent/loop.d.ts +86 -0
  14. package/dist/agent/loop.d.ts.map +1 -0
  15. package/dist/agent/loop.js +858 -0
  16. package/dist/agent/loop.js.map +1 -0
  17. package/dist/agent/memory.d.ts +21 -0
  18. package/dist/agent/memory.d.ts.map +1 -0
  19. package/dist/agent/memory.js +128 -0
  20. package/dist/agent/memory.js.map +1 -0
  21. package/dist/agent/security/execution_audit.d.ts +17 -0
  22. package/dist/agent/security/execution_audit.d.ts.map +1 -0
  23. package/dist/agent/security/execution_audit.js +126 -0
  24. package/dist/agent/security/execution_audit.js.map +1 -0
  25. package/dist/agent/security/input_validation/entity.d.ts +57 -0
  26. package/dist/agent/security/input_validation/entity.d.ts.map +1 -0
  27. package/dist/agent/security/input_validation/entity.js +121 -0
  28. package/dist/agent/security/input_validation/entity.js.map +1 -0
  29. package/dist/agent/security/input_validation/index.d.ts +114 -0
  30. package/dist/agent/security/input_validation/index.d.ts.map +1 -0
  31. package/dist/agent/security/input_validation/index.js +971 -0
  32. package/dist/agent/security/input_validation/index.js.map +1 -0
  33. package/dist/agent/security/input_validation/lattice.d.ts +33 -0
  34. package/dist/agent/security/input_validation/lattice.d.ts.map +1 -0
  35. package/dist/agent/security/input_validation/lattice.js +61 -0
  36. package/dist/agent/security/input_validation/lattice.js.map +1 -0
  37. package/dist/agent/security/input_validation/program_graph.d.ts +51 -0
  38. package/dist/agent/security/input_validation/program_graph.d.ts.map +1 -0
  39. package/dist/agent/security/input_validation/program_graph.js +285 -0
  40. package/dist/agent/security/input_validation/program_graph.js.map +1 -0
  41. package/dist/agent/security/input_validation/security_policy.d.ts +29 -0
  42. package/dist/agent/security/input_validation/security_policy.d.ts.map +1 -0
  43. package/dist/agent/security/input_validation/security_policy.js +256 -0
  44. package/dist/agent/security/input_validation/security_policy.js.map +1 -0
  45. package/dist/agent/security/memory_audit.d.ts +14 -0
  46. package/dist/agent/security/memory_audit.d.ts.map +1 -0
  47. package/dist/agent/security/memory_audit.js +126 -0
  48. package/dist/agent/security/memory_audit.js.map +1 -0
  49. package/dist/agent/security/skill_audit.d.ts +15 -0
  50. package/dist/agent/security/skill_audit.d.ts.map +1 -0
  51. package/dist/agent/security/skill_audit.js +112 -0
  52. package/dist/agent/security/skill_audit.js.map +1 -0
  53. package/dist/agent/security/snapshot_and_rollback/base.d.ts +10 -0
  54. package/dist/agent/security/snapshot_and_rollback/base.d.ts.map +1 -0
  55. package/dist/agent/security/snapshot_and_rollback/base.js +10 -0
  56. package/dist/agent/security/snapshot_and_rollback/base.js.map +1 -0
  57. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.d.ts +52 -0
  58. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.d.ts.map +1 -0
  59. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.js +358 -0
  60. package/dist/agent/security/snapshot_and_rollback/docker_snapshot.js.map +1 -0
  61. package/dist/agent/security/snapshot_and_rollback/index.d.ts +7 -0
  62. package/dist/agent/security/snapshot_and_rollback/index.d.ts.map +1 -0
  63. package/dist/agent/security/snapshot_and_rollback/index.js +450 -0
  64. package/dist/agent/security/snapshot_and_rollback/index.js.map +1 -0
  65. package/dist/agent/skills.d.ts +35 -0
  66. package/dist/agent/skills.d.ts.map +1 -0
  67. package/dist/agent/skills.js +235 -0
  68. package/dist/agent/skills.js.map +1 -0
  69. package/dist/agent/subagent.d.ts +39 -0
  70. package/dist/agent/subagent.d.ts.map +1 -0
  71. package/dist/agent/subagent.js +151 -0
  72. package/dist/agent/subagent.js.map +1 -0
  73. package/dist/agent/tools/base.d.ts +32 -0
  74. package/dist/agent/tools/base.d.ts.map +1 -0
  75. package/dist/agent/tools/base.js +91 -0
  76. package/dist/agent/tools/base.js.map +1 -0
  77. package/dist/agent/tools/cron.d.ts +46 -0
  78. package/dist/agent/tools/cron.d.ts.map +1 -0
  79. package/dist/agent/tools/cron.js +95 -0
  80. package/dist/agent/tools/cron.js.map +1 -0
  81. package/dist/agent/tools/filesystem.d.ts +102 -0
  82. package/dist/agent/tools/filesystem.d.ts.map +1 -0
  83. package/dist/agent/tools/filesystem.js +257 -0
  84. package/dist/agent/tools/filesystem.js.map +1 -0
  85. package/dist/agent/tools/message.d.ts +40 -0
  86. package/dist/agent/tools/message.d.ts.map +1 -0
  87. package/dist/agent/tools/message.js +55 -0
  88. package/dist/agent/tools/message.js.map +1 -0
  89. package/dist/agent/tools/registry.d.ts +16 -0
  90. package/dist/agent/tools/registry.d.ts.map +1 -0
  91. package/dist/agent/tools/registry.js +47 -0
  92. package/dist/agent/tools/registry.js.map +1 -0
  93. package/dist/agent/tools/shell.d.ts +40 -0
  94. package/dist/agent/tools/shell.d.ts.map +1 -0
  95. package/dist/agent/tools/shell.js +166 -0
  96. package/dist/agent/tools/shell.js.map +1 -0
  97. package/dist/agent/tools/spawn.d.ts +30 -0
  98. package/dist/agent/tools/spawn.d.ts.map +1 -0
  99. package/dist/agent/tools/spawn.js +50 -0
  100. package/dist/agent/tools/spawn.js.map +1 -0
  101. package/dist/agent/tools/web.d.ts +59 -0
  102. package/dist/agent/tools/web.d.ts.map +1 -0
  103. package/dist/agent/tools/web.js +167 -0
  104. package/dist/agent/tools/web.js.map +1 -0
  105. package/dist/bus/events.d.ts +31 -0
  106. package/dist/bus/events.d.ts.map +1 -0
  107. package/dist/bus/events.js +28 -0
  108. package/dist/bus/events.js.map +1 -0
  109. package/dist/bus/queue.d.ts +32 -0
  110. package/dist/bus/queue.d.ts.map +1 -0
  111. package/dist/bus/queue.js +104 -0
  112. package/dist/bus/queue.js.map +1 -0
  113. package/dist/channels/base.d.ts +25 -0
  114. package/dist/channels/base.d.ts.map +1 -0
  115. package/dist/channels/base.js +54 -0
  116. package/dist/channels/base.js.map +1 -0
  117. package/dist/channels/dingtalk.d.ts +31 -0
  118. package/dist/channels/dingtalk.d.ts.map +1 -0
  119. package/dist/channels/dingtalk.js +177 -0
  120. package/dist/channels/dingtalk.js.map +1 -0
  121. package/dist/channels/discord.d.ts +30 -0
  122. package/dist/channels/discord.d.ts.map +1 -0
  123. package/dist/channels/discord.js +197 -0
  124. package/dist/channels/discord.js.map +1 -0
  125. package/dist/channels/email.d.ts +41 -0
  126. package/dist/channels/email.d.ts.map +1 -0
  127. package/dist/channels/email.js +210 -0
  128. package/dist/channels/email.js.map +1 -0
  129. package/dist/channels/feishu.d.ts +32 -0
  130. package/dist/channels/feishu.d.ts.map +1 -0
  131. package/dist/channels/feishu.js +109 -0
  132. package/dist/channels/feishu.js.map +1 -0
  133. package/dist/channels/manager.d.ts +24 -0
  134. package/dist/channels/manager.d.ts.map +1 -0
  135. package/dist/channels/manager.js +205 -0
  136. package/dist/channels/manager.js.map +1 -0
  137. package/dist/channels/mochat.d.ts +38 -0
  138. package/dist/channels/mochat.d.ts.map +1 -0
  139. package/dist/channels/mochat.js +201 -0
  140. package/dist/channels/mochat.js.map +1 -0
  141. package/dist/channels/qq.d.ts +40 -0
  142. package/dist/channels/qq.d.ts.map +1 -0
  143. package/dist/channels/qq.js +280 -0
  144. package/dist/channels/qq.js.map +1 -0
  145. package/dist/channels/slack.d.ts +27 -0
  146. package/dist/channels/slack.d.ts.map +1 -0
  147. package/dist/channels/slack.js +118 -0
  148. package/dist/channels/slack.js.map +1 -0
  149. package/dist/channels/telegram.d.ts +31 -0
  150. package/dist/channels/telegram.d.ts.map +1 -0
  151. package/dist/channels/telegram.js +218 -0
  152. package/dist/channels/telegram.js.map +1 -0
  153. package/dist/channels/whatsapp.d.ts +29 -0
  154. package/dist/channels/whatsapp.d.ts.map +1 -0
  155. package/dist/channels/whatsapp.js +117 -0
  156. package/dist/channels/whatsapp.js.map +1 -0
  157. package/dist/cli/commands.d.ts +8 -0
  158. package/dist/cli/commands.d.ts.map +1 -0
  159. package/dist/cli/commands.js +537 -0
  160. package/dist/cli/commands.js.map +1 -0
  161. package/dist/config/loader.d.ts +24 -0
  162. package/dist/config/loader.d.ts.map +1 -0
  163. package/dist/config/loader.js +182 -0
  164. package/dist/config/loader.js.map +1 -0
  165. package/dist/config/schema.d.ts +2921 -0
  166. package/dist/config/schema.d.ts.map +1 -0
  167. package/dist/config/schema.js +257 -0
  168. package/dist/config/schema.js.map +1 -0
  169. package/dist/cron/service.d.ts +38 -0
  170. package/dist/cron/service.d.ts.map +1 -0
  171. package/dist/cron/service.js +336 -0
  172. package/dist/cron/service.js.map +1 -0
  173. package/dist/cron/types.d.ts +46 -0
  174. package/dist/cron/types.d.ts.map +1 -0
  175. package/dist/cron/types.js +6 -0
  176. package/dist/cron/types.js.map +1 -0
  177. package/dist/heartbeat/service.d.ts +26 -0
  178. package/dist/heartbeat/service.d.ts.map +1 -0
  179. package/dist/heartbeat/service.js +142 -0
  180. package/dist/heartbeat/service.js.map +1 -0
  181. package/dist/index.d.ts +7 -0
  182. package/dist/index.d.ts.map +1 -0
  183. package/dist/index.js +14 -0
  184. package/dist/index.js.map +1 -0
  185. package/dist/providers/base.d.ts +38 -0
  186. package/dist/providers/base.d.ts.map +1 -0
  187. package/dist/providers/base.js +21 -0
  188. package/dist/providers/base.js.map +1 -0
  189. package/dist/providers/litellm_provider.d.ts +35 -0
  190. package/dist/providers/litellm_provider.d.ts.map +1 -0
  191. package/dist/providers/litellm_provider.js +205 -0
  192. package/dist/providers/litellm_provider.js.map +1 -0
  193. package/dist/providers/registry.d.ts +44 -0
  194. package/dist/providers/registry.d.ts.map +1 -0
  195. package/dist/providers/registry.js +252 -0
  196. package/dist/providers/registry.js.map +1 -0
  197. package/dist/providers/transcription.d.ts +10 -0
  198. package/dist/providers/transcription.d.ts.map +1 -0
  199. package/dist/providers/transcription.js +83 -0
  200. package/dist/providers/transcription.js.map +1 -0
  201. package/dist/session/manager.d.ts +35 -0
  202. package/dist/session/manager.d.ts.map +1 -0
  203. package/dist/session/manager.js +193 -0
  204. package/dist/session/manager.js.map +1 -0
  205. package/dist/utils/helpers.d.ts +15 -0
  206. package/dist/utils/helpers.d.ts.map +1 -0
  207. package/dist/utils/helpers.js +100 -0
  208. package/dist/utils/helpers.js.map +1 -0
  209. package/dist/utils/logger.d.ts +7 -0
  210. package/dist/utils/logger.d.ts.map +1 -0
  211. package/dist/utils/logger.js +25 -0
  212. package/dist/utils/logger.js.map +1 -0
  213. package/package.json +58 -0
  214. package/templates/AGENTS.md +51 -0
  215. package/templates/HEARTBEAT.md +16 -0
  216. package/templates/SOUL.md +36 -0
  217. package/templates/TOOLS.md +150 -0
  218. package/templates/USER.md +17 -0
  219. package/templates/memory/MEMORY.md +23 -0
@@ -0,0 +1,44 @@
1
+ /**
2
+ * Provider Registry
3
+ *
4
+ * Single source of truth for LLM provider metadata.
5
+ * Order matters — controls match priority and fallback. Gateways first.
6
+ */
7
+ export interface ProviderSpec {
8
+ /** Config field name, e.g. "dashscope" */
9
+ name: string;
10
+ /** Model-name keywords for matching (lowercase) */
11
+ keywords: readonly string[];
12
+ /** LiteLLM / OpenAI env var key */
13
+ envKey: string;
14
+ /** Shown in `seclaw status` */
15
+ displayName: string;
16
+ /** Prefix applied to model, e.g. "dashscope" → "dashscope/{model}" */
17
+ litellmPrefix: string;
18
+ /** Don't prefix if model already starts with these */
19
+ skipPrefixes: readonly string[];
20
+ /** Extra env vars as [envName, template] pairs */
21
+ envExtras: readonly [string, string][];
22
+ /** Routes any model (OpenRouter, AiHubMix) */
23
+ isGateway: boolean;
24
+ /** Local deployment (vLLM, Ollama) */
25
+ isLocal: boolean;
26
+ /** Match by api_key prefix, e.g. "sk-or-" */
27
+ detectByKeyPrefix: string;
28
+ /** Match substring in api_base URL */
29
+ detectByBaseKeyword: string;
30
+ /** Fallback base URL */
31
+ defaultApiBase: string;
32
+ /** Strip "provider/" before re-prefixing */
33
+ stripModelPrefix: boolean;
34
+ /** Per-model param overrides: [pattern, overrides][] */
35
+ modelOverrides: readonly [string, Record<string, unknown>][];
36
+ }
37
+ export declare const PROVIDERS: readonly ProviderSpec[];
38
+ /** Match a standard provider by model-name keyword. Skips gateways/local. */
39
+ export declare function findByModel(model: string): ProviderSpec | undefined;
40
+ /** Detect gateway/local provider. */
41
+ export declare function findGateway(providerName?: string | null, apiKey?: string | null, apiBase?: string | null): ProviderSpec | undefined;
42
+ /** Find a provider spec by config field name, e.g. "dashscope" */
43
+ export declare function findByName(name: string): ProviderSpec | undefined;
44
+ //# sourceMappingURL=registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/providers/registry.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,WAAW,YAAY;IAC3B,0CAA0C;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,mDAAmD;IACnD,QAAQ,EAAE,SAAS,MAAM,EAAE,CAAC;IAC5B,mCAAmC;IACnC,MAAM,EAAE,MAAM,CAAC;IACf,+BAA+B;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,sEAAsE;IACtE,aAAa,EAAE,MAAM,CAAC;IACtB,sDAAsD;IACtD,YAAY,EAAE,SAAS,MAAM,EAAE,CAAC;IAChC,kDAAkD;IAClD,SAAS,EAAE,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC;IACvC,8CAA8C;IAC9C,SAAS,EAAE,OAAO,CAAC;IACnB,sCAAsC;IACtC,OAAO,EAAE,OAAO,CAAC;IACjB,6CAA6C;IAC7C,iBAAiB,EAAE,MAAM,CAAC;IAC1B,sCAAsC;IACtC,mBAAmB,EAAE,MAAM,CAAC;IAC5B,wBAAwB;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,4CAA4C;IAC5C,gBAAgB,EAAE,OAAO,CAAC;IAC1B,wDAAwD;IACxD,cAAc,EAAE,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC;CAC9D;AAUD,eAAO,MAAM,SAAS,EAAE,SAAS,YAAY,EAoNnC,CAAC;AAMX,6EAA6E;AAC7E,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS,CAOnE;AAED,qCAAqC;AACrC,wBAAgB,WAAW,CACzB,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,EAC5B,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,EACtB,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,GACtB,YAAY,GAAG,SAAS,CAc1B;AAED,kEAAkE;AAClE,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS,CAEjE"}
@@ -0,0 +1,252 @@
1
+ "use strict";
2
+ /**
3
+ * Provider Registry
4
+ *
5
+ * Single source of truth for LLM provider metadata.
6
+ * Order matters — controls match priority and fallback. Gateways first.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.PROVIDERS = void 0;
10
+ exports.findByModel = findByModel;
11
+ exports.findGateway = findGateway;
12
+ exports.findByName = findByName;
13
+ function spec(s) {
14
+ return s;
15
+ }
16
+ // ---------------------------------------------------------------------------
17
+ // PROVIDERS — the registry. Order = priority. Gateways first.
18
+ // ---------------------------------------------------------------------------
19
+ exports.PROVIDERS = [
20
+ // === Gateways ============================================================
21
+ spec({
22
+ name: "openrouter",
23
+ keywords: ["openrouter"],
24
+ envKey: "OPENROUTER_API_KEY",
25
+ displayName: "OpenRouter",
26
+ litellmPrefix: "openrouter",
27
+ skipPrefixes: [],
28
+ envExtras: [],
29
+ isGateway: true,
30
+ isLocal: false,
31
+ detectByKeyPrefix: "sk-or-",
32
+ detectByBaseKeyword: "openrouter",
33
+ defaultApiBase: "https://openrouter.ai/api/v1",
34
+ stripModelPrefix: false,
35
+ modelOverrides: [],
36
+ }),
37
+ spec({
38
+ name: "aihubmix",
39
+ keywords: ["aihubmix"],
40
+ envKey: "OPENAI_API_KEY",
41
+ displayName: "AiHubMix",
42
+ litellmPrefix: "openai",
43
+ skipPrefixes: [],
44
+ envExtras: [],
45
+ isGateway: true,
46
+ isLocal: false,
47
+ detectByKeyPrefix: "",
48
+ detectByBaseKeyword: "aihubmix",
49
+ defaultApiBase: "https://aihubmix.com/v1",
50
+ stripModelPrefix: true,
51
+ modelOverrides: [],
52
+ }),
53
+ // === Standard providers ==================================================
54
+ spec({
55
+ name: "anthropic",
56
+ keywords: ["anthropic", "claude"],
57
+ envKey: "ANTHROPIC_API_KEY",
58
+ displayName: "Anthropic",
59
+ litellmPrefix: "",
60
+ skipPrefixes: [],
61
+ envExtras: [],
62
+ isGateway: false,
63
+ isLocal: false,
64
+ detectByKeyPrefix: "",
65
+ detectByBaseKeyword: "",
66
+ defaultApiBase: "",
67
+ stripModelPrefix: false,
68
+ modelOverrides: [],
69
+ }),
70
+ spec({
71
+ name: "openai",
72
+ keywords: ["openai", "gpt"],
73
+ envKey: "OPENAI_API_KEY",
74
+ displayName: "OpenAI",
75
+ litellmPrefix: "",
76
+ skipPrefixes: [],
77
+ envExtras: [],
78
+ isGateway: false,
79
+ isLocal: false,
80
+ detectByKeyPrefix: "",
81
+ detectByBaseKeyword: "",
82
+ defaultApiBase: "",
83
+ stripModelPrefix: false,
84
+ modelOverrides: [],
85
+ }),
86
+ spec({
87
+ name: "deepseek",
88
+ keywords: ["deepseek"],
89
+ envKey: "DEEPSEEK_API_KEY",
90
+ displayName: "DeepSeek",
91
+ litellmPrefix: "deepseek",
92
+ skipPrefixes: ["deepseek/"],
93
+ envExtras: [],
94
+ isGateway: false,
95
+ isLocal: false,
96
+ detectByKeyPrefix: "",
97
+ detectByBaseKeyword: "",
98
+ defaultApiBase: "",
99
+ stripModelPrefix: false,
100
+ modelOverrides: [],
101
+ }),
102
+ spec({
103
+ name: "gemini",
104
+ keywords: ["gemini"],
105
+ envKey: "GEMINI_API_KEY",
106
+ displayName: "Gemini",
107
+ litellmPrefix: "gemini",
108
+ skipPrefixes: ["gemini/"],
109
+ envExtras: [],
110
+ isGateway: false,
111
+ isLocal: false,
112
+ detectByKeyPrefix: "",
113
+ detectByBaseKeyword: "",
114
+ defaultApiBase: "",
115
+ stripModelPrefix: false,
116
+ modelOverrides: [],
117
+ }),
118
+ spec({
119
+ name: "zhipu",
120
+ keywords: ["zhipu", "glm", "zai"],
121
+ envKey: "ZAI_API_KEY",
122
+ displayName: "Zhipu AI",
123
+ litellmPrefix: "zai",
124
+ skipPrefixes: ["zhipu/", "zai/", "openrouter/", "hosted_vllm/"],
125
+ envExtras: [["ZHIPUAI_API_KEY", "{api_key}"]],
126
+ isGateway: false,
127
+ isLocal: false,
128
+ detectByKeyPrefix: "",
129
+ detectByBaseKeyword: "",
130
+ defaultApiBase: "",
131
+ stripModelPrefix: false,
132
+ modelOverrides: [],
133
+ }),
134
+ spec({
135
+ name: "dashscope",
136
+ keywords: ["qwen", "dashscope"],
137
+ envKey: "DASHSCOPE_API_KEY",
138
+ displayName: "DashScope",
139
+ litellmPrefix: "dashscope",
140
+ skipPrefixes: ["dashscope/", "openrouter/"],
141
+ envExtras: [],
142
+ isGateway: false,
143
+ isLocal: false,
144
+ detectByKeyPrefix: "",
145
+ detectByBaseKeyword: "",
146
+ defaultApiBase: "",
147
+ stripModelPrefix: false,
148
+ modelOverrides: [],
149
+ }),
150
+ spec({
151
+ name: "moonshot",
152
+ keywords: ["moonshot", "kimi"],
153
+ envKey: "MOONSHOT_API_KEY",
154
+ displayName: "Moonshot",
155
+ litellmPrefix: "moonshot",
156
+ skipPrefixes: ["moonshot/", "openrouter/"],
157
+ envExtras: [["MOONSHOT_API_BASE", "{api_base}"]],
158
+ isGateway: false,
159
+ isLocal: false,
160
+ detectByKeyPrefix: "",
161
+ detectByBaseKeyword: "",
162
+ defaultApiBase: "https://api.moonshot.ai/v1",
163
+ stripModelPrefix: false,
164
+ modelOverrides: [["kimi-k2.5", { temperature: 1.0 }]],
165
+ }),
166
+ spec({
167
+ name: "minimax",
168
+ keywords: ["minimax"],
169
+ envKey: "MINIMAX_API_KEY",
170
+ displayName: "MiniMax",
171
+ litellmPrefix: "minimax",
172
+ skipPrefixes: ["minimax/", "openrouter/"],
173
+ envExtras: [],
174
+ isGateway: false,
175
+ isLocal: false,
176
+ detectByKeyPrefix: "",
177
+ detectByBaseKeyword: "",
178
+ defaultApiBase: "https://api.minimax.io/v1",
179
+ stripModelPrefix: false,
180
+ modelOverrides: [],
181
+ }),
182
+ // === Local deployment ====================================================
183
+ spec({
184
+ name: "vllm",
185
+ keywords: ["vllm"],
186
+ envKey: "HOSTED_VLLM_API_KEY",
187
+ displayName: "vLLM/Local",
188
+ litellmPrefix: "hosted_vllm",
189
+ skipPrefixes: [],
190
+ envExtras: [],
191
+ isGateway: false,
192
+ isLocal: true,
193
+ detectByKeyPrefix: "",
194
+ detectByBaseKeyword: "",
195
+ defaultApiBase: "",
196
+ stripModelPrefix: false,
197
+ modelOverrides: [],
198
+ }),
199
+ // === Auxiliary ===========================================================
200
+ spec({
201
+ name: "groq",
202
+ keywords: ["groq"],
203
+ envKey: "GROQ_API_KEY",
204
+ displayName: "Groq",
205
+ litellmPrefix: "groq",
206
+ skipPrefixes: ["groq/"],
207
+ envExtras: [],
208
+ isGateway: false,
209
+ isLocal: false,
210
+ detectByKeyPrefix: "",
211
+ detectByBaseKeyword: "",
212
+ defaultApiBase: "",
213
+ stripModelPrefix: false,
214
+ modelOverrides: [],
215
+ }),
216
+ ];
217
+ // ---------------------------------------------------------------------------
218
+ // Lookup helpers
219
+ // ---------------------------------------------------------------------------
220
+ /** Match a standard provider by model-name keyword. Skips gateways/local. */
221
+ function findByModel(model) {
222
+ const modelLower = model.toLowerCase();
223
+ for (const s of exports.PROVIDERS) {
224
+ if (s.isGateway || s.isLocal)
225
+ continue;
226
+ if (s.keywords.some((kw) => modelLower.includes(kw)))
227
+ return s;
228
+ }
229
+ return undefined;
230
+ }
231
+ /** Detect gateway/local provider. */
232
+ function findGateway(providerName, apiKey, apiBase) {
233
+ // 1. Direct match by config key
234
+ if (providerName) {
235
+ const s = findByName(providerName);
236
+ if (s && (s.isGateway || s.isLocal))
237
+ return s;
238
+ }
239
+ // 2. Auto-detect
240
+ for (const s of exports.PROVIDERS) {
241
+ if (s.detectByKeyPrefix && apiKey?.startsWith(s.detectByKeyPrefix))
242
+ return s;
243
+ if (s.detectByBaseKeyword && apiBase?.includes(s.detectByBaseKeyword))
244
+ return s;
245
+ }
246
+ return undefined;
247
+ }
248
+ /** Find a provider spec by config field name, e.g. "dashscope" */
249
+ function findByName(name) {
250
+ return exports.PROVIDERS.find((s) => s.name === name);
251
+ }
252
+ //# sourceMappingURL=registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/providers/registry.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Voice transcription provider
3
+ */
4
+ export declare class GroqTranscriptionProvider {
5
+ private apiKey;
6
+ private apiUrl;
7
+ constructor(apiKey?: string | null);
8
+ transcribe(filePath: string): Promise<string>;
9
+ }
10
+ //# sourceMappingURL=transcription.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transcription.d.ts","sourceRoot":"","sources":["../../src/providers/transcription.ts"],"names":[],"mappings":"AAAA;;GAEG;AAQH,qBAAa,yBAAyB;IACpC,OAAO,CAAC,MAAM,CAAgB;IAC9B,OAAO,CAAC,MAAM,CAAyD;gBAE3D,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI;IAI5B,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;CA8BpD"}
@@ -0,0 +1,83 @@
1
+ "use strict";
2
+ /**
3
+ * Voice transcription provider
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ var __importDefault = (this && this.__importDefault) || function (mod) {
39
+ return (mod && mod.__esModule) ? mod : { "default": mod };
40
+ };
41
+ Object.defineProperty(exports, "__esModule", { value: true });
42
+ exports.GroqTranscriptionProvider = void 0;
43
+ const fs = __importStar(require("fs"));
44
+ const path = __importStar(require("path"));
45
+ const form_data_1 = __importDefault(require("form-data"));
46
+ const axios_1 = __importDefault(require("axios"));
47
+ const logger_1 = require("../utils/logger");
48
+ class GroqTranscriptionProvider {
49
+ apiKey;
50
+ apiUrl = "https://api.groq.com/openai/v1/audio/transcriptions";
51
+ constructor(apiKey) {
52
+ this.apiKey = apiKey ?? process.env.GROQ_API_KEY ?? null;
53
+ }
54
+ async transcribe(filePath) {
55
+ if (!this.apiKey) {
56
+ logger_1.logger.warn("Groq API key not configured for transcription");
57
+ return "";
58
+ }
59
+ if (!fs.existsSync(filePath)) {
60
+ logger_1.logger.error({ filePath }, "Audio file not found");
61
+ return "";
62
+ }
63
+ try {
64
+ const form = new form_data_1.default();
65
+ form.append("file", fs.createReadStream(filePath), path.basename(filePath));
66
+ form.append("model", "whisper-large-v3");
67
+ const response = await axios_1.default.post(this.apiUrl, form, {
68
+ headers: {
69
+ Authorization: `Bearer ${this.apiKey}`,
70
+ ...form.getHeaders(),
71
+ },
72
+ timeout: 60000,
73
+ });
74
+ return response.data?.text ?? "";
75
+ }
76
+ catch (e) {
77
+ logger_1.logger.error({ err: e }, "Groq transcription error");
78
+ return "";
79
+ }
80
+ }
81
+ }
82
+ exports.GroqTranscriptionProvider = GroqTranscriptionProvider;
83
+ //# sourceMappingURL=transcription.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transcription.js","sourceRoot":"","sources":["../../src/providers/transcription.ts"],"names":[],"mappings":";AAAA;;GAEG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEH,uCAAyB;AACzB,2CAA6B;AAC7B,0DAAiC;AACjC,kDAA0B;AAC1B,4CAAyC;AAEzC,MAAa,yBAAyB;IAC5B,MAAM,CAAgB;IACtB,MAAM,GAAG,qDAAqD,CAAC;IAEvE,YAAY,MAAsB;QAChC,IAAI,CAAC,MAAM,GAAG,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,IAAI,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,QAAgB;QAC/B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,eAAM,CAAC,IAAI,CAAC,+CAA+C,CAAC,CAAC;YAC7D,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC7B,eAAM,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,EAAE,sBAAsB,CAAC,CAAC;YACnD,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,mBAAQ,EAAE,CAAC;YAC5B,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC5E,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAAC;YAEzC,MAAM,QAAQ,GAAG,MAAM,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,EAAE;gBACnD,OAAO,EAAE;oBACP,aAAa,EAAE,UAAU,IAAI,CAAC,MAAM,EAAE;oBACtC,GAAG,IAAI,CAAC,UAAU,EAAE;iBACrB;gBACD,OAAO,EAAE,KAAK;aACf,CAAC,CAAC;YAEH,OAAO,QAAQ,CAAC,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;QACnC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,eAAM,CAAC,KAAK,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,EAAE,0BAA0B,CAAC,CAAC;YACrD,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;CACF;AAtCD,8DAsCC"}
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Session management
3
+ */
4
+ export interface Message {
5
+ role: string;
6
+ content: unknown;
7
+ timestamp?: string;
8
+ [key: string]: unknown;
9
+ }
10
+ export interface Session {
11
+ key: string;
12
+ messages: Message[];
13
+ createdAt: Date;
14
+ updatedAt: Date;
15
+ metadata: Record<string, unknown>;
16
+ lastConsolidated: number;
17
+ }
18
+ export declare function createSession(key: string): Session;
19
+ export declare function addMessage(session: Session, role: string, content: unknown, extra?: Record<string, unknown>): void;
20
+ export declare function getHistory(session: Session, maxMessages?: number): Message[];
21
+ export declare function clearSession(session: Session): void;
22
+ export declare class SessionManager {
23
+ workspace: string;
24
+ sessionsDir: string;
25
+ private _cache;
26
+ constructor(workspace: string);
27
+ private _getSessionPath;
28
+ getOrCreate(key: string): Session;
29
+ private _load;
30
+ save(session: Session): void;
31
+ invalidate(key: string): void;
32
+ delete(key: string): boolean;
33
+ listSessions(): Array<Record<string, string>>;
34
+ }
35
+ //# sourceMappingURL=manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"manager.d.ts","sourceRoot":"","sources":["../../src/session/manager.ts"],"names":[],"mappings":"AAAA;;GAEG;AAQH,MAAM,WAAW,OAAO;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,OAAO;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,EAAE,OAAO,EAAE,CAAC;IACpB,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CASlD;AAED,wBAAgB,UAAU,CACxB,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,OAAO,EAChB,KAAK,GAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAM,GAClC,IAAI,CAQN;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,SAAM,GAAG,OAAO,EAAE,CAIzE;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAInD;AAID,qBAAa,cAAc;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,MAAM,CAA8B;gBAEhC,SAAS,EAAE,MAAM;IAK7B,OAAO,CAAC,eAAe;IAKvB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IASjC,OAAO,CAAC,KAAK;IAsCb,IAAI,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI;IAoB5B,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAI7B,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;IAU5B,YAAY,IAAI,KAAK,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CA4B9C"}
@@ -0,0 +1,193 @@
1
+ "use strict";
2
+ /**
3
+ * Session management
4
+ */
5
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ var desc = Object.getOwnPropertyDescriptor(m, k);
8
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
9
+ desc = { enumerable: true, get: function() { return m[k]; } };
10
+ }
11
+ Object.defineProperty(o, k2, desc);
12
+ }) : (function(o, m, k, k2) {
13
+ if (k2 === undefined) k2 = k;
14
+ o[k2] = m[k];
15
+ }));
16
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
17
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
18
+ }) : function(o, v) {
19
+ o["default"] = v;
20
+ });
21
+ var __importStar = (this && this.__importStar) || (function () {
22
+ var ownKeys = function(o) {
23
+ ownKeys = Object.getOwnPropertyNames || function (o) {
24
+ var ar = [];
25
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
26
+ return ar;
27
+ };
28
+ return ownKeys(o);
29
+ };
30
+ return function (mod) {
31
+ if (mod && mod.__esModule) return mod;
32
+ var result = {};
33
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
34
+ __setModuleDefault(result, mod);
35
+ return result;
36
+ };
37
+ })();
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.SessionManager = void 0;
40
+ exports.createSession = createSession;
41
+ exports.addMessage = addMessage;
42
+ exports.getHistory = getHistory;
43
+ exports.clearSession = clearSession;
44
+ const fs = __importStar(require("fs"));
45
+ const path = __importStar(require("path"));
46
+ const os = __importStar(require("os"));
47
+ const logger_1 = require("../utils/logger");
48
+ const helpers_1 = require("../utils/helpers");
49
+ function createSession(key) {
50
+ return {
51
+ key,
52
+ messages: [],
53
+ createdAt: new Date(),
54
+ updatedAt: new Date(),
55
+ metadata: {},
56
+ lastConsolidated: 0,
57
+ };
58
+ }
59
+ function addMessage(session, role, content, extra = {}) {
60
+ session.messages.push({
61
+ role,
62
+ content,
63
+ timestamp: new Date().toISOString(),
64
+ ...extra,
65
+ });
66
+ session.updatedAt = new Date();
67
+ }
68
+ function getHistory(session, maxMessages = 500) {
69
+ return session.messages
70
+ .slice(-maxMessages)
71
+ .map((m) => ({ role: m.role, content: m.content }));
72
+ }
73
+ function clearSession(session) {
74
+ session.messages = [];
75
+ session.lastConsolidated = 0;
76
+ session.updatedAt = new Date();
77
+ }
78
+ // ─── SessionManager ───────────────────────────────────────────────────────────
79
+ class SessionManager {
80
+ workspace;
81
+ sessionsDir;
82
+ _cache = new Map();
83
+ constructor(workspace) {
84
+ this.workspace = workspace;
85
+ this.sessionsDir = (0, helpers_1.ensureDir)(path.join(os.homedir(), ".seclaw", "sessions"));
86
+ }
87
+ _getSessionPath(key) {
88
+ const safeKey = (0, helpers_1.safeFilename)(key.replace(":", "_"));
89
+ return path.join(this.sessionsDir, `${safeKey}.jsonl`);
90
+ }
91
+ getOrCreate(key) {
92
+ const cached = this._cache.get(key);
93
+ if (cached)
94
+ return cached;
95
+ const session = this._load(key) ?? createSession(key);
96
+ this._cache.set(key, session);
97
+ return session;
98
+ }
99
+ _load(key) {
100
+ const p = this._getSessionPath(key);
101
+ if (!fs.existsSync(p))
102
+ return null;
103
+ try {
104
+ const lines = fs.readFileSync(p, "utf8").split("\n").filter((l) => l.trim());
105
+ const messages = [];
106
+ let metadata = {};
107
+ let createdAt = null;
108
+ let lastConsolidated = 0;
109
+ for (const line of lines) {
110
+ const data = JSON.parse(line);
111
+ if (data["_type"] === "metadata") {
112
+ metadata = data["metadata"] ?? {};
113
+ createdAt = data["createdAt"]
114
+ ? new Date(data["createdAt"])
115
+ : null;
116
+ lastConsolidated = data["lastConsolidated"] ?? 0;
117
+ }
118
+ else {
119
+ messages.push(data);
120
+ }
121
+ }
122
+ return {
123
+ key,
124
+ messages,
125
+ createdAt: createdAt ?? new Date(),
126
+ updatedAt: new Date(),
127
+ metadata,
128
+ lastConsolidated,
129
+ };
130
+ }
131
+ catch (e) {
132
+ logger_1.logger.warn({ err: e, key }, "Failed to load session");
133
+ return null;
134
+ }
135
+ }
136
+ save(session) {
137
+ const p = this._getSessionPath(session.key);
138
+ const lines = [];
139
+ const metaLine = {
140
+ _type: "metadata",
141
+ createdAt: session.createdAt.toISOString(),
142
+ updatedAt: session.updatedAt.toISOString(),
143
+ metadata: session.metadata,
144
+ lastConsolidated: session.lastConsolidated,
145
+ };
146
+ lines.push(JSON.stringify(metaLine));
147
+ for (const msg of session.messages) {
148
+ lines.push(JSON.stringify(msg));
149
+ }
150
+ fs.writeFileSync(p, lines.join("\n") + "\n");
151
+ this._cache.set(session.key, session);
152
+ }
153
+ invalidate(key) {
154
+ this._cache.delete(key);
155
+ }
156
+ delete(key) {
157
+ this._cache.delete(key);
158
+ const p = this._getSessionPath(key);
159
+ if (fs.existsSync(p)) {
160
+ fs.unlinkSync(p);
161
+ return true;
162
+ }
163
+ return false;
164
+ }
165
+ listSessions() {
166
+ const sessions = [];
167
+ for (const file of fs.readdirSync(this.sessionsDir)) {
168
+ if (!file.endsWith(".jsonl"))
169
+ continue;
170
+ const p = path.join(this.sessionsDir, file);
171
+ try {
172
+ const firstLine = fs.readFileSync(p, "utf8").split("\n")[0];
173
+ if (firstLine) {
174
+ const data = JSON.parse(firstLine);
175
+ if (data["_type"] === "metadata") {
176
+ sessions.push({
177
+ key: path.basename(file, ".jsonl").replace("_", ":"),
178
+ createdAt: data["createdAt"] ?? "",
179
+ updatedAt: data["updatedAt"] ?? "",
180
+ path: p,
181
+ });
182
+ }
183
+ }
184
+ }
185
+ catch {
186
+ continue;
187
+ }
188
+ }
189
+ return sessions.sort((a, b) => (b["updatedAt"] ?? "").localeCompare(a["updatedAt"] ?? ""));
190
+ }
191
+ }
192
+ exports.SessionManager = SessionManager;
193
+ //# sourceMappingURL=manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"manager.js","sourceRoot":"","sources":["../../src/session/manager.ts"],"names":[],"mappings":";AAAA;;GAEG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwBH,sCASC;AAED,gCAaC;AAED,gCAIC;AAED,oCAIC;AA1DD,uCAAyB;AACzB,2CAA6B;AAC7B,uCAAyB;AACzB,4CAAyC;AACzC,8CAA2D;AAkB3D,SAAgB,aAAa,CAAC,GAAW;IACvC,OAAO;QACL,GAAG;QACH,QAAQ,EAAE,EAAE;QACZ,SAAS,EAAE,IAAI,IAAI,EAAE;QACrB,SAAS,EAAE,IAAI,IAAI,EAAE;QACrB,QAAQ,EAAE,EAAE;QACZ,gBAAgB,EAAE,CAAC;KACpB,CAAC;AACJ,CAAC;AAED,SAAgB,UAAU,CACxB,OAAgB,EAChB,IAAY,EACZ,OAAgB,EAChB,QAAiC,EAAE;IAEnC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;QACpB,IAAI;QACJ,OAAO;QACP,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACnC,GAAG,KAAK;KACT,CAAC,CAAC;IACH,OAAO,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;AACjC,CAAC;AAED,SAAgB,UAAU,CAAC,OAAgB,EAAE,WAAW,GAAG,GAAG;IAC5D,OAAO,OAAO,CAAC,QAAQ;SACpB,KAAK,CAAC,CAAC,WAAW,CAAC;SACnB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;AACxD,CAAC;AAED,SAAgB,YAAY,CAAC,OAAgB;IAC3C,OAAO,CAAC,QAAQ,GAAG,EAAE,CAAC;IACtB,OAAO,CAAC,gBAAgB,GAAG,CAAC,CAAC;IAC7B,OAAO,CAAC,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC;AACjC,CAAC;AAED,iFAAiF;AAEjF,MAAa,cAAc;IACzB,SAAS,CAAS;IAClB,WAAW,CAAS;IACZ,MAAM,GAAG,IAAI,GAAG,EAAmB,CAAC;IAE5C,YAAY,SAAiB;QAC3B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,IAAA,mBAAS,EAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAC;IAC/E,CAAC;IAEO,eAAe,CAAC,GAAW;QACjC,MAAM,OAAO,GAAG,IAAA,sBAAY,EAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,OAAO,QAAQ,CAAC,CAAC;IACzD,CAAC;IAED,WAAW,CAAC,GAAW;QACrB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACpC,IAAI,MAAM;YAAE,OAAO,MAAM,CAAC;QAE1B,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,aAAa,CAAC,GAAG,CAAC,CAAC;QACtD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;QAC9B,OAAO,OAAO,CAAC;IACjB,CAAC;IAEO,KAAK,CAAC,GAAW;QACvB,MAAM,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QACpC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;YAAE,OAAO,IAAI,CAAC;QAEnC,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,EAAE,CAAC,YAAY,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;YAC7E,MAAM,QAAQ,GAAc,EAAE,CAAC;YAC/B,IAAI,QAAQ,GAA4B,EAAE,CAAC;YAC3C,IAAI,SAAS,GAAgB,IAAI,CAAC;YAClC,IAAI,gBAAgB,GAAG,CAAC,CAAC;YAEzB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAA4B,CAAC;gBACzD,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,UAAU,EAAE,CAAC;oBACjC,QAAQ,GAAI,IAAI,CAAC,UAAU,CAA6B,IAAI,EAAE,CAAC;oBAC/D,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC;wBAC3B,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,CAAW,CAAC;wBACvC,CAAC,CAAC,IAAI,CAAC;oBACT,gBAAgB,GAAI,IAAI,CAAC,kBAAkB,CAAY,IAAI,CAAC,CAAC;gBAC/D,CAAC;qBAAM,CAAC;oBACN,QAAQ,CAAC,IAAI,CAAC,IAAe,CAAC,CAAC;gBACjC,CAAC;YACH,CAAC;YAED,OAAO;gBACL,GAAG;gBACH,QAAQ;gBACR,SAAS,EAAE,SAAS,IAAI,IAAI,IAAI,EAAE;gBAClC,SAAS,EAAE,IAAI,IAAI,EAAE;gBACrB,QAAQ;gBACR,gBAAgB;aACjB,CAAC;QACJ,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,eAAM,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,wBAAwB,CAAC,CAAC;YACvD,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAED,IAAI,CAAC,OAAgB;QACnB,MAAM,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAa,EAAE,CAAC;QAE3B,MAAM,QAAQ,GAAG;YACf,KAAK,EAAE,UAAU;YACjB,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE;YAC1C,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE;YAC1C,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;SAC3C,CAAC;QACF,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACrC,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACnC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QAClC,CAAC;QAED,EAAE,CAAC,aAAa,CAAC,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IACxC,CAAC;IAED,UAAU,CAAC,GAAW;QACpB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,GAAW;QAChB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACxB,MAAM,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QACpC,IAAI,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;YACrB,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACjB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,YAAY;QACV,MAAM,QAAQ,GAAkC,EAAE,CAAC;QAEnD,KAAK,MAAM,IAAI,IAAI,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC;YACpD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;gBAAE,SAAS;YACvC,MAAM,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;YAC5C,IAAI,CAAC;gBACH,MAAM,SAAS,GAAG,EAAE,CAAC,YAAY,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC5D,IAAI,SAAS,EAAE,CAAC;oBACd,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAA4B,CAAC;oBAC9D,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,UAAU,EAAE,CAAC;wBACjC,QAAQ,CAAC,IAAI,CAAC;4BACZ,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC;4BACpD,SAAS,EAAG,IAAI,CAAC,WAAW,CAAY,IAAI,EAAE;4BAC9C,SAAS,EAAG,IAAI,CAAC,WAAW,CAAY,IAAI,EAAE;4BAC9C,IAAI,EAAE,CAAC;yBACR,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,SAAS;YACX,CAAC;QACH,CAAC;QAED,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAC5B,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAC3D,CAAC;IACJ,CAAC;CACF;AA5HD,wCA4HC"}