opencode-immune 1.0.18 → 1.0.19
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.
- package/dist/plugin.js +29 -29
- package/package.json +1 -1
package/dist/plugin.js
CHANGED
|
@@ -467,12 +467,12 @@ function createTodoEnforcerChatMessage(state) {
|
|
|
467
467
|
await addManagedUltraworkSession(state, sessionID);
|
|
468
468
|
await writeUltraworkMarker(state);
|
|
469
469
|
}
|
|
470
|
-
else if (sessionID && agent && record?.kind === "root") {
|
|
471
|
-
await removeManagedUltraworkSession(state, sessionID, `session taken over by agent \"${agent}\"`);
|
|
472
|
-
}
|
|
473
470
|
else if (sessionID && agent && record?.kind === "child") {
|
|
474
471
|
await updateManagedSessionAgent(state, sessionID, agent);
|
|
475
472
|
}
|
|
473
|
+
// NOTE: Do NOT remove managed root sessions when agent changes.
|
|
474
|
+
// 0-ultrawork delegates to subagents (1-van, 7-backlog, etc.) which
|
|
475
|
+
// may appear as agent in chat.message but the session is still managed.
|
|
476
476
|
// On user message, check previous assistant turn's counters
|
|
477
477
|
// then reset for next turn
|
|
478
478
|
if (state.toolCallCount > 3 && !state.todoWriteUsed) {
|
|
@@ -791,12 +791,11 @@ function createFallbackModels(state) {
|
|
|
791
791
|
}
|
|
792
792
|
}
|
|
793
793
|
}
|
|
794
|
-
else if (getManagedSession(state, input.sessionID)?.kind === "root") {
|
|
795
|
-
await removeManagedUltraworkSession(state, input.sessionID, `session switched to agent \"${input.agent}\"`);
|
|
796
|
-
}
|
|
797
794
|
else if (getManagedSession(state, input.sessionID)?.kind === "child") {
|
|
798
795
|
await updateManagedSessionAgent(state, input.sessionID, input.agent);
|
|
799
796
|
}
|
|
797
|
+
// NOTE: Do NOT remove managed root sessions when agent changes in chat.params.
|
|
798
|
+
// Subagent calls from 0-ultrawork (1-van, 7-backlog, etc.) use the same session.
|
|
800
799
|
// Log model and agent for observability
|
|
801
800
|
const modelId = input.model && "id" in input.model
|
|
802
801
|
? input.model.id
|
|
@@ -936,28 +935,8 @@ function createMultiCycleHandler(state) {
|
|
|
936
935
|
await clearUltraworkMarker(state);
|
|
937
936
|
console.log("[opencode-immune] Multi-Cycle: ALL_CYCLES_COMPLETE detected, ultrawork marker cleared.");
|
|
938
937
|
}
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
const managedSession = getManagedSession(state, sessionID);
|
|
942
|
-
if (sessionID &&
|
|
943
|
-
messageRole === "assistant" &&
|
|
944
|
-
RATE_LIMIT_MESSAGE_PATTERN.test(messageContent)) {
|
|
945
|
-
if (managedSession && !managedSession.fallbackModel) {
|
|
946
|
-
await setSessionFallbackModel(state, sessionID, RATE_LIMIT_FALLBACK_MODEL);
|
|
947
|
-
console.log(`[opencode-immune] Rate limit message detected in chat output for session ${sessionID}. ` +
|
|
948
|
-
`Fallback model pinned to ${RATE_LIMIT_FALLBACK_MODEL.providerID}/${RATE_LIMIT_FALLBACK_MODEL.modelID}.`);
|
|
949
|
-
}
|
|
950
|
-
if (managedSession) {
|
|
951
|
-
scheduleManagedSessionRetry(state, sessionID, {
|
|
952
|
-
delayMs: 1_000,
|
|
953
|
-
reason: "rate-limit message fallback",
|
|
954
|
-
countAgainstBudget: false,
|
|
955
|
-
abortBeforePrompt: true,
|
|
956
|
-
});
|
|
957
|
-
}
|
|
958
|
-
}
|
|
959
|
-
// ── PRE_COMMIT: execute /commit ──
|
|
960
|
-
if (messageContent.includes(PRE_COMMIT_MARKER) && !state.commitPending) {
|
|
938
|
+
// ── PRE_COMMIT: execute /commit (checked before managed session guard) ──
|
|
939
|
+
if (messageContent.includes(PRE_COMMIT_MARKER) && !state.commitPending && sessionID) {
|
|
961
940
|
state.commitPending = true;
|
|
962
941
|
console.log("[opencode-immune] Multi-Cycle: PRE_COMMIT detected, executing /commit...");
|
|
963
942
|
// Small delay to let the message finish rendering
|
|
@@ -980,7 +959,7 @@ function createMultiCycleHandler(state) {
|
|
|
980
959
|
}
|
|
981
960
|
}, 2_000);
|
|
982
961
|
}
|
|
983
|
-
// ── CYCLE_COMPLETE: create new session ──
|
|
962
|
+
// ── CYCLE_COMPLETE: create new session (checked before managed session guard) ──
|
|
984
963
|
if (messageContent.includes(CYCLE_COMPLETE_MARKER)) {
|
|
985
964
|
state.cycleCount++;
|
|
986
965
|
if (state.cycleCount >= MAX_CYCLES) {
|
|
@@ -1031,6 +1010,27 @@ function createMultiCycleHandler(state) {
|
|
|
1031
1010
|
}
|
|
1032
1011
|
}, 8_000); // 8s delay: let /commit finish first
|
|
1033
1012
|
}
|
|
1013
|
+
if (!isManagedRootUltraworkSession(state, sessionID))
|
|
1014
|
+
return;
|
|
1015
|
+
const managedSession = getManagedSession(state, sessionID);
|
|
1016
|
+
// Rate-limit message detection (only for managed root sessions)
|
|
1017
|
+
if (sessionID &&
|
|
1018
|
+
messageRole === "assistant" &&
|
|
1019
|
+
RATE_LIMIT_MESSAGE_PATTERN.test(messageContent)) {
|
|
1020
|
+
if (managedSession && !managedSession.fallbackModel) {
|
|
1021
|
+
await setSessionFallbackModel(state, sessionID, RATE_LIMIT_FALLBACK_MODEL);
|
|
1022
|
+
console.log(`[opencode-immune] Rate limit message detected in chat output for session ${sessionID}. ` +
|
|
1023
|
+
`Fallback model pinned to ${RATE_LIMIT_FALLBACK_MODEL.providerID}/${RATE_LIMIT_FALLBACK_MODEL.modelID}.`);
|
|
1024
|
+
}
|
|
1025
|
+
if (managedSession) {
|
|
1026
|
+
scheduleManagedSessionRetry(state, sessionID, {
|
|
1027
|
+
delayMs: 1_000,
|
|
1028
|
+
reason: "rate-limit message fallback",
|
|
1029
|
+
countAgainstBudget: false,
|
|
1030
|
+
abortBeforePrompt: true,
|
|
1031
|
+
});
|
|
1032
|
+
}
|
|
1033
|
+
}
|
|
1034
1034
|
};
|
|
1035
1035
|
}
|
|
1036
1036
|
// ═══════════════════════════════════════════════════════════════════════════════
|