From 123ae82fca3009df7144fa8d41e1185cd63e61e1 Mon Sep 17 00:00:00 2001 From: Peter Steinberger Date: Sat, 14 Feb 2026 21:48:02 +0000 Subject: [PATCH] refactor(auth): dedupe legacy auth store migration --- src/agents/auth-profiles/store.ts | 100 ++++++++++++------------------ 1 file changed, 38 insertions(+), 62 deletions(-) diff --git a/src/agents/auth-profiles/store.ts b/src/agents/auth-profiles/store.ts index 989d89d8e..8c6f65012 100644 --- a/src/agents/auth-profiles/store.ts +++ b/src/agents/auth-profiles/store.ts @@ -184,6 +184,42 @@ function mergeOAuthFileIntoStore(store: AuthProfileStore): boolean { return mutated; } +function applyLegacyStore(store: AuthProfileStore, legacy: LegacyAuthStore): void { + for (const [provider, cred] of Object.entries(legacy)) { + const profileId = `${provider}:default`; + if (cred.type === "api_key") { + store.profiles[profileId] = { + type: "api_key", + provider: String(cred.provider ?? provider), + key: cred.key, + ...(cred.email ? { email: cred.email } : {}), + }; + continue; + } + if (cred.type === "token") { + store.profiles[profileId] = { + type: "token", + provider: String(cred.provider ?? provider), + token: cred.token, + ...(typeof cred.expires === "number" ? { expires: cred.expires } : {}), + ...(cred.email ? { email: cred.email } : {}), + }; + continue; + } + store.profiles[profileId] = { + type: "oauth", + provider: String(cred.provider ?? provider), + access: cred.access, + refresh: cred.refresh, + expires: cred.expires, + ...(cred.enterpriseUrl ? { enterpriseUrl: cred.enterpriseUrl } : {}), + ...(cred.projectId ? { projectId: cred.projectId } : {}), + ...(cred.accountId ? { accountId: cred.accountId } : {}), + ...(cred.email ? { email: cred.email } : {}), + }; + } +} + export function loadAuthProfileStore(): AuthProfileStore { const authPath = resolveAuthStorePath(); const raw = loadJsonFile(authPath); @@ -204,37 +240,7 @@ export function loadAuthProfileStore(): AuthProfileStore { version: AUTH_STORE_VERSION, profiles: {}, }; - for (const [provider, cred] of Object.entries(legacy)) { - const profileId = `${provider}:default`; - if (cred.type === "api_key") { - store.profiles[profileId] = { - type: "api_key", - provider: String(cred.provider ?? provider), - key: cred.key, - ...(cred.email ? { email: cred.email } : {}), - }; - } else if (cred.type === "token") { - store.profiles[profileId] = { - type: "token", - provider: String(cred.provider ?? provider), - token: cred.token, - ...(typeof cred.expires === "number" ? { expires: cred.expires } : {}), - ...(cred.email ? { email: cred.email } : {}), - }; - } else { - store.profiles[profileId] = { - type: "oauth", - provider: String(cred.provider ?? provider), - access: cred.access, - refresh: cred.refresh, - expires: cred.expires, - ...(cred.enterpriseUrl ? { enterpriseUrl: cred.enterpriseUrl } : {}), - ...(cred.projectId ? { projectId: cred.projectId } : {}), - ...(cred.accountId ? { accountId: cred.accountId } : {}), - ...(cred.email ? { email: cred.email } : {}), - }; - } - } + applyLegacyStore(store, legacy); syncExternalCliCredentials(store); return store; } @@ -280,37 +286,7 @@ function loadAuthProfileStoreForAgent( profiles: {}, }; if (legacy) { - for (const [provider, cred] of Object.entries(legacy)) { - const profileId = `${provider}:default`; - if (cred.type === "api_key") { - store.profiles[profileId] = { - type: "api_key", - provider: String(cred.provider ?? provider), - key: cred.key, - ...(cred.email ? { email: cred.email } : {}), - }; - } else if (cred.type === "token") { - store.profiles[profileId] = { - type: "token", - provider: String(cred.provider ?? provider), - token: cred.token, - ...(typeof cred.expires === "number" ? { expires: cred.expires } : {}), - ...(cred.email ? { email: cred.email } : {}), - }; - } else { - store.profiles[profileId] = { - type: "oauth", - provider: String(cred.provider ?? provider), - access: cred.access, - refresh: cred.refresh, - expires: cred.expires, - ...(cred.enterpriseUrl ? { enterpriseUrl: cred.enterpriseUrl } : {}), - ...(cred.projectId ? { projectId: cred.projectId } : {}), - ...(cred.accountId ? { accountId: cred.accountId } : {}), - ...(cred.email ? { email: cred.email } : {}), - }; - } - } + applyLegacyStore(store, legacy); } const mergedOAuth = mergeOAuthFileIntoStore(store);