@pedrohnas/opencode-telegram 1.2.1 → 1.3.1

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 (39) hide show
  1. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-40-45-070Z.png +0 -0
  2. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-41-15-698Z.yml +168 -0
  3. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-41-25-514Z.yml +219 -0
  4. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-41-40-888Z.yml +221 -0
  5. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-41-46-079Z.yml +230 -0
  6. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-41-53-985Z.yml +235 -0
  7. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-42-03-227Z.yml +235 -0
  8. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-42-08-587Z.yml +248 -0
  9. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-42-16-524Z.yml +234 -0
  10. package/.claude/skills/playwright-cli/data/page-2026-02-09T02-42-26-086Z.yml +196 -0
  11. package/docs/AUDIT.md +193 -0
  12. package/docs/PROGRESS.md +191 -0
  13. package/docs/plans/phase-5.md +410 -0
  14. package/docs/plans/phase-6.5.md +426 -0
  15. package/docs/plans/phase-6.md +349 -0
  16. package/e2e/helpers.ts +34 -0
  17. package/e2e/phase-5.test.ts +295 -0
  18. package/e2e/phase-6.5.test.ts +239 -0
  19. package/e2e/phase-6.test.ts +302 -0
  20. package/package.json +5 -2
  21. package/src/api-server.test.ts +309 -0
  22. package/src/api-server.ts +201 -0
  23. package/src/bot.test.ts +354 -0
  24. package/src/bot.ts +200 -2
  25. package/src/config.test.ts +16 -0
  26. package/src/config.ts +4 -0
  27. package/src/event-bus.test.ts +337 -1
  28. package/src/event-bus.ts +83 -3
  29. package/src/handlers/agents.test.ts +122 -0
  30. package/src/handlers/agents.ts +93 -0
  31. package/src/handlers/media.test.ts +264 -0
  32. package/src/handlers/media.ts +168 -0
  33. package/src/handlers/models.test.ts +319 -0
  34. package/src/handlers/models.ts +191 -0
  35. package/src/index.ts +15 -0
  36. package/src/send/draft-stream.test.ts +76 -0
  37. package/src/send/draft-stream.ts +13 -1
  38. package/src/session-manager.test.ts +46 -0
  39. package/src/session-manager.ts +10 -1
@@ -196,3 +196,49 @@ describe("SessionManager", () => {
196
196
  expect(sm.get("12345")?.sessionId).toBe("existing")
197
197
  })
198
198
  })
199
+
200
+ // --- Phase 5: model/agent override fields ---
201
+
202
+ describe("SessionEntry overrides", () => {
203
+ let sm: SessionManager
204
+
205
+ beforeEach(() => {
206
+ sm = new SessionManager({ maxEntries: 10, ttlMs: 60000 })
207
+ })
208
+
209
+ test("set/get preserves modelOverride", () => {
210
+ sm.set("123", {
211
+ sessionId: "s1",
212
+ directory: "/tmp",
213
+ modelOverride: { providerID: "anthropic", modelID: "claude-sonnet-4-5-20250929" },
214
+ })
215
+ const entry = sm.get("123")
216
+ expect(entry?.modelOverride).toEqual({
217
+ providerID: "anthropic",
218
+ modelID: "claude-sonnet-4-5-20250929",
219
+ })
220
+ })
221
+
222
+ test("set/get preserves agentOverride", () => {
223
+ sm.set("123", {
224
+ sessionId: "s1",
225
+ directory: "/tmp",
226
+ agentOverride: "code",
227
+ })
228
+ const entry = sm.get("123")
229
+ expect(entry?.agentOverride).toBe("code")
230
+ })
231
+
232
+ test("getOrCreate returns entry without overrides by default", async () => {
233
+ const sdk = {
234
+ session: {
235
+ create: mock(async () => ({
236
+ data: { id: "new-session", title: "", directory: "/tmp" },
237
+ })),
238
+ },
239
+ }
240
+ const entry = await sm.getOrCreate("456", sdk as any)
241
+ expect(entry.modelOverride).toBeUndefined()
242
+ expect(entry.agentOverride).toBeUndefined()
243
+ })
244
+ })
@@ -15,6 +15,8 @@ export type SessionEntry = {
15
15
  directory: string
16
16
  createdAt: number
17
17
  lastAccessAt: number
18
+ modelOverride?: { providerID: string; modelID: string }
19
+ agentOverride?: string
18
20
  }
19
21
 
20
22
  export type SessionManagerOptions = {
@@ -79,7 +81,12 @@ export class SessionManager {
79
81
 
80
82
  set(
81
83
  chatKey: string,
82
- init: { sessionId: string; directory: string },
84
+ init: {
85
+ sessionId: string
86
+ directory: string
87
+ modelOverride?: { providerID: string; modelID: string }
88
+ agentOverride?: string
89
+ },
83
90
  ): void {
84
91
  // Clean up old binding if exists
85
92
  const old = this.map.get(chatKey)
@@ -92,6 +99,8 @@ export class SessionManager {
92
99
  directory: init.directory,
93
100
  createdAt: Date.now(),
94
101
  lastAccessAt: Date.now(),
102
+ modelOverride: init.modelOverride,
103
+ agentOverride: init.agentOverride,
95
104
  }
96
105
 
97
106
  this.insert(chatKey, entry)