// Code generated by sqlc. DO NOT EDIT. // versions: // sqlc v1.30.0 package sqlc import ( "github.com/jackc/pgx/v5/pgtype" ) type Bot struct { ID pgtype.UUID `json:"id"` OwnerUserID pgtype.UUID `json:"owner_user_id"` DisplayName pgtype.Text `json:"display_name"` AvatarUrl pgtype.Text `json:"avatar_url"` Timezone pgtype.Text `json:"timezone"` IsActive bool `json:"is_active"` Status string `json:"status"` Language string `json:"language"` ReasoningEnabled bool `json:"reasoning_enabled"` ReasoningEffort string `json:"reasoning_effort"` ChatModelID pgtype.UUID `json:"chat_model_id"` SearchProviderID pgtype.UUID `json:"search_provider_id"` MemoryProviderID pgtype.UUID `json:"memory_provider_id"` HeartbeatEnabled bool `json:"heartbeat_enabled"` HeartbeatInterval int32 `json:"heartbeat_interval"` HeartbeatPrompt string `json:"heartbeat_prompt"` HeartbeatModelID pgtype.UUID `json:"heartbeat_model_id"` CompactionEnabled bool `json:"compaction_enabled"` CompactionThreshold int32 `json:"compaction_threshold"` CompactionRatio int32 `json:"compaction_ratio"` CompactionModelID pgtype.UUID `json:"compaction_model_id"` TitleModelID pgtype.UUID `json:"title_model_id"` ImageModelID pgtype.UUID `json:"image_model_id"` DiscussProbeModelID pgtype.UUID `json:"discuss_probe_model_id"` TtsModelID pgtype.UUID `json:"tts_model_id"` BrowserContextID pgtype.UUID `json:"browser_context_id"` ContextTokenBudget pgtype.Int4 `json:"context_token_budget"` PersistFullToolResults bool `json:"persist_full_tool_results"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` AclDefaultEffect string `json:"acl_default_effect"` } type BotAclRule struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` Action string `json:"action"` Effect string `json:"effect"` SubjectKind string `json:"subject_kind"` ChannelIdentityID pgtype.UUID `json:"channel_identity_id"` SourceChannel pgtype.Text `json:"source_channel"` SourceConversationType pgtype.Text `json:"source_conversation_type"` SourceConversationID pgtype.Text `json:"source_conversation_id"` SourceThreadID pgtype.Text `json:"source_thread_id"` CreatedByUserID pgtype.UUID `json:"created_by_user_id"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` Priority int32 `json:"priority"` Enabled bool `json:"enabled"` Description pgtype.Text `json:"description"` SubjectChannelType pgtype.Text `json:"subject_channel_type"` } type BotChannelConfig struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` ChannelType string `json:"channel_type"` Credentials []byte `json:"credentials"` ExternalIdentity pgtype.Text `json:"external_identity"` SelfIdentity []byte `json:"self_identity"` Routing []byte `json:"routing"` Capabilities []byte `json:"capabilities"` Disabled bool `json:"disabled"` VerifiedAt pgtype.Timestamptz `json:"verified_at"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type BotChannelRoute struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` ChannelType string `json:"channel_type"` ChannelConfigID pgtype.UUID `json:"channel_config_id"` ExternalConversationID string `json:"external_conversation_id"` ExternalThreadID pgtype.Text `json:"external_thread_id"` ConversationType pgtype.Text `json:"conversation_type"` DefaultReplyTarget pgtype.Text `json:"default_reply_target"` ActiveSessionID pgtype.UUID `json:"active_session_id"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type BotEmailBinding struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` EmailProviderID pgtype.UUID `json:"email_provider_id"` EmailAddress string `json:"email_address"` CanRead bool `json:"can_read"` CanWrite bool `json:"can_write"` CanDelete bool `json:"can_delete"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type BotHeartbeatLog struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` SessionID pgtype.UUID `json:"session_id"` Status string `json:"status"` ResultText string `json:"result_text"` ErrorMessage string `json:"error_message"` Usage []byte `json:"usage"` ModelID pgtype.UUID `json:"model_id"` StartedAt pgtype.Timestamptz `json:"started_at"` CompletedAt pgtype.Timestamptz `json:"completed_at"` } type BotHistoryMessage struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` SessionID pgtype.UUID `json:"session_id"` SenderChannelIdentityID pgtype.UUID `json:"sender_channel_identity_id"` SenderAccountUserID pgtype.UUID `json:"sender_account_user_id"` SourceMessageID pgtype.Text `json:"source_message_id"` SourceReplyToMessageID pgtype.Text `json:"source_reply_to_message_id"` Role string `json:"role"` Content []byte `json:"content"` Metadata []byte `json:"metadata"` Usage []byte `json:"usage"` ModelID pgtype.UUID `json:"model_id"` CompactID pgtype.UUID `json:"compact_id"` EventID pgtype.UUID `json:"event_id"` DisplayText pgtype.Text `json:"display_text"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type BotHistoryMessageAsset struct { ID pgtype.UUID `json:"id"` MessageID pgtype.UUID `json:"message_id"` Role string `json:"role"` Ordinal int32 `json:"ordinal"` ContentHash string `json:"content_hash"` Name string `json:"name"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type BotHistoryMessageCompact struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` SessionID pgtype.UUID `json:"session_id"` Status string `json:"status"` Summary string `json:"summary"` MessageCount int32 `json:"message_count"` ErrorMessage string `json:"error_message"` Usage []byte `json:"usage"` ModelID pgtype.UUID `json:"model_id"` StartedAt pgtype.Timestamptz `json:"started_at"` CompletedAt pgtype.Timestamptz `json:"completed_at"` } type BotSession struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` RouteID pgtype.UUID `json:"route_id"` ChannelType pgtype.Text `json:"channel_type"` Type string `json:"type"` Title string `json:"title"` Metadata []byte `json:"metadata"` ParentSessionID pgtype.UUID `json:"parent_session_id"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` DeletedAt pgtype.Timestamptz `json:"deleted_at"` } type BotSessionEvent struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` SessionID pgtype.UUID `json:"session_id"` EventKind string `json:"event_kind"` EventData []byte `json:"event_data"` ExternalMessageID pgtype.Text `json:"external_message_id"` SenderChannelIdentityID pgtype.UUID `json:"sender_channel_identity_id"` ReceivedAtMs int64 `json:"received_at_ms"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type BotStorageBinding struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` StorageProviderID pgtype.UUID `json:"storage_provider_id"` BasePath string `json:"base_path"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type BrowserContext struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type ChannelIdentity struct { ID pgtype.UUID `json:"id"` UserID pgtype.UUID `json:"user_id"` ChannelType string `json:"channel_type"` ChannelSubjectID string `json:"channel_subject_id"` DisplayName pgtype.Text `json:"display_name"` AvatarUrl pgtype.Text `json:"avatar_url"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type ChannelIdentityBindCode struct { ID pgtype.UUID `json:"id"` Token string `json:"token"` IssuedByUserID pgtype.UUID `json:"issued_by_user_id"` ChannelType pgtype.Text `json:"channel_type"` ExpiresAt pgtype.Timestamptz `json:"expires_at"` UsedAt pgtype.Timestamptz `json:"used_at"` UsedByChannelIdentityID pgtype.UUID `json:"used_by_channel_identity_id"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type Container struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` ContainerID string `json:"container_id"` ContainerName string `json:"container_name"` Image string `json:"image"` Status string `json:"status"` Namespace string `json:"namespace"` AutoStart bool `json:"auto_start"` ContainerPath string `json:"container_path"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` LastStartedAt pgtype.Timestamptz `json:"last_started_at"` LastStoppedAt pgtype.Timestamptz `json:"last_stopped_at"` } type ContainerVersion struct { ID pgtype.UUID `json:"id"` ContainerID string `json:"container_id"` SnapshotID pgtype.UUID `json:"snapshot_id"` Version int32 `json:"version"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type EmailOauthToken struct { ID pgtype.UUID `json:"id"` EmailProviderID pgtype.UUID `json:"email_provider_id"` EmailAddress string `json:"email_address"` AccessToken string `json:"access_token"` RefreshToken string `json:"refresh_token"` ExpiresAt pgtype.Timestamptz `json:"expires_at"` Scope string `json:"scope"` State string `json:"state"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type EmailOutbox struct { ID pgtype.UUID `json:"id"` ProviderID pgtype.UUID `json:"provider_id"` BotID pgtype.UUID `json:"bot_id"` MessageID string `json:"message_id"` FromAddress string `json:"from_address"` ToAddresses []byte `json:"to_addresses"` Subject string `json:"subject"` BodyText string `json:"body_text"` BodyHtml string `json:"body_html"` Attachments []byte `json:"attachments"` Status string `json:"status"` Error string `json:"error"` SentAt pgtype.Timestamptz `json:"sent_at"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type EmailProvider struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` Provider string `json:"provider"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type LifecycleEvent struct { ID string `json:"id"` ContainerID string `json:"container_id"` EventType string `json:"event_type"` Payload []byte `json:"payload"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type McpConnection struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` Name string `json:"name"` Type string `json:"type"` Config []byte `json:"config"` IsActive bool `json:"is_active"` Status string `json:"status"` ToolsCache []byte `json:"tools_cache"` LastProbedAt pgtype.Timestamptz `json:"last_probed_at"` StatusMessage string `json:"status_message"` AuthType string `json:"auth_type"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type McpOauthToken struct { ID pgtype.UUID `json:"id"` ConnectionID pgtype.UUID `json:"connection_id"` ResourceMetadataUrl string `json:"resource_metadata_url"` AuthorizationServerUrl string `json:"authorization_server_url"` AuthorizationEndpoint string `json:"authorization_endpoint"` TokenEndpoint string `json:"token_endpoint"` RegistrationEndpoint string `json:"registration_endpoint"` ScopesSupported []string `json:"scopes_supported"` ClientID string `json:"client_id"` ClientSecret string `json:"client_secret"` AccessToken string `json:"access_token"` RefreshToken string `json:"refresh_token"` TokenType string `json:"token_type"` ExpiresAt pgtype.Timestamptz `json:"expires_at"` Scope string `json:"scope"` PkceCodeVerifier string `json:"pkce_code_verifier"` StateParam string `json:"state_param"` ResourceUri string `json:"resource_uri"` RedirectUri string `json:"redirect_uri"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type MediaAsset struct { ID pgtype.UUID `json:"id"` BotID pgtype.UUID `json:"bot_id"` StorageProviderID pgtype.UUID `json:"storage_provider_id"` ContentHash string `json:"content_hash"` MediaType string `json:"media_type"` Mime string `json:"mime"` SizeBytes int64 `json:"size_bytes"` StorageKey string `json:"storage_key"` OriginalName pgtype.Text `json:"original_name"` Width pgtype.Int4 `json:"width"` Height pgtype.Int4 `json:"height"` DurationMs pgtype.Int8 `json:"duration_ms"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type MemoryProvider struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` Provider string `json:"provider"` Config []byte `json:"config"` IsDefault bool `json:"is_default"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type Model struct { ID pgtype.UUID `json:"id"` ModelID string `json:"model_id"` Name pgtype.Text `json:"name"` ProviderID pgtype.UUID `json:"provider_id"` Type string `json:"type"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type ModelVariant struct { ID pgtype.UUID `json:"id"` ModelUuid pgtype.UUID `json:"model_uuid"` VariantID string `json:"variant_id"` Weight int32 `json:"weight"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type Provider struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` ClientType string `json:"client_type"` Icon pgtype.Text `json:"icon"` Enable bool `json:"enable"` Config []byte `json:"config"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type ProviderOauthToken struct { ID pgtype.UUID `json:"id"` ProviderID pgtype.UUID `json:"provider_id"` AccessToken string `json:"access_token"` RefreshToken string `json:"refresh_token"` ExpiresAt pgtype.Timestamptz `json:"expires_at"` Scope string `json:"scope"` TokenType string `json:"token_type"` State string `json:"state"` PkceCodeVerifier string `json:"pkce_code_verifier"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type Schedule struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` Description string `json:"description"` Pattern string `json:"pattern"` MaxCalls pgtype.Int4 `json:"max_calls"` CurrentCalls int32 `json:"current_calls"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` Enabled bool `json:"enabled"` Command string `json:"command"` BotID pgtype.UUID `json:"bot_id"` } type ScheduleLog struct { ID pgtype.UUID `json:"id"` ScheduleID pgtype.UUID `json:"schedule_id"` BotID pgtype.UUID `json:"bot_id"` SessionID pgtype.UUID `json:"session_id"` Status string `json:"status"` ResultText string `json:"result_text"` ErrorMessage string `json:"error_message"` Usage []byte `json:"usage"` ModelID pgtype.UUID `json:"model_id"` StartedAt pgtype.Timestamptz `json:"started_at"` CompletedAt pgtype.Timestamptz `json:"completed_at"` } type SearchProvider struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` Provider string `json:"provider"` Config []byte `json:"config"` Enable bool `json:"enable"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type Snapshot struct { ID pgtype.UUID `json:"id"` ContainerID string `json:"container_id"` RuntimeSnapshotName string `json:"runtime_snapshot_name"` DisplayName pgtype.Text `json:"display_name"` ParentRuntimeSnapshotName pgtype.Text `json:"parent_runtime_snapshot_name"` Snapshotter string `json:"snapshotter"` Source string `json:"source"` CreatedAt pgtype.Timestamptz `json:"created_at"` } type StorageProvider struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` Provider string `json:"provider"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type Task struct { ID string `json:"id"` BotID string `json:"bot_id"` Name string `json:"name"` Command string `json:"command"` Status string `json:"status"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` ExecID pgtype.Text `json:"exec_id"` Pid pgtype.Int4 `json:"pid"` } type TtsModel struct { ID pgtype.UUID `json:"id"` ModelID string `json:"model_id"` Name pgtype.Text `json:"name"` TtsProviderID pgtype.UUID `json:"tts_provider_id"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type TtsProvider struct { ID pgtype.UUID `json:"id"` Name string `json:"name"` Provider string `json:"provider"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` Enable bool `json:"enable"` } type User struct { ID pgtype.UUID `json:"id"` Username pgtype.Text `json:"username"` Email pgtype.Text `json:"email"` PasswordHash pgtype.Text `json:"password_hash"` Role string `json:"role"` DisplayName pgtype.Text `json:"display_name"` AvatarUrl pgtype.Text `json:"avatar_url"` Timezone string `json:"timezone"` DataRoot pgtype.Text `json:"data_root"` LastLoginAt pgtype.Timestamptz `json:"last_login_at"` IsActive bool `json:"is_active"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type UserChannelBinding struct { ID pgtype.UUID `json:"id"` UserID pgtype.UUID `json:"user_id"` ChannelType string `json:"channel_type"` Config []byte `json:"config"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` } type UserProviderOauthToken struct { ID pgtype.UUID `json:"id"` ProviderID pgtype.UUID `json:"provider_id"` UserID pgtype.UUID `json:"user_id"` AccessToken string `json:"access_token"` RefreshToken string `json:"refresh_token"` ExpiresAt pgtype.Timestamptz `json:"expires_at"` Scope string `json:"scope"` TokenType string `json:"token_type"` State string `json:"state"` PkceCodeVerifier string `json:"pkce_code_verifier"` Metadata []byte `json:"metadata"` CreatedAt pgtype.Timestamptz `json:"created_at"` UpdatedAt pgtype.Timestamptz `json:"updated_at"` }