Fetches the audit log of your Dynatrace environment.
The full list can be lengthy, so you can narrow it down by specifying filter parameters, like tags. See the Parameters section for more details.
You can limit the output by using the pagination:
GET | SaaS | https://{your-environment-id}.live.dynatrace.com/api/v2/auditlogs |
Environment ActiveGateCluster ActiveGate | https://{your-activegate-domain}:9999/e/{your-environment-id}/api/v2/auditlogs |
To execute this request, you need an access token with auditLogs.read
scope.
To learn how to obtain and use it, see Tokens and authentication.
The cursor for the next page of results. You can find it in the nextPageKey field of the previous response.
The first page is always returned if you don't specify the nextPageKey query parameter.
When the nextPageKey is set to obtain subsequent pages, you must omit all other query parameters.
The amount of log entries in a single response payload.
The maximal allowed page size is 5000.
If not set, 1000 is used.
Filters the audit log. You can use the following criteria:
user("userIdentification")
. The EQUALS
operator applies.eventType("value")
. The EQUALS
operator applies.category("value")
. The EQUALS
operator applies.entityId("id")
. The CONTAINS
operator applies.dt.settings.schema_id("id")
. The EQUALS
operator applies.dt.settings.scope_id("id")
. The EQUALS
operator applies.dt.settings.key("key")
. The EQUALS
operator applies.dt.settings.object_id("id")
. The EQUALS
operator applies.For each criterion, you can specify multiple alternatives with comma-separated values. In this case, the OR logic applies. For example, eventType("CREATE","UPDATE")
means eventType can be "CREATE" or "UPDATE".
You can specify multiple comma-separated criteria, such as eventType("CREATE","UPDATE"),category("CONFIG")
. Only results matching all criteria are included in response.
Specify the value of a criterion as a quoted string. The following special characters must be escaped with a tilde (~
) inside quotes:
~
"
The start of the requested timeframe.
You can use one of the following formats:
2021-01-25T05:57:01.123+01:00
. If no time zone is specified, UTC is used. You can use a space character instead of the T
. Seconds and fractions of a second are optional.now-NU/A
, where N
is the amount of time, U
is the unit of time, and A
is an alignment. The alignment rounds all the smaller values to the nearest zero in the past. For example, now-1y/w
is one year back, aligned by a week.
You can also specify relative timeframe without an alignment: now-NU
.
Supported time units for the relative timeframe are:
m
: minutesh
: hoursd
: daysw
: weeksM
: monthsy
: yearsIf not set, the relative timeframe of two weeks is used (now-2w
).
The end of the requested timeframe.
You can use one of the following formats:
2021-01-25T05:57:01.123+01:00
. If no time zone is specified, UTC is used. You can use a space character instead of the T
. Seconds and fractions of a second are optional.now-NU/A
, where N
is the amount of time, U
is the unit of time, and A
is an alignment. The alignment rounds all the smaller values to the nearest zero in the past. For example, now-1y/w
is one year back, aligned by a week.
You can also specify relative timeframe without an alignment: now-NU
.
Supported time units for the relative timeframe are:
m
: minutesh
: hoursd
: daysw
: weeksM
: monthsy
: yearsIf not set, the current timestamp is used.
The sorting of audit log entries:
timestamp
: Oldest first.-timestamp
: Newest first.If not set, the newest first sorting is applied.
AuditLog
objectThe audit log of your environment.
The cursor for the next page of results. Has the value of null
on the last page.
Use it in the nextPageKey query parameter to obtain subsequent pages of the result.
The number of entries per page.
The total number of entries in the result.
AuditLogEntry
objectAn entry of the audit log.
The category of the recorded operation.
ACTIVEGATE_TOKEN
CONFIG
MANUAL_TAGGING_SERVICE
TENANT_LIFECYCLE
TOKEN
WEB_UI
The key of the affected object of a setting for entries of category CONFIG
.
The ID of the affected object of a setting for entries of category CONFIG
.
The value summary for entries of category CONFIG
.
The schema ID or config ID for entries of category CONFIG
.
The persistence scope for entries of category CONFIG
, e.g. an ME identifier.
The display name of the scope for entries of category CONFIG
.
The ID of an entity from the category.
For example, it can be config ID for the CONFIG
category or token ID for the TOKEN
category.
The ID of the Dynatrace environment where the recorded operation occurred.
The type of the recorded operation.
LOGIN
-> A user logged inLOGOUT
-> A user logged outCREATE
-> An object was createdUPDATE
-> An object was updatedDELETE
-> An object was deletedREVOKE
-> An Active Gate token was revokedTAG_ADD
-> A manual tag was addedTAG_REMOVE
-> A manual tag was removedTAG_UPDATE
-> A manual tag was updatedREMOTE_CONFIGURATION_MANAGEMENT
-> A Remote Configuration Management related operation occurredCREATE
DELETE
LOGIN
LOGOUT
REVOKE
TAG_ADD
TAG_REMOVE
TAG_UPDATE
UPDATE
The ID of the log entry.
The logged message.
The patch of the recorded operation as the JSON representation.
The format is an enhanced RFC 6902. The patch also carries the previous value in the oldValue field.
The recorded operation is successful (true
) or failed (false
).
The timestamp of the record creation, in UTC milliseconds.
The ID of the user who performed the recorded operation.
The origin and the IP address of the user.
The type of the authentication of the user.
USER_NAME
-> User was logged in the UITOKEN_HASH
-> URL Token or DevOps Token, the hash of the token is loggedSERVICE_NAME
-> No authenticated user at all, this action was performed by a system service automaticallyPUBLIC_TOKEN_IDENTIFIER
-> API Token, the public token id is loggedPUBLIC_TOKEN_IDENTIFIER
SERVICE_NAME
TOKEN_HASH
USER_NAME
AnyValue
objectA schema representing an arbitrary value type.
{"auditLogs": [{"category": "CONFIG","entityId": "MOBILE_RUM: MOBILE_APPLICATION-752C223D59734CD2","environmentId": "prod-env-13","eventType": "UPDATE","logId": "197425568800060000","patch": [{"oldValue": 20000,"op": "replace","path": "/refreshTimeIntervalMillis","value": 30000}],"success": true,"timestamp": 1974255688445,"user": "test.user@company.com","userOrigin": "webui (192.168.0.2)","userType": "USER_NAME"}],"nextPageKey": "___a7acX3q0AAAAAACJidWlsdGluOnNlcnZpY2lUVEJCUzBaNVIxVjJOSGt6Y3oyLTcwMUZWRkxlclH__9rtpxferQ","pageSize": 5,"totalCount": 10}
In this example, the request fetches all logins (filter=eventType(LOGIN)
) from the audit log of the mySampleEnv environment for the last week (from=now-1w
).
The API token is passed in the Authorization header.
The response is truncated to the first three entries.
curl -X GET \'https://mySampleEnv.live.dynatrace.com/api/v2/auditlogs?filter=eventType%28LOGIN%29&from=now-1w' \-H 'Authorization: Api-Token dt0c01.abc123.abcdefjhij1234567890'
https://mySampleEnv.live.dynatrace.com/api/v2/auditlogs?filter=eventType%28LOGIN%29&from=now-1w
{"totalCount": 5820,"nextPageKey": "vu8y3hPZ3q0AAAAAAi_neQJ8qUAAAAFu0T-ECgAAAW71TAgKAAAD6AAQZXZlbnRUeXBlKExPR0lOKQC-7zLeE9nerQ","auditLogs": [{"logId": "157607341600050000","eventType": "LOGIN","category": "WEB_UI","entityId": "240.204.62.255","environmentId": "yasmuoujsw","user": "Dynatrace support user #877988415","userType": "USER_NAME","userOrigin": "Forwarded: 240.204.62.255","timestamp": 1576073415531,"success": true},{"logId": "157607338800050000","eventType": "LOGIN","category": "WEB_UI","entityId": "55.199.177.119","environmentId": "yasmuoujsw","user": "Dynatrace support user #490812376","userType": "USER_NAME","userOrigin": "Forwarded: 55.199.177.119","timestamp": 1576073388150,"success": true},{"logId": "157607338300060000","eventType": "LOGIN","category": "WEB_UI","entityId": "75.16.11.184","environmentId": "umsaywsjuo","user": "Dynatrace support user #765684830","userType": "USER_NAME","userOrigin": "Forwarded: 75.16.11.184","timestamp": 1576073381543,"success": true}]}
200