Agent Fetch Logs
Fetches log entries from a given agent or agents. Useful for debugging and monitoring agent behavior.
Invoke the $fetch-logs operation
Single Agent
[base]/Agent/[id]/$fetch-logs
For example:
medplum get 'Agent/[id]/$fetch-logs'
Multiple Agents
[base]/Agent/$fetch-logs
For example:
medplum get 'Agent/$fetch-logs?_tag=Group+A'
Parameters
limit(optional; default:20): Maximum number of log entries to return per agent
Single Agent Response
When querying a single agent by ID, the response is a Parameters resource containing the logs.
Valid Response
Example response when logs are successfully retrieved:
{
"resourceType": "Parameters",
"parameter": [
{
"name": "logs",
"valueString": "{\"level\":\"INFO\",\"timestamp\":\"2024-04-19T00:00:00.000Z\",\"msg\":\"Agent started successfully\"}\n{\"level\":\"INFO\",\"timestamp\":\"2024-04-19T00:01:00.000Z\",\"msg\":\"Processing message\"}\n{\"level\":\"ERROR\",\"timestamp\":\"2024-04-19T00:02:00.000Z\",\"msg\":\"An error occurred\",\"error\":\"Error: Connection failed\"}"
}
]
}
The logs parameter contains a newline-separated string of JSON objects, where each object represents a log message with:
level: Log level (ERROR,WARN,INFO,DEBUG)timestamp: ISO 8601 timestampmsg: Log message- Additional fields may be present (e.g.,
errorfor error logs)
Multi-Agent Response
When querying multiple agents, the response is a Bundle of Parameters. Each Parameters within the Bundle contains an agent and a result, which is the result of calling the $fetch-logs operation on this Agent, either a Parameters or OperationOutcome resource.
Valid Response
Example response for multiple agents:
{
"resourceType": "Bundle",
"type": "collection",
"entry": [
{
"resource": {
"resourceType": "Parameters",
"parameter": [
{
"name": "agent",
"resource": {
"resourceType": "Agent",
"name": "Test Agent 1",
"status": "active",
"id": "93f8b2fb-65a3-4977-a175-71b73b26fde7",
"meta": {
"versionId": "e182201a-6925-467f-a92b-496193fb4c39",
"lastUpdated": "2024-04-19T20:29:25.087Z"
}
}
},
{
"name": "result",
"resource": {
"resourceType": "Parameters",
"parameter": [
{
"name": "logs",
"valueString": "{\"level\":\"INFO\",\"timestamp\":\"2024-04-19T00:00:00.000Z\",\"msg\":\"Agent started\"}\n{\"level\":\"INFO\",\"timestamp\":\"2024-04-19T00:01:00.000Z\",\"msg\":\"Processing message\"}"
}
]
}
}
]
}
},
{
"resource": {
"resourceType": "Parameters",
"parameter": [
{
"name": "agent",
"resource": {
"resourceType": "Agent",
"name": "Test Agent 2",
"status": "active",
"id": "a1b2c3d4-5e6f-7890-abcd-ef1234567890",
"meta": {
"versionId": "f293201a-6925-467f-a92b-496193fb4c39",
"lastUpdated": "2024-04-19T20:29:25.087Z"
}
}
},
{
"name": "result",
"resource": {
"resourceType": "OperationOutcome",
"issue": [
{
"severity": "error",
"code": "exception",
"details": {
"text": "Failed to fetch logs: Agent not responding"
}
}
]
}
}
]
}
}
]
}
Invalid Response
Example outcome when an ID was not supplied to the operation:
{
"resourceType": "OperationOutcome",
"issue": [
{
"severity": "error",
"code": "invalid",
"details": {
"text": "Must specify agent ID or identifier"
}
}
]
}
Example outcome when exceeding max _count limit:
{
"resourceType": "OperationOutcome",
"issue": [
{
"severity": "error",
"code": "invalid",
"details": {
"text": "'_count' of 101 is greater than max of 100"
}
}
]
}
Using search parameters
All of the Agent search parameters can be used to select which agents to query logs from when using the multi-agent endpoint.
Some useful search parameters are:
namestatus_countand_offset
Recipes
Single Agent by ID
Fetch logs from a specific agent by ID:
medplum get 'Agent/93f8b2fb-65a3-4977-a175-71b73b26fde7/$fetch-logs'
Single Agent by ID with Limit
Fetch the last 10 log entries from a specific agent:
medplum get 'Agent/93f8b2fb-65a3-4977-a175-71b73b26fde7/$fetch-logs?limit=10'
Single Agent by Identifier
Fetch logs from a specific agent by identifier:
medplum get 'Agent/$fetch-logs?identifier=agent-007'
Multiple Agents by Name
Fetch logs from all agents with a specific name prefix:
medplum get 'Agent/$fetch-logs?name=Production+Agent'
Multiple Agents by Status
Fetch logs from all active agents:
medplum get 'Agent/$fetch-logs?status=active'
Multiple Agents with Limit
Fetch logs from all agents, limited to 5 entries per agent:
medplum get 'Agent/$fetch-logs?limit=5'
Paging Through Agent Logs
Fetch logs from agents in batches, 50 agents at a time:
medplum get 'Agent/$fetch-logs?_count=50&_offset=0'
medplum get 'Agent/$fetch-logs?_count=50&_offset=50'