mirror of
http://10.0.2.1:3031/sauer/claude-code.git
synced 2026-06-30 18:16:58 +10:00
82 lines
10 KiB
TypeScript
82 lines
10 KiB
TypeScript
|
|
import * as React from 'react';
|
||
|
|
import { clearTrustedDeviceTokenCache } from '../../bridge/trustedDevice.js';
|
||
|
|
import { Text } from '../../ink.js';
|
||
|
|
import { refreshGrowthBookAfterAuthChange } from '../../services/analytics/growthbook.js';
|
||
|
|
import { getGroveNoticeConfig, getGroveSettings } from '../../services/api/grove.js';
|
||
|
|
import { clearPolicyLimitsCache } from '../../services/policyLimits/index.js';
|
||
|
|
// flushTelemetry is loaded lazily to avoid pulling in ~1.1MB of OpenTelemetry at startup
|
||
|
|
import { clearRemoteManagedSettingsCache } from '../../services/remoteManagedSettings/index.js';
|
||
|
|
import { getClaudeAIOAuthTokens, removeApiKey } from '../../utils/auth.js';
|
||
|
|
import { clearBetasCaches } from '../../utils/betas.js';
|
||
|
|
import { saveGlobalConfig } from '../../utils/config.js';
|
||
|
|
import { gracefulShutdownSync } from '../../utils/gracefulShutdown.js';
|
||
|
|
import { getSecureStorage } from '../../utils/secureStorage/index.js';
|
||
|
|
import { clearToolSchemaCache } from '../../utils/toolSchemaCache.js';
|
||
|
|
import { resetUserCache } from '../../utils/user.js';
|
||
|
|
export async function performLogout({
|
||
|
|
clearOnboarding = false
|
||
|
|
}): Promise<void> {
|
||
|
|
// Flush telemetry BEFORE clearing credentials to prevent org data leakage
|
||
|
|
const {
|
||
|
|
flushTelemetry
|
||
|
|
} = await import('../../utils/telemetry/instrumentation.js');
|
||
|
|
await flushTelemetry();
|
||
|
|
await removeApiKey();
|
||
|
|
|
||
|
|
// Wipe all secure storage data on logout
|
||
|
|
const secureStorage = getSecureStorage();
|
||
|
|
secureStorage.delete();
|
||
|
|
await clearAuthRelatedCaches();
|
||
|
|
saveGlobalConfig(current => {
|
||
|
|
const updated = {
|
||
|
|
...current
|
||
|
|
};
|
||
|
|
if (clearOnboarding) {
|
||
|
|
updated.hasCompletedOnboarding = false;
|
||
|
|
updated.subscriptionNoticeCount = 0;
|
||
|
|
updated.hasAvailableSubscription = false;
|
||
|
|
if (updated.customApiKeyResponses?.approved) {
|
||
|
|
updated.customApiKeyResponses = {
|
||
|
|
...updated.customApiKeyResponses,
|
||
|
|
approved: []
|
||
|
|
};
|
||
|
|
}
|
||
|
|
}
|
||
|
|
updated.oauthAccount = undefined;
|
||
|
|
return updated;
|
||
|
|
});
|
||
|
|
}
|
||
|
|
|
||
|
|
// clearing anything memoized that must be invalidated when user/session/auth changes
|
||
|
|
export async function clearAuthRelatedCaches(): Promise<void> {
|
||
|
|
// Clear the OAuth token cache
|
||
|
|
getClaudeAIOAuthTokens.cache?.clear?.();
|
||
|
|
clearTrustedDeviceTokenCache();
|
||
|
|
clearBetasCaches();
|
||
|
|
clearToolSchemaCache();
|
||
|
|
|
||
|
|
// Clear user data cache BEFORE GrowthBook refresh so it picks up fresh credentials
|
||
|
|
resetUserCache();
|
||
|
|
refreshGrowthBookAfterAuthChange();
|
||
|
|
|
||
|
|
// Clear Grove config cache
|
||
|
|
getGroveNoticeConfig.cache?.clear?.();
|
||
|
|
getGroveSettings.cache?.clear?.();
|
||
|
|
|
||
|
|
// Clear remotely managed settings cache
|
||
|
|
await clearRemoteManagedSettingsCache();
|
||
|
|
|
||
|
|
// Clear policy limits cache
|
||
|
|
await clearPolicyLimitsCache();
|
||
|
|
}
|
||
|
|
export async function call(): Promise<React.ReactNode> {
|
||
|
|
await performLogout({
|
||
|
|
clearOnboarding: true
|
||
|
|
});
|
||
|
|
const message = <Text>Successfully logged out from your Anthropic account.</Text>;
|
||
|
|
setTimeout(() => {
|
||
|
|
gracefulShutdownSync(0, 'logout');
|
||
|
|
}, 200);
|
||
|
|
return message;
|
||
|
|
}
|
||
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImNsZWFyVHJ1c3RlZERldmljZVRva2VuQ2FjaGUiLCJUZXh0IiwicmVmcmVzaEdyb3d0aEJvb2tBZnRlckF1dGhDaGFuZ2UiLCJnZXRHcm92ZU5vdGljZUNvbmZpZyIsImdldEdyb3ZlU2V0dGluZ3MiLCJjbGVhclBvbGljeUxpbWl0c0NhY2hlIiwiY2xlYXJSZW1vdGVNYW5hZ2VkU2V0dGluZ3NDYWNoZSIsImdldENsYXVkZUFJT0F1dGhUb2tlbnMiLCJyZW1vdmVBcGlLZXkiLCJjbGVhckJldGFzQ2FjaGVzIiwic2F2ZUdsb2JhbENvbmZpZyIsImdyYWNlZnVsU2h1dGRvd25TeW5jIiwiZ2V0U2VjdXJlU3RvcmFnZSIsImNsZWFyVG9vbFNjaGVtYUNhY2hlIiwicmVzZXRVc2VyQ2FjaGUiLCJwZXJmb3JtTG9nb3V0IiwiY2xlYXJPbmJvYXJkaW5nIiwiUHJvbWlzZSIsImZsdXNoVGVsZW1ldHJ5Iiwic2VjdXJlU3RvcmFnZSIsImRlbGV0ZSIsImNsZWFyQXV0aFJlbGF0ZWRDYWNoZXMiLCJjdXJyZW50IiwidXBkYXRlZCIsImhhc0NvbXBsZXRlZE9uYm9hcmRpbmciLCJzdWJzY3JpcHRpb25Ob3RpY2VDb3VudCIsImhhc0F2YWlsYWJsZVN1YnNjcmlwdGlvbiIsImN1c3RvbUFwaUtleVJlc3BvbnNlcyIsImFwcHJvdmVkIiwib2F1dGhBY2NvdW50IiwidW5kZWZpbmVkIiwiY2FjaGUiLCJjbGVhciIsImNhbGwiLCJSZWFjdE5vZGUiLCJtZXNzYWdlIiwic2V0VGltZW91dCJdLCJzb3VyY2VzIjpbImxvZ291dC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBjbGVhclRydXN0ZWREZXZpY2VUb2tlbkNhY2hlIH0gZnJvbSAnLi4vLi4vYnJpZGdlL3RydXN0ZWREZXZpY2UuanMnXG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vLi4vaW5rLmpzJ1xuaW1wb3J0IHsgcmVmcmVzaEdyb3d0aEJvb2tBZnRlckF1dGhDaGFuZ2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9hbmFseXRpY3MvZ3Jvd3RoYm9vay5qcydcbmltcG9ydCB7XG4gIGdldEdyb3ZlTm90aWNlQ29uZmlnLFxuICBnZXRHcm92ZVNldHRpbmdzLFxufSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9hcGkvZ3JvdmUuanMnXG5pbXBvcnQgeyBjbGVhclBvbGljeUxpbWl0c0NhY2hlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvcG9saWN5TGltaXRzL2luZGV4LmpzJ1xuLy8gZmx1c2hUZWxlbWV0cnkgaXMgbG9hZGVkIGxhemlseSB0byBhdm9pZCBwdWxsaW5nIGluIH4xLjFNQiBvZiBPcGVuVGVsZW1ldHJ5IGF0IHN0YXJ0dXBcbmltcG9ydCB7IGNsZWFyUmVtb3RlTWFuYWdlZFNldHRpbmdzQ2FjaGUgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9yZW1vdGVNYW5hZ2VkU2V0dGluZ3MvaW5kZXguanMnXG5pbXBvcnQgeyBnZXRDbGF1ZGVBSU9BdXRoVG9rZW5zLCByZW1vdmVBcGlLZXkgfSBmcm9tICcuLi8uLi91dGlscy9hdXRoLmpzJ1xuaW1wb3J0IHsgY2xlYXJCZXRhc0NhY2hlcyB9IGZyb20gJy4uLy4uL3V0aWxzL2JldGFzLmpzJ1xuaW1wb3J0IHsgc2F2ZUdsb2JhbENvbmZpZyB9IGZyb20gJy4uLy4uL3V0aWxzL2NvbmZpZy5qcydcbmltcG9ydCB7IGdyYWNlZnVsU2h1dGRvd25TeW5jIH0gZnJvbSAnLi4vLi4vdXRpbHMvZ3JhY2VmdWxTaHV0ZG93bi5qcydcbmltcG9ydCB7IGdldFNlY3VyZVN0b3JhZ2UgfSBmcm9tICcuLi8uLi91dGlscy9zZWN1cmVTdG9yYWdlL2luZGV4LmpzJ1xuaW1wb3J0IHsgY2xlYXJUb29sU2NoZW1hQ2FjaGUgfSBmcm9tICcuLi8uLi91dGlscy90b29sU2NoZW1hQ2FjaGUuanMnXG5pbXBvcnQgeyByZXNldFVzZXJDYWNoZSB9IGZyb20gJy4uLy4uL3V0aWxzL3VzZXIuanMnXG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBwZXJmb3JtTG9nb3V0KHtcbiAgY2xlYXJPbmJvYXJkaW5nID0gZmFsc2UsXG59KTogUHJvbWlzZTx2b2lkPiB7XG4gIC8vIEZsdXNoIHRlbGVtZXRyeSBCRUZPUkUgY2xlYXJpbmcgY3JlZGVudGlhbHMgdG8gcHJldmVudCBvcmcgZGF0YSBsZWFrYWdlXG4gIGNvbnN0IHsgZmx1c2hUZWxlbWV0cnkgfSA9IGF3YWl0IGltcG9ydChcbiAgICAnLi4vLi4vdXRpbHMvdGVsZW1ldHJ5L2luc3RydW1lbnRhdGlvbi5qcydcbiAgKVxuICBhd2FpdCBmbHVzaFRlbGVtZXRyeSgpXG5cbiAgYXdhaXQgcmVtb3ZlQXBpS2V5KClcblxuICAvLyBXaXBlIGFsbCBzZWN1cmUgc3RvcmFnZSBkYXRhIG9uIGxvZ291dFxuICBjb25zdCBzZWN1cmVTdG9yYWdlID0gZ2V0U2VjdXJlU3RvcmFnZSgpXG4gIHNlY3VyZVN0b3JhZ2UuZGVsZXRlKClcblxuICBhd2FpdCBjbGVhckF1dGhSZWxhdGVkQ2FjaGVzKClcbiAgc2F2ZUdsb2JhbENvbmZpZyhjdXJyZW50ID0+IHtcbiAgICBjb25zdCB1cGRhdGVkID0geyAuLi5jdXJyZW50IH1cbiAgICBpZiAoY2xlYXJPbmJvYXJkaW5nKSB7XG4gICAgICB1cGRhdGVkLmhhc0NvbXBsZXRlZE9uYm9hcmRpbmcgPSBmYWxzZVxuICAgICAgdXBkYXRlZC5zdWJzY3JpcHRpb25Ob3RpY2VDb3VudCA9IDBcbiAgICAgIHVwZGF0ZWQuaGFzQXZhaWxhYmxlU3Vic2NyaXB0aW9uID0gZmFsc2VcbiAgICAgIGlmICh1cGRhdGVkLmN1c3RvbUFwaUtleVJlc3BvbnNlcz8uYXBwcm92ZWQpIHtcbiAgICAgICAgdXBkYXRlZC5jdXN0b21BcGlLZXlSZXNwb25zZXMgPSB7XG4gICAgICAgICAgLi4udXBkYXRlZC5jdXN0b21BcGlLZXlSZXNwb25zZXMsXG4gICAgICAgICAgYXBwcm92ZWQ6IFtdLFxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICAgIHVwZGF0ZWQub2F1dGhBY2NvdW50ID0gdW5kZWZpbmVkXG4gICAgcmV0dXJuIHVwZGF0ZWRcbiAgfSlcbn1cblxuLy8gY2xlYXJpbmcgYW55dGhpbmcgbWVtb2l6ZWQgdGhhdCBtdXN0IGJlIGludmFsaWRhdGVkIHdoZW4gdXNlci9zZXNzaW9uL2F1dGggY2hhbmdlc1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGNsZWFyQXV0aFJlbGF0ZWRDYWNoZXMoKTogUHJvbWlzZTx2b2lkPiB7XG4gIC8vIENsZWFyIHRoZSBPQXV0aCB0b2tlbiBjYWNoZVxuICBnZXRDbGF1ZGVBSU9BdXRoVG9rZW5zLmNhY2hlPy5jbGVhcj8uKClcbiAgY2xlYXJUcnVzdGVkRGV2aWNlVG9rZW5DYWNoZSg
|