@getpaseo/server 0.1.84 → 0.1.86

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 (60) hide show
  1. package/dist/scripts/supervisor-entrypoint.js +1 -0
  2. package/dist/server/server/agent/agent-manager.d.ts +4 -0
  3. package/dist/server/server/agent/agent-manager.js +23 -0
  4. package/dist/server/server/agent/agent-metadata-generator.d.ts +9 -0
  5. package/dist/server/server/agent/agent-metadata-generator.js +11 -2
  6. package/dist/server/server/agent/agent-response-loop.d.ts +1 -1
  7. package/dist/server/server/agent/agent-response-loop.js +3 -13
  8. package/dist/server/server/agent/create-agent/create.d.ts +2 -0
  9. package/dist/server/server/agent/create-agent/create.js +7 -0
  10. package/dist/server/server/agent/create-agent-lifecycle-dispatch.js +0 -1
  11. package/dist/server/server/agent/import-sessions.d.ts +3 -0
  12. package/dist/server/server/agent/import-sessions.js +11 -0
  13. package/dist/server/server/agent/mcp-server.d.ts +0 -1
  14. package/dist/server/server/agent/mcp-server.js +0 -4
  15. package/dist/server/server/agent/providers/claude/agent.d.ts +2 -1
  16. package/dist/server/server/agent/providers/claude/agent.js +70 -0
  17. package/dist/server/server/agent/providers/claude/feature-definitions.d.ts +8 -0
  18. package/dist/server/server/agent/providers/claude/feature-definitions.js +36 -0
  19. package/dist/server/server/agent/providers/claude/models.js +19 -5
  20. package/dist/server/server/agent/providers/tool-call-detail-primitives.js +6 -3
  21. package/dist/server/server/agent/providers/tool-call-mapper-utils.d.ts +5 -0
  22. package/dist/server/server/agent/providers/tool-call-mapper-utils.js +62 -0
  23. package/dist/server/server/agent/structured-generation-providers.d.ts +29 -0
  24. package/dist/server/server/agent/structured-generation-providers.js +192 -0
  25. package/dist/server/server/auto-archive-on-merge/archive-if-safe.d.ts +0 -2
  26. package/dist/server/server/auto-archive-on-merge/archive-if-safe.js +0 -1
  27. package/dist/server/server/bootstrap.d.ts +7 -0
  28. package/dist/server/server/bootstrap.js +11 -2
  29. package/dist/server/server/config.js +1 -0
  30. package/dist/server/server/daemon-config-store.js +46 -6
  31. package/dist/server/server/daemon-worker.js +1 -0
  32. package/dist/server/server/file-explorer/service.js +4 -4
  33. package/dist/server/server/paseo-worktree-archive-service.d.ts +2 -6
  34. package/dist/server/server/paseo-worktree-archive-service.js +13 -33
  35. package/dist/server/server/persisted-config.d.ts +77 -22
  36. package/dist/server/server/persisted-config.js +13 -0
  37. package/dist/server/server/schedule/service.d.ts +1 -0
  38. package/dist/server/server/schedule/service.js +15 -0
  39. package/dist/server/server/session.d.ts +3 -2
  40. package/dist/server/server/session.js +77 -25
  41. package/dist/server/server/speech/providers/local/runtime.js +52 -133
  42. package/dist/server/server/speech/providers/local/sherpa/model-catalog.d.ts +9 -2
  43. package/dist/server/server/speech/providers/local/sherpa/model-catalog.js +7 -0
  44. package/dist/server/server/speech/providers/local/worker-bytes.d.ts +4 -0
  45. package/dist/server/server/speech/providers/local/worker-bytes.js +9 -0
  46. package/dist/server/server/speech/providers/local/worker-client.d.ts +80 -0
  47. package/dist/server/server/speech/providers/local/worker-client.js +438 -0
  48. package/dist/server/server/speech/providers/local/worker-process.d.ts +2 -0
  49. package/dist/server/server/speech/providers/local/worker-process.js +270 -0
  50. package/dist/server/server/speech/providers/local/worker-protocol.d.ts +95 -0
  51. package/dist/server/server/speech/providers/local/worker-protocol.js +2 -0
  52. package/dist/server/server/websocket-server.js +2 -0
  53. package/dist/server/server/worktree-branch-name-generator.d.ts +9 -0
  54. package/dist/server/server/worktree-branch-name-generator.js +11 -2
  55. package/dist/server/utils/worktree.d.ts +1 -1
  56. package/dist/server/utils/worktree.js +2 -2
  57. package/dist/src/server/persisted-config.js +13 -0
  58. package/package.json +5 -10
  59. package/dist/server/utils/branch-slug.d.ts +0 -14
  60. package/dist/server/utils/branch-slug.js +0 -49
