refactor: centralize session agent resolution
This commit is contained in:
@@ -3,7 +3,11 @@ import path from "node:path";
|
|||||||
|
|
||||||
import type { ClawdbotConfig } from "../config/config.js";
|
import type { ClawdbotConfig } from "../config/config.js";
|
||||||
import { resolveStateDir } from "../config/paths.js";
|
import { resolveStateDir } from "../config/paths.js";
|
||||||
import { DEFAULT_AGENT_ID, normalizeAgentId } from "../routing/session-key.js";
|
import {
|
||||||
|
DEFAULT_AGENT_ID,
|
||||||
|
normalizeAgentId,
|
||||||
|
parseAgentSessionKey,
|
||||||
|
} from "../routing/session-key.js";
|
||||||
import { resolveUserPath } from "../utils.js";
|
import { resolveUserPath } from "../utils.js";
|
||||||
import { DEFAULT_AGENT_WORKSPACE_DIR } from "./workspace.js";
|
import { DEFAULT_AGENT_WORKSPACE_DIR } from "./workspace.js";
|
||||||
|
|
||||||
@@ -49,6 +53,26 @@ export function resolveDefaultAgentId(cfg: ClawdbotConfig): string {
|
|||||||
return normalizeAgentId(chosen || DEFAULT_AGENT_ID);
|
return normalizeAgentId(chosen || DEFAULT_AGENT_ID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function resolveSessionAgentIds(params: {
|
||||||
|
sessionKey?: string;
|
||||||
|
config?: ClawdbotConfig;
|
||||||
|
}): { defaultAgentId: string; sessionAgentId: string } {
|
||||||
|
const defaultAgentId = resolveDefaultAgentId(params.config ?? {});
|
||||||
|
const sessionKey = params.sessionKey?.trim();
|
||||||
|
const parsed = sessionKey ? parseAgentSessionKey(sessionKey) : null;
|
||||||
|
const sessionAgentId = parsed?.agentId
|
||||||
|
? normalizeAgentId(parsed.agentId)
|
||||||
|
: defaultAgentId;
|
||||||
|
return { defaultAgentId, sessionAgentId };
|
||||||
|
}
|
||||||
|
|
||||||
|
export function resolveSessionAgentId(params: {
|
||||||
|
sessionKey?: string;
|
||||||
|
config?: ClawdbotConfig;
|
||||||
|
}): string {
|
||||||
|
return resolveSessionAgentIds(params).sessionAgentId;
|
||||||
|
}
|
||||||
|
|
||||||
function resolveAgentEntry(
|
function resolveAgentEntry(
|
||||||
cfg: ClawdbotConfig,
|
cfg: ClawdbotConfig,
|
||||||
agentId: string,
|
agentId: string,
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ import { shouldLogVerbose } from "../globals.js";
|
|||||||
import { createSubsystemLogger } from "../logging.js";
|
import { createSubsystemLogger } from "../logging.js";
|
||||||
import { runCommandWithTimeout } from "../process/exec.js";
|
import { runCommandWithTimeout } from "../process/exec.js";
|
||||||
import { resolveUserPath } from "../utils.js";
|
import { resolveUserPath } from "../utils.js";
|
||||||
|
import { resolveSessionAgentIds } from "./agent-scope.js";
|
||||||
import { FailoverError, resolveFailoverStatus } from "./failover-error.js";
|
import { FailoverError, resolveFailoverStatus } from "./failover-error.js";
|
||||||
import {
|
import {
|
||||||
buildBootstrapContextFiles,
|
buildBootstrapContextFiles,
|
||||||
@@ -136,6 +137,7 @@ function buildSystemPrompt(params: {
|
|||||||
defaultThinkLevel?: ThinkLevel;
|
defaultThinkLevel?: ThinkLevel;
|
||||||
extraSystemPrompt?: string;
|
extraSystemPrompt?: string;
|
||||||
ownerNumbers?: string[];
|
ownerNumbers?: string[];
|
||||||
|
heartbeatPrompt?: string;
|
||||||
tools: AgentTool[];
|
tools: AgentTool[];
|
||||||
contextFiles?: EmbeddedContextFile[];
|
contextFiles?: EmbeddedContextFile[];
|
||||||
modelDisplay: string;
|
modelDisplay: string;
|
||||||
@@ -150,9 +152,7 @@ function buildSystemPrompt(params: {
|
|||||||
extraSystemPrompt: params.extraSystemPrompt,
|
extraSystemPrompt: params.extraSystemPrompt,
|
||||||
ownerNumbers: params.ownerNumbers,
|
ownerNumbers: params.ownerNumbers,
|
||||||
reasoningTagHint: false,
|
reasoningTagHint: false,
|
||||||
heartbeatPrompt: resolveHeartbeatPrompt(
|
heartbeatPrompt: params.heartbeatPrompt,
|
||||||
params.config?.agents?.defaults?.heartbeat?.prompt,
|
|
||||||
),
|
|
||||||
runtimeInfo: {
|
runtimeInfo: {
|
||||||
host: "clawdbot",
|
host: "clawdbot",
|
||||||
os: `${os.type()} ${os.release()}`,
|
os: `${os.type()} ${os.release()}`,
|
||||||
@@ -374,12 +374,23 @@ export async function runClaudeCliAgent(params: {
|
|||||||
params.sessionKey ?? params.sessionId,
|
params.sessionKey ?? params.sessionId,
|
||||||
);
|
);
|
||||||
const contextFiles = buildBootstrapContextFiles(bootstrapFiles);
|
const contextFiles = buildBootstrapContextFiles(bootstrapFiles);
|
||||||
|
const { defaultAgentId, sessionAgentId } = resolveSessionAgentIds({
|
||||||
|
sessionKey: params.sessionKey,
|
||||||
|
config: params.config,
|
||||||
|
});
|
||||||
|
const heartbeatPrompt =
|
||||||
|
sessionAgentId === defaultAgentId
|
||||||
|
? resolveHeartbeatPrompt(
|
||||||
|
params.config?.agents?.defaults?.heartbeat?.prompt,
|
||||||
|
)
|
||||||
|
: undefined;
|
||||||
const systemPrompt = buildSystemPrompt({
|
const systemPrompt = buildSystemPrompt({
|
||||||
workspaceDir,
|
workspaceDir,
|
||||||
config: params.config,
|
config: params.config,
|
||||||
defaultThinkLevel: params.thinkLevel,
|
defaultThinkLevel: params.thinkLevel,
|
||||||
extraSystemPrompt,
|
extraSystemPrompt,
|
||||||
ownerNumbers: params.ownerNumbers,
|
ownerNumbers: params.ownerNumbers,
|
||||||
|
heartbeatPrompt,
|
||||||
tools: [],
|
tools: [],
|
||||||
contextFiles,
|
contextFiles,
|
||||||
modelDisplay,
|
modelDisplay,
|
||||||
|
|||||||
@@ -3,11 +3,11 @@ import { SessionManager } from "@mariozechner/pi-coding-agent";
|
|||||||
import { Type } from "@sinclair/typebox";
|
import { Type } from "@sinclair/typebox";
|
||||||
import { describe, expect, it, vi } from "vitest";
|
import { describe, expect, it, vi } from "vitest";
|
||||||
import type { ClawdbotConfig } from "../config/config.js";
|
import type { ClawdbotConfig } from "../config/config.js";
|
||||||
|
import { resolveSessionAgentIds } from "./agent-scope.js";
|
||||||
import {
|
import {
|
||||||
applyGoogleTurnOrderingFix,
|
applyGoogleTurnOrderingFix,
|
||||||
buildEmbeddedSandboxInfo,
|
buildEmbeddedSandboxInfo,
|
||||||
createSystemPromptOverride,
|
createSystemPromptOverride,
|
||||||
resolveSessionAgentIds,
|
|
||||||
splitSdkTools,
|
splitSdkTools,
|
||||||
} from "./pi-embedded-runner.js";
|
} from "./pi-embedded-runner.js";
|
||||||
import type { SandboxContext } from "./sandbox.js";
|
import type { SandboxContext } from "./sandbox.js";
|
||||||
@@ -82,6 +82,22 @@ describe("resolveSessionAgentIds", () => {
|
|||||||
expect(sessionAgentId).toBe("beta");
|
expect(sessionAgentId).toBe("beta");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("falls back to the configured default for global sessions", () => {
|
||||||
|
const { sessionAgentId } = resolveSessionAgentIds({
|
||||||
|
sessionKey: "global",
|
||||||
|
config: cfg,
|
||||||
|
});
|
||||||
|
expect(sessionAgentId).toBe("beta");
|
||||||
|
});
|
||||||
|
|
||||||
|
it("keeps the agent id for provider-qualified agent sessions", () => {
|
||||||
|
const { sessionAgentId } = resolveSessionAgentIds({
|
||||||
|
sessionKey: "agent:beta:slack:channel:C1",
|
||||||
|
config: cfg,
|
||||||
|
});
|
||||||
|
expect(sessionAgentId).toBe("beta");
|
||||||
|
});
|
||||||
|
|
||||||
it("uses the agent id from agent session keys", () => {
|
it("uses the agent id from agent session keys", () => {
|
||||||
const { sessionAgentId } = resolveSessionAgentIds({
|
const { sessionAgentId } = resolveSessionAgentIds({
|
||||||
sessionKey: "agent:main:main",
|
sessionKey: "agent:main:main",
|
||||||
|
|||||||
@@ -33,14 +33,10 @@ import {
|
|||||||
type enqueueCommand,
|
type enqueueCommand,
|
||||||
enqueueCommandInLane,
|
enqueueCommandInLane,
|
||||||
} from "../process/command-queue.js";
|
} from "../process/command-queue.js";
|
||||||
import {
|
|
||||||
normalizeAgentId,
|
|
||||||
parseAgentSessionKey,
|
|
||||||
} from "../routing/session-key.js";
|
|
||||||
import { normalizeMessageProvider } from "../utils/message-provider.js";
|
import { normalizeMessageProvider } from "../utils/message-provider.js";
|
||||||
import { resolveUserPath } from "../utils.js";
|
import { resolveUserPath } from "../utils.js";
|
||||||
import { resolveClawdbotAgentDir } from "./agent-paths.js";
|
import { resolveClawdbotAgentDir } from "./agent-paths.js";
|
||||||
import { resolveDefaultAgentId } from "./agent-scope.js";
|
import { resolveSessionAgentIds } from "./agent-scope.js";
|
||||||
import {
|
import {
|
||||||
markAuthProfileFailure,
|
markAuthProfileFailure,
|
||||||
markAuthProfileGood,
|
markAuthProfileGood,
|
||||||
@@ -560,19 +556,6 @@ export function buildEmbeddedSandboxInfo(
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export function resolveSessionAgentIds(params: {
|
|
||||||
sessionKey?: string;
|
|
||||||
config?: ClawdbotConfig;
|
|
||||||
}): { defaultAgentId: string; sessionAgentId: string } {
|
|
||||||
const defaultAgentId = resolveDefaultAgentId(params.config ?? {});
|
|
||||||
const sessionKey = params.sessionKey?.trim();
|
|
||||||
const parsed = sessionKey ? parseAgentSessionKey(sessionKey) : null;
|
|
||||||
const sessionAgentId = parsed?.agentId
|
|
||||||
? normalizeAgentId(parsed.agentId)
|
|
||||||
: defaultAgentId;
|
|
||||||
return { defaultAgentId, sessionAgentId };
|
|
||||||
}
|
|
||||||
|
|
||||||
function buildEmbeddedSystemPrompt(params: {
|
function buildEmbeddedSystemPrompt(params: {
|
||||||
workspaceDir: string;
|
workspaceDir: string;
|
||||||
defaultThinkLevel?: ThinkLevel;
|
defaultThinkLevel?: ThinkLevel;
|
||||||
|
|||||||
@@ -5,8 +5,8 @@ import { fileURLToPath } from "node:url";
|
|||||||
import {
|
import {
|
||||||
resolveAgentConfig,
|
resolveAgentConfig,
|
||||||
resolveAgentDir,
|
resolveAgentDir,
|
||||||
resolveAgentIdFromSessionKey,
|
|
||||||
resolveAgentWorkspaceDir,
|
resolveAgentWorkspaceDir,
|
||||||
|
resolveSessionAgentId,
|
||||||
} from "../agents/agent-scope.js";
|
} from "../agents/agent-scope.js";
|
||||||
import { resolveModelRefFromString } from "../agents/model-selection.js";
|
import { resolveModelRefFromString } from "../agents/model-selection.js";
|
||||||
import {
|
import {
|
||||||
@@ -250,7 +250,10 @@ export async function getReplyFromConfig(
|
|||||||
configOverride?: ClawdbotConfig,
|
configOverride?: ClawdbotConfig,
|
||||||
): Promise<ReplyPayload | ReplyPayload[] | undefined> {
|
): Promise<ReplyPayload | ReplyPayload[] | undefined> {
|
||||||
const cfg = configOverride ?? loadConfig();
|
const cfg = configOverride ?? loadConfig();
|
||||||
const agentId = resolveAgentIdFromSessionKey(ctx.SessionKey);
|
const agentId = resolveSessionAgentId({
|
||||||
|
sessionKey: ctx.SessionKey,
|
||||||
|
config: cfg,
|
||||||
|
});
|
||||||
const agentCfg = cfg.agents?.defaults;
|
const agentCfg = cfg.agents?.defaults;
|
||||||
const sessionCfg = cfg.session;
|
const sessionCfg = cfg.session;
|
||||||
const { defaultProvider, defaultModel, aliasIndex } = resolveDefaultModel({
|
const { defaultProvider, defaultModel, aliasIndex } = resolveDefaultModel({
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
import { resolveSessionAgentId } from "../../agents/agent-scope.js";
|
||||||
import { abortEmbeddedPiRun } from "../../agents/pi-embedded.js";
|
import { abortEmbeddedPiRun } from "../../agents/pi-embedded.js";
|
||||||
import type { ClawdbotConfig } from "../../config/config.js";
|
import type { ClawdbotConfig } from "../../config/config.js";
|
||||||
import {
|
import {
|
||||||
@@ -7,10 +8,7 @@ import {
|
|||||||
saveSessionStore,
|
saveSessionStore,
|
||||||
type SessionEntry,
|
type SessionEntry,
|
||||||
} from "../../config/sessions.js";
|
} from "../../config/sessions.js";
|
||||||
import {
|
import { parseAgentSessionKey } from "../../routing/session-key.js";
|
||||||
parseAgentSessionKey,
|
|
||||||
resolveAgentIdFromSessionKey,
|
|
||||||
} from "../../routing/session-key.js";
|
|
||||||
import { resolveCommandAuthorization } from "../command-auth.js";
|
import { resolveCommandAuthorization } from "../command-auth.js";
|
||||||
import {
|
import {
|
||||||
normalizeCommandBody,
|
normalizeCommandBody,
|
||||||
@@ -80,9 +78,10 @@ export async function tryFastAbortFromMessage(params: {
|
|||||||
if (!auth.isAuthorizedSender) return { handled: false, aborted: false };
|
if (!auth.isAuthorizedSender) return { handled: false, aborted: false };
|
||||||
|
|
||||||
const targetKey = resolveAbortTargetKey(ctx);
|
const targetKey = resolveAbortTargetKey(ctx);
|
||||||
const agentId = resolveAgentIdFromSessionKey(
|
const agentId = resolveSessionAgentId({
|
||||||
targetKey ?? ctx.SessionKey ?? "",
|
sessionKey: targetKey ?? ctx.SessionKey ?? "",
|
||||||
);
|
config: cfg,
|
||||||
|
});
|
||||||
const raw = stripStructuralPrefixes(ctx.Body ?? "");
|
const raw = stripStructuralPrefixes(ctx.Body ?? "");
|
||||||
const isGroup = ctx.ChatType?.trim().toLowerCase() === "group";
|
const isGroup = ctx.ChatType?.trim().toLowerCase() === "group";
|
||||||
const stripped = isGroup ? stripMentions(raw, ctx, cfg, agentId) : raw;
|
const stripped = isGroup ? stripMentions(raw, ctx, cfg, agentId) : raw;
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import {
|
import {
|
||||||
resolveAgentDir,
|
resolveAgentDir,
|
||||||
resolveDefaultAgentId,
|
resolveDefaultAgentId,
|
||||||
|
resolveSessionAgentId,
|
||||||
} from "../../agents/agent-scope.js";
|
} from "../../agents/agent-scope.js";
|
||||||
import {
|
import {
|
||||||
ensureAuthProfileStore,
|
ensureAuthProfileStore,
|
||||||
@@ -26,7 +27,6 @@ import {
|
|||||||
unsetConfigOverride,
|
unsetConfigOverride,
|
||||||
} from "../../config/runtime-overrides.js";
|
} from "../../config/runtime-overrides.js";
|
||||||
import {
|
import {
|
||||||
resolveAgentIdFromSessionKey,
|
|
||||||
resolveSessionFilePath,
|
resolveSessionFilePath,
|
||||||
type SessionEntry,
|
type SessionEntry,
|
||||||
type SessionScope,
|
type SessionScope,
|
||||||
@@ -148,7 +148,7 @@ export async function buildStatusReply(params: {
|
|||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
const statusAgentId = sessionKey
|
const statusAgentId = sessionKey
|
||||||
? resolveAgentIdFromSessionKey(sessionKey)
|
? resolveSessionAgentId({ sessionKey, config: cfg })
|
||||||
: resolveDefaultAgentId(cfg);
|
: resolveDefaultAgentId(cfg);
|
||||||
const statusAgentDir = resolveAgentDir(cfg, statusAgentId);
|
const statusAgentDir = resolveAgentDir(cfg, statusAgentId);
|
||||||
let usageLine: string | null = null;
|
let usageLine: string | null = null;
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ import {
|
|||||||
resolveAgentConfig,
|
resolveAgentConfig,
|
||||||
resolveAgentDir,
|
resolveAgentDir,
|
||||||
resolveDefaultAgentId,
|
resolveDefaultAgentId,
|
||||||
|
resolveSessionAgentId,
|
||||||
} from "../../agents/agent-scope.js";
|
} from "../../agents/agent-scope.js";
|
||||||
import {
|
import {
|
||||||
isProfileInCooldown,
|
isProfileInCooldown,
|
||||||
@@ -31,7 +32,6 @@ import {
|
|||||||
import { resolveSandboxConfigForAgent } from "../../agents/sandbox.js";
|
import { resolveSandboxConfigForAgent } from "../../agents/sandbox.js";
|
||||||
import type { ClawdbotConfig } from "../../config/config.js";
|
import type { ClawdbotConfig } from "../../config/config.js";
|
||||||
import {
|
import {
|
||||||
resolveAgentIdFromSessionKey,
|
|
||||||
resolveAgentMainSessionKey,
|
resolveAgentMainSessionKey,
|
||||||
type SessionEntry,
|
type SessionEntry,
|
||||||
saveSessionStore,
|
saveSessionStore,
|
||||||
@@ -491,14 +491,18 @@ export async function handleDirectiveOnly(params: {
|
|||||||
currentReasoningLevel,
|
currentReasoningLevel,
|
||||||
currentElevatedLevel,
|
currentElevatedLevel,
|
||||||
} = params;
|
} = params;
|
||||||
const activeAgentId = params.sessionKey
|
const activeAgentId = resolveSessionAgentId({
|
||||||
? resolveAgentIdFromSessionKey(params.sessionKey)
|
sessionKey: params.sessionKey,
|
||||||
: resolveDefaultAgentId(params.cfg);
|
config: params.cfg,
|
||||||
|
});
|
||||||
const agentDir = resolveAgentDir(params.cfg, activeAgentId);
|
const agentDir = resolveAgentDir(params.cfg, activeAgentId);
|
||||||
const runtimeIsSandboxed = (() => {
|
const runtimeIsSandboxed = (() => {
|
||||||
const sessionKey = params.sessionKey?.trim();
|
const sessionKey = params.sessionKey?.trim();
|
||||||
if (!sessionKey) return false;
|
if (!sessionKey) return false;
|
||||||
const agentId = resolveAgentIdFromSessionKey(sessionKey);
|
const agentId = resolveSessionAgentId({
|
||||||
|
sessionKey,
|
||||||
|
config: params.cfg,
|
||||||
|
});
|
||||||
const sandboxCfg = resolveSandboxConfigForAgent(params.cfg, agentId);
|
const sandboxCfg = resolveSandboxConfigForAgent(params.cfg, agentId);
|
||||||
if (sandboxCfg.mode === "off") return false;
|
if (sandboxCfg.mode === "off") return false;
|
||||||
const mainKey = resolveAgentMainSessionKey({
|
const mainKey = resolveAgentMainSessionKey({
|
||||||
@@ -1013,7 +1017,7 @@ export async function persistInlineDirectives(params: {
|
|||||||
} = params;
|
} = params;
|
||||||
let { provider, model } = params;
|
let { provider, model } = params;
|
||||||
const activeAgentId = sessionKey
|
const activeAgentId = sessionKey
|
||||||
? resolveAgentIdFromSessionKey(sessionKey)
|
? resolveSessionAgentId({ sessionKey, config: cfg })
|
||||||
: resolveDefaultAgentId(cfg);
|
: resolveDefaultAgentId(cfg);
|
||||||
const agentDir = resolveAgentDir(cfg, activeAgentId);
|
const agentDir = resolveAgentDir(cfg, activeAgentId);
|
||||||
|
|
||||||
|
|||||||
@@ -7,12 +7,12 @@
|
|||||||
* across multiple providers.
|
* across multiple providers.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import { resolveSessionAgentId } from "../../agents/agent-scope.js";
|
||||||
import { resolveEffectiveMessagesConfig } from "../../agents/identity.js";
|
import { resolveEffectiveMessagesConfig } from "../../agents/identity.js";
|
||||||
import type { ClawdbotConfig } from "../../config/config.js";
|
import type { ClawdbotConfig } from "../../config/config.js";
|
||||||
import { sendMessageDiscord } from "../../discord/send.js";
|
import { sendMessageDiscord } from "../../discord/send.js";
|
||||||
import { sendMessageIMessage } from "../../imessage/send.js";
|
import { sendMessageIMessage } from "../../imessage/send.js";
|
||||||
import { sendMessageMSTeams } from "../../msteams/send.js";
|
import { sendMessageMSTeams } from "../../msteams/send.js";
|
||||||
import { resolveAgentIdFromSessionKey } from "../../routing/session-key.js";
|
|
||||||
import { sendMessageSignal } from "../../signal/send.js";
|
import { sendMessageSignal } from "../../signal/send.js";
|
||||||
import { sendMessageSlack } from "../../slack/send.js";
|
import { sendMessageSlack } from "../../slack/send.js";
|
||||||
import { sendMessageTelegram } from "../../telegram/send.js";
|
import { sendMessageTelegram } from "../../telegram/send.js";
|
||||||
@@ -67,7 +67,10 @@ export async function routeReply(
|
|||||||
const responsePrefix = params.sessionKey
|
const responsePrefix = params.sessionKey
|
||||||
? resolveEffectiveMessagesConfig(
|
? resolveEffectiveMessagesConfig(
|
||||||
cfg,
|
cfg,
|
||||||
resolveAgentIdFromSessionKey(params.sessionKey),
|
resolveSessionAgentId({
|
||||||
|
sessionKey: params.sessionKey,
|
||||||
|
config: cfg,
|
||||||
|
}),
|
||||||
).responsePrefix
|
).responsePrefix
|
||||||
: cfg.messages?.responsePrefix === "auto"
|
: cfg.messages?.responsePrefix === "auto"
|
||||||
? undefined
|
? undefined
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import {
|
|||||||
CURRENT_SESSION_VERSION,
|
CURRENT_SESSION_VERSION,
|
||||||
SessionManager,
|
SessionManager,
|
||||||
} from "@mariozechner/pi-coding-agent";
|
} from "@mariozechner/pi-coding-agent";
|
||||||
|
import { resolveSessionAgentId } from "../../agents/agent-scope.js";
|
||||||
import type { ClawdbotConfig } from "../../config/config.js";
|
import type { ClawdbotConfig } from "../../config/config.js";
|
||||||
import {
|
import {
|
||||||
buildGroupDisplayName,
|
buildGroupDisplayName,
|
||||||
@@ -13,7 +14,6 @@ import {
|
|||||||
DEFAULT_RESET_TRIGGERS,
|
DEFAULT_RESET_TRIGGERS,
|
||||||
type GroupKeyResolution,
|
type GroupKeyResolution,
|
||||||
loadSessionStore,
|
loadSessionStore,
|
||||||
resolveAgentIdFromSessionKey,
|
|
||||||
resolveGroupSessionKey,
|
resolveGroupSessionKey,
|
||||||
resolveSessionFilePath,
|
resolveSessionFilePath,
|
||||||
resolveSessionKey,
|
resolveSessionKey,
|
||||||
@@ -92,7 +92,10 @@ export async function initSessionState(params: {
|
|||||||
const { ctx, cfg, commandAuthorized } = params;
|
const { ctx, cfg, commandAuthorized } = params;
|
||||||
const sessionCfg = cfg.session;
|
const sessionCfg = cfg.session;
|
||||||
const mainKey = normalizeMainKey(sessionCfg?.mainKey);
|
const mainKey = normalizeMainKey(sessionCfg?.mainKey);
|
||||||
const agentId = resolveAgentIdFromSessionKey(ctx.SessionKey);
|
const agentId = resolveSessionAgentId({
|
||||||
|
sessionKey: ctx.SessionKey,
|
||||||
|
config: cfg,
|
||||||
|
});
|
||||||
const resetTriggers = sessionCfg?.resetTriggers?.length
|
const resetTriggers = sessionCfg?.resetTriggers?.length
|
||||||
? sessionCfg.resetTriggers
|
? sessionCfg.resetTriggers
|
||||||
: DEFAULT_RESET_TRIGGERS;
|
: DEFAULT_RESET_TRIGGERS;
|
||||||
|
|||||||
Reference in New Issue
Block a user