47 lines
1.8 KiB
TypeScript
47 lines
1.8 KiB
TypeScript
import { getSessionId } from '../bootstrap/state.js'
|
|
import { checkStatsigFeatureGate_CACHED_MAY_BE_STALE } from '../services/analytics/growthbook.js'
|
|
import type { SessionId } from '../types/ids.js'
|
|
import { isEnvTruthy } from '../utils/envUtils.js'
|
|
|
|
// -- config
|
|
|
|
// Immutable values snapshotted once at query() entry. Separating these from
|
|
// the per-iteration State struct and the mutable ToolUseContext makes future
|
|
// step() extraction tractable — a pure reducer can take (state, event, config)
|
|
// where config is plain data.
|
|
//
|
|
// Intentionally excludes feature() gates — those are tree-shaking boundaries
|
|
// and must stay inline at the guarded blocks for dead-code elimination.
|
|
export type QueryConfig = {
|
|
sessionId: SessionId
|
|
|
|
// Runtime gates (env/statsig). NOT feature() gates — see above.
|
|
gates: {
|
|
// Statsig — CACHED_MAY_BE_STALE already admits staleness, so snapshotting
|
|
// once per query() call stays within the existing contract.
|
|
streamingToolExecution: boolean
|
|
emitToolUseSummaries: boolean
|
|
isAnt: boolean
|
|
fastModeEnabled: boolean
|
|
}
|
|
}
|
|
|
|
export function buildQueryConfig(): QueryConfig {
|
|
return {
|
|
sessionId: getSessionId(),
|
|
gates: {
|
|
streamingToolExecution: checkStatsigFeatureGate_CACHED_MAY_BE_STALE(
|
|
'tengu_streaming_tool_execution2',
|
|
),
|
|
emitToolUseSummaries: isEnvTruthy(
|
|
process.env.CLAUDE_CODE_EMIT_TOOL_USE_SUMMARIES,
|
|
),
|
|
isAnt: process.env.USER_TYPE === 'ant',
|
|
// Inlined from fastMode.ts to avoid pulling its heavy module graph
|
|
// (axios, settings, auth, model, oauth, config) into test shards that
|
|
// didn't previously load it — changes init order and breaks unrelated tests.
|
|
fastModeEnabled: !isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_FAST_MODE),
|
|
},
|
|
}
|
|
}
|