21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
# File 'lib/legion/mcp/tools/get_task_logs.rb', line 21
def call(id:, limit: 50)
log.info('Starting legion.mcp.tools.get_task_logs.call')
return error_response('legion-data is not connected') unless data_connected?
task = Legion::Data::Model::Task[id.to_i]
return error_response("Task #{id} not found") unless task
limit = limit.to_i.clamp(1, 100)
logs = Legion::Data::Model::TaskLog
.where(task_id: id.to_i)
.order(Sequel.desc(:id))
.limit(limit)
.all.map(&:values)
text_response(logs)
rescue StandardError => e
handle_exception(e, level: :warn, operation: 'legion.mcp.tools.get_task_logs.call')
log.warn("GetTaskLogs#call failed: #{e.message}")
error_response("Failed to get task logs: #{e.message}")
end
|