Logged events
In addition to standard logging in the GitLab Rails Monolith instance, specialized logging is available for features based on large language models (LLMs).
Events logged
Returning from Service due to validation
- Description: user not permitted to perform action
- Class:
Llm::BaseService
- Ai_event_name: permission_denied
- Level: info
- Arguments:
- none
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: yes
- Sidekiq: no
Enqueuing CompletionWorker
- Description: scheduling completion worker in sidekiq
- Class:
Llm::BaseService
- Ai_event_name: worker_enqueued
- Level: info
- Arguments:
user_id: message.user.id
resource_id: message.resource&.id
resource_class: message.resource&.class&.name
request_id: message.request_id
action_name: message.ai_action
options: job_options
- Part of the system: abstraction_layer
- Expanded logging?: yes
- Rails: yes
- Sidekiq: no
aborting: missing resource
- Description: If there is no resource for slash command
- Class:
Llm::ChatService
- Ai_event_name: missing_resource
- Level: info
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: yes
- Sidekiq: no
Performing CompletionService
- Description: performing completion
- Class:
Llm::Internal::CompletionService
- Ai_event_name: completion_service_performed
- Level: info
- Arguments:
user_id: prompt_message.user.to_gid
resource_id: prompt_message.resource&.to_gid
action_name: prompt_message.ai_action
request_id: prompt_message.request_id
client_subscription_id: prompt_message.client_subscription_id
completion_service_name: completion_class_name
- Part of the system: abstraction_layer
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Answer from LLM response
- Description: Get answer from response
- Class:
Gitlab::Llm::Chain::Answer
- Ai_event_name: answer_received
- Level: info
- Arguments:
llm_answer_content: content
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Final answer
- Description: Get final answer from response
- Class:
Gitlab::Llm::Chain::Answer
- Ai_event_name: final_answer_received
- Level: info
- Arguments:
llm_answer_content: content
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Default final answer
- Description: Default final answer: I'm sorry, I couldn't respond in time. Please try a more specific request or enter /clear to start a new chat.
- Class:
Gitlab::Llm::Chain::Answer
- Ai_event_name: default_final_answer_received
- Level: info
- Arguments:
error_code: "A6000"
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Error message/ "Error"
- Description: when answering with an error
- Class:
Gitlab::Llm::Chain::Answer
- Ai_event_name: error_returned
- Level: error
- Arguments:
error: content
error_code: error_code
source: source
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Received response from AI gateway
- Description: when response from AIGW is returned
- Class:
Gitlab::Llm::AiGateway::Client
- Ai_event_name: response_received
- Level: info
- Arguments:
response_from_llm: response_body
- Part of the system: abstraction_layer
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Received error from AI gateway
- Description: when error is returned from AIGW for streaming command
- Class:
Gitlab::Llm::AiGateway::Client
- Ai_event_name: error_response_received
- Level: error
- Arguments:
response_from_llm: parsed_response.dig('detail', 0, 'msg')
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Performing request to AI gateway
- Description: before performing request to the AI GW
- Class:
Gitlab::Llm::AiGateway::Client
- Ai_event_name: performing_request
- Level: info
- Arguments:
url: url
body: body
timeout: timeout
stream: stream
- Part of the system: abstraction_layer
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Creating user access token
- Description: creating short-lived token in AIGW
- Class:
Gitlab::Llm::AiGateway::CodeSuggestionsClient
- Ai_event_name: user_token_created
- Level: info
- Arguments:
- none
- Part of the system: code suggestions
- Expanded logging?: no
- Rails: yes
- Sidekiq: no
Received response from Anthropic
- Description: Received response
- Class:
Gitlab::Llm::Anthropic::Client
- Ai_event_name: response_received
- Level: info
- Arguments:
ai_request_type: request_type
unit_primitive: unit_primitive
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Response content
- Description: Content of response
- Class:
Gitlab::Llm::Anthropic::Client
- Ai_event_name: response_received
- Level: info
- Arguments:
ai_request_type: request_type
unit_primitive: unit_primitive
response_from_llm: response_body
- Part of the system: abstraction_layer
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Performing request to Anthropic
- Description: performing completion request
- Class:
Gitlab::Llm::Anthropic::Client
- Ai_event_name: performing_request
- Level: info
- Arguments:
options: options
ai_request_type: request_type
unit_primitive: unit_primitive
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Searching docs from AI gateway
- Description: performing search docs request
- Class:
Gitlab::Llm::AiGateway::DocsClient
- Ai_event_name: performing_request
- Level: info
- Arguments:
options: options
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Searched docs content from AI gateway
- Description: response from AIGW with docs
- Class:
Gitlab::Llm::AiGateway::DocsClient
- Ai_event_name: response_received
- Level: info
- Arguments:
response_from_llm: response
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Json parsing error during Question Categorization
- Description: logged when json is not parsable
- Class:
Gitlab::Llm::AiGateway::Completions::CategorizeQuestions
- Ai_event_name: error
- Level: error
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Response did not contain defined categories
- Description: logged when response is not containing one of the defined categories
- Class:
Gitlab::Llm::AiGateway::Completions::CategorizeQuestions
- Ai_event_name: error
- Level: error
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Error response received while categorizing question
- Description: logged when response returned is not succesful
- Class:
Gitlab::Llm::AiGateway::Completions::CategorizeQuestions
- Ai_event_name: error
- Level: error
- Arguments:
error_type: response.dig('error', 'type')
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Picked tool
- Description: information about tool picked by chat
- Class:
Gitlab::Llm::Chain::Agents::ZeroShot::Executor
- Ai_event_name: picked_tool
- Level: info
- Arguments:
duo_chat_tool: tool_class.to_s
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Made request to AI Client
- Description: making request for chat
- Class:
Gitlab::Llm::Chain::Requests::AiGateway
- Ai_event_name: response_received
- Level: info
- Arguments:
prompt: prompt[:prompt]
response_from_llm: response
unit_primitive: unit_primitive
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Streaming error
- Description: Error returned when streaming
- Class:
Gitlab::Llm::Chain::Requests::Anthropic
- Ai_event_name: error_response_received
- Level: error
- Arguments:
error: data&.dig("error")
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Got Final Result for documentation question content
- Description: got result for documentation question - content
- Class:
Gitlab::Llm::Chain::Tools::EmbeddingsCompletion
- Ai_event_name: response_received
- Level: info
- Arguments:
prompt: final_prompt[:prompt]
response_from_llm: final_prompt_result
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Streaming error
- Description: when error is returned from AIGW for streaming command in docs question
- Class:
Gitlab::Llm::Chain::Tools::EmbeddingsCompletion
- Ai_event_name: error_response_received
- Level: error
- Arguments:
error: error.message
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Answer already received from tool
- Description: when tool was already picked up (content: You already have the answer from #{self.class::NAME} tool, read carefully.)
- Class:
Gitlab::Llm::Chain::Tools::Tool
- Ai_event_name: incorrect_response_received
- Level: info
- Arguments:
error_message: content
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Tool cycling detected
- Description: When tool is picked up again
- Class:
Gitlab::Llm::Chain::Tools::Tool
- Ai_event_name: incorrect_response_received
- Level: info
- Arguments:
picked_tool: cls.class.to_s
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Calling TanukiBot
- Description: performing documentation request
- Class:
Gitlab::Llm::Chain::Tools::GitlabDocumentation::Executor
- Ai_event_name: documentation_question_initial_request
- Level: info
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Error finding #{resource_name}
- Description: when resource (issue/epic/mr) is not found
- Class:
Gitlab::Llm::Chain::Tools::Identifier
- Ai_event_name: incorrect_response_received
- Level: error
- Arguments:
error_message: authorizer.message
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Answer received from LLM
- Description: response from identifier
- Class:
Gitlab::Llm::Chain::Tools::Identifier
- Ai_event_name: response_received
- Level: info
- Arguments:
response_from_llm: content
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Json parsing error
- Description: when json is malformed (Observation: JSON has an invalid format. Please retry)
- Class:
Gitlab::Llm::Chain::Tools::Identifier
- Ai_event_name: error
- Level: error
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Resource already identified
- Description: already identified resource (You already have identified the #{resource_name} #{resource.to_global_id}, read carefully.)
- Class:
Gitlab::Llm::Chain::Tools::Identifier
- Ai_event_name: incorrect_response_received
- Level: info
- Arguments:
error_message: content
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Supported Issuable Typees Ability Allowed
- Description: logging the ability (policy.can?) for the issue/epic
- Class:
Gitlab::Llm::Chain::Tools::SummarizeComments::Executor
- Ai_event_name: permission
- Level: info
- Arguments:
allowed: ability
- Part of the system: feature
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Supported Issuable Typees Ability Allowed
- Description: logging the ability (policy.can?) for the issue/epic
- Class:
Gitlab::Llm::Chain::Tools::SummarizeComments::ExecutorOld
- Ai_event_name: permission
- Level: info
- Arguments:
allowed: ability
- Part of the system: feature
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Answer content for summarize_comments
- Description: Answer for summarize comments feature
- Class:
Gitlab::Llm::Chain::Tools::SummarizeComments::ExecutorOld
- Ai_event_name: response_received
- Level: info
- Arguments:
response_from_llm: content
- Part of the system: feature
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Content of the prompt from chat request
- Description: chat-related request
- Class:
Gitlab::Llm::Chain::Concerns::AiDependent
- Ai_event_name: prompt_content
- Level: info
- Arguments:
prompt: prompt_text
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
"Too many requests, will retry in #{delay} seconds"
- Description: When entered in exponential backoff loop
- Class:
Gitlab::Llm::Chain::Concerns::ExponentialBackoff
- Ai_event_name: retrying_request
- Level: info
- Arguments:
- none
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Resource not found
- Description: Resource not found/not authorized
- Class:
Gitlab::Llm::Utils::Authorizer
- Ai_event_name: permission_denied
- Level: info
- Arguments:
error_code: "M3003"
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
No access to Duo Chat
- Description: No access to duo chat
- Class:
Gitlab::Llm::Utils::Authorizer
- Ai_event_name: permission_denied
- Level: info
- Arguments:
error_code: "M3004"
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
AI is disabled
- Description: AI is not enabled for container
- Class:
Gitlab::Llm::Utils::Authorizer
- Ai_event_name: permission_denied
- Level: info
- Arguments:
error_code: "M3002"
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Performing request to Vertex
- Description: performing request
- Class:
Gitlab::Llm::VertexAi::Client
- Ai_event_name: performing_request
- Level: info
- Arguments:
unit_primitive: unit_primitive
options: config
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Response content
- Description: response from aigw - vertex -content
- Class:
Gitlab::Llm::VertexAi::Client
- Ai_event_name: response_received
- Level: info
- Arguments:
unit_primitive: unit_primitive
response_from_llm: response.to_json
- Part of the system: abstraction_layer
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Received response from Vertex
- Description: response from aigw - vertex
- Class:
Gitlab::Llm::VertexAi::Client
- Ai_event_name: response_received
- Level: info
- Arguments:
unit_primitive: unit_primitive
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Empty response from Vertex
- Description: empty response from aigw - vertex
- Class:
Gitlab::Llm::VertexAi::Client
- Ai_event_name: empty_response_received
- Level: error
- Arguments:
unit_primitive: unit_primitive
- Part of the system: abstraction_layer
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Surface an unknown event as a final answer to the user
- Description: unknown event
- Class:
Gitlab::Llm::Chain::Agents::SingleActionExecutor
- Ai_event_name: unknown_event
- Level: warn
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Failed to find a tool in GitLab Rails
- Description: failed to find a tool
- Class:
Gitlab::Llm::Chain::Agents::SingleActionExecutor
- Ai_event_name: tool_not_find
- Level: error
- Arguments:
tool_name: tool_name
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Received an event from v2/chat/agent
- Description: Received event
- Class:
Gitlab::Duo::Chat::StepExecutor
- Ai_event_name: event_received
- Level: info
- Arguments:
event: event
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Failed to update observation
- Description: Failed to update observation
- Class:
Gitlab::Duo::Chat::StepExecutor
- Ai_event_name: agent_steps_empty
- Level: error
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Request to v2/chat/agent
- Description: request
- Class:
Gitlab::Duo::Chat::StepExecutor
- Ai_event_name: performing_request
- Level: info
- Arguments:
params: params
- Part of the system: duo_chat
- Expanded logging?: yes
- Rails: no
- Sidekiq: yes
Finished streaming from v2/chat/agent
- Description: finished streaming
- Class:
Gitlab::Duo::Chat::StepExecutor
- Ai_event_name: streaming_finished
- Level: info
- Arguments:
- none
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Received error from Duo Chat Agent
- Description: Error returned when streaming
- Class:
Gitlab::Duo::Chat::StepExecutor
- Ai_event_name: error_returned
- Level: error
- Arguments:
status: response.code
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Failed to parse a chunk from Duo Chat Agent
- Description: failed to parse a chunk
- Class:
Gitlab::Duo::Chat::AgentEventParser
- Ai_event_name: parsing_error
- Level: warn
- Arguments:
event_json_size: event_json.length
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes
Failed to find the event class in GitLab-Rails
- Description: no event class
- Class:
Gitlab::Duo::Chat::AgentEventParser
- Ai_event_name: parsing_error
- Level: error
- Arguments:
event_type: event['type']
- Part of the system: duo_chat
- Expanded logging?: no
- Rails: no
- Sidekiq: yes