@@ -446,7 +446,41 @@ export declare const PersistedConfigSchema: z.ZodObject<{
446
446
  extends?: string | undefined;
447
447
  order?: number | undefined;
448
448
  }>, unknown>>;
449
+ metadataGeneration: z.ZodOptional<z.ZodObject<{
450
+ providers: z.ZodOptional<z.ZodArray<z.ZodObject<{
451
+ provider: z.ZodString;
452
+ model: z.ZodOptional<z.ZodString>;
453
+ thinkingOptionId: z.ZodOptional<z.ZodString>;
454
+ }, "strict", z.ZodTypeAny, {
455
+ provider: string;
456
+ model?: string | undefined;
457
+ thinkingOptionId?: string | undefined;
458
+ }, {
459
+ provider: string;
460
+ model?: string | undefined;
461
+ thinkingOptionId?: string | undefined;
462
+ }>, "many">>;
463
+ }, "strict", z.ZodTypeAny, {
464
+ providers?: {
465
+ provider: string;
466
+ model?: string | undefined;
467
+ thinkingOptionId?: string | undefined;
468
+ }[] | undefined;
469
+ }, {
470
+ providers?: {
471
+ provider: string;
472
+ model?: string | undefined;
473
+ thinkingOptionId?: string | undefined;
474
+ }[] | undefined;
475
+ }>>;
449
476
  }, "strict", z.ZodTypeAny, {
477
+ metadataGeneration?: {
478
+ providers?: {
479
+ provider: string;
480
+ model?: string | undefined;
481
+ thinkingOptionId?: string | undefined;
482
+ }[] | undefined;
483
+ } | undefined;
450
484
  providers?: Record<string, {
451
485
  description?: string | undefined;
452
486
  label?: string | undefined;
@@ -482,6 +516,13 @@ export declare const PersistedConfigSchema: z.ZodObject<{
482
516
  order?: number | undefined;
483
517
  }> | undefined;
484
518
  }, {
519
+ metadataGeneration?: {
520
+ providers?: {
521
+ provider: string;
522
+ model?: string | undefined;
523
+ thinkingOptionId?: string | undefined;
524
+ }[] | undefined;
525
+ } | undefined;
485
526
  providers?: unknown;
486
527
  }>>;
487
528
  features: z.ZodOptional<z.ZodObject<{
@@ -561,14 +602,14 @@ export declare const PersistedConfigSchema: z.ZodObject<{
561
602
  }, "strict", z.ZodTypeAny, {
562
603
  provider?: "local" | "openai" | undefined;
563
604
  model?: string | undefined;
564
- speed?: number | undefined;
565
605
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
606
+ speed?: number | undefined;
566
607
  speakerId?: number | undefined;
567
608
  }, {
568
609
  provider?: string | undefined;
569
610
  model?: string | undefined;
570
- speed?: number | undefined;
571
611
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
612
+ speed?: number | undefined;
572
613
  speakerId?: number | undefined;
573
614
  }>>;
574
615
  }, "strict", z.ZodTypeAny, {
@@ -588,8 +629,8 @@ export declare const PersistedConfigSchema: z.ZodObject<{
588
629
  tts?: {
589
630
  provider?: "local" | "openai" | undefined;
590
631
  model?: string | undefined;
591
- speed?: number | undefined;
592
632
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
633
+ speed?: number | undefined;
593
634
  speakerId?: number | undefined;
594
635
  } | undefined;
595
636
  }, {
@@ -609,8 +650,8 @@ export declare const PersistedConfigSchema: z.ZodObject<{
609
650
  tts?: {
610
651
  provider?: string | undefined;
611
652
  model?: string | undefined;
612
- speed?: number | undefined;
613
653
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
654
+ speed?: number | undefined;
614
655
  speakerId?: number | undefined;
615
656
  } | undefined;
616
657
  }>>;
@@ -641,8 +682,8 @@ export declare const PersistedConfigSchema: z.ZodObject<{
641
682
  tts?: {
642
683
  provider?: "local" | "openai" | undefined;
643
684
  model?: string | undefined;
644
- speed?: number | undefined;
645
685
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
686
+ speed?: number | undefined;
646
687
  speakerId?: number | undefined;
647
688
  } | undefined;
648
689
  } | undefined;
@@ -673,8 +714,8 @@ export declare const PersistedConfigSchema: z.ZodObject<{
673
714
  tts?: {
674
715
  provider?: string | undefined;
675
716
  model?: string | undefined;
676
- speed?: number | undefined;
677
717
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
718
+ speed?: number | undefined;
678
719
  speakerId?: number | undefined;
679
720
  } | undefined;
680
721
  } | undefined;
@@ -722,6 +763,10 @@ export declare const PersistedConfigSchema: z.ZodObject<{
722
763
  }>>;
723
764
  }, "strict", z.ZodTypeAny, {
724
765
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
766
+ console?: {
767
+ level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
768
+ format?: "json" | "pretty" | undefined;
769
+ } | undefined;
725
770
  file?: {
726
771
  path?: string | undefined;
727
772
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
@@ -731,12 +776,12 @@ export declare const PersistedConfigSchema: z.ZodObject<{
731
776
  } | undefined;
732
777
  } | undefined;
733
778
  format?: "json" | "pretty" | undefined;
779
+ }, {
780
+ level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
734
781
  console?: {
735
782
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
736
783
  format?: "json" | "pretty" | undefined;
737
784
  } | undefined;
738
- }, {
739
- level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
740
785
  file?: {
741
786
  path?: string | undefined;
742
787
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
@@ -746,10 +791,6 @@ export declare const PersistedConfigSchema: z.ZodObject<{
746
791
  } | undefined;
747
792
  } | undefined;
748
793
  format?: "json" | "pretty" | undefined;
749
- console?: {
750
- level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
751
- format?: "json" | "pretty" | undefined;
752
- } | undefined;
753
794
  }>>;
754
795
  }, "strict", z.ZodTypeAny, {
755
796
  version?: 1 | undefined;
@@ -780,14 +821,18 @@ export declare const PersistedConfigSchema: z.ZodObject<{
780
821
  tts?: {
781
822
  provider?: "local" | "openai" | undefined;
782
823
  model?: string | undefined;
783
- speed?: number | undefined;
784
824
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
825
+ speed?: number | undefined;
785
826
  speakerId?: number | undefined;
786
827
  } | undefined;
787
828
  } | undefined;
788
829
  } | undefined;
789
830
  log?: {
790
831
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
832
+ console?: {
833
+ level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
834
+ format?: "json" | "pretty" | undefined;
835
+ } | undefined;
791
836
  file?: {
792
837
  path?: string | undefined;
793
838
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
@@ -797,12 +842,15 @@ export declare const PersistedConfigSchema: z.ZodObject<{
797
842
  } | undefined;
798
843
  } | undefined;
799
844
  format?: "json" | "pretty" | undefined;
800
- console?: {
801
- level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
802
- format?: "json" | "pretty" | undefined;
803
- } | undefined;
804
845
  } | undefined;
805
846
  agents?: {
847
+ metadataGeneration?: {
848
+ providers?: {
849
+ provider: string;
850
+ model?: string | undefined;
851
+ thinkingOptionId?: string | undefined;
852
+ }[] | undefined;
853
+ } | undefined;
806
854
  providers?: Record<string, {
807
855
  description?: string | undefined;
808
856
  label?: string | undefined;
@@ -901,14 +949,18 @@ export declare const PersistedConfigSchema: z.ZodObject<{
901
949
  tts?: {
902
950
  provider?: string | undefined;
903
951
  model?: string | undefined;
904
- speed?: number | undefined;
905
952
  voice?: "alloy" | "echo" | "fable" | "onyx" | "nova" | "shimmer" | undefined;
953
+ speed?: number | undefined;
906
954
  speakerId?: number | undefined;
907
955
  } | undefined;
908
956
  } | undefined;
909
957
  } | undefined;
910
958
  log?: {
911
959
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
960
+ console?: {
961
+ level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
962
+ format?: "json" | "pretty" | undefined;
963
+ } | undefined;
912
964
  file?: {
913
965
  path?: string | undefined;
914
966
  level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
@@ -918,12 +970,15 @@ export declare const PersistedConfigSchema: z.ZodObject<{
918
970
  } | undefined;
919
971
  } | undefined;
920
972
  format?: "json" | "pretty" | undefined;
921
- console?: {
922
- level?: "error" | "fatal" | "warn" | "info" | "debug" | "trace" | undefined;
923
- format?: "json" | "pretty" | undefined;
924
- } | undefined;
925
973
  } | undefined;
926
974
  agents?: {
975
+ metadataGeneration?: {
976
+ providers?: {
977
+ provider: string;
978
+ model?: string | undefined;
979
+ thinkingOptionId?: string | undefined;
980
+ }[] | undefined;
981
+ } | undefined;
927
982
  providers?: unknown;
928
983
  } | undefined;
929
984
  app?: {
@@ -112,6 +112,18 @@ const FeatureVoiceModeSchema = z
112
112
  .optional(),
113
113
  })
114
114
  .strict();
115
+ const StructuredGenerationProviderConfigSchema = z
116
+ .object({
117
+ provider: z.string().min(1),
118
+ model: z.string().min(1).optional(),
119
+ thinkingOptionId: z.string().min(1).optional(),
120
+ })
121
+ .strict();
122
+ const AgentMetadataGenerationSchema = z
123
+ .object({
124
+ providers: z.array(StructuredGenerationProviderConfigSchema).optional(),
125
+ })
126
+ .strict();
115
127
  const BUILTIN_PROVIDER_IDS = ["claude", "codex", "copilot", "opencode", "pi"];
116
128
  function isLegacyProviderEntry(value) {
117
129
  if (!value || typeof value !== "object" || Array.isArray(value)) {
@@ -203,6 +215,7 @@ export const PersistedConfigSchema = z
203
215
  agents: z
204
216
  .object({
205
217
  providers: z.preprocess(normalizeAgentProviders, ProviderOverridesSchema).optional(),
218
+ metadataGeneration: AgentMetadataGenerationSchema.optional(),
206
219
  })
207
220
  .strict()
208
221
  .optional(),
@@ -30,6 +30,7 @@ export declare class ScheduleService {
30
30
  resume(id: string): Promise<StoredSchedule>;
31
31
  update(input: UpdateScheduleInput): Promise<StoredSchedule>;
32
32
  delete(id: string): Promise<void>;
33
+ deleteForAgent(agentId: string): Promise<number>;
33
34
  runOnce(id: string): Promise<StoredSchedule>;
34
35
  tick(): Promise<void>;
35
36
  private recoverInterruptedRuns;
@@ -244,6 +244,21 @@ export class ScheduleService {
244
244
  async delete(id) {
245
245
  await this.store.delete(id);
246
246
  }
247
+ async deleteForAgent(agentId) {
248
+ const schedules = await this.store.list();
249
+ const matches = schedules.filter((schedule) => schedule.target.type === "agent" && schedule.target.agentId === agentId);
250
+ const results = await Promise.allSettled(matches.map((schedule) => this.store.delete(schedule.id)));
251
+ let deleted = 0;
252
+ for (const [index, result] of results.entries()) {
253
+ if (result.status === "fulfilled") {
254
+ deleted += 1;
255
+ }
256
+ else {
257
+ this.logger.warn({ err: result.reason, scheduleId: matches[index].id, agentId }, "Failed to delete schedule for archived agent; continuing");
258
+ }
259
+ }
260
+ return deleted;
261
+ }
247
262
  async runOnce(id) {
248
263
  const schedule = await this.inspect(id);
249
264
  if (schedule.status === "completed") {
@@ -160,7 +160,6 @@ export declare class Session {
160
160
  private agentUpdatesSubscription;
161
161
  private workspaceUpdatesSubscription;
162
162
  private clientActivity;
163
- private readonly MOBILE_BACKGROUND_STREAM_GRACE_MS;
164
163
  private readonly terminalManager;
165
164
  private readonly providerSnapshotManager;
166
165
  private unsubscribeProviderSnapshotEvents;
@@ -217,6 +216,8 @@ export declare class Session {
217
216
  appVisible: boolean;
218
217
  appVisibilityChangedAt: Date;
219
218
  } | null;
219
+ private getFocusedAgentSelectionForCwd;
220
+ private readStructuredGenerationDaemonConfig;
220
221
  getRuntimeMetrics(): SessionRuntimeMetrics;
221
222
  emitServerMessage(message: SessionOutboundMessage): void;
222
223
  /**
@@ -245,7 +246,6 @@ export declare class Session {
245
246
  private bindVoiceBridges;
246
247
  private initializePerSessionManagers;
247
248
  private subscribeToAgentEvents;
248
- private shouldSkipAgentStreamForward;
249
249
  private buildAgentStreamPayload;
250
250
  private buildAgentPayload;
251
251
  private buildStoredAgentPayload;
@@ -405,6 +405,7 @@ export declare class Session {
405
405
  private handleCheckoutMergeFromBaseRequest;
406
406
  private handleCheckoutPullRequest;
407
407
  private handleCheckoutPushRequest;
408
+ private handleCheckoutRefreshRequest;
408
409
  private handleCheckoutPrCreateRequest;
409
410
  private handleCheckoutPrMergeRequest;
410
411
  private assertCurrentPullRequestHasGithubMergeFacts;
@@ -39,7 +39,8 @@ import { archiveAgentCommand, cancelAgentRunCommand, closeAgentCommand, setAgent
39
39
  import { buildStoredAgentPayload, resolveEffectiveThinkingOptionId, resolveStoredAgentPayloadUpdatedAt, toAgentPayload, } from "./agent/agent-projections.js";
40
40
  import { appendTimelineItemIfAgentKnown, emitLiveTimelineItemIfAgentKnown, } from "./agent/timeline-append.js";
41
41
  import { projectTimelineRows, selectTimelineWindowByProjectedLimit, } from "./agent/timeline-projection.js";
42
- import { DEFAULT_STRUCTURED_GENERATION_PROVIDERS, StructuredAgentFallbackError, StructuredAgentResponseError, generateStructuredAgentResponseWithFallback, } from "./agent/agent-response-loop.js";
42
+ import { StructuredAgentFallbackError, StructuredAgentResponseError, generateStructuredAgentResponseWithFallback, } from "./agent/agent-response-loop.js";
43
+ import { resolveStructuredGenerationProviders, } from "./agent/structured-generation-providers.js";
43
44
  import { getAgentStreamEventTurnId, } from "./agent/agent-sdk-types.js";
44
45
  import { ImportSessionsRequestError, importProviderSession, listImportableProviderSessions, normalizeImportAgentRequest, } from "./agent/import-sessions.js";
45
46
  import { checkoutLiteFromGitSnapshot, normalizeWorkspaceId as normalizePersistedWorkspaceId, deriveProjectGroupingName, classifyDirectoryForProjectMembership, deriveWorkspaceDisplayName, } from "./workspace-registry-model.js";
@@ -52,7 +53,7 @@ import { buildMetadataPrompt } from "../utils/build-metadata-prompt.js";
52
53
  import { archivePersistedWorkspaceRecord } from "./workspace-archive-service.js";
53
54
  import { WorkspaceReconciliationService } from "./workspace-reconciliation-service.js";
54
55
  import { checkoutResolvedBranch, commitChanges, mergeToBase, mergeFromBase, pullCurrentBranch, pushCurrentBranch, createPullRequest, renameCurrentBranch, } from "../utils/checkout-git.js";
55
- import { validateBranchSlug } from "../utils/branch-slug.js";
56
+ import { validateBranchSlug } from "@getpaseo/protocol/branch-slug";
56
57
  import { getProjectIcon } from "../utils/project-icon.js";
57
58
  import { expandTilde } from "../utils/path.js";
58
59
  import { searchHomeDirectories, searchWorkspaceEntries } from "../utils/directory-suggestions.js";
@@ -292,7 +293,6 @@ export class Session {
292
293
  this.agentUpdatesSubscription = null;
293
294
  this.workspaceUpdatesSubscription = null;
294
295
  this.clientActivity = null;
295
- this.MOBILE_BACKGROUND_STREAM_GRACE_MS = 60000;
296
296
  this.unsubscribeProviderSnapshotEvents = null;
297
297
  this.inflightRequests = 0;
298
298
  this.peakInflightRequests = 0;
@@ -481,6 +481,26 @@ export class Session {
481
481
  getClientActivity() {
482
482
  return this.clientActivity;
483
483
  }
484
+ getFocusedAgentSelectionForCwd(cwd) {
485
+ const focusedAgentId = this.clientActivity?.focusedAgentId;
486
+ if (!focusedAgentId) {
487
+ return undefined;
488
+ }
489
+ const agent = this.agentManager.getAgent(focusedAgentId);
490
+ if (!agent || agent.cwd !== cwd) {
491
+ return undefined;
492
+ }
493
+ return {
494
+ provider: agent.provider,
495
+ model: agent.runtimeInfo?.model ?? agent.config.model ?? null,
496
+ thinkingOptionId: agent.runtimeInfo?.thinkingOptionId ?? agent.config.thinkingOptionId ?? null,
497
+ };
498
+ }
499
+ readStructuredGenerationDaemonConfig() {
500
+ return {
501
+ metadataGeneration: this.daemonConfigStore.get().metadataGeneration,
502
+ };
503
+ }
484
504
  getRuntimeMetrics() {
485
505
  const terminalMetrics = this.terminalController.getMetrics();
486
506
  return {
@@ -669,12 +689,6 @@ export class Session {
669
689
  }, "Failed to auto-allow speak tool permission in voice mode");
670
690
  });
671
691
  }
672
- // Reduce bandwidth/CPU on mobile: only forward high-frequency agent stream events
673
- // for the focused agent, with a short grace window while backgrounded.
674
- // History catch-up is handled via pull-based `fetch_agent_timeline_request`.
675
- if (this.shouldSkipAgentStreamForward(event.agentId)) {
676
- return;
677
- }
678
692
  const serializedEvent = serializeAgentStreamEvent(event.event);
679
693
  if (!serializedEvent) {
680
694
  return;
@@ -713,20 +727,6 @@ export class Session {
713
727
  // Title updates may be applied asynchronously after agent creation.
714
728
  }, { replayState: false });
715
729
  }
716
- shouldSkipAgentStreamForward(agentId) {
717
- const activity = this.clientActivity;
718
- if (activity?.deviceType !== "mobile") {
719
- return false;
720
- }
721
- if (!activity.focusedAgentId || activity.focusedAgentId !== agentId) {
722
- return true;
723
- }
724
- if (activity.appVisible) {
725
- return false;
726
- }
727
- const hiddenForMs = Date.now() - activity.appVisibilityChangedAt.getTime();
728
- return hiddenForMs >= this.MOBILE_BACKGROUND_STREAM_GRACE_MS;
729
- }
730
730
  buildAgentStreamPayload(event, serializedEvent) {
731
731
  return {
732
732
  agentId: event.agentId,
@@ -1288,6 +1288,8 @@ export class Session {
1288
1288
  return this.handleCheckoutPullRequest(msg);
1289
1289
  case "checkout_push_request":
1290
1290
  return this.handleCheckoutPushRequest(msg);
1291
+ case "checkout.refresh.request":
1292
+ return this.handleCheckoutRefreshRequest(msg);
1291
1293
  case "checkout_pr_create_request":
1292
1294
  return this.handleCheckoutPrCreateRequest(msg);
1293
1295
  case "checkout_pr_merge_request":
@@ -2093,6 +2095,7 @@ export class Session {
2093
2095
  paseoHome: this.paseoHome,
2094
2096
  workspaceGitService: this.workspaceGitService,
2095
2097
  providerSnapshotManager: this.providerSnapshotManager,
2098
+ daemonConfig: this.readStructuredGenerationDaemonConfig(),
2096
2099
  }, {
2097
2100
  kind: "session",
2098
2101
  config: createAgentConfig,
@@ -2266,6 +2269,8 @@ export class Session {
2266
2269
  agentManager: this.agentManager,
2267
2270
  agentStorage: this.agentStorage,
2268
2271
  workspaceGitService: this.workspaceGitService,
2272
+ providerSnapshotManager: this.providerSnapshotManager,
2273
+ daemonConfig: this.readStructuredGenerationDaemonConfig(),
2269
2274
  paseoHome: this.paseoHome,
2270
2275
  logger: this.sessionLogger,
2271
2276
  });
@@ -2463,6 +2468,9 @@ export class Session {
2463
2468
  agentManager: this.agentManager,
2464
2469
  cwd,
2465
2470
  workspaceGitService: this.workspaceGitService,
2471
+ providerSnapshotManager: this.providerSnapshotManager,
2472
+ daemonConfig: this.readStructuredGenerationDaemonConfig(),
2473
+ currentSelection: this.getFocusedAgentSelectionForCwd(cwd),
2466
2474
  firstAgentContext,
2467
2475
  logger: this.sessionLogger,
2468
2476
  });
@@ -2857,6 +2865,12 @@ export class Session {
2857
2865
  patch.length > 0 ? patch : "(No diff available)",
2858
2866
  ].join("\n"),
2859
2867
  });
2868
+ const providers = await resolveStructuredGenerationProviders({
2869
+ cwd,
2870
+ providerSnapshotManager: this.providerSnapshotManager,
2871
+ daemonConfig: this.readStructuredGenerationDaemonConfig(),
2872
+ currentSelection: this.getFocusedAgentSelectionForCwd(cwd),
2873
+ });
2860
2874
  try {
2861
2875
  const result = await generateStructuredAgentResponseWithFallback({
2862
2876
  manager: this.agentManager,
@@ -2865,7 +2879,7 @@ export class Session {
2865
2879
  schema,
2866
2880
  schemaName: "CommitMessage",
2867
2881
  maxRetries: 2,
2868
- providers: DEFAULT_STRUCTURED_GENERATION_PROVIDERS,
2882
+ providers,
2869
2883
  persistSession: false,
2870
2884
  agentConfigOverrides: {
2871
2885
  title: "Commit generator",
@@ -2919,6 +2933,12 @@ export class Session {
2919
2933
  patch.length > 0 ? patch : "(No diff available)",
2920
2934
  ].join("\n"),
2921
2935
  });
2936
+ const providers = await resolveStructuredGenerationProviders({
2937
+ cwd,
2938
+ providerSnapshotManager: this.providerSnapshotManager,
2939
+ daemonConfig: this.readStructuredGenerationDaemonConfig(),
2940
+ currentSelection: this.getFocusedAgentSelectionForCwd(cwd),
2941
+ });
2922
2942
  try {
2923
2943
  return await generateStructuredAgentResponseWithFallback({
2924
2944
  manager: this.agentManager,
@@ -2927,7 +2947,7 @@ export class Session {
2927
2947
  schema,
2928
2948
  schemaName: "PullRequest",
2929
2949
  maxRetries: 2,
2930
- providers: DEFAULT_STRUCTURED_GENERATION_PROVIDERS,
2950
+ providers,
2931
2951
  persistSession: false,
2932
2952
  agentConfigOverrides: {
2933
2953
  title: "PR generator",
@@ -3972,6 +3992,38 @@ export class Session {
3972
3992
  });
3973
3993
  }
3974
3994
  }
3995
+ async handleCheckoutRefreshRequest(msg) {
3996
+ const { cwd, requestId } = msg;
3997
+ try {
3998
+ this.github.invalidate({ cwd });
3999
+ await this.workspaceGitService.getSnapshot(cwd, {
4000
+ force: true,
4001
+ includeGitHub: true,
4002
+ reason: "manual-refresh",
4003
+ });
4004
+ this.checkoutDiffManager.scheduleRefreshForCwd(cwd);
4005
+ this.emit({
4006
+ type: "checkout.refresh.response",
4007
+ payload: {
4008
+ cwd,
4009
+ success: true,
4010
+ error: null,
4011
+ requestId,
4012
+ },
4013
+ });
4014
+ }
4015
+ catch (error) {
4016
+ this.emit({
4017
+ type: "checkout.refresh.response",
4018
+ payload: {
4019
+ cwd,
4020
+ success: false,
4021
+ error: toCheckoutError(error),
4022
+ requestId,
4023
+ },
4024
+ });
4025
+ }
4026
+ }
3975
4027
  async handleCheckoutPrCreateRequest(msg) {
3976
4028
  const { cwd, requestId } = msg;
3977
4029
  try {