Documentation
¶
Index ¶
- Constants
- Variables
- func AddSkillSource(name, path, description string) error
- func ApplyProjectSkills(projectPath string, desired []SkillCandidate) error
- func BridgeDaemonHint() string
- func CheckClaudeHooksInstalled(configDir string) bool
- func CleanStaleEventFiles()
- func ClearMCPCache(projectPath string)
- func ClearProjectMCPs(projectPath string) error
- func ClearUserConfigCache()
- func ConductorDir() (string, error)
- func ConductorNameDir(name string) (string, error)
- func ConductorProfileDir(profile string) (string, error)
- func ConductorSessionTitle(name string) string
- func ConvertToClaudeDirName(path string) string
- func CreateExampleConfig() error
- func CreateProfile(profile string) error
- func DeleteProfile(profile string) error
- func ExpandPath(path string) string
- func GenerateHeartbeatPlist(name string, intervalMinutes int) (string, error)
- func GenerateLaunchdPlist() (string, error)
- func GenerateSessionName() string
- func GenerateSystemdBridgeService() (string, error)
- func GenerateSystemdHeartbeatService(name string) (string, error)
- func GenerateSystemdHeartbeatTimer(name string, intervalMinutes int) string
- func GenerateUniqueSessionName(instances []*Instance, groupPath string) string
- func GetAgentDeckDir() (string, error)
- func GetAvailableGeminiModels() ([]string, error)
- func GetAvailableMCPNames() []string
- func GetAvailableMCPs() map[string]MCPDef
- func GetClaudeCommand() string
- func GetClaudeConfigDir() string
- func GetClaudeSessionID(projectPath string) (string, error)
- func GetConfigPath() (string, error)
- func GetCustomToolNames() []string
- func GetDBPathForProfile(profile string) (string, error)
- func GetDefaultTool() string
- func GetDirectoryCompletions(input string) ([]string, error)
- func GetEffectiveProfile(explicit string) string
- func GetEventsDir() string
- func GetGeminiConfigDir() string
- func GetGeminiMCPNames() []string
- func GetGeminiSessionsDir(projectPath string) string
- func GetGlobalHTTPPool() *mcppool.HTTPPool
- func GetGlobalMCPNames() []string
- func GetGlobalPool() *mcppool.Pool
- func GetGlobalPoolRunningCount() int
- func GetGroupLevel(path string) int
- func GetHTTPServerStatus(name string) string
- func GetHooksDir() string
- func GetMCPDefaultScope() string
- func GetManageMCPJson() bool
- func GetProfileDir(profile string) (string, error)
- func GetProfilesDir() (string, error)
- func GetProjectClaudeSkillsPath(projectPath string) string
- func GetProjectMCPNames(projectPath string) []string
- func GetProjectSkillsManifestPath(projectPath string) string
- func GetSkillPoolPath() (string, error)
- func GetSkillSourcesPath() (string, error)
- func GetSkillsRootPath() (string, error)
- func GetTheme() string
- func GetToolBusyPatterns(toolName string) []string
- func GetToolIcon(toolName string) string
- func GetUserConfigPath() (string, error)
- func GetUserMCPNames() []string
- func GetUserMCPRootPath() string
- func GroupByProject(instances []*Instance) map[string][]*Instance
- func HashProjectPath(projectPath string) string
- func HeartbeatPlistLabel(name string) string
- func HeartbeatPlistPath(name string) (string, error)
- func InitializeGlobalPool(ctx context.Context, config *UserConfig, sessions []*Instance) (*mcppool.Pool, error)
- func InjectClaudeHooks(configDir string) (bool, error)
- func InstallBridgeDaemon() (string, error)
- func InstallBridgeScript() error
- func InstallHeartbeatDaemon(name, profile string, intervalMinutes int) error
- func InstallHeartbeatScript(name, profile string) error
- func InstallPolicyMD(customPath string) error
- func InstallSharedClaudeMD(customPath string) error
- func IsBridgeDaemonRunning() bool
- func IsClaudeConfigDirExplicit() bool
- func IsConductorSetup(name string) bool
- func IsHTTPServerRunning(name string) bool
- func LaunchdPlistPath() (string, error)
- func ListMaterializedProjectSkills(projectPath string) ([]string, error)
- func ListProfiles() ([]string, error)
- func LoadSkillSources() (map[string]SkillSourceDef, error)
- func MarshalToolOptions(opts ToolOptions) (json.RawMessage, error)
- func MergeToolPatterns(toolName string) *tmux.RawPatterns
- func MigrateConductorPolicySplit() ([]string, error)
- func MigrateLegacyConductors() ([]string, error)
- func NeedsMigration() (bool, error)
- func ProfileExists(profile string) (bool, error)
- func PruneMCPCache(maxAge time.Duration)
- func ReadPrevEventStatus(instanceID string) string
- func RemoveClaudeHooks(configDir string) (bool, error)
- func RemoveHeartbeatPlist(name string) error
- func RemoveSkillSource(name string) error
- func ResolveTheme() string
- func RestoreFromArchive(baseDir string) error
- func SaveConductorMeta(meta *ConductorMeta) error
- func SaveConfig(config *Config) error
- func SaveProjectSkillsManifest(projectPath string, manifest *ProjectSkillsManifest) error
- func SaveSkillSources(sources map[string]SkillSourceDef) error
- func SaveUserConfig(config *UserConfig) error
- func SetDefaultProfile(profile string) error
- func SetupConductor(name, profile string, heartbeatEnabled bool, description string, ...) error
- func SetupConductorProfile(profile string) error
- func ShutdownGlobalPool(shouldShutdown bool) error
- func StartHTTPServer(name string, def *MCPDef) error
- func StartMaintenanceWorker(ctx context.Context, onComplete func(MaintenanceResult))
- func SystemdBridgeServicePath() (string, error)
- func SystemdHeartbeatServiceName(name string) string
- func SystemdHeartbeatServicePath(name string) (string, error)
- func SystemdHeartbeatTimerName(name string) string
- func SystemdHeartbeatTimerPath(name string) (string, error)
- func SystemdUserDir() (string, error)
- func TeardownConductor(name string) error
- func TeardownConductorProfile(profile string) error
- func TierName(tier SearchTier) string
- func ToggleLocalMCP(projectPath, mcpName string) error
- func UninstallBridgeDaemon() error
- func UninstallHeartbeatDaemon(name string) error
- func UpdateClaudeSessionsWithDedup(instances []*Instance)
- func UpdateGeminiAnalyticsFromDisk(projectPath, sessionID string, analytics *GeminiSessionAnalytics) error
- func ValidateConductorName(name string) error
- func WriteGeminiMCPSettings(enabledNames []string) error
- func WriteGlobalMCP(enabledNames []string) error
- func WriteMCPJsonFromConfig(projectPath string, enabledNames []string) error
- func WriteStatusEvent(event StatusEvent) error
- func WriteUserMCP(enabledNames []string) error
- type AnalyticsDisplaySettings
- type BillingBlock
- type ClaudeConfig
- type ClaudeOptions
- type ClaudeProject
- type ClaudeSettings
- type CodexOptions
- type CodexSettings
- type CompletionCycler
- type ConductorMeta
- type ConductorSettings
- type Config
- type ContentBuffer
- type ExperimentsSettings
- type FileTracker
- type GeminiMCPConfig
- type GeminiModelPricing
- type GeminiSessionAnalytics
- type GeminiSessionInfo
- type GeminiSettings
- type GlobalSearchIndex
- func (idx *GlobalSearchIndex) Close()
- func (idx *GlobalSearchIndex) EntryCount() int
- func (idx *GlobalSearchIndex) FuzzySearch(query string) []*SearchResult
- func (idx *GlobalSearchIndex) GetTier() SearchTier
- func (idx *GlobalSearchIndex) IsLoading() bool
- func (idx *GlobalSearchIndex) Search(query string) []*SearchResult
- type GlobalSearchSettings
- type Group
- type GroupData
- type GroupTree
- func (t *GroupTree) AddSession(inst *Instance)
- func (t *GroupTree) CollapseGroup(path string)
- func (t *GroupTree) CreateGroup(name string) *Group
- func (t *GroupTree) CreateSubgroup(parentPath, name string) *Group
- func (t *GroupTree) DefaultPathForGroup(groupPath string) string
- func (t *GroupTree) DeleteGroup(path string) []*Instance
- func (t *GroupTree) ExpandGroup(path string)
- func (t *GroupTree) ExpandGroupWithParents(path string)
- func (t *GroupTree) Flatten() []Item
- func (t *GroupTree) GetAllInstances() []*Instance
- func (t *GroupTree) GetGroupNames() []string
- func (t *GroupTree) GetGroupPaths() []string
- func (t *GroupTree) GroupCount() int
- func (t *GroupTree) MoveGroupDown(path string)
- func (t *GroupTree) MoveGroupUp(path string)
- func (t *GroupTree) MoveSessionDown(inst *Instance)
- func (t *GroupTree) MoveSessionToGroup(inst *Instance, newGroupPath string)
- func (t *GroupTree) MoveSessionUp(inst *Instance)
- func (t *GroupTree) RemoveSession(inst *Instance)
- func (t *GroupTree) RenameGroup(oldPath, newName string)
- func (t *GroupTree) SessionCount() int
- func (t *GroupTree) SessionCountForGroup(groupPath string) int
- func (t *GroupTree) SetDefaultPathForGroup(groupPath, defaultPath string) bool
- func (t *GroupTree) ShallowCopyForSave() *GroupTree
- func (t *GroupTree) SyncWithInstances(instances []*Instance)
- func (t *GroupTree) ToggleGroup(path string)
- type HTTPServerConfig
- type HookStatus
- type Instance
- func DiscoverExistingTmuxSessions(existingInstances []*Instance) ([]*Instance, error)
- func FilterByQuery(instances []*Instance, query string) []*Instance
- func NewInstance(title, projectPath string) *Instance
- func NewInstanceWithGroup(title, projectPath, groupPath string) *Instance
- func NewInstanceWithGroupAndTool(title, projectPath, groupPath, tool string) *Instance
- func NewInstanceWithTool(title, projectPath, tool string) *Instance
- func (i *Instance) CanFork() bool
- func (i *Instance) CanForkOpenCode() bool
- func (i *Instance) CanRestart() bool
- func (i *Instance) CanRestartGeneric() bool
- func (i *Instance) CaptureLoadedMCPs()
- func (i *Instance) ClearHookStatus()
- func (inst *Instance) ClearParent()
- func (i *Instance) CreateForkedInstance(newTitle, newGroupPath string) (*Instance, string, error)
- func (i *Instance) CreateForkedInstanceWithOptions(newTitle, newGroupPath string, opts *ClaudeOptions) (*Instance, string, error)
- func (i *Instance) CreateForkedOpenCodeInstance(newTitle, newGroupPath string) (*Instance, string, error)
- func (i *Instance) CreateForkedOpenCodeInstanceWithOptions(newTitle, newGroupPath string, opts *OpenCodeOptions) (*Instance, string, error)
- func (i *Instance) DetectCodexSession()
- func (i *Instance) DetectOpenCodeSession()
- func (i *Instance) Exists() bool
- func (i *Instance) ForceNextStatusCheck()
- func (i *Instance) Fork(newTitle, newGroupPath string) (string, error)
- func (i *Instance) ForkOpenCode(newTitle, newGroupPath string) (string, error)
- func (i *Instance) ForkOpenCodeWithOptions(newTitle, newGroupPath string, opts *OpenCodeOptions) (string, error)
- func (i *Instance) ForkWithOptions(newTitle, newGroupPath string, opts *ClaudeOptions) (string, error)
- func (i *Instance) GetActualWorkDir() string
- func (i *Instance) GetClaudeOptions() *ClaudeOptions
- func (i *Instance) GetCodexOptions() *CodexOptions
- func (i *Instance) GetGenericSessionID() string
- func (i *Instance) GetHookStatus() (string, bool)
- func (i *Instance) GetJSONLPath() string
- func (inst *Instance) GetLastActivityTime() time.Time
- func (i *Instance) GetLastResponse() (*ResponseOutput, error)
- func (i *Instance) GetMCPInfo() *MCPInfo
- func (i *Instance) GetOpenCodeOptions() *OpenCodeOptions
- func (i *Instance) GetSessionIDFromTmux() string
- func (inst *Instance) GetStatusThreadSafe() Status
- func (i *Instance) GetTmuxSession() *tmux.Session
- func (inst *Instance) GetToolThreadSafe() string
- func (inst *Instance) GetWaitingSince() time.Time
- func (i *Instance) HasUpdated() bool
- func (inst *Instance) IsSubSession() bool
- func (inst *Instance) IsWorktree() bool
- func (i *Instance) Kill() error
- func (inst *Instance) MarkAccessed()
- func (i *Instance) PostStartSync(maxWait time.Duration)
- func (i *Instance) Preview() (string, error)
- func (i *Instance) PreviewFull() (string, error)
- func (i *Instance) Restart() error
- func (i *Instance) SetAcknowledgedFromShared(ack bool)
- func (i *Instance) SetClaudeOptions(opts *ClaudeOptions) error
- func (i *Instance) SetCodexOptions(opts *CodexOptions) error
- func (i *Instance) SetGeminiModel(model string) error
- func (i *Instance) SetGeminiYoloMode(enabled bool)
- func (i *Instance) SetOpenCodeOptions(opts *OpenCodeOptions) error
- func (inst *Instance) SetParent(parentID string)
- func (inst *Instance) SetParentWithPath(parentID, parentProjectPath string)
- func (inst *Instance) SetStatusThreadSafe(s Status)
- func (inst *Instance) SetToolThreadSafe(t string)
- func (i *Instance) Start() error
- func (i *Instance) StartWithMessage(message string) error
- func (i *Instance) SyncSessionIDsToTmux()
- func (i *Instance) SyncTmuxDisplayName()
- func (i *Instance) UpdateClaudeSession(excludeIDs map[string]bool)
- func (i *Instance) UpdateCodexSession(excludeIDs map[string]bool)
- func (i *Instance) UpdateGeminiSession(excludeIDs map[string]bool)
- func (i *Instance) UpdateHookStatus(status *HookStatus)
- func (i *Instance) UpdateStatus() error
- func (i *Instance) WaitForClaudeSession(maxWait time.Duration) string
- func (i *Instance) WaitForClaudeSessionWithExclude(maxWait time.Duration, excludeIDs map[string]bool) string
- type InstanceData
- type InstanceSettings
- type Item
- type ItemType
- type LocalMCP
- type LogSettings
- type MCPDef
- type MCPInfo
- type MCPMode
- type MCPPoolSettings
- type MCPServer
- type MCPServerConfig
- type MaintenanceResult
- type MaintenanceSettings
- type MatchRange
- type MigrationResult
- type ModelPricing
- type NotificationEntry
- type NotificationManager
- func (nm *NotificationManager) Add(inst *Instance) error
- func (nm *NotificationManager) Clear()
- func (nm *NotificationManager) Count() int
- func (nm *NotificationManager) FormatBar() string
- func (nm *NotificationManager) GetEntries() []*NotificationEntry
- func (nm *NotificationManager) GetSessionByKey(key string) *NotificationEntry
- func (nm *NotificationManager) Has(sessionID string) bool
- func (nm *NotificationManager) Remove(sessionID string)
- func (nm *NotificationManager) SyncFromInstances(instances []*Instance, currentSessionID string) (added, removed []string)
- type NotificationsConfig
- type OpenCodeOptions
- type OpenCodeSettings
- type PreviewSettings
- type ProfileClaudeSettings
- type ProfileSettings
- type ProjectMCPSettings
- type ProjectSkillAttachment
- type ProjectSkillsManifest
- type ResponseOutput
- type SearchEntry
- type SearchResult
- type SearchTier
- type SessionAnalytics
- type ShellSettings
- type SkillCandidate
- type SkillSource
- type SkillSourceDef
- type SkillSourcesConfig
- type SlackSettings
- type Status
- type StatusEvent
- type StatusEventWatcher
- type StatusFileWatcher
- type StatusSettings
- type Storage
- func (s *Storage) Close() error
- func (s *Storage) DeleteInstance(id string) error
- func (s *Storage) GetDB() *statedb.StateDB
- func (s *Storage) GetFileMtime() (time.Time, error)
- func (s *Storage) GetUpdatedAt() (time.Time, error)
- func (s *Storage) Load() ([]*Instance, error)
- func (s *Storage) LoadLite() ([]*InstanceData, []*GroupData, error)
- func (s *Storage) LoadWithGroups() ([]*Instance, []*GroupData, error)
- func (s *Storage) Path() string
- func (s *Storage) Profile() string
- func (s *Storage) Save(instances []*Instance) error
- func (s *Storage) SaveGroupsOnly(groupTree *GroupTree) error
- func (s *Storage) SaveWithGroups(instances []*Instance, groupTree *GroupTree) error
- type StorageData
- type SubagentInfo
- type TelegramSettings
- type TmuxSettings
- type ToolCall
- type ToolDef
- type ToolOptions
- type ToolOptionsWrapper
- type UpdateSettings
- type UserConfig
- type WorktreeSettings
Constants ¶
const ( // DefaultProfile is the name of the default profile DefaultProfile = "default" // ProfilesDirName is the directory containing all profiles ProfilesDirName = "profiles" // ConfigFileName is the global config file name ConfigFileName = "config.json" )
const DefaultGroupName = "My Sessions"
DefaultGroupName is the display name for the default group where ungrouped sessions go
const DefaultGroupPath = "my-sessions"
DefaultGroupPath is the normalized path for the default group (used for lookups and protection)
const LaunchdPlistName = "com.agentdeck.conductor-bridge"
LaunchdPlistName is the launchd label for the conductor bridge daemon
const TierThresholdBalanced = 500 * 1024 * 1024
TierThresholdBalanced is the max size for balanced tier (500MB)
const TierThresholdInstant = 100 * 1024 * 1024
TierThresholdInstant is the max size for instant tier (100MB)
const UserConfigFileName = "config.toml"
UserConfigFileName is the TOML config file for user preferences
Variables ¶
var ( ErrSkillSourceExists = errors.New("skill source already exists") ErrSkillSourceNotFound = errors.New("skill source not found") ErrSkillNotFound = errors.New("skill not found") ErrSkillAmbiguous = errors.New("skill reference is ambiguous") ErrSkillAlreadyAttached = errors.New("skill already attached") ErrSkillNotAttached = errors.New("skill not attached") ErrSkillTargetConflict = errors.New("skill target path conflict") )
Functions ¶
func AddSkillSource ¶ added in v0.19.1
AddSkillSource adds a new named local source path.
func ApplyProjectSkills ¶ added in v0.19.1
func ApplyProjectSkills(projectPath string, desired []SkillCandidate) error
ApplyProjectSkills makes project attachments exactly match desired candidates. This is useful for TUI apply flows where users move items between columns.
func BridgeDaemonHint ¶ added in v0.16.0
func BridgeDaemonHint() string
BridgeDaemonHint returns a platform-appropriate hint for starting the bridge daemon.
func CheckClaudeHooksInstalled ¶ added in v0.16.0
CheckClaudeHooksInstalled checks if agent-deck hooks are present in settings.json.
func CleanStaleEventFiles ¶ added in v0.18.0
func CleanStaleEventFiles()
CleanStaleEventFiles removes event files older than 24 hours.
func ClearMCPCache ¶ added in v0.5.3
func ClearMCPCache(projectPath string)
ClearMCPCache invalidates the MCP cache for a project path and all parent directories This is important because getMCPInfoUncached walks up parent directories to find .mcp.json
func ClearProjectMCPs ¶ added in v0.5.3
ClearProjectMCPs removes all MCPs from projects[path].mcpServers in Claude's config
func ClearUserConfigCache ¶ added in v0.8.12
func ClearUserConfigCache()
ClearUserConfigCache clears the cached user config, allowing tests to reset state This does NOT reload - the next LoadUserConfig() call will read fresh from disk
func ConductorDir ¶ added in v0.12.0
ConductorDir returns the base conductor directory (~/.agent-deck/conductor)
func ConductorNameDir ¶ added in v0.12.0
ConductorNameDir returns the directory for a named conductor (~/.agent-deck/conductor/<name>)
func ConductorProfileDir ¶ added in v0.12.0
ConductorProfileDir returns the per-profile conductor directory. Deprecated: Use ConductorNameDir instead. Kept for backward compatibility.
func ConductorSessionTitle ¶ added in v0.12.0
ConductorSessionTitle returns the session title for a named conductor
func ConvertToClaudeDirName ¶ added in v0.8.49
ConvertToClaudeDirName converts a filesystem path to Claude's directory naming format. Claude Code replaces all non-alphanumeric characters (except hyphens) with hyphens. Example: /Users/master/Code cloud/!Project → -Users-master-Code-cloud--Project
func CreateExampleConfig ¶ added in v0.3.0
func CreateExampleConfig() error
CreateExampleConfig creates an example config file if none exists
func CreateProfile ¶ added in v0.3.0
CreateProfile creates a new empty profile
func DeleteProfile ¶ added in v0.3.0
DeleteProfile deletes a profile and all its data
func ExpandPath ¶ added in v0.19.6
ExpandPath expands environment variables and ~ prefix in a path. Use resolvePath when relative paths also need to be resolved against a working directory.
func GenerateHeartbeatPlist ¶ added in v0.13.0
GenerateHeartbeatPlist returns a launchd plist for a conductor's heartbeat timer
func GenerateLaunchdPlist ¶ added in v0.12.0
GenerateLaunchdPlist returns a launchd plist with paths substituted
func GenerateSessionName ¶ added in v0.13.0
func GenerateSessionName() string
GenerateSessionName returns a random "adjective-noun" name.
func GenerateSystemdBridgeService ¶ added in v0.16.0
GenerateSystemdBridgeService returns a systemd unit for the bridge daemon
func GenerateSystemdHeartbeatService ¶ added in v0.16.0
GenerateSystemdHeartbeatService returns a systemd service unit for a conductor heartbeat
func GenerateSystemdHeartbeatTimer ¶ added in v0.16.0
GenerateSystemdHeartbeatTimer returns a systemd timer unit for a conductor heartbeat
func GenerateUniqueSessionName ¶ added in v0.13.0
GenerateUniqueSessionName generates a name that doesn't collide with existing session titles in the given group. Retries up to 10 times, then falls back to appending a timestamp.
func GetAgentDeckDir ¶ added in v0.3.0
GetAgentDeckDir returns the base agent-deck directory (~/.agent-deck)
func GetAvailableGeminiModels ¶ added in v0.8.79
GetAvailableGeminiModels returns a sorted list of Gemini models that support generateContent. Priority: 1) GEMINI_MODELS_OVERRIDE env var, 2) cached API result, 3) live API call, 4) fallback list.
func GetAvailableMCPNames ¶ added in v0.5.3
func GetAvailableMCPNames() []string
GetAvailableMCPNames returns sorted list of MCP names from config.toml
func GetAvailableMCPs ¶ added in v0.5.3
GetAvailableMCPs returns MCPs from config.toml as a map This replaces the old catalog-based approach with explicit user configuration
func GetClaudeCommand ¶ added in v0.8.30
func GetClaudeCommand() string
GetClaudeCommand returns the configured Claude command/alias Priority: 1) UserConfig setting, 2) Default "claude" This allows users to configure an alias like "cdw" or "cdp" that sets CLAUDE_CONFIG_DIR automatically, avoiding the need for config_dir setting
func GetClaudeConfigDir ¶ added in v0.4.1
func GetClaudeConfigDir() string
GetClaudeConfigDir returns the Claude config directory for the active profile. Priority: 1. CLAUDE_CONFIG_DIR env var 2. profile-specific override: [profiles.<profile>.claude].config_dir 3. global setting: [claude].config_dir 4. default: ~/.claude
func GetClaudeSessionID ¶ added in v0.4.1
GetClaudeSessionID returns the ACTIVE session ID for a project path It first tries to find the currently running session by checking recently modified .jsonl files, then falls back to lastSessionId from config
func GetConfigPath ¶ added in v0.3.0
GetConfigPath returns the path to the global config file
func GetCustomToolNames ¶ added in v0.8.87
func GetCustomToolNames() []string
GetCustomToolNames returns sorted custom tool names from config.toml, excluding names that shadow built-in tools (claude, gemini, opencode, codex, shell, cursor, aider). Returns nil if no custom tools are configured.
func GetDBPathForProfile ¶ added in v0.11.0
GetDBPathForProfile returns the path to the state.db file for a specific profile.
func GetDefaultTool ¶ added in v0.4.3
func GetDefaultTool() string
GetDefaultTool returns the user's preferred default tool for new sessions Returns empty string if not configured (defaults to shell)
func GetDirectoryCompletions ¶ added in v0.8.86
GetDirectoryCompletions returns a list of directories that match the input prefix. Supports absolute, relative, and tilde-prefixed (~) paths.
func GetEffectiveProfile ¶ added in v0.3.0
GetEffectiveProfile returns the profile to use, considering: 1. Explicitly provided profile (from -p flag) 2. Environment variable AGENTDECK_PROFILE 3. Config default profile 4. Fallback to "default"
func GetEventsDir ¶ added in v0.18.0
func GetEventsDir() string
GetEventsDir returns the path to the events directory.
func GetGeminiConfigDir ¶ added in v0.8.0
func GetGeminiConfigDir() string
GetGeminiConfigDir returns ~/.gemini Unlike Claude, Gemini has no GEMINI_CONFIG_DIR env var override
func GetGeminiMCPNames ¶ added in v0.8.1
func GetGeminiMCPNames() []string
GetGeminiMCPNames returns names of configured MCPs from settings.json
func GetGeminiSessionsDir ¶ added in v0.8.0
GetGeminiSessionsDir returns the chats directory for a project Format: ~/.gemini/tmp/<project_hash>/chats/
func GetGlobalHTTPPool ¶ added in v0.8.96
GetGlobalHTTPPool returns the global HTTP pool instance (may be nil)
func GetGlobalMCPNames ¶ added in v0.5.3
func GetGlobalMCPNames() []string
GetGlobalMCPNames returns the names of MCPs currently in Claude's global config
func GetGlobalPool ¶ added in v0.6.2
GetGlobalPool returns the global socket pool instance (may be nil if disabled)
func GetGlobalPoolRunningCount ¶ added in v0.8.70
func GetGlobalPoolRunningCount() int
GetGlobalPoolRunningCount returns the number of running MCPs in the global pool
func GetGroupLevel ¶
GetGroupLevel returns the nesting level of a group (0 for root, 1 for child, etc.)
func GetHTTPServerStatus ¶ added in v0.8.96
GetHTTPServerStatus returns the status of an HTTP MCP server
func GetHooksDir ¶ added in v0.16.0
func GetHooksDir() string
GetHooksDir returns the path to the hooks status directory.
func GetMCPDefaultScope ¶ added in v0.10.11
func GetMCPDefaultScope() string
GetMCPDefaultScope returns the configured default MCP scope. Returns "local", "global", or "user". Defaults to "local" if unset or invalid.
func GetManageMCPJson ¶ added in v0.19.6
func GetManageMCPJson() bool
GetManageMCPJson returns whether agent-deck should write to .mcp.json files. Defaults to true when unset.
func GetProfileDir ¶ added in v0.3.0
GetProfileDir returns the path to a specific profile's directory
func GetProfilesDir ¶ added in v0.3.0
GetProfilesDir returns the path to the profiles directory
func GetProjectClaudeSkillsPath ¶ added in v0.19.1
GetProjectClaudeSkillsPath returns <project>/.claude/skills.
func GetProjectMCPNames ¶ added in v0.5.3
GetProjectMCPNames returns MCPs from projects[path].mcpServers in Claude's config
func GetProjectSkillsManifestPath ¶ added in v0.19.1
GetProjectSkillsManifestPath returns <project>/.agent-deck/skills.toml.
func GetSkillPoolPath ¶ added in v0.19.1
GetSkillPoolPath returns ~/.agent-deck/skills/pool.
func GetSkillSourcesPath ¶ added in v0.19.1
GetSkillSourcesPath returns ~/.agent-deck/skills/sources.toml.
func GetSkillsRootPath ¶ added in v0.19.1
GetSkillsRootPath returns ~/.agent-deck/skills.
func GetTheme ¶ added in v0.8.16
func GetTheme() string
GetTheme returns the current theme, defaulting to "dark"
func GetToolBusyPatterns ¶ added in v0.3.0
GetToolBusyPatterns returns busy patterns for a tool (custom + built-in)
func GetToolIcon ¶ added in v0.3.0
GetToolIcon returns the icon for a tool (custom or built-in)
func GetUserConfigPath ¶ added in v0.3.0
GetUserConfigPath returns the path to the user config file
func GetUserMCPNames ¶ added in v0.8.69
func GetUserMCPNames() []string
GetUserMCPNames returns the names of MCPs in ~/.claude.json (ROOT config) These MCPs are loaded by ALL Claude sessions regardless of CLAUDE_CONFIG_DIR. This is different from GetGlobalMCPNames which reads from $CLAUDE_CONFIG_DIR/.claude.json
func GetUserMCPRootPath ¶ added in v0.8.69
func GetUserMCPRootPath() string
GetUserMCPRootPath returns the path to ~/.claude.json (ROOT config, always read by Claude) This is the ROOT config that Claude ALWAYS reads, regardless of CLAUDE_CONFIG_DIR setting. MCPs defined here apply to ALL Claude sessions globally.
func GroupByProject ¶
GroupByProject groups sessions by their parent project directory
func HashProjectPath ¶ added in v0.8.0
HashProjectPath generates SHA256 hash of absolute project path This matches Gemini CLI's project hash algorithm for session storage VERIFIED: echo -n "/Users/ashesh" | shasum -a 256 NOTE: Must resolve symlinks (e.g., /tmp -> /private/tmp on macOS)
func HeartbeatPlistLabel ¶ added in v0.13.0
HeartbeatPlistLabel returns the launchd label for a conductor's heartbeat
func HeartbeatPlistPath ¶ added in v0.13.0
HeartbeatPlistPath returns the path where a conductor's heartbeat plist should be installed
func InitializeGlobalPool ¶ added in v0.6.2
func InitializeGlobalPool(ctx context.Context, config *UserConfig, sessions []*Instance) (*mcppool.Pool, error)
InitializeGlobalPool creates and starts the global MCP pool
func InjectClaudeHooks ¶ added in v0.16.0
InjectClaudeHooks injects agent-deck hook entries into Claude Code's settings.json. Uses read-preserve-modify-write pattern to preserve all existing settings and user hooks. Returns true if hooks were newly installed, false if already present.
func InstallBridgeDaemon ¶ added in v0.16.0
InstallBridgeDaemon installs and starts the bridge daemon. macOS: launchd plist; Linux: systemd user service. Returns the unit/plist file path on success.
func InstallBridgeScript ¶ added in v0.12.0
func InstallBridgeScript() error
InstallBridgeScript copies bridge.py to the conductor base directory. It writes from the embedded const.
func InstallHeartbeatDaemon ¶ added in v0.16.0
InstallHeartbeatDaemon installs and starts the heartbeat timer for a conductor. macOS: launchd plist; Linux: systemd timer/service pair.
func InstallHeartbeatScript ¶ added in v0.13.0
InstallHeartbeatScript writes the heartbeat.sh script for a conductor. This is a standalone heartbeat that works without Telegram.
func InstallPolicyMD ¶ added in v0.19.6
InstallPolicyMD writes the default POLICY.md to the conductor base directory, or creates a symlink if customPath is provided. This contains agent behavior rules (auto-response policy, escalation guidelines).
func InstallSharedClaudeMD ¶ added in v0.12.0
InstallSharedClaudeMD writes the shared CLAUDE.md to the conductor base directory, or creates a symlink if customPath is provided. This contains CLI reference, protocols, and rules shared by all conductors.
func IsBridgeDaemonRunning ¶ added in v0.16.0
func IsBridgeDaemonRunning() bool
IsBridgeDaemonRunning checks if the bridge daemon is currently running.
func IsClaudeConfigDirExplicit ¶ added in v0.8.12
func IsClaudeConfigDirExplicit() bool
IsClaudeConfigDirExplicit returns true if the Claude config directory is explicitly configured (via CLAUDE_CONFIG_DIR env var, profile override, or global config.toml setting). When false, the user is using the default path and we should NOT override CLAUDE_CONFIG_DIR in commands, allowing the shell's environment to be respected.
This is critical for WSL and other environments where users may have CLAUDE_CONFIG_DIR set in their .bashrc/.zshrc - agent-deck should not override that with a hardcoded default path.
func IsConductorSetup ¶ added in v0.12.0
IsConductorSetup checks if a named conductor is set up by verifying meta.json exists
func IsHTTPServerRunning ¶ added in v0.8.96
IsHTTPServerRunning checks if an HTTP MCP server is running
func LaunchdPlistPath ¶ added in v0.12.0
LaunchdPlistPath returns the path where the plist should be installed
func ListMaterializedProjectSkills ¶ added in v0.19.1
ListMaterializedProjectSkills returns all entries currently present in .claude/skills.
func ListProfiles ¶ added in v0.3.0
ListProfiles returns all available profile names
func LoadSkillSources ¶ added in v0.19.1
func LoadSkillSources() (map[string]SkillSourceDef, error)
LoadSkillSources loads the global source registry. If no registry exists yet, defaults are returned.
func MarshalToolOptions ¶ added in v0.8.39
func MarshalToolOptions(opts ToolOptions) (json.RawMessage, error)
MarshalToolOptions serializes tool options to JSON
func MergeToolPatterns ¶ added in v0.9.2
func MergeToolPatterns(toolName string) *tmux.RawPatterns
MergeToolPatterns returns merged RawPatterns for a tool, combining built-in defaults with any user overrides/extras from config.toml. Works for ALL tools: built-in (claude, gemini, etc.) and custom. Returns nil only if there are no defaults AND no config entry.
func MigrateConductorPolicySplit ¶ added in v0.19.6
MigrateConductorPolicySplit updates legacy generated per-conductor CLAUDE.md templates to include POLICY.md instructions. It only rewrites non-symlink CLAUDE.md files that exactly match the legacy generated template.
func MigrateLegacyConductors ¶ added in v0.12.0
MigrateLegacyConductors scans for conductor dirs that have CLAUDE.md but no meta.json, and creates meta.json for them. Returns the names of migrated conductors.
func NeedsMigration ¶ added in v0.3.0
NeedsMigration checks if migration from old layout is needed
func ProfileExists ¶ added in v0.3.0
ProfileExists checks if a profile exists
func PruneMCPCache ¶ added in v0.10.6
PruneMCPCache removes cache entries older than maxAge to prevent unbounded growth. Called periodically from the TUI tick handler.
func ReadPrevEventStatus ¶ added in v0.18.0
ReadPrevEventStatus reads the previous status from an existing event file. Returns empty string if no event file exists or can't be read.
func RemoveClaudeHooks ¶ added in v0.16.0
RemoveClaudeHooks removes agent-deck hook entries from Claude Code's settings.json. Returns true if hooks were removed, false if none found.
func RemoveHeartbeatPlist ¶ added in v0.13.0
RemoveHeartbeatPlist removes the launchd plist for a conductor's heartbeat
func RemoveSkillSource ¶ added in v0.19.1
RemoveSkillSource removes a named source.
func ResolveTheme ¶ added in v0.15.0
func ResolveTheme() string
ResolveTheme resolves the configured theme to "dark" or "light". If theme is "system", detects the OS dark mode setting. Falls back to "dark" on detection failure.
func RestoreFromArchive ¶ added in v0.8.79
RestoreFromArchive moves all files from archive/ subdirectories back to their parent directories under baseDir/profiles/*/.
func SaveConductorMeta ¶ added in v0.12.0
func SaveConductorMeta(meta *ConductorMeta) error
SaveConductorMeta writes meta.json for a conductor
func SaveConfig ¶ added in v0.3.0
SaveConfig saves the global configuration
func SaveProjectSkillsManifest ¶ added in v0.19.1
func SaveProjectSkillsManifest(projectPath string, manifest *ProjectSkillsManifest) error
SaveProjectSkillsManifest writes project attachment state atomically.
func SaveSkillSources ¶ added in v0.19.1
func SaveSkillSources(sources map[string]SkillSourceDef) error
SaveSkillSources writes the source registry atomically.
func SaveUserConfig ¶ added in v0.8.15
func SaveUserConfig(config *UserConfig) error
SaveUserConfig writes the config to config.toml using atomic write pattern This clears the cache so next LoadUserConfig() reads fresh values
func SetDefaultProfile ¶ added in v0.3.0
SetDefaultProfile sets the default profile in the config
func SetupConductor ¶ added in v0.12.0
func SetupConductor(name, profile string, heartbeatEnabled bool, description string, customClaudeMD string, customPolicyMD string) error
SetupConductor creates the conductor directory, per-conductor CLAUDE.md, and meta.json. If customClaudeMD is provided, creates a symlink instead of writing the template. If customPolicyMD is provided, creates a per-conductor POLICY.md symlink (overrides the shared POLICY.md). It does NOT register the session (that's done by the CLI handler which has access to storage).
func SetupConductorProfile ¶ added in v0.12.0
SetupConductorProfile creates the conductor directory and CLAUDE.md for a profile. Deprecated: Use SetupConductor instead. Kept for backward compatibility.
func ShutdownGlobalPool ¶ added in v0.6.2
ShutdownGlobalPool stops the global pools if shouldShutdown is true. If shouldShutdown is false, it disconnects from the pools but leaves processes running.
func StartHTTPServer ¶ added in v0.8.96
StartHTTPServer starts an HTTP MCP server on demand This is called when an HTTP MCP with server config is attached to a session
func StartMaintenanceWorker ¶ added in v0.8.79
func StartMaintenanceWorker(ctx context.Context, onComplete func(MaintenanceResult))
StartMaintenanceWorker launches a background goroutine that runs maintenance on a 15-minute ticker with an immediate first run. It checks GetMaintenanceSettings().Enabled before each run.
func SystemdBridgeServicePath ¶ added in v0.16.0
SystemdBridgeServicePath returns the full path to the bridge systemd service file
func SystemdHeartbeatServiceName ¶ added in v0.16.0
SystemdHeartbeatServiceName returns the systemd service name for a conductor heartbeat
func SystemdHeartbeatServicePath ¶ added in v0.16.0
SystemdHeartbeatServicePath returns the full path to a heartbeat systemd service
func SystemdHeartbeatTimerName ¶ added in v0.16.0
SystemdHeartbeatTimerName returns the systemd timer name for a conductor heartbeat
func SystemdHeartbeatTimerPath ¶ added in v0.16.0
SystemdHeartbeatTimerPath returns the full path to a heartbeat systemd timer
func SystemdUserDir ¶ added in v0.16.0
SystemdUserDir returns the systemd user unit directory (~/.config/systemd/user/)
func TeardownConductor ¶ added in v0.12.0
TeardownConductor removes the conductor directory for a named conductor. It does NOT remove the session from storage (that's done by the CLI handler).
func TeardownConductorProfile ¶ added in v0.12.0
TeardownConductorProfile removes the conductor directory for a profile. Deprecated: Use TeardownConductor instead. Kept for backward compatibility.
func TierName ¶ added in v0.5.3
func TierName(tier SearchTier) string
TierName returns a human-readable name for the tier
func ToggleLocalMCP ¶ added in v0.5.3
ToggleLocalMCP toggles a Local MCP on/off It respects the existing mode (whitelist vs blacklist) or initializes with blacklist
func UninstallBridgeDaemon ¶ added in v0.16.0
func UninstallBridgeDaemon() error
UninstallBridgeDaemon stops and removes the bridge daemon.
func UninstallHeartbeatDaemon ¶ added in v0.16.0
UninstallHeartbeatDaemon stops and removes the heartbeat timer for a conductor.
func UpdateClaudeSessionsWithDedup ¶ added in v0.4.1
func UpdateClaudeSessionsWithDedup(instances []*Instance)
UpdateClaudeSessionsWithDedup clears duplicate Claude session IDs across instances. The oldest session (by CreatedAt) keeps its ID, newer duplicates are cleared. With tmux env being authoritative, duplicates shouldn't occur in normal use, but we handle them defensively for loaded/migrated sessions.
func UpdateGeminiAnalyticsFromDisk ¶ added in v0.8.35
func UpdateGeminiAnalyticsFromDisk(projectPath, sessionID string, analytics *GeminiSessionAnalytics) error
UpdateGeminiAnalyticsFromDisk updates the analytics struct from the session file on disk. Uses mtime caching to skip re-parsing unchanged files (important for 40MB+ session files).
func ValidateConductorName ¶ added in v0.12.0
ValidateConductorName checks that a conductor name is valid
func WriteGeminiMCPSettings ¶ added in v0.8.1
WriteGeminiMCPSettings writes MCPs to ~/.gemini/settings.json Preserves existing config fields (security, theme, etc.) Uses atomic write with .tmp file for safety
func WriteGlobalMCP ¶ added in v0.5.3
WriteGlobalMCP adds or removes MCPs from Claude's global config This modifies ~/.claude-work/.claude.json → mcpServers
func WriteMCPJsonFromConfig ¶ added in v0.5.3
WriteMCPJsonFromConfig writes enabled MCPs from config.toml to project's .mcp.json It preserves any existing entries not managed by agent-deck (not defined in config.toml)
func WriteStatusEvent ¶ added in v0.18.0
func WriteStatusEvent(event StatusEvent) error
WriteStatusEvent atomically writes a status event to the events directory. Uses tmp file + rename to avoid partial reads by watchers.
func WriteUserMCP ¶ added in v0.8.69
WriteUserMCP writes MCPs to ~/.claude.json (ROOT config) Uses socket proxies if pool is running, otherwise falls back to stdio WARNING: MCPs written here affect ALL Claude sessions regardless of profile!
Types ¶
type AnalyticsDisplaySettings ¶ added in v0.8.53
type AnalyticsDisplaySettings struct {
// ShowContextBar shows the context window usage bar (default: true)
ShowContextBar *bool `toml:"show_context_bar"`
// ShowTokens shows the token breakdown (In/Out/Cache/Total) (default: false)
ShowTokens *bool `toml:"show_tokens"`
// ShowSessionInfo shows duration, turns, start time (default: false)
ShowSessionInfo *bool `toml:"show_session_info"`
// ShowTools shows the top tool calls (default: true)
ShowTools *bool `toml:"show_tools"`
// ShowCost shows the estimated cost (default: false)
ShowCost *bool `toml:"show_cost"`
}
AnalyticsDisplaySettings configures which analytics sections to display All settings use pointers to distinguish "not set" from "explicitly false"
func (*AnalyticsDisplaySettings) GetShowContextBar ¶ added in v0.8.53
func (a *AnalyticsDisplaySettings) GetShowContextBar() bool
GetShowContextBar returns whether to show context bar, defaulting to true
func (*AnalyticsDisplaySettings) GetShowCost ¶ added in v0.8.53
func (a *AnalyticsDisplaySettings) GetShowCost() bool
GetShowCost returns whether to show cost estimate, defaulting to false
func (*AnalyticsDisplaySettings) GetShowSessionInfo ¶ added in v0.8.53
func (a *AnalyticsDisplaySettings) GetShowSessionInfo() bool
GetShowSessionInfo returns whether to show session info, defaulting to false
func (*AnalyticsDisplaySettings) GetShowTokens ¶ added in v0.8.53
func (a *AnalyticsDisplaySettings) GetShowTokens() bool
GetShowTokens returns whether to show token breakdown, defaulting to false
func (*AnalyticsDisplaySettings) GetShowTools ¶ added in v0.8.53
func (a *AnalyticsDisplaySettings) GetShowTools() bool
GetShowTools returns whether to show tool calls, defaulting to false
type BillingBlock ¶ added in v0.8.27
type BillingBlock struct {
StartTime time.Time `json:"start_time"`
EndTime time.Time `json:"end_time"`
TokensUsed int `json:"tokens_used"`
IsActive bool `json:"is_active"`
}
BillingBlock represents a 5-hour billing window
func CalculateBillingBlocks ¶ added in v0.8.27
func CalculateBillingBlocks(timestamps []time.Time, windowSize time.Duration) []BillingBlock
CalculateBillingBlocks groups timestamps into billing windows. Claude Code API bills in 5-hour windows. Each block represents a billing period. Timestamps are sorted chronologically and grouped - a new block starts when a timestamp exceeds the windowSize from the current block's start time. The last block is marked as "active" if it's still within the window from now.
type ClaudeConfig ¶ added in v0.4.1
type ClaudeConfig struct {
Projects map[string]ClaudeProject `json:"projects"`
}
ClaudeConfig represents the structure of .claude.json
type ClaudeOptions ¶ added in v0.8.39
type ClaudeOptions struct {
// SessionMode: "new" (default), "continue" (-c), or "resume" (-r)
SessionMode string `json:"session_mode,omitempty"`
// ResumeSessionID is the session ID for -r flag (only when SessionMode="resume")
ResumeSessionID string `json:"resume_session_id,omitempty"`
// SkipPermissions adds --dangerously-skip-permissions flag
SkipPermissions bool `json:"skip_permissions,omitempty"`
// AllowSkipPermissions adds --allow-dangerously-skip-permissions flag
// Only used when SkipPermissions is false (SkipPermissions takes precedence)
AllowSkipPermissions bool `json:"allow_skip_permissions,omitempty"`
// UseChrome adds --chrome flag
UseChrome bool `json:"use_chrome,omitempty"`
// UseTeammateMode adds --teammate-mode tmux flag
UseTeammateMode bool `json:"use_teammate_mode,omitempty"`
// Transient fields for worktree fork (not persisted)
WorkDir string `json:"-"`
WorktreePath string `json:"-"`
WorktreeRepoRoot string `json:"-"`
WorktreeBranch string `json:"-"`
}
ClaudeOptions holds launch options for Claude Code sessions
func NewClaudeOptions ¶ added in v0.8.39
func NewClaudeOptions(config *UserConfig) *ClaudeOptions
NewClaudeOptions creates ClaudeOptions with defaults from config
func UnmarshalClaudeOptions ¶ added in v0.8.39
func UnmarshalClaudeOptions(data json.RawMessage) (*ClaudeOptions, error)
UnmarshalClaudeOptions deserializes ClaudeOptions from JSON wrapper
func (*ClaudeOptions) ToArgs ¶ added in v0.8.39
func (o *ClaudeOptions) ToArgs() []string
ToArgs returns command-line arguments based on options
func (*ClaudeOptions) ToArgsForFork ¶ added in v0.8.39
func (o *ClaudeOptions) ToArgsForFork() []string
ToArgsForFork returns arguments suitable for fork resume command Fork always uses --resume internally, so session mode flags are not included
func (*ClaudeOptions) ToolName ¶ added in v0.8.39
func (o *ClaudeOptions) ToolName() string
ToolName returns "claude"
type ClaudeProject ¶ added in v0.4.1
type ClaudeProject struct {
LastSessionId string `json:"lastSessionId"`
}
ClaudeProject represents a project entry in Claude's config
type ClaudeSettings ¶ added in v0.4.1
type ClaudeSettings struct {
// Command is the Claude CLI command or alias to use (e.g., "claude", "cdw", "cdp")
// Default: "claude"
// This allows using shell aliases that set CLAUDE_CONFIG_DIR automatically
Command string `toml:"command"`
// ConfigDir is the path to Claude's config directory
// Default: ~/.claude (or CLAUDE_CONFIG_DIR env var)
ConfigDir string `toml:"config_dir"`
// DangerousMode enables --dangerously-skip-permissions flag for Claude sessions
// Default: true (nil = use default true, explicitly set false to disable)
// Power users typically want this enabled for faster iteration
DangerousMode *bool `toml:"dangerous_mode"`
// AllowDangerousMode enables --allow-dangerously-skip-permissions flag
// This unlocks bypass as an option without activating it by default.
// Ignored when dangerous_mode is true (the stronger flag takes precedence).
// Default: false
AllowDangerousMode bool `toml:"allow_dangerous_mode"`
// EnvFile is a .env file specific to Claude sessions
// Sourced AFTER global [shell].env_files
// Path can be absolute, ~ for home, $HOME/${VAR} for env vars, or relative to session working directory
EnvFile string `toml:"env_file"`
// HooksEnabled enables Claude Code hooks for real-time status detection.
// When enabled, agent-deck uses lifecycle hooks (SessionStart, Stop, etc.)
// for instant, deterministic status updates instead of polling tmux content.
// Default: true (nil = use default true, set false to disable)
HooksEnabled *bool `toml:"hooks_enabled"`
}
ClaudeSettings defines Claude Code configuration
func (*ClaudeSettings) GetDangerousMode ¶ added in v0.8.76
func (c *ClaudeSettings) GetDangerousMode() bool
GetDangerousMode returns whether dangerous mode is enabled, defaulting to true Power users (the primary audience) typically want this enabled for faster iteration
func (*ClaudeSettings) GetHooksEnabled ¶ added in v0.16.0
func (c *ClaudeSettings) GetHooksEnabled() bool
GetHooksEnabled returns whether Claude Code hooks are enabled, defaulting to true
type CodexOptions ¶ added in v0.10.18
type CodexOptions struct {
// YoloMode enables --yolo flag (bypass approvals and sandbox)
// nil = inherit from global config, true/false = explicit override
YoloMode *bool `json:"yolo_mode,omitempty"`
}
CodexOptions holds launch options for Codex CLI sessions
func NewCodexOptions ¶ added in v0.10.18
func NewCodexOptions(config *UserConfig) *CodexOptions
NewCodexOptions creates CodexOptions with defaults from global config
func UnmarshalCodexOptions ¶ added in v0.10.18
func UnmarshalCodexOptions(data json.RawMessage) (*CodexOptions, error)
UnmarshalCodexOptions deserializes CodexOptions from JSON wrapper
func (*CodexOptions) ToArgs ¶ added in v0.10.18
func (o *CodexOptions) ToArgs() []string
ToArgs returns command-line arguments based on options
func (*CodexOptions) ToolName ¶ added in v0.10.18
func (o *CodexOptions) ToolName() string
ToolName returns "codex"
type CodexSettings ¶ added in v0.10.18
type CodexSettings struct {
// YoloMode enables --yolo flag for Codex sessions (bypass approvals and sandbox)
// Default: false
YoloMode bool `toml:"yolo_mode"`
}
CodexSettings defines Codex CLI configuration
type CompletionCycler ¶ added in v0.8.86
type CompletionCycler struct {
// contains filtered or unexported fields
}
CompletionCycler manages the state of directory autocomplete.
func (*CompletionCycler) IsActive ¶ added in v0.8.86
func (c *CompletionCycler) IsActive() bool
IsActive returns true if the cycler has active matches.
func (*CompletionCycler) Next ¶ added in v0.8.86
func (c *CompletionCycler) Next() string
Next returns the next match in the cycle. Wraps around to the beginning if the end is reached.
func (*CompletionCycler) Reset ¶ added in v0.8.86
func (c *CompletionCycler) Reset()
Reset clears the cycler state.
func (*CompletionCycler) SetMatches ¶ added in v0.8.86
func (c *CompletionCycler) SetMatches(matches []string)
SetMatches sets the matches for the cycler and resets the index.
type ConductorMeta ¶ added in v0.12.0
type ConductorMeta struct {
Name string `json:"name"`
Profile string `json:"profile"`
HeartbeatEnabled bool `json:"heartbeat_enabled"`
HeartbeatInterval int `json:"heartbeat_interval"` // 0 = use global default
Description string `json:"description,omitempty"`
CreatedAt string `json:"created_at"`
}
ConductorMeta holds metadata for a named conductor instance
func ListConductors ¶ added in v0.12.0
func ListConductors() ([]ConductorMeta, error)
ListConductors scans all conductor directories that have meta.json
func ListConductorsForProfile ¶ added in v0.12.0
func ListConductorsForProfile(profile string) ([]ConductorMeta, error)
ListConductorsForProfile returns conductors belonging to a specific profile
func LoadConductorMeta ¶ added in v0.12.0
func LoadConductorMeta(name string) (*ConductorMeta, error)
LoadConductorMeta reads meta.json for a named conductor
type ConductorSettings ¶ added in v0.12.0
type ConductorSettings struct {
// Enabled activates the conductor system
Enabled bool `toml:"enabled"`
// HeartbeatInterval is the interval in minutes between heartbeat checks
// Default: 15
HeartbeatInterval int `toml:"heartbeat_interval"`
// Profiles is the list of agent-deck profiles to manage
// Kept for backward compat but ignored after migration to meta.json-based discovery
Profiles []string `toml:"profiles"`
// Telegram defines Telegram bot integration settings
Telegram TelegramSettings `toml:"telegram"`
// Slack defines Slack bot integration settings
Slack SlackSettings `toml:"slack"`
}
ConductorSettings defines conductor (meta-agent orchestration) configuration
func GetConductorSettings ¶ added in v0.12.0
func GetConductorSettings() ConductorSettings
GetConductorSettings loads and returns conductor settings from config
func (*ConductorSettings) GetHeartbeatInterval ¶ added in v0.12.0
func (c *ConductorSettings) GetHeartbeatInterval() int
GetHeartbeatInterval returns the heartbeat interval, defaulting to 15 minutes
func (*ConductorSettings) GetProfiles ¶ added in v0.12.0
func (c *ConductorSettings) GetProfiles() []string
GetProfiles returns the configured profiles, defaulting to ["default"]
type Config ¶ added in v0.3.0
type Config struct {
// DefaultProfile is the profile to use when none is specified
DefaultProfile string `json:"default_profile"`
// LastUsed is the most recently used profile (for future use)
LastUsed string `json:"last_used,omitempty"`
// Version tracks config format for future migrations
Version int `json:"version"`
}
Config represents the global agent-deck configuration
func LoadConfig ¶ added in v0.3.0
LoadConfig loads the global configuration
type ContentBuffer ¶ added in v0.10.0
type ContentBuffer struct {
// contains filtered or unexported fields
}
ContentBuffer stores full content and a lowercased copy for fast search. It is safe for concurrent reads and append-only writes.
func (*ContentBuffer) Append ¶ added in v0.10.0
func (b *ContentBuffer) Append(data []byte)
func (*ContentBuffer) CopyData ¶ added in v0.10.0
func (b *ContentBuffer) CopyData() []byte
func (*ContentBuffer) Size ¶ added in v0.10.5
func (b *ContentBuffer) Size() int64
Size returns the total memory used by this buffer (data + lowercased copy)
func (*ContentBuffer) With ¶ added in v0.10.0
func (b *ContentBuffer) With(fn func(data, lower []byte))
type ExperimentsSettings ¶ added in v0.8.43
type ExperimentsSettings struct {
// Directory is the base directory for experiments
// Default: ~/src/tries
Directory string `toml:"directory"`
// DatePrefix adds YYYY-MM-DD- prefix to new experiment folders
// Default: true
DatePrefix bool `toml:"date_prefix"`
// DefaultTool is the AI tool to use for experiment sessions
// Default: "claude"
DefaultTool string `toml:"default_tool"`
}
ExperimentsSettings defines experiment folder configuration
func GetExperimentsSettings ¶ added in v0.8.43
func GetExperimentsSettings() ExperimentsSettings
GetExperimentsSettings returns experiments settings with defaults applied
type FileTracker ¶ added in v0.5.3
FileTracker tracks file state for incremental updates
type GeminiMCPConfig ¶ added in v0.8.1
type GeminiMCPConfig struct {
MCPServers map[string]MCPServerConfig `json:"mcpServers"`
}
GeminiMCPConfig represents settings.json structure VERIFIED: Actual settings.json does NOT have mcp.allowed/excluded (Simplified structure compared to research docs)
type GeminiModelPricing ¶ added in v0.8.35
GeminiModelPricing holds pricing per million tokens
type GeminiSessionAnalytics ¶ added in v0.8.35
type GeminiSessionAnalytics struct {
// Token usage
InputTokens int `json:"input_tokens"`
OutputTokens int `json:"output_tokens"`
// Current context size (last turn's input + cache read tokens)
CurrentContextTokens int `json:"current_context_tokens"`
// Session metrics
TotalTurns int `json:"total_turns"`
Duration time.Duration `json:"duration"`
StartTime time.Time `json:"start_time"`
LastActive time.Time `json:"last_active"`
// Cost estimation
EstimatedCost float64 `json:"estimated_cost"`
// Model detected from session file messages
Model string `json:"model,omitempty"`
// In-memory cache: last file modification time (skip re-parse if unchanged)
LastFileModTime time.Time `json:"-"`
}
GeminiSessionAnalytics holds metrics for a Gemini session
func (*GeminiSessionAnalytics) CalculateCost ¶ added in v0.8.35
func (a *GeminiSessionAnalytics) CalculateCost(model string) float64
CalculateCost estimates session cost based on token usage and model pricing
func (*GeminiSessionAnalytics) TotalTokens ¶ added in v0.8.35
func (a *GeminiSessionAnalytics) TotalTokens() int
TotalTokens returns the sum of input and output tokens
type GeminiSessionInfo ¶ added in v0.8.1
type GeminiSessionInfo struct {
SessionID string // Full UUID
Filename string // session-2025-12-26T15-09-4d8fcb4d.json
StartTime time.Time
LastUpdated time.Time
MessageCount int
}
GeminiSessionInfo holds parsed session metadata
func ListGeminiSessions ¶ added in v0.8.1
func ListGeminiSessions(projectPath string) ([]GeminiSessionInfo, error)
ListGeminiSessions returns all sessions for a project path Scans ~/.gemini/tmp/<hash>/chats/ and parses session files Sorted by LastUpdated (most recent first)
type GeminiSettings ¶ added in v0.8.35
type GeminiSettings struct {
// YoloMode enables --yolo flag for Gemini sessions (auto-approve all actions)
// Default: false
YoloMode bool `toml:"yolo_mode"`
// DefaultModel is the model to use for new Gemini sessions (e.g., "gemini-2.5-flash")
// If empty, Gemini CLI uses its own default
DefaultModel string `toml:"default_model"`
// EnvFile is a .env file specific to Gemini sessions
// Sourced AFTER global [shell].env_files
// Path can be absolute, ~ for home, $HOME/${VAR} for env vars, or relative to session working directory
EnvFile string `toml:"env_file"`
}
GeminiSettings defines Gemini CLI configuration
type GlobalSearchIndex ¶ added in v0.5.3
type GlobalSearchIndex struct {
// contains filtered or unexported fields
}
GlobalSearchIndex manages the searchable session index
func NewGlobalSearchIndex ¶ added in v0.5.3
func NewGlobalSearchIndex(claudeDir string, config GlobalSearchSettings) (*GlobalSearchIndex, error)
NewGlobalSearchIndex creates a new search index
func (*GlobalSearchIndex) Close ¶ added in v0.5.3
func (idx *GlobalSearchIndex) Close()
Close shuts down the index and releases all memory
func (*GlobalSearchIndex) EntryCount ¶ added in v0.5.3
func (idx *GlobalSearchIndex) EntryCount() int
EntryCount returns the number of indexed entries
func (*GlobalSearchIndex) FuzzySearch ¶ added in v0.5.3
func (idx *GlobalSearchIndex) FuzzySearch(query string) []*SearchResult
FuzzySearch performs fuzzy matching with typo tolerance
func (*GlobalSearchIndex) GetTier ¶ added in v0.5.3
func (idx *GlobalSearchIndex) GetTier() SearchTier
GetTier returns the current search tier
func (*GlobalSearchIndex) IsLoading ¶ added in v0.5.3
func (idx *GlobalSearchIndex) IsLoading() bool
IsLoading returns true if the index is still loading
func (*GlobalSearchIndex) Search ¶ added in v0.5.3
func (idx *GlobalSearchIndex) Search(query string) []*SearchResult
Search performs a simple substring search
type GlobalSearchSettings ¶ added in v0.5.3
type GlobalSearchSettings struct {
// Enabled enables/disables global search feature (default: true when loaded via LoadUserConfig)
Enabled bool `toml:"enabled"`
// Tier controls search strategy: "auto", "instant", "balanced", "disabled"
// auto: Auto-detect based on data size (recommended)
// instant: Force full in-memory (fast, uses more RAM)
// balanced: Force LRU cache mode (slower, capped RAM)
// disabled: Disable global search entirely
Tier string `toml:"tier"`
// MemoryLimitMB caps memory usage for search index (default: 100)
// Only applies to balanced tier
MemoryLimitMB int `toml:"memory_limit_mb"`
// RecentDays limits search to sessions from last N days (0 = all)
// Reduces index size for users with long history (default: 90)
RecentDays int `toml:"recent_days"`
// IndexRateLimit limits files indexed per second during background indexing
// Lower = less CPU impact (default: 20)
IndexRateLimit int `toml:"index_rate_limit"`
}
GlobalSearchSettings defines global conversation search configuration
type Group ¶
type Group struct {
Name string
Path string // Full path like "projects" or "projects/devops"
Expanded bool
Sessions []*Instance
Order int
DefaultPath string // Explicit default path for new sessions in this group
}
Group represents a group of sessions
type GroupData ¶
type GroupData struct {
Name string `json:"name"`
Path string `json:"path"`
Expanded bool `json:"expanded"`
Order int `json:"order"`
DefaultPath string `json:"default_path,omitempty"`
}
GroupData represents serializable group data
type GroupTree ¶
type GroupTree struct {
Groups map[string]*Group // path -> group
GroupList []*Group // Ordered list of groups
Expanded map[string]bool // Collapsed state persistence
}
GroupTree manages hierarchical session organization
func NewGroupTree ¶
NewGroupTree creates a new group tree from instances
func NewGroupTreeWithGroups ¶
NewGroupTreeWithGroups creates a group tree from instances and stored group data
func (*GroupTree) AddSession ¶
AddSession adds a session to the appropriate group
func (*GroupTree) CollapseGroup ¶
CollapseGroup collapses a group
func (*GroupTree) CreateGroup ¶
CreateGroup creates a new empty group
func (*GroupTree) CreateSubgroup ¶
CreateSubgroup creates a new empty group under a parent group
func (*GroupTree) DefaultPathForGroup ¶ added in v0.19.1
DefaultPathForGroup returns the effective default path for creating new sessions in the group: explicit configured default_path first, then most recent session path.
func (*GroupTree) DeleteGroup ¶
DeleteGroup deletes a group, all its subgroups, and moves all sessions to default
func (*GroupTree) ExpandGroup ¶
ExpandGroup expands a group
func (*GroupTree) ExpandGroupWithParents ¶
ExpandGroupWithParents expands a group and all its parent groups This ensures the group and its contents are visible in the flattened view
func (*GroupTree) GetAllInstances ¶
GetAllInstances returns all instances in order
func (*GroupTree) GetGroupNames ¶
GetGroupNames returns all group names for selection
func (*GroupTree) GetGroupPaths ¶
GetGroupPaths returns all group paths for selection
func (*GroupTree) GroupCount ¶
GroupCount returns total group count
func (*GroupTree) MoveGroupDown ¶
MoveGroupDown moves a group down in the order (only within siblings at same level)
func (*GroupTree) MoveGroupUp ¶
MoveGroupUp moves a group up in the order (only within siblings at same level)
func (*GroupTree) MoveSessionDown ¶
MoveSessionDown moves a session down within its group
func (*GroupTree) MoveSessionToGroup ¶
MoveSessionToGroup moves a session to a different group
func (*GroupTree) MoveSessionUp ¶
MoveSessionUp moves a session up within its group
func (*GroupTree) RemoveSession ¶
RemoveSession removes a session from its group
func (*GroupTree) RenameGroup ¶
RenameGroup renames a group and updates all subgroups
func (*GroupTree) SessionCount ¶
SessionCount returns total session count
func (*GroupTree) SessionCountForGroup ¶ added in v0.8.37
SessionCountForGroup returns session count for a group INCLUDING all its subgroups This enables hierarchical counts like "Project (5)" where 5 includes all nested sessions
func (*GroupTree) SetDefaultPathForGroup ¶ added in v0.19.1
SetDefaultPathForGroup sets (or clears) an explicit default path for a group.
func (*GroupTree) ShallowCopyForSave ¶ added in v0.7.0
ShallowCopyForSave creates a copy of the GroupTree that's safe to use from a goroutine for saving purposes. It deep copies the Group structs to prevent data races when the main thread modifies group fields (Name, Path, Expanded, Order) while a background goroutine reads them.
func (*GroupTree) SyncWithInstances ¶
SyncWithInstances updates the tree with a new set of instances while preserving existing group structure (including empty groups)
func (*GroupTree) ToggleGroup ¶
ToggleGroup toggles the expanded state of a group
type HTTPServerConfig ¶ added in v0.8.96
type HTTPServerConfig struct {
// Command is the executable to run (e.g., "uvx", "python", "node")
Command string `toml:"command"`
// Args are command-line arguments for the server
Args []string `toml:"args"`
// Env is environment variables for the server process
Env map[string]string `toml:"env"`
// StartupTimeout is milliseconds to wait for server to become ready (default: 5000)
StartupTimeout int `toml:"startup_timeout"`
// HealthCheck is an optional health endpoint URL to poll (e.g., "http://localhost:30000/health")
// If not set, the main URL is used for health checking
HealthCheck string `toml:"health_check"`
}
HTTPServerConfig defines how to auto-start an HTTP MCP server
func (*HTTPServerConfig) GetStartupTimeout ¶ added in v0.8.96
func (c *HTTPServerConfig) GetStartupTimeout() int
GetStartupTimeout returns the startup timeout in milliseconds, defaulting to 5000ms
type HookStatus ¶ added in v0.16.0
type HookStatus struct {
Status string // running, idle, waiting, dead
SessionID string // Claude session ID
Event string // Hook event name
UpdatedAt time.Time // When this status was received
}
HookStatus holds the decoded status from a hook status file.
type Instance ¶
type Instance struct {
ID string `json:"id"`
Title string `json:"title"`
ProjectPath string `json:"project_path"`
GroupPath string `json:"group_path"` // e.g., "projects/devops"
Order int `json:"order"` // Position within group (for reorder persistence)
ParentSessionID string `json:"parent_session_id,omitempty"` // Links to parent session (makes this a sub-session)
ParentProjectPath string `json:"parent_project_path,omitempty"` // Parent's project path (for --add-dir access)
// Git worktree support
WorktreePath string `json:"worktree_path,omitempty"` // Path to worktree (if session is in worktree)
WorktreeRepoRoot string `json:"worktree_repo_root,omitempty"` // Original repo root
WorktreeBranch string `json:"worktree_branch,omitempty"` // Branch name in worktree
Command string `json:"command"`
Wrapper string `json:"wrapper,omitempty"` // Optional wrapper command with {command} placeholder
Tool string `json:"tool"`
Status Status `json:"status"`
CreatedAt time.Time `json:"created_at"`
LastAccessedAt time.Time `json:"last_accessed_at,omitempty"` // When user last attached
// Claude Code integration
ClaudeSessionID string `json:"claude_session_id,omitempty"`
ClaudeDetectedAt time.Time `json:"claude_detected_at,omitempty"`
// Gemini CLI integration
GeminiSessionID string `json:"gemini_session_id,omitempty"`
GeminiDetectedAt time.Time `json:"gemini_detected_at,omitempty"`
GeminiYoloMode *bool `json:"gemini_yolo_mode,omitempty"` // Per-session override (nil = use global config)
GeminiModel string `json:"gemini_model,omitempty"` // Active model for this session
GeminiAnalytics *GeminiSessionAnalytics `json:"gemini_analytics,omitempty"` // Per-session analytics
// OpenCode CLI integration
OpenCodeSessionID string `json:"opencode_session_id,omitempty"`
OpenCodeDetectedAt time.Time `json:"opencode_detected_at,omitempty"`
OpenCodeStartedAt int64 `json:"-"` // Unix millis when we started OpenCode (for session matching, not persisted)
// Codex CLI integration
CodexSessionID string `json:"codex_session_id,omitempty"`
CodexDetectedAt time.Time `json:"codex_detected_at,omitempty"`
CodexStartedAt int64 `json:"-"` // Unix millis when we started Codex (for session matching, not persisted)
// Latest user input for context (extracted from session files)
LatestPrompt string `json:"latest_prompt,omitempty"`
// MCP tracking - which MCPs were loaded when session started/restarted
// Used to detect pending MCPs (added after session start) and stale MCPs (removed but still running)
LoadedMCPNames []string `json:"loaded_mcp_names,omitempty"`
// ToolOptions stores tool-specific launch options (Claude, Codex, Gemini, etc.)
// JSON structure: {"tool": "claude", "options": {...}}
ToolOptionsJSON json.RawMessage `json:"tool_options,omitempty"`
// SkipMCPRegenerate skips .mcp.json regeneration on next Restart()
// Set by MCP dialog Apply() to avoid race condition where Apply writes
// config then Restart immediately overwrites it with different pool state
SkipMCPRegenerate bool `json:"-"` // Don't persist, transient flag
// contains filtered or unexported fields
}
Instance represents a single agent/shell session
func DiscoverExistingTmuxSessions ¶
DiscoverExistingTmuxSessions finds all tmux sessions and converts them to instances
func FilterByQuery ¶
FilterByQuery filters sessions by title, project path, tool, or status Supports status filters: "waiting", "running", "idle", "error"
func NewInstance ¶
NewInstance creates a new session instance
func NewInstanceWithGroup ¶
NewInstanceWithGroup creates a new session instance with explicit group
func NewInstanceWithGroupAndTool ¶ added in v0.4.1
NewInstanceWithGroupAndTool creates a new session with explicit group and tool
func NewInstanceWithTool ¶ added in v0.4.1
NewInstanceWithTool creates a new session with tool-specific initialization
func (*Instance) CanForkOpenCode ¶ added in v0.8.99
CanForkOpenCode returns true if this OpenCode session can be forked
func (*Instance) CanRestart ¶ added in v0.4.1
CanRestart returns true if the session can be restarted For Claude sessions with known ID: can always restart (interrupt and resume) For Gemini sessions with known ID: can always restart (interrupt and resume) For OpenCode sessions with known ID: can always restart (interrupt and resume) For Codex sessions with known ID: can always restart (interrupt and resume) For custom tools with session resume config: can restart if session ID available For other sessions: only if dead/error state
func (*Instance) CanRestartGeneric ¶ added in v0.8.27
CanRestartGeneric returns true if a custom tool can be restarted with session resume
func (*Instance) CaptureLoadedMCPs ¶ added in v0.5.3
func (i *Instance) CaptureLoadedMCPs()
CaptureLoadedMCPs captures the current MCP names as the "loaded" state This should be called when a session starts or restarts, so we can track which MCPs are actually loaded in the running Claude session vs just configured
func (*Instance) ClearHookStatus ¶ added in v0.16.0
func (i *Instance) ClearHookStatus()
ClearHookStatus resets the hook-based status, forcing the next UpdateStatus() to fall through to polling. Used when the user manually overrides status (e.g., pressing 'u' to unacknowledge after an Escape interrupt where the Stop hook didn't fire).
func (*Instance) ClearParent ¶ added in v0.7.0
func (inst *Instance) ClearParent()
ClearParent removes the parent session link
func (*Instance) CreateForkedInstance ¶ added in v0.4.1
CreateForkedInstance creates a new Instance configured for forking Deprecated: Use CreateForkedInstanceWithOptions instead
func (*Instance) CreateForkedInstanceWithOptions ¶ added in v0.8.39
func (i *Instance) CreateForkedInstanceWithOptions(newTitle, newGroupPath string, opts *ClaudeOptions) (*Instance, string, error)
CreateForkedInstanceWithOptions creates a new Instance configured for forking with custom options
func (*Instance) CreateForkedOpenCodeInstance ¶ added in v0.8.99
func (i *Instance) CreateForkedOpenCodeInstance(newTitle, newGroupPath string) (*Instance, string, error)
CreateForkedOpenCodeInstance creates a new Instance configured for forking an OpenCode session Deprecated: Use CreateForkedOpenCodeInstanceWithOptions instead.
func (*Instance) CreateForkedOpenCodeInstanceWithOptions ¶ added in v0.12.1
func (i *Instance) CreateForkedOpenCodeInstanceWithOptions(newTitle, newGroupPath string, opts *OpenCodeOptions) (*Instance, string, error)
CreateForkedOpenCodeInstanceWithOptions creates a new Instance configured for forking with custom options
func (*Instance) DetectCodexSession ¶ added in v0.8.76
func (i *Instance) DetectCodexSession()
DetectCodexSession is the public wrapper for async Codex session detection Call this for restored sessions that don't have a session ID yet
func (*Instance) DetectOpenCodeSession ¶ added in v0.8.72
func (i *Instance) DetectOpenCodeSession()
DetectOpenCodeSession is the public wrapper for async OpenCode session detection Call this for restored sessions that don't have a session ID yet
func (*Instance) ForceNextStatusCheck ¶ added in v0.16.0
func (i *Instance) ForceNextStatusCheck()
ForceNextStatusCheck clears the idle polling optimization so the next UpdateStatus() performs a full check instead of short-circuiting. Call this before UpdateStatus() when a status-affecting change was made externally (e.g. the u key toggling acknowledged state).
func (*Instance) Fork ¶ added in v0.4.1
Fork returns the command to create a forked Claude session Uses capture-resume pattern: starts fork in print mode to get new session ID, stores in tmux environment, then resumes interactively Deprecated: Use ForkWithOptions instead
func (*Instance) ForkOpenCode ¶ added in v0.8.99
ForkOpenCode returns the command to create a forked OpenCode session. Uses export/import to clone the session with a new ID, then launches the forked session with opencode -s <new-id>. Deprecated: Use ForkOpenCodeWithOptions instead.
func (*Instance) ForkOpenCodeWithOptions ¶ added in v0.12.1
func (i *Instance) ForkOpenCodeWithOptions(newTitle, newGroupPath string, opts *OpenCodeOptions) (string, error)
ForkOpenCodeWithOptions returns the command to create a forked OpenCode session with custom options. Uses export/import to clone the session with a new ID, then launches the forked session with opencode -s <new-id> plus any model/agent flags.
func (*Instance) ForkWithOptions ¶ added in v0.8.39
func (i *Instance) ForkWithOptions(newTitle, newGroupPath string, opts *ClaudeOptions) (string, error)
ForkWithOptions returns the command to create a forked Claude session with custom options Uses capture-resume pattern: starts fork in print mode to get new session ID, stores in tmux environment, then resumes interactively
func (*Instance) GetActualWorkDir ¶ added in v0.4.1
GetActualWorkDir returns the actual working directory from tmux, or falls back to ProjectPath
func (*Instance) GetClaudeOptions ¶ added in v0.8.39
func (i *Instance) GetClaudeOptions() *ClaudeOptions
GetClaudeOptions returns Claude-specific options, or nil if not set
func (*Instance) GetCodexOptions ¶ added in v0.10.18
func (i *Instance) GetCodexOptions() *CodexOptions
GetCodexOptions returns Codex-specific options, or nil if not set
func (*Instance) GetGenericSessionID ¶ added in v0.8.27
GetGenericSessionID gets session ID from tmux environment for a custom tool Uses the session_id_env field from tool config
func (*Instance) GetHookStatus ¶ added in v0.16.0
GetHookStatus returns the current hook-based status and its freshness. Freshness window is tool-specific.
func (*Instance) GetJSONLPath ¶ added in v0.8.27
GetJSONLPath returns the path to the Claude session JSONL file for analytics Returns empty string if this is not a Claude session or no session ID is available
func (*Instance) GetLastActivityTime ¶ added in v0.5.6
GetLastActivityTime returns when the session was last active (content changed) Returns CreatedAt if no activity has been tracked yet
func (*Instance) GetLastResponse ¶ added in v0.7.0
func (i *Instance) GetLastResponse() (*ResponseOutput, error)
GetLastResponse returns the last assistant response from the session For Claude: Parses the JSONL file for the last assistant message For Gemini: Parses the JSON session file for the last assistant message For Codex/Others: Attempts to parse terminal output
func (*Instance) GetMCPInfo ¶ added in v0.5.3
GetMCPInfo returns MCP server information for this session Returns nil if not a Claude or Gemini session
func (*Instance) GetOpenCodeOptions ¶ added in v0.12.1
func (i *Instance) GetOpenCodeOptions() *OpenCodeOptions
GetOpenCodeOptions returns OpenCode-specific options, or nil if not set
func (*Instance) GetSessionIDFromTmux ¶ added in v0.5.0
GetSessionIDFromTmux reads Claude session ID from tmux environment This is the primary method for sessions started with the capture-resume pattern
func (*Instance) GetStatusThreadSafe ¶ added in v0.10.6
GetStatusThreadSafe returns the session status with read-lock protection. Use this when reading Status from a goroutine concurrent with backgroundStatusUpdate.
func (*Instance) GetTmuxSession ¶
GetTmuxSession returns the tmux session object
func (*Instance) GetToolThreadSafe ¶ added in v0.10.6
GetToolThreadSafe returns the tool name with read-lock protection.
func (*Instance) GetWaitingSince ¶ added in v0.8.50
GetWaitingSince returns when the session transitioned to waiting status Used for sorting notification bar (newest waiting sessions first)
func (*Instance) HasUpdated ¶
HasUpdated checks if there's new output since last check
func (*Instance) IsSubSession ¶ added in v0.7.0
IsSubSession returns true if this session has a parent
func (*Instance) IsWorktree ¶ added in v0.8.22
IsWorktree returns true if this session is running in a git worktree
func (*Instance) MarkAccessed ¶ added in v0.5.3
func (inst *Instance) MarkAccessed()
MarkAccessed updates the LastAccessedAt timestamp to now
func (*Instance) PostStartSync ¶ added in v0.8.97
PostStartSync captures session IDs from tmux environment after Start() or Restart(). Designed for CLI commands that exit after starting. The TUI doesn't need this because its background worker handles detection.
For Claude: polls tmux env for CLAUDE_SESSION_ID (set by bash uuidgen before exec). For Gemini: reads session ID from filesystem. For OpenCode/Codex: no-op (async goroutine detection, too slow for sync CLI).
func (*Instance) PreviewFull ¶
PreviewFull returns all terminal output
func (*Instance) Restart ¶ added in v0.4.1
Restart restarts the Claude session For Claude sessions with known ID: sends Ctrl+C twice and resume command to existing session For dead sessions or unknown ID: recreates the tmux session
func (*Instance) SetAcknowledgedFromShared ¶ added in v0.11.0
SetAcknowledgedFromShared applies an acknowledgment from another TUI instance (read from SQLite). This transitions a YELLOW (waiting) session to GRAY (idle) without requiring the user to interact with this specific TUI instance.
func (*Instance) SetClaudeOptions ¶ added in v0.8.39
func (i *Instance) SetClaudeOptions(opts *ClaudeOptions) error
SetClaudeOptions stores Claude-specific options
func (*Instance) SetCodexOptions ¶ added in v0.10.18
func (i *Instance) SetCodexOptions(opts *CodexOptions) error
SetCodexOptions stores Codex-specific options
func (*Instance) SetGeminiModel ¶ added in v0.8.79
SetGeminiModel sets the Gemini model for this session and triggers a restart if running.
func (*Instance) SetGeminiYoloMode ¶ added in v0.8.50
SetGeminiYoloMode sets the YOLO mode for Gemini and syncs it to the tmux environment. This ensures the background status worker sees the correct state during restarts.
func (*Instance) SetOpenCodeOptions ¶ added in v0.12.1
func (i *Instance) SetOpenCodeOptions(opts *OpenCodeOptions) error
SetOpenCodeOptions stores OpenCode-specific options
func (*Instance) SetParentWithPath ¶ added in v0.8.34
SetParentWithPath sets both parent session ID and parent's project path The project path is used to grant subagent access via --add-dir
func (*Instance) SetStatusThreadSafe ¶ added in v0.10.6
SetStatusThreadSafe sets the session status with write-lock protection.
func (*Instance) SetToolThreadSafe ¶ added in v0.10.6
SetToolThreadSafe sets the tool name with write-lock protection.
func (*Instance) StartWithMessage ¶ added in v0.6.2
StartWithMessage starts the session and sends an initial message when ready The message is sent synchronously after detecting the agent's prompt This approach is more reliable than embedding send logic in the tmux command Works for Claude, Gemini, OpenCode, and other agents
func (*Instance) SyncSessionIDsToTmux ¶ added in v0.8.95
func (i *Instance) SyncSessionIDsToTmux()
SyncSessionIDsToTmux syncs session IDs from Instance to tmux environment. PERFORMANCE: This is called on-demand (e.g., first attach) rather than at load time to reduce subprocess overhead during TUI startup.
Session IDs are needed in tmux environment for restart/resume operations that spawn new processes. Without this sync, R key wouldn't resume the correct session.
func (*Instance) SyncTmuxDisplayName ¶ added in v0.8.80
func (i *Instance) SyncTmuxDisplayName()
SyncTmuxDisplayName updates the tmux status bar to reflect the current title.
func (*Instance) UpdateClaudeSession ¶ added in v0.4.1
UpdateClaudeSession updates the Claude session ID from tmux environment. The capture-resume pattern (used in Start/Fork/Restart) sets CLAUDE_SESSION_ID in the tmux environment, making this the single authoritative source.
No file scanning fallback - we rely on the consistent capture-resume pattern.
func (*Instance) UpdateCodexSession ¶ added in v0.8.76
UpdateCodexSession updates the Codex session ID. Primary source: tmux environment. Fallback: project-aware filesystem scan.
func (*Instance) UpdateGeminiSession ¶ added in v0.8.1
UpdateGeminiSession updates the Gemini session ID, YOLO mode, analytics, and latest prompt. Delegates to focused helpers for each concern.
func (*Instance) UpdateHookStatus ¶ added in v0.16.0
func (i *Instance) UpdateHookStatus(status *HookStatus)
UpdateHookStatus updates the instance's hook-based status fields. Called by StatusFileWatcher when a hook status file changes.
func (*Instance) UpdateStatus ¶
UpdateStatus updates the session status by checking tmux. Thread-safe: acquires write lock to protect Status, Tool, and internal cache fields.
func (*Instance) WaitForClaudeSession ¶ added in v0.4.1
WaitForClaudeSession waits for the tmux environment variable to be set. The capture-resume pattern sets CLAUDE_SESSION_ID in tmux env, so we poll for that. Returns the detected session ID or empty string after timeout.
func (*Instance) WaitForClaudeSessionWithExclude ¶ added in v0.5.0
func (i *Instance) WaitForClaudeSessionWithExclude(maxWait time.Duration, excludeIDs map[string]bool) string
WaitForClaudeSessionWithExclude waits for the tmux environment variable to be set. The excludeIDs parameter is kept for API compatibility but not used since tmux env is authoritative and won't return duplicate IDs.
type InstanceData ¶
type InstanceData struct {
ID string `json:"id"`
Title string `json:"title"`
ProjectPath string `json:"project_path"`
GroupPath string `json:"group_path"`
Order int `json:"order"`
ParentSessionID string `json:"parent_session_id,omitempty"` // Links to parent session (sub-session support)
Command string `json:"command"`
Wrapper string `json:"wrapper,omitempty"`
Tool string `json:"tool"`
Status Status `json:"status"`
CreatedAt time.Time `json:"created_at"`
LastAccessedAt time.Time `json:"last_accessed_at,omitempty"`
TmuxSession string `json:"tmux_session"`
// Worktree support
WorktreePath string `json:"worktree_path,omitempty"`
WorktreeRepoRoot string `json:"worktree_repo_root,omitempty"`
WorktreeBranch string `json:"worktree_branch,omitempty"`
// Claude session (persisted for resume after app restart)
ClaudeSessionID string `json:"claude_session_id,omitempty"`
ClaudeDetectedAt time.Time `json:"claude_detected_at,omitempty"`
// Gemini session (persisted for resume after app restart)
GeminiSessionID string `json:"gemini_session_id,omitempty"`
GeminiDetectedAt time.Time `json:"gemini_detected_at,omitempty"`
GeminiYoloMode *bool `json:"gemini_yolo_mode,omitempty"`
GeminiModel string `json:"gemini_model,omitempty"`
// OpenCode session (persisted for resume after app restart)
OpenCodeSessionID string `json:"opencode_session_id,omitempty"`
OpenCodeDetectedAt time.Time `json:"opencode_detected_at,omitempty"`
// Codex session (persisted for resume after app restart)
CodexSessionID string `json:"codex_session_id,omitempty"`
CodexDetectedAt time.Time `json:"codex_detected_at,omitempty"`
// Latest user input for context
LatestPrompt string `json:"latest_prompt,omitempty"`
// Tool-specific launch options (generic for all tools: claude, codex, etc.)
ToolOptionsJSON json.RawMessage `json:"tool_options,omitempty"`
// MCP tracking (persisted for sync status display)
LoadedMCPNames []string `json:"loaded_mcp_names,omitempty"`
}
InstanceData represents the serializable session data
type InstanceSettings ¶ added in v0.8.74
type InstanceSettings struct {
// AllowMultiple allows running multiple agent-deck TUI instances for the same profile
// When true (default), multiple instances can run, but only the first (primary) manages the notification bar
// When false, only one instance can run per profile
AllowMultiple *bool `toml:"allow_multiple"`
}
InstanceSettings configures multiple agent-deck instance behavior
func GetInstanceSettings ¶ added in v0.8.74
func GetInstanceSettings() InstanceSettings
GetInstanceSettings returns instance behavior settings
func (*InstanceSettings) GetAllowMultiple ¶ added in v0.8.97
func (i *InstanceSettings) GetAllowMultiple() bool
GetAllowMultiple returns whether multiple instances are allowed, defaulting to true
type Item ¶
type Item struct {
Type ItemType
Group *Group
Session *Instance
Level int // Indentation level (0 for root groups, 1 for sessions)
Path string // Group path for this item
IsLastInGroup bool // True if this is the last session in its group (for tree rendering)
RootGroupNum int // Pre-computed root group number for hotkey display (1-9, 0 if not a root group)
IsSubSession bool // True if this session has a parent session
IsLastSubSession bool // True if this is the last sub-session of its parent (for tree rendering)
ParentIsLastInGroup bool // True if parent session is last top-level item (for tree line rendering)
}
Item represents a single item in the flattened group tree view
type LocalMCP ¶ added in v0.6.1
type LocalMCP struct {
Name string // MCP name
SourcePath string // Directory containing the .mcp.json file
}
LocalMCP represents an MCP defined in a local .mcp.json file
type LogSettings ¶ added in v0.5.3
type LogSettings struct {
// MaxSizeMB is the maximum size in MB before a log file is truncated
// When a log exceeds this size, it keeps only the last MaxLines lines
// Default: 10 (10MB)
MaxSizeMB int `toml:"max_size_mb"`
// MaxLines is the number of lines to keep when truncating
// Default: 10000
MaxLines int `toml:"max_lines"`
// RemoveOrphans removes log files for sessions that no longer exist
// Default: true
RemoveOrphans bool `toml:"remove_orphans"`
// DebugLevel sets the minimum log level: "debug", "info", "warn", "error"
// Default: "info"
DebugLevel string `toml:"debug_level"`
// DebugFormat sets the log format: "json" (default) or "text"
DebugFormat string `toml:"debug_format"`
// DebugMaxMB is the max size in MB for debug.log before rotation
// Default: 10
DebugMaxMB int `toml:"debug_max_mb"`
// DebugBackups is the number of rotated debug.log files to keep
// Default: 5
DebugBackups int `toml:"debug_backups"`
// DebugRetentionDays is the number of days to keep rotated debug logs
// Default: 10
DebugRetentionDays int `toml:"debug_retention_days"`
// DebugCompress enables gzip compression for rotated debug logs
// Default: true
DebugCompress bool `toml:"debug_compress"`
// RingBufferMB is the in-memory ring buffer size in MB for crash dumps
// Default: 10
RingBufferMB int `toml:"ring_buffer_mb"`
// PprofEnabled starts a pprof server on localhost:6060 when debug mode is active
// Default: false
PprofEnabled bool `toml:"pprof_enabled"`
// AggregateIntervalS is the event aggregation flush interval in seconds
// Default: 30
AggregateIntervalS int `toml:"aggregate_interval_secs"`
}
LogSettings defines log file management configuration
func GetLogSettings ¶ added in v0.5.3
func GetLogSettings() LogSettings
GetLogSettings returns log management settings with defaults applied
type MCPDef ¶ added in v0.5.3
type MCPDef struct {
// Command is the executable to run (e.g., "npx", "docker", "node")
// Required for stdio MCPs, optional for HTTP/SSE MCPs
Command string `toml:"command"`
// Args are command-line arguments
Args []string `toml:"args"`
// Env is optional environment variables
Env map[string]string `toml:"env"`
// Description is optional help text shown in the MCP Manager
Description string `toml:"description"`
// URL is the endpoint for HTTP/SSE MCPs (e.g., "http://localhost:8000/mcp")
// If set, this MCP uses HTTP or SSE transport instead of stdio
URL string `toml:"url"`
// Transport specifies the MCP transport type: "stdio" (default), "http", or "sse"
// Only needed when URL is set; defaults to "http" if URL is present
Transport string `toml:"transport"`
// Headers is optional HTTP headers for HTTP/SSE MCPs (e.g., for authentication)
// Example: { Authorization = "Bearer token123" }
Headers map[string]string `toml:"headers"`
// Server defines how to auto-start an HTTP MCP server process
// When set, agent-deck will start the server before connecting via HTTP
// This is optional - you can also connect to externally managed servers
Server *HTTPServerConfig `toml:"server"`
}
MCPDef defines an MCP server configuration for the MCP Manager
func GetMCPDef ¶ added in v0.5.3
GetMCPDef returns a specific MCP definition by name Returns nil if not found
func (*MCPDef) GetTransport ¶ added in v0.8.96
GetTransport returns the transport type, defaulting to "http" if URL is set
func (*MCPDef) HasAutoStartServer ¶ added in v0.8.96
HasAutoStartServer returns true if this HTTP MCP has server auto-start configured
type MCPInfo ¶ added in v0.5.3
type MCPInfo struct {
Global []string // From CLAUDE_CONFIG_DIR/.claude.json mcpServers
Project []string // From CLAUDE_CONFIG_DIR/.claude.json projects[path].mcpServers
LocalMCPs []LocalMCP // From .mcp.json files (walks up parent directories)
}
MCPInfo contains MCP server information for a session
func GetGeminiMCPInfo ¶ added in v0.8.1
GetGeminiMCPInfo reads MCP configuration from settings.json Returns MCPInfo with Global MCPs only (Gemini has no project-level MCPs) VERIFIED: settings.json structure is simple {"mcpServers": {...}}
func GetMCPInfo ¶ added in v0.5.3
GetMCPInfo retrieves MCP server information for a project path (cached) It reads from three sources: 1. Global MCPs: CLAUDE_CONFIG_DIR/.claude.json → mcpServers 2. Project MCPs: CLAUDE_CONFIG_DIR/.claude.json → projects[projectPath].mcpServers 3. Local MCPs: {projectPath}/.mcp.json → mcpServers
func (*MCPInfo) AllNames ¶ added in v0.5.3
AllNames returns a deduplicated, sorted list of all MCP names across all sources Used for capturing loaded MCPs at session start for sync tracking
type MCPMode ¶ added in v0.5.3
type MCPMode int
MCPMode indicates how MCP enabling/disabling is configured
func GetMCPMode ¶ added in v0.5.3
GetMCPMode determines the MCP configuration mode for a project
type MCPPoolSettings ¶ added in v0.6.2
type MCPPoolSettings struct {
// Enabled enables HTTP pool mode (default: false)
Enabled bool `toml:"enabled"`
// AutoStart starts pool when agent-deck launches (default: true)
AutoStart bool `toml:"auto_start"`
// PortStart is the first port in the pool range (default: 8001)
PortStart int `toml:"port_start"`
// PortEnd is the last port in the pool range (default: 8050)
PortEnd int `toml:"port_end"`
// StartOnDemand starts MCPs lazily on first attach (default: false)
StartOnDemand bool `toml:"start_on_demand"`
// ShutdownOnExit stops HTTP servers when agent-deck quits (default: true)
ShutdownOnExit bool `toml:"shutdown_on_exit"`
// PoolMCPs is the list of MCPs to run in pool mode
// Empty = auto-detect common MCPs (memory, exa, firecrawl, etc.)
PoolMCPs []string `toml:"pool_mcps"`
// FallbackStdio uses stdio for MCPs without socket support (default: true)
FallbackStdio bool `toml:"fallback_to_stdio"`
// ShowStatus shows pool status in TUI (default: true)
ShowStatus bool `toml:"show_pool_status"`
// PoolAll pools all MCPs by default (default: false)
PoolAll bool `toml:"pool_all"`
// ExcludeMCPs excludes specific MCPs from pool when pool_all = true
ExcludeMCPs []string `toml:"exclude_mcps"`
// SocketWaitTimeout is seconds to wait for socket to become ready (default: 5)
SocketWaitTimeout int `toml:"socket_wait_timeout"`
}
MCPPoolSettings defines HTTP MCP pool configuration
type MCPServer ¶ added in v0.5.3
MCPServer represents an MCP with its enabled state
func GetLocalMCPState ¶ added in v0.5.3
GetLocalMCPState returns Local MCPs with their enabled state
type MCPServerConfig ¶ added in v0.5.3
type MCPServerConfig struct {
Type string `json:"type,omitempty"`
Command string `json:"command,omitempty"`
Args []string `json:"args,omitempty"`
Env map[string]string `json:"env,omitempty"`
URL string `json:"url,omitempty"` // For HTTP transport
Headers map[string]string `json:"headers,omitempty"` // For HTTP transport (e.g., Authorization)
}
MCPServerConfig represents an MCP server configuration (Claude's format)
type MaintenanceResult ¶ added in v0.8.79
type MaintenanceResult struct {
PrunedLogs int
PrunedBackups int
ArchivedSessions int
Duration time.Duration
}
MaintenanceResult holds the outcome of a maintenance run.
func RunMaintenance ¶ added in v0.8.79
func RunMaintenance() MaintenanceResult
RunMaintenance executes all maintenance tasks and returns the result.
type MaintenanceSettings ¶ added in v0.8.79
type MaintenanceSettings struct {
// Enabled enables the maintenance worker (default: false)
// Prunes Gemini logs, cleans old backups, archives bloated sessions
Enabled bool `toml:"enabled"`
}
MaintenanceSettings controls the automatic maintenance worker
func GetMaintenanceSettings ¶ added in v0.8.79
func GetMaintenanceSettings() MaintenanceSettings
GetMaintenanceSettings returns maintenance settings from config
type MatchRange ¶ added in v0.5.3
MatchRange represents a match position in content
type MigrationResult ¶ added in v0.3.0
type MigrationResult struct {
Migrated bool // True if migration was performed
ProfilePath string // Path to the migrated profile
SessionCount int // Number of sessions migrated
Message string // Human-readable message
}
MigrationResult contains information about the migration outcome
func MigrateToProfiles ¶ added in v0.3.0
func MigrateToProfiles() (*MigrationResult, error)
MigrateToProfiles migrates from the old single-file layout to the profiles layout. This is safe to call multiple times - it will only migrate once.
Old layout:
~/.agent-deck/sessions.json ~/.agent-deck/sessions.json.bak ~/.agent-deck/sessions.json.bak.1 ~/.agent-deck/sessions.json.bak.2
New layout:
~/.agent-deck/config.json ~/.agent-deck/profiles/default/sessions.json ~/.agent-deck/profiles/default/sessions.json.bak ~/.agent-deck/profiles/default/sessions.json.bak.1 ~/.agent-deck/profiles/default/sessions.json.bak.2 ~/.agent-deck/logs/ (unchanged)
type ModelPricing ¶ added in v0.8.27
ModelPricing holds pricing per million tokens for a model
type NotificationEntry ¶ added in v0.8.43
type NotificationEntry struct {
SessionID string
TmuxName string
Title string
AssignedKey string
WaitingSince time.Time
Status Status // For icon rendering when show_all enabled
}
NotificationEntry represents a waiting session in the notification bar
type NotificationManager ¶ added in v0.8.43
type NotificationManager struct {
// contains filtered or unexported fields
}
NotificationManager tracks waiting sessions for the notification bar
func NewNotificationManager ¶ added in v0.8.43
func NewNotificationManager(maxShown int, showAll bool) *NotificationManager
NewNotificationManager creates a new notification manager
func (*NotificationManager) Add ¶ added in v0.8.43
func (nm *NotificationManager) Add(inst *Instance) error
Add registers a session as waiting (newest goes to position [0])
func (*NotificationManager) Clear ¶ added in v0.8.43
func (nm *NotificationManager) Clear()
Clear removes all notifications
func (*NotificationManager) Count ¶ added in v0.8.43
func (nm *NotificationManager) Count() int
Count returns number of notifications
func (*NotificationManager) FormatBar ¶ added in v0.8.43
func (nm *NotificationManager) FormatBar() string
FormatBar returns the formatted status bar text
func (*NotificationManager) GetEntries ¶ added in v0.8.43
func (nm *NotificationManager) GetEntries() []*NotificationEntry
GetEntries returns a copy of current entries (newest first)
func (*NotificationManager) GetSessionByKey ¶ added in v0.8.43
func (nm *NotificationManager) GetSessionByKey(key string) *NotificationEntry
GetSessionByKey returns the entry for a given key (1-6)
func (*NotificationManager) Has ¶ added in v0.8.43
func (nm *NotificationManager) Has(sessionID string) bool
Has checks if a session is in notifications
func (*NotificationManager) Remove ¶ added in v0.8.43
func (nm *NotificationManager) Remove(sessionID string)
Remove removes a session from notifications
func (*NotificationManager) SyncFromInstances ¶ added in v0.8.43
func (nm *NotificationManager) SyncFromInstances(instances []*Instance, currentSessionID string) (added, removed []string)
SyncFromInstances updates notifications based on current instance states Call this periodically to sync with actual session statuses
type NotificationsConfig ¶ added in v0.8.43
type NotificationsConfig struct {
// Enabled shows notification bar in tmux status (default: true)
Enabled bool `toml:"enabled"`
// MaxShown is the maximum number of sessions shown in the bar (default: 6)
MaxShown int `toml:"max_shown"`
// ShowAll displays all sessions (with status icons) instead of only waiting sessions (default: false)
ShowAll bool `toml:"show_all"`
}
NotificationsConfig configures the waiting session notification bar
func GetNotificationsSettings ¶ added in v0.8.43
func GetNotificationsSettings() NotificationsConfig
GetNotificationsSettings returns notification bar settings with defaults applied
type OpenCodeOptions ¶ added in v0.12.1
type OpenCodeOptions struct {
// SessionMode: "new" (default), "continue" (-c), or "resume" (-s)
SessionMode string `json:"session_mode,omitempty"`
// ResumeSessionID is the session ID for -s flag (only when SessionMode="resume")
ResumeSessionID string `json:"resume_session_id,omitempty"`
// Model overrides the model (e.g., "anthropic/claude-sonnet-4-5-20250929")
Model string `json:"model,omitempty"`
// Agent overrides the agent to use
Agent string `json:"agent,omitempty"`
}
OpenCodeOptions holds launch options for OpenCode CLI sessions
func NewOpenCodeOptions ¶ added in v0.12.1
func NewOpenCodeOptions(config *UserConfig) *OpenCodeOptions
NewOpenCodeOptions creates OpenCodeOptions with defaults from config
func UnmarshalOpenCodeOptions ¶ added in v0.12.1
func UnmarshalOpenCodeOptions(data json.RawMessage) (*OpenCodeOptions, error)
UnmarshalOpenCodeOptions deserializes OpenCodeOptions from JSON wrapper
func (*OpenCodeOptions) ToArgs ¶ added in v0.12.1
func (o *OpenCodeOptions) ToArgs() []string
ToArgs returns command-line arguments based on options
func (*OpenCodeOptions) ToArgsForFork ¶ added in v0.12.1
func (o *OpenCodeOptions) ToArgsForFork() []string
ToArgsForFork returns arguments suitable for fork resume command. Fork uses -s internally, so session mode flags are excluded.
func (*OpenCodeOptions) ToolName ¶ added in v0.12.1
func (o *OpenCodeOptions) ToolName() string
ToolName returns "opencode"
type OpenCodeSettings ¶ added in v0.12.1
type OpenCodeSettings struct {
// DefaultModel is the model to use for new OpenCode sessions
// Format: "provider/model" (e.g., "anthropic/claude-sonnet-4-5-20250929")
// If empty, OpenCode uses its own default
DefaultModel string `toml:"default_model"`
// DefaultAgent is the agent to use for new OpenCode sessions
// If empty, OpenCode uses its own default
DefaultAgent string `toml:"default_agent"`
// EnvFile is a .env file specific to OpenCode sessions
// Sourced AFTER global [shell].env_files
// Path can be absolute, ~ for home, $HOME/${VAR} for env vars, or relative to session working directory
EnvFile string `toml:"env_file"`
}
OpenCodeSettings defines OpenCode CLI configuration
type PreviewSettings ¶ added in v0.8.27
type PreviewSettings struct {
// ShowOutput shows terminal output in preview pane (including launch animation)
// Default: true (pointer to distinguish "not set" from "explicitly false")
ShowOutput *bool `toml:"show_output"`
// ShowAnalytics shows session analytics panel for Claude sessions
// Default: false (pointer to distinguish "not set" from "explicitly false")
ShowAnalytics *bool `toml:"show_analytics"`
// Analytics configures which sections to show in the analytics panel
Analytics AnalyticsDisplaySettings `toml:"analytics"`
}
PreviewSettings defines preview pane configuration
func GetPreviewSettings ¶ added in v0.8.27
func GetPreviewSettings() PreviewSettings
GetPreviewSettings returns preview settings with defaults applied
func (*PreviewSettings) GetAnalyticsSettings ¶ added in v0.8.53
func (p *PreviewSettings) GetAnalyticsSettings() AnalyticsDisplaySettings
GetAnalyticsSettings returns the analytics display settings with defaults applied
func (*PreviewSettings) GetShowAnalytics ¶ added in v0.8.27
func (p *PreviewSettings) GetShowAnalytics() bool
GetShowAnalytics returns whether to show analytics, defaulting to false
func (*PreviewSettings) GetShowOutput ¶ added in v0.8.33
func (p *PreviewSettings) GetShowOutput() bool
GetShowOutput returns whether to show terminal output, defaulting to true
type ProfileClaudeSettings ¶ added in v0.19.1
type ProfileClaudeSettings struct {
// ConfigDir overrides [claude].config_dir for this profile only.
ConfigDir string `toml:"config_dir"`
}
ProfileClaudeSettings defines profile-specific Claude overrides.
type ProfileSettings ¶ added in v0.19.1
type ProfileSettings struct {
// Claude defines Claude Code overrides for a specific profile.
Claude ProfileClaudeSettings `toml:"claude"`
}
ProfileSettings defines per-profile configuration overrides.
type ProjectMCPSettings ¶ added in v0.5.3
type ProjectMCPSettings struct {
EnableAllProjectMcpServers bool `json:"enableAllProjectMcpServers,omitempty"`
EnabledMcpjsonServers []string `json:"enabledMcpjsonServers,omitempty"`
DisabledMcpjsonServers []string `json:"disabledMcpjsonServers,omitempty"`
}
ProjectMCPSettings represents .claude/settings.local.json
type ProjectSkillAttachment ¶ added in v0.19.1
type ProjectSkillAttachment struct {
ID string `toml:"id"`
Name string `toml:"name"`
Source string `toml:"source"`
SourcePath string `toml:"source_path"`
EntryName string `toml:"entry_name"`
TargetPath string `toml:"target_path"` // relative to project path
Mode string `toml:"mode,omitempty"`
AttachedAt string `toml:"attached_at,omitempty"`
}
ProjectSkillAttachment is persisted in .agent-deck/skills.toml.
func AttachSkillToProject ¶ added in v0.19.1
func AttachSkillToProject(projectPath, skillRef, sourceName string) (*ProjectSkillAttachment, error)
AttachSkillToProject resolves and attaches one skill into <project>/.claude/skills.
func DetachSkillFromProject ¶ added in v0.19.1
func DetachSkillFromProject(projectPath, skillRef, sourceName string) (*ProjectSkillAttachment, error)
DetachSkillFromProject detaches one managed skill and removes its manifest entry.
func GetAttachedProjectSkills ¶ added in v0.19.1
func GetAttachedProjectSkills(projectPath string) ([]ProjectSkillAttachment, error)
GetAttachedProjectSkills returns manifest-backed attached skills.
type ProjectSkillsManifest ¶ added in v0.19.1
type ProjectSkillsManifest struct {
Skills []ProjectSkillAttachment `toml:"skills"`
}
ProjectSkillsManifest is the project-local attachment state.
func LoadProjectSkillsManifest ¶ added in v0.19.1
func LoadProjectSkillsManifest(projectPath string) (*ProjectSkillsManifest, error)
LoadProjectSkillsManifest reads project attachment state.
type ResponseOutput ¶ added in v0.7.0
type ResponseOutput struct {
Tool string `json:"tool"` // Tool type (claude, gemini, etc.)
Role string `json:"role"` // Always "assistant" for now
Content string `json:"content"` // The actual response text
Timestamp string `json:"timestamp,omitempty"` // When the response was generated (Claude only)
SessionID string `json:"session_id,omitempty"` // Claude session ID (if available)
}
ResponseOutput represents a parsed response from an agent session
type SearchEntry ¶ added in v0.5.3
type SearchEntry struct {
SessionID string // Claude session UUID
FilePath string // Path to .jsonl file
CWD string // Project working directory
Summary string // First user message or summary
ModTime time.Time // File modification time
FileSize int64 // File size in bytes
// contains filtered or unexported fields
}
SearchEntry represents a searchable Claude session
func (*SearchEntry) ContentPreview ¶ added in v0.10.0
func (e *SearchEntry) ContentPreview(max int) string
func (*SearchEntry) ContentString ¶ added in v0.10.0
func (e *SearchEntry) ContentString() string
func (*SearchEntry) GetSnippet ¶ added in v0.5.3
func (e *SearchEntry) GetSnippet(query string, windowSize int) string
GetSnippet extracts a context window around the first match Uses rune-based indexing to safely handle UTF-8 content Optimized: Single rune conversion instead of triple conversion
func (*SearchEntry) Match ¶ added in v0.5.3
func (e *SearchEntry) Match(query string) []MatchRange
Match searches for query in entry content (case-insensitive) Returns match positions for highlighting
func (*SearchEntry) MatchCount ¶ added in v0.10.0
func (e *SearchEntry) MatchCount(query string) int
type SearchResult ¶ added in v0.5.3
type SearchResult struct {
Entry *SearchEntry
Matches []MatchRange
Score int
Snippet string
}
SearchResult represents a search result with match info
type SearchTier ¶ added in v0.5.3
type SearchTier int
SearchTier represents the search strategy tier
const ( TierInstant SearchTier = iota // < 100MB, full in-memory TierBalanced // 100MB-500MB, on-demand scan to cap memory )
func DetectTier ¶ added in v0.5.3
func DetectTier(totalSize int64) SearchTier
DetectTier determines the appropriate search tier based on data size
type SessionAnalytics ¶ added in v0.8.27
type SessionAnalytics struct {
// Token usage (cumulative across all turns)
InputTokens int `json:"input_tokens"`
OutputTokens int `json:"output_tokens"`
CacheReadTokens int `json:"cache_read_input_tokens"`
CacheWriteTokens int `json:"cache_creation_input_tokens"`
// Current context size (last turn's input + cache read tokens)
// This represents the actual context window usage, not cumulative totals
CurrentContextTokens int `json:"current_context_tokens"`
// Session metrics
TotalTurns int `json:"total_turns"`
Duration time.Duration `json:"duration"`
StartTime time.Time `json:"start_time"`
LastActive time.Time `json:"last_active"`
// Tool usage
ToolCalls []ToolCall `json:"tool_calls"`
// Subagents
Subagents []SubagentInfo `json:"subagents"`
// Cost estimation
EstimatedCost float64 `json:"estimated_cost"`
// 5-hour billing blocks
BillingBlocks []BillingBlock `json:"billing_blocks"`
}
SessionAnalytics holds parsed session metrics from Claude JSONL files
func ParseSessionJSONL ¶ added in v0.8.27
func ParseSessionJSONL(path string) (*SessionAnalytics, error)
ParseSessionJSONL parses a Claude session JSONL file and returns analytics
func (*SessionAnalytics) CalculateCost ¶ added in v0.8.27
func (a *SessionAnalytics) CalculateCost(model string) float64
CalculateCost estimates session cost based on token usage and model pricing
func (*SessionAnalytics) ContextPercent ¶ added in v0.8.27
func (a *SessionAnalytics) ContextPercent(modelLimit int) float64
ContextPercent returns the percentage of context window used Uses CurrentContextTokens (last turn's input + cache) for accurate context usage modelLimit is the model's context window size (defaults to 200000 for Claude)
func (*SessionAnalytics) TotalTokens ¶ added in v0.8.27
func (a *SessionAnalytics) TotalTokens() int
TotalTokens returns the sum of all token types
type ShellSettings ¶ added in v0.8.77
type ShellSettings struct {
// EnvFiles is a list of .env files to source for ALL sessions
// Paths can be absolute, ~ for home, $HOME/${VAR} for env vars, or relative to session working directory
// Files are sourced in order; later files override earlier ones
EnvFiles []string `toml:"env_files"`
// InitScript is an optional shell script or command to run before each session
// Useful for direnv, nvm, pyenv, etc.
// Can be a file path (e.g., "~/.agent-deck/init.sh") or inline command
// (e.g., 'eval "$(direnv hook bash)"')
InitScript string `toml:"init_script"`
// IgnoreMissingEnvFiles silently ignores missing .env files (default: true)
// When false, sessions will error if an env_file doesn't exist
IgnoreMissingEnvFiles *bool `toml:"ignore_missing_env_files"`
}
ShellSettings defines shell environment configuration for sessions
func (*ShellSettings) GetIgnoreMissingEnvFiles ¶ added in v0.8.77
func (s *ShellSettings) GetIgnoreMissingEnvFiles() bool
GetIgnoreMissingEnvFiles returns whether to ignore missing env files, defaulting to true
type SkillCandidate ¶ added in v0.19.1
type SkillCandidate struct {
ID string `json:"id"` // source/name
Name string `json:"name"`
Source string `json:"source"`
SourcePath string `json:"source_path"`
EntryName string `json:"entry_name"` // directory/file name in source
Description string `json:"description,omitempty"`
Kind string `json:"kind"` // "dir" or "file"
}
SkillCandidate is a discovered skill from one source.
func ListAvailableSkills ¶ added in v0.19.1
func ListAvailableSkills() ([]SkillCandidate, error)
ListAvailableSkills returns all discovered skills across enabled sources.
func ResolveSkillCandidate ¶ added in v0.19.1
func ResolveSkillCandidate(skillRef, sourceName string) (*SkillCandidate, error)
ResolveSkillCandidate resolves one skill from discovery by name or source/name.
type SkillSource ¶ added in v0.19.1
type SkillSource struct {
Name string `json:"name"`
Path string `json:"path"`
Description string `json:"description,omitempty"`
Enabled bool `json:"enabled"`
}
SkillSource is a resolved source used for display and discovery.
func ListSkillSources ¶ added in v0.19.1
func ListSkillSources() ([]SkillSource, error)
ListSkillSources returns sorted source definitions for display.
type SkillSourceDef ¶ added in v0.19.1
type SkillSourceDef struct {
Path string `toml:"path"`
Description string `toml:"description,omitempty"`
Enabled *bool `toml:"enabled,omitempty"`
}
SkillSourceDef defines a named source path for discovering skills.
func (SkillSourceDef) IsEnabled ¶ added in v0.19.1
func (s SkillSourceDef) IsEnabled() bool
IsEnabled returns true when the source should be considered during discovery.
type SkillSourcesConfig ¶ added in v0.19.1
type SkillSourcesConfig struct {
Sources map[string]SkillSourceDef `toml:"sources"`
}
SkillSourcesConfig is persisted in ~/.agent-deck/skills/sources.toml.
type SlackSettings ¶ added in v0.16.0
type SlackSettings struct {
// BotToken is the Slack bot token (xoxb-...)
BotToken string `toml:"bot_token"`
// AppToken is the Slack app-level token for Socket Mode (xapp-...)
AppToken string `toml:"app_token"`
// ChannelID is the Slack channel where the bot listens and posts (C01234...)
ChannelID string `toml:"channel_id"`
// ListenMode controls when the bot responds: "mentions" (only @mentions) or "all" (all channel messages)
// Default: "mentions"
ListenMode string `toml:"listen_mode"`
// AllowedUserIDs is a list of Slack user IDs authorized to use the bot.
// If empty, all users are allowed (backward compatible).
// Get user ID from Slack: Right-click user → View profile → More → Copy member ID
AllowedUserIDs []string `toml:"allowed_user_ids"`
}
SlackSettings defines Slack bot configuration for the conductor bridge
type StatusEvent ¶ added in v0.18.0
type StatusEvent struct {
InstanceID string `json:"instance_id"`
Title string `json:"title"`
Tool string `json:"tool"`
Status string `json:"status"`
PrevStatus string `json:"prev_status"`
Timestamp int64 `json:"ts"`
}
StatusEvent represents a session status change event. Written atomically to ~/.agent-deck/events/ by both the hook handler (Claude) and the TUI's background status poller (all tools).
type StatusEventWatcher ¶ added in v0.18.0
type StatusEventWatcher struct {
// contains filtered or unexported fields
}
StatusEventWatcher watches ~/.agent-deck/events/ for new status events using fsnotify. Delivers parsed StatusEvent structs via a channel.
func NewStatusEventWatcher ¶ added in v0.18.0
func NewStatusEventWatcher(filterInstanceID string) (*StatusEventWatcher, error)
NewStatusEventWatcher creates a watcher for the events directory. If filterInstanceID is non-empty, only events for that instance are delivered. Call Start() in a goroutine, then read from EventCh().
func (*StatusEventWatcher) EventCh ¶ added in v0.18.0
func (w *StatusEventWatcher) EventCh() <-chan StatusEvent
EventCh returns the channel that delivers parsed status events.
func (*StatusEventWatcher) Start ¶ added in v0.18.0
func (w *StatusEventWatcher) Start()
Start begins watching the events directory. Must be called in a goroutine. Blocks until Stop() is called or the context is cancelled.
func (*StatusEventWatcher) Stop ¶ added in v0.18.0
func (w *StatusEventWatcher) Stop()
Stop shuts down the watcher and closes the event channel.
func (*StatusEventWatcher) WaitForStatus ¶ added in v0.18.0
func (w *StatusEventWatcher) WaitForStatus(statuses []string, timeout time.Duration) (StatusEvent, error)
WaitForStatus blocks until an event with one of the given statuses is received, or the timeout expires.
type StatusFileWatcher ¶ added in v0.16.0
type StatusFileWatcher struct {
// contains filtered or unexported fields
}
StatusFileWatcher watches ~/.agent-deck/hooks/ for status file changes and updates instance hook status in real time.
func NewStatusFileWatcher ¶ added in v0.16.0
func NewStatusFileWatcher(onChange func()) (*StatusFileWatcher, error)
NewStatusFileWatcher creates a new watcher for the hooks directory. Call Start() to begin watching.
func (*StatusFileWatcher) GetHookStatus ¶ added in v0.16.0
func (w *StatusFileWatcher) GetHookStatus(instanceID string) *HookStatus
GetHookStatus returns the hook status for an instance, or nil if not available.
func (*StatusFileWatcher) Start ¶ added in v0.16.0
func (w *StatusFileWatcher) Start()
Start begins watching the hooks directory. Must be called in a goroutine.
func (*StatusFileWatcher) Stop ¶ added in v0.16.0
func (w *StatusFileWatcher) Stop()
Stop shuts down the watcher.
type StatusSettings ¶ added in v0.11.0
type StatusSettings struct {
}
func GetStatusSettings ¶ added in v0.11.0
func GetStatusSettings() StatusSettings
GetStatusSettings returns status detection settings with defaults applied.
type Storage ¶
type Storage struct {
// contains filtered or unexported fields
}
Storage handles persistence of session data via SQLite. Thread-safe with mutex protection for concurrent access within a single process. Multiple processes share data via SQLite WAL mode.
func NewStorageWithProfile ¶ added in v0.3.0
NewStorageWithProfile creates a storage instance for a specific profile. If profile is empty, uses the effective profile (from env var or config). Automatically runs migration from old layout if needed, then opens SQLite. If sessions.json exists and state.db is empty, auto-migrates data.
func (*Storage) DeleteInstance ¶ added in v0.11.3
DeleteInstance removes a single instance from the database by ID. This ensures the row is immediately removed, preventing resurrection on reload.
func (*Storage) GetDB ¶ added in v0.11.0
GetDB returns the underlying StateDB for direct access (status writes, heartbeat, etc.)
func (*Storage) GetFileMtime ¶ added in v0.10.15
GetFileMtime returns the filesystem modification time of the database file. This is useful for detecting external changes when polling.
func (*Storage) GetUpdatedAt ¶ added in v0.6.1
GetUpdatedAt returns the last modification timestamp from SQLite metadata.
func (*Storage) LoadLite ¶ added in v0.8.95
func (s *Storage) LoadLite() ([]*InstanceData, []*GroupData, error)
LoadLite reads session data from SQLite without tmux reconnection. This is a fast path for operations that only need to read session metadata (e.g., finding current session by tmux name) without initializing full Instance objects. Returns raw InstanceData and GroupData without any subprocess calls.
func (*Storage) LoadWithGroups ¶
LoadWithGroups reads instances and groups from SQLite, reconnects tmux sessions.
func (*Storage) Save ¶
Save persists instances to SQLite DEPRECATED: Use SaveWithGroups to ensure groups are not lost
func (*Storage) SaveGroupsOnly ¶ added in v0.11.3
SaveGroupsOnly persists only the groups table to SQLite. This is a lightweight save for visual state like group expanded/collapsed. It does NOT call Touch() to avoid triggering StorageWatcher reloads on other instances.
type StorageData ¶
type StorageData struct {
Instances []*InstanceData `json:"instances"`
Groups []*GroupData `json:"groups,omitempty"` // Persist empty groups
UpdatedAt time.Time `json:"updated_at"`
}
StorageData represents the JSON structure for persistence (kept for migration/compat)
type SubagentInfo ¶ added in v0.8.27
type SubagentInfo struct {
ID string `json:"id"`
StartTime time.Time `json:"start_time"`
Turns int `json:"turns"`
}
SubagentInfo holds metadata about a subagent spawned during a session
type TelegramSettings ¶ added in v0.12.0
type TelegramSettings struct {
// Token is the Telegram bot token from @BotFather
Token string `toml:"token"`
// UserID is the authorized Telegram user ID from @userinfobot
UserID int64 `toml:"user_id"`
}
TelegramSettings defines Telegram bot configuration for the conductor bridge
type TmuxSettings ¶ added in v0.12.1
type TmuxSettings struct {
// InjectStatusLine controls whether agent-deck injects a custom status line
// into new tmux sessions. When false, the tmux status bar is not modified,
// allowing users to use their own tmux status line configuration.
// Default: true (nil = use default true)
InjectStatusLine *bool `toml:"inject_status_line"`
// Options is a map of tmux option names to values.
// These are passed to `tmux set-option -t <session>` after defaults.
Options map[string]string `toml:"options"`
}
TmuxSettings allows users to override tmux options applied to every session. Options are applied AFTER agent-deck's defaults, so they take precedence.
Example config.toml:
[tmux]
inject_status_line = false
options = { "allow-passthrough" = "all", "history-limit" = "50000" }
func GetTmuxSettings ¶ added in v0.12.1
func GetTmuxSettings() TmuxSettings
GetTmuxSettings returns tmux option overrides from config
func (TmuxSettings) GetInjectStatusLine ¶ added in v0.15.0
func (t TmuxSettings) GetInjectStatusLine() bool
GetInjectStatusLine returns whether to inject status line, defaulting to true
type ToolDef ¶ added in v0.3.0
type ToolDef struct {
// Command is the shell command to run
Command string `toml:"command"`
// Wrapper is an optional command that wraps the tool command.
// Use {command} placeholder to include the tool command, or omit it to replace the command.
// Example: wrapper = "nvim +'terminal {command}' +'startinsert'"
Wrapper string `toml:"wrapper"`
// Icon is the emoji/symbol to display
Icon string `toml:"icon"`
// BusyPatterns are strings that indicate the tool is busy
BusyPatterns []string `toml:"busy_patterns"`
// PromptPatterns are strings that indicate the tool is waiting for input
PromptPatterns []string `toml:"prompt_patterns"`
// DetectPatterns are regex patterns to auto-detect this tool from terminal content
DetectPatterns []string `toml:"detect_patterns"`
// ResumeFlag is the CLI flag to resume a session (e.g., "--resume")
ResumeFlag string `toml:"resume_flag"`
// SessionIDEnv is the tmux environment variable name storing the session ID
SessionIDEnv string `toml:"session_id_env"`
// DangerousMode enables dangerous mode flag for this tool
DangerousMode bool `toml:"dangerous_mode"`
// DangerousFlag is the CLI flag for dangerous mode (e.g., "--dangerously-skip-permissions")
DangerousFlag string `toml:"dangerous_flag"`
// OutputFormatFlag is the CLI flag for JSON output format (e.g., "--output-format json")
OutputFormatFlag string `toml:"output_format_flag"`
// SessionIDJsonPath is the jq path to extract session ID from JSON output
SessionIDJsonPath string `toml:"session_id_json_path"`
// EnvFile is a .env file specific to this tool
// Sourced AFTER global [shell].env_files
// Path can be absolute, ~ for home, $HOME/${VAR} for env vars, or relative to session working directory
EnvFile string `toml:"env_file"`
// Env is inline environment variables for this tool
// These are exported AFTER env_file (highest priority)
// Example: env = { ANTHROPIC_BASE_URL = "https://...", API_KEY = "token" }
Env map[string]string `toml:"env"`
// BusyPatternsExtra appends additional busy patterns to the built-in defaults
BusyPatternsExtra []string `toml:"busy_patterns_extra"`
// PromptPatternsExtra appends additional prompt patterns to the built-in defaults
PromptPatternsExtra []string `toml:"prompt_patterns_extra"`
// SpinnerChars replaces the default spinner characters entirely (use with caution)
SpinnerChars []string `toml:"spinner_chars"`
// SpinnerCharsExtra appends additional spinner characters to the built-in defaults
SpinnerCharsExtra []string `toml:"spinner_chars_extra"`
}
ToolDef defines a custom AI tool
func GetToolDef ¶ added in v0.3.0
GetToolDef returns a tool definition from user config Returns nil if tool is not defined
type ToolOptions ¶ added in v0.8.39
type ToolOptions interface {
// ToolName returns the name of the tool (e.g., "claude", "codex")
ToolName() string
// ToArgs returns command-line arguments for the tool
ToArgs() []string
}
ToolOptions is the interface for tool-specific launch options Each AI tool (claude, codex, gemini, etc.) can have its own options struct that implements this interface
type ToolOptionsWrapper ¶ added in v0.8.39
type ToolOptionsWrapper struct {
Tool string `json:"tool"`
Options json.RawMessage `json:"options"`
}
ToolOptionsWrapper wraps tool options for JSON serialization JSON structure: {"tool": "claude", "options": {...}}
type UpdateSettings ¶ added in v0.8.2
type UpdateSettings struct {
// AutoUpdate automatically installs updates without prompting
// Default: false
AutoUpdate bool `toml:"auto_update"`
// CheckEnabled enables automatic update checks on startup
// Default: true
CheckEnabled bool `toml:"check_enabled"`
// CheckIntervalHours is how often to check for updates (in hours)
// Default: 24
CheckIntervalHours int `toml:"check_interval_hours"`
// NotifyInCLI shows update notification in CLI commands (not just TUI)
// Default: true
NotifyInCLI bool `toml:"notify_in_cli"`
}
UpdateSettings defines auto-update configuration
func GetUpdateSettings ¶ added in v0.8.2
func GetUpdateSettings() UpdateSettings
GetUpdateSettings returns update settings with defaults applied
type UserConfig ¶ added in v0.3.0
type UserConfig struct {
// DefaultTool is the pre-selected AI tool when creating new sessions
// Valid values: "claude", "gemini", "opencode", "codex", or any custom tool name
// If empty or invalid, defaults to "shell" (no pre-selection)
DefaultTool string `toml:"default_tool"`
// Theme sets the color scheme: "dark" (default), "light", or "system"
Theme string `toml:"theme"`
// Tools defines custom AI tool configurations
Tools map[string]ToolDef `toml:"tools"`
// MCPDefaultScope sets the default scope for MCP operations
// Valid values: "local" (default), "global", "user"
MCPDefaultScope string `toml:"mcp_default_scope"`
// ManageMCPJson controls whether agent-deck writes to .mcp.json in project directories.
// Set to false to prevent agent-deck from touching any .mcp.json files, which is useful
// when you manage that file manually or via another tool.
// Default: true (nil = true)
ManageMCPJson *bool `toml:"manage_mcp_json"`
// MCPs defines available MCP servers for the MCP Manager
// These can be attached/detached per-project via the MCP Manager (M key)
MCPs map[string]MCPDef `toml:"mcps"`
// Claude defines Claude Code integration settings
Claude ClaudeSettings `toml:"claude"`
// Profiles defines optional per-profile overrides.
// Example:
// [profiles.work.claude]
// config_dir = "~/.claude-work"
Profiles map[string]ProfileSettings `toml:"profiles"`
// Gemini defines Gemini CLI integration settings
Gemini GeminiSettings `toml:"gemini"`
// OpenCode defines OpenCode CLI integration settings
OpenCode OpenCodeSettings `toml:"opencode"`
// Codex defines Codex CLI integration settings
Codex CodexSettings `toml:"codex"`
// Worktree defines git worktree preferences
Worktree WorktreeSettings `toml:"worktree"`
// GlobalSearch defines global conversation search settings
GlobalSearch GlobalSearchSettings `toml:"global_search"`
// Logs defines session log management settings
Logs LogSettings `toml:"logs"`
// MCPPool defines HTTP MCP pool settings for shared MCP servers
MCPPool MCPPoolSettings `toml:"mcp_pool"`
// Updates defines auto-update settings
Updates UpdateSettings `toml:"updates"`
// Preview defines preview pane display settings
Preview PreviewSettings `toml:"preview"`
// Experiments defines experiment folder settings for 'try' command
Experiments ExperimentsSettings `toml:"experiments"`
// Notifications defines waiting session notification bar settings
Notifications NotificationsConfig `toml:"notifications"`
// Instances defines multiple instance behavior settings
Instances InstanceSettings `toml:"instances"`
// Shell defines global shell environment settings for sessions
Shell ShellSettings `toml:"shell"`
// Maintenance defines automatic maintenance worker settings
Maintenance MaintenanceSettings `toml:"maintenance"`
// Status defines session status detection settings
Status StatusSettings `toml:"status"`
// Conductor defines conductor (meta-agent orchestration) settings
Conductor ConductorSettings `toml:"conductor"`
// Tmux defines tmux option overrides applied to every session
Tmux TmuxSettings `toml:"tmux"`
}
UserConfig represents user-facing configuration in TOML format
func LoadUserConfig ¶ added in v0.3.0
func LoadUserConfig() (*UserConfig, error)
LoadUserConfig loads the user configuration from TOML file Returns cached config after first load
func ReloadUserConfig ¶ added in v0.3.0
func ReloadUserConfig() (*UserConfig, error)
ReloadUserConfig forces a reload of the user config
func (*UserConfig) GetProfileClaudeConfigDir ¶ added in v0.19.1
func (c *UserConfig) GetProfileClaudeConfigDir(profile string) string
GetProfileClaudeConfigDir returns the profile-specific Claude config directory, if configured.
func (*UserConfig) GetShowAnalytics ¶ added in v0.8.27
func (c *UserConfig) GetShowAnalytics() bool
GetShowAnalytics returns whether to show analytics panel, defaulting to false
func (*UserConfig) GetShowOutput ¶ added in v0.8.27
func (c *UserConfig) GetShowOutput() bool
GetShowOutput returns whether to show terminal output in preview
type WorktreeSettings ¶ added in v0.8.22
type WorktreeSettings struct {
// AutoCleanup: remove worktree when session is deleted
AutoCleanup bool `toml:"auto_cleanup"`
// DefaultLocation: "sibling" (next to repo), "subdirectory" (inside .worktrees/),
// or a custom path (e.g., "~/worktrees") creating <path>/<repo_name>/<branch>
DefaultLocation string `toml:"default_location"`
// PathTemplate: custom path template for worktree location.
// Variables: {repo-name}, {repo-root}, {branch}, {session-id}
// Unknown variables like {foo} are left as-is in the path.
// If set, overrides DefaultLocation.
PathTemplate *string `toml:"path_template"`
}
WorktreeSettings contains git worktree preferences.
func GetWorktreeSettings ¶ added in v0.8.22
func GetWorktreeSettings() WorktreeSettings
GetWorktreeSettings returns worktree settings with defaults applied
func (*WorktreeSettings) Template ¶ added in v0.10.10
func (w *WorktreeSettings) Template() string
Template returns the path template if set, or empty string if nil.
Source Files
¶
- analytics.go
- claude.go
- claude_hooks.go
- conductor.go
- conductor_templates.go
- config.go
- discovery.go
- env.go
- event_watcher.go
- event_writer.go
- gemini.go
- gemini_analytics.go
- gemini_mcp.go
- global_search.go
- groups.go
- hook_watcher.go
- instance.go
- maintenance.go
- mcp_catalog.go
- migration.go
- namegen.go
- notifications.go
- pool_manager.go
- skills_catalog.go
- storage.go
- tooloptions.go
- userconfig.go
- utils.go