rename.ts
commands/rename/rename.ts
88
Lines
2759
Bytes
1
Exports
9
Imports
10
Keywords
What this is
This page documents one file from the repository and includes its full source so you can read it without leaving the docs site.
Beginner explanation
This file lives in the command layer. It likely turns a user action into concrete program behavior.
How it is used
Start from the exports list and related files. Those are the easiest clues for where this file fits into the system.
Expert explanation
Architecturally, this file intersects with commands. It contains 88 lines, 9 detected imports, and 1 detected exports.
Important relationships
Detected exports
call
Keywords
newnamecontextsessionnamebridgeondoneargsdisplayutilsteammate
Detected imports
crypto../../bootstrap/state.js../../bridge/bridgeConfig.js../../Tool.js../../types/command.js../../utils/messages.js../../utils/sessionStorage.js../../utils/teammate.js./generateSessionName.js
Source notes
This page embeds the full file contents. Small or leaf files are still indexed honestly instead of being over-explained.
Full source
import type { UUID } from 'crypto'
import { getSessionId } from '../../bootstrap/state.js'
import {
getBridgeBaseUrlOverride,
getBridgeTokenOverride,
} from '../../bridge/bridgeConfig.js'
import type { ToolUseContext } from '../../Tool.js'
import type {
LocalJSXCommandContext,
LocalJSXCommandOnDone,
} from '../../types/command.js'
import { getMessagesAfterCompactBoundary } from '../../utils/messages.js'
import {
getTranscriptPath,
saveAgentName,
saveCustomTitle,
} from '../../utils/sessionStorage.js'
import { isTeammate } from '../../utils/teammate.js'
import { generateSessionName } from './generateSessionName.js'
export async function call(
onDone: LocalJSXCommandOnDone,
context: ToolUseContext & LocalJSXCommandContext,
args: string,
): Promise<null> {
// Prevent teammates from renaming - their names are set by team leader
if (isTeammate()) {
onDone(
'Cannot rename: This session is a swarm teammate. Teammate names are set by the team leader.',
{ display: 'system' },
)
return null
}
let newName: string
if (!args || args.trim() === '') {
const generated = await generateSessionName(
getMessagesAfterCompactBoundary(context.messages),
context.abortController.signal,
)
if (!generated) {
onDone(
'Could not generate a name: no conversation context yet. Usage: /rename <name>',
{ display: 'system' },
)
return null
}
newName = generated
} else {
newName = args.trim()
}
const sessionId = getSessionId() as UUID
const fullPath = getTranscriptPath()
// Always save the custom title (session name)
await saveCustomTitle(sessionId, newName, fullPath)
// Sync title to bridge session on claude.ai/code (best-effort, non-blocking).
// v2 env-less bridge stores cse_* in replBridgeSessionId —
// updateBridgeSessionTitle retags internally for the compat endpoint.
const appState = context.getAppState()
const bridgeSessionId = appState.replBridgeSessionId
if (bridgeSessionId) {
const tokenOverride = getBridgeTokenOverride()
void import('../../bridge/createSession.js').then(
({ updateBridgeSessionTitle }) =>
updateBridgeSessionTitle(bridgeSessionId, newName, {
baseUrl: getBridgeBaseUrlOverride(),
getAccessToken: tokenOverride ? () => tokenOverride : undefined,
}).catch(() => {}),
)
}
// Also persist as the session's agent name for prompt-bar display
await saveAgentName(sessionId, newName, fullPath)
context.setAppState(prev => ({
...prev,
standaloneAgentContext: {
...prev.standaloneAgentContext,
name: newName,
},
}))
onDone(`Session renamed to: ${newName}`, { display: 'system' })
return null
}