fix (gateway): redact sensitive status details for non-admin scopes

This commit is contained in:
Vignesh Natarajan
2026-02-14 21:14:55 -08:00
parent 0dec234505
commit fac040cb10
4 changed files with 133 additions and 4 deletions

View File

@@ -67,7 +67,30 @@ const buildFlags = (entry?: SessionEntry): string[] => {
return flags;
};
export async function getStatusSummary(): Promise<StatusSummary> {
export function redactSensitiveStatusSummary(summary: StatusSummary): StatusSummary {
return {
...summary,
sessions: {
...summary.sessions,
paths: [],
defaults: {
model: null,
contextTokens: null,
},
recent: [],
byAgent: summary.sessions.byAgent.map((entry) => ({
...entry,
path: "[redacted]",
recent: [],
})),
},
};
}
export async function getStatusSummary(
options: { includeSensitive?: boolean } = {},
): Promise<StatusSummary> {
const { includeSensitive = true } = options;
const cfg = loadConfig();
const linkContext = await resolveLinkChannelContext(cfg);
const agentList = listAgentsForGateway(cfg);
@@ -179,7 +202,7 @@ export async function getStatusSummary(): Promise<StatusSummary> {
const recent = allSessions.slice(0, 10);
const totalSessions = allSessions.length;
return {
const summary: StatusSummary = {
linkChannel: linkContext
? {
id: linkContext.plugin.id,
@@ -205,4 +228,5 @@ export async function getStatusSummary(): Promise<StatusSummary> {
byAgent,
},
};
return includeSensitive ? summary : redactSensitiveStatusSummary(summary);
}