Files
orcs-code/src/migrations/migrateBypassPermissionsAcceptedToSettings.ts
did:key:z6MkqDnb7Siv3Cwj7pGJq4T5EsUisECqR8KpnDLwcaZq5TPr d2542c9a62 asdf
Squash the current repository state back into one baseline commit while
preserving the README reframing and repository contents.

Constraint: User explicitly requested a single squashed commit with subject "asdf"
Confidence: high
Scope-risk: broad
Reversibility: clean
Directive: This commit intentionally rewrites published history; coordinate before future force-pushes
Tested: git status clean; local history rewritten to one commit; force-pushed main to origin and instructkr
Not-tested: Fresh clone verification after push
2026-03-31 03:34:03 -07:00

41 lines
1.2 KiB
TypeScript

import { logEvent } from 'src/services/analytics/index.js'
import { getGlobalConfig, saveGlobalConfig } from '../utils/config.js'
import { logError } from '../utils/log.js'
import {
hasSkipDangerousModePermissionPrompt,
updateSettingsForSource,
} from '../utils/settings/settings.js'
/**
* Migration: Move bypassPermissionsModeAccepted from global config to settings.json
* as skipDangerousModePermissionPrompt. This is a better home since settings.json
* is the user-configurable settings file.
*/
export function migrateBypassPermissionsAcceptedToSettings(): void {
const globalConfig = getGlobalConfig()
if (!globalConfig.bypassPermissionsModeAccepted) {
return
}
try {
if (!hasSkipDangerousModePermissionPrompt()) {
updateSettingsForSource('userSettings', {
skipDangerousModePermissionPrompt: true,
})
}
logEvent('tengu_migrate_bypass_permissions_accepted', {})
saveGlobalConfig(current => {
if (!('bypassPermissionsModeAccepted' in current)) return current
const { bypassPermissionsModeAccepted: _, ...updatedConfig } = current
return updatedConfig
})
} catch (error) {
logError(
new Error(`Failed to migrate bypass permissions accepted: ${error}`),
)
}
}