You can retrieve and filter all access-related events using:
Filter all events
1 2 3 4 5 6 7 8 910111213
client// (1).logs// (2).getEvents(KeycloakEventRequest.builder()// (3).dateFrom("2023-01-01")// (4).dateTo("2023-01-31")// (5).type(KeycloakEventType.LOGIN)// (6).type(KeycloakEventType.LOGOUT).build()).stream()// (7).limit(1000)// (8).forEach(event->{// (9)// Do something with each event});
From a client...
... access the logs endpoints.
The getEvents() method allows you to filter across all access events that are logged.
(Optional) You can filter by events only back to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by events only up to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by one or more types of events, for example focusing only on logins and logouts.
Like other paginated resources, you can iterate or stream the results. The access events will be lazily-fetched from Atlan.
When streaming, you can apply any additional constraints such as limiting or further filtering.
And of course, you can then actually do something with each event.
Filter all events
1 2 3 4 5 6 7 8 910111213
frompyatlan.model.enumsimportKeycloakEventTypefrompyatlan.model.keycloak_eventsimportKeycloakEventRequestfrompyatlan.client.atlanimportAtlanClientrequest=KeycloakEventRequest(# (1)date_from="2023-01-01",# (2)date_to="2023-01-31",# (3)types=[KeycloakEventType.LOGIN,KeycloakEventType.LOGOUT]# (4))client=AtlanClient()events=client.admin.get_keycloak_events(request)# (5)foreventinevents:# (6)# Do something with each event
Begin by defining your filter criteria in a KeycloakEventRequest.
(Optional) You can filter by events only back to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by events only up to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by one or more types of events, for example focusing only on logins and logouts.
From a client, call the admin.get_keycloak_events() method with your requested filters.
Like other paginated resources, you can iterate directly through the results. The access events will be lazily-fetched from Atlan.
Filter all events
1 2 3 4 5 6 7 8 910111213
client// (1).logs// (2).getEvents(KeycloakEventRequest.builder()// (3).dateFrom("2023-01-01")// (4).dateTo("2023-01-31")// (5).type(KeycloakEventType.LOGIN)// (6).type(KeycloakEventType.LOGOUT).build()).stream()// (7).limit(1000)// (8).forEach{// (9)// Do something with each event}
From a client...
... access the logs endpoints.
The getEvents() method allows you to filter across all access events that are logged.
(Optional) You can filter by events only back to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by events only up to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by one or more types of events, for example focusing only on logins and logouts.
Like other paginated resources, you can iterate or stream the results. The access events will be lazily-fetched from Atlan.
When streaming, you can apply any additional constraints such as limiting or further filtering.
And of course, you can then actually do something with each event.
GET /api/service/events/login?dateFrom=2023-01-01&dateTo=2023-01-31&type=LOGIN&type=LOGOUT
1
// (1)!
All parameters for filtering the logs are query parameters sent in the URL itself.
Common event types
Some of the common event types you might want to filter on include:
Type
Meaning
LOGIN
User has logged in.
LOGOUT
User has logged out.
REGISTER
User has registered.
UPDATE_EMAIL
Email address for an account has changed.
UPDATE_PASSWORD
Password for an account has changed.
SEND_VERIFY_EMAIL
Verification email has been sent.
VERIFY_EMAIL
Email address for an account has been verified.
SEND_RESET_PASSWORD
Password reset email has been sent.
RESET_PASSWORD
Password for the account has been reset.
CODE_TO_TOKEN
Application / client has exchanged a code for a token.
You can retrieve and filter administrative events using:
Filter admin events
1 2 3 4 5 6 7 8 910111213141516
client// (1).logs// (2).getAdminEvents(AdminEventRequest.builder()// (3).dateFrom("2023-01-01")// (4).dateTo("2023-01-31")// (5).operationType(AdminOperationType.CREATE)// (6).operationType(AdminOperationType.UPDATE).resourceType(AdminResourceType.REALM_ROLE)// (7).resourceType(AdminResourceType.REALM_ROLE_MAPPING).resourcePath("roles/connection_admins_e71551e0-7f59-44bb-989c-e434f2e5bcae")// (8).build()).stream()// (9).limit(1000)// (10).forEach(event->{// (11)// Do something with each event});
From a client...
... access the logs endpoints.
The getAdminEvents() method allows you to filter across all admin events that are logged.
(Optional) You can filter by events only back to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by events only up to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by one or more operations, for example focusing only on creation and updates.
(Optional) You can filter by one or more resource types, for example only new roles or mappings to roles.
(Optional) You can filter by a specific resource, such as the role associated with all admins for a specific connection in Atlan.
Like other paginated resources, you can iterate or stream the results. The access events will be lazily-fetched from Atlan.
When streaming, you can apply any additional constraints such as limiting or further filtering.
And of course, you can then actually do something with each event.
Filter admin events
1 2 3 4 5 6 7 8 9101112131415
frompyatlan.model.enumsimportAdminOperationType,AdminResourceTypefrompyatlan.model.keycloak_eventsimportAdminEventRequestfrompyatlan.client.atlanimportAtlanClientrequest=AdminEventRequest(# (1)date_from="2023-01-01",# (2)date_to="2023-01-31",# (3)operation_types=[AdminOperationType.CREATE,AdminOperationType.UPDATE],# (4)resource_types=[AdminResourceType.REALM_ROLE,AdminResourceType.REALM_ROLE_MAPPING],# (5)resource_path="roles/connection_admins_e71551e0-7f59-44bb-989c-e434f2e5bcae"# (6))client=AtlanClient()events=client.admin.get_admin_events(request)# (7)foreventinevents:# (8)# Do something with each event
Begin by defining your filter criteria in a AdminEventRequest.
(Optional) You can filter by events only back to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by events only up to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by one or more operations, for example focusing only on creation and updates.
(Optional) You can filter by one or more resource types, for example only new roles or mappings to roles.
(Optional) You can filter by a specific resource, such as the role associated with all admins for a specific connection in Atlan.
From a client, call the admin.get_admin_events() method with your requested filters.
Like other paginated resources, you can iterate directly through the results. The access events will be lazily-fetched from Atlan.
Filter admin events
1 2 3 4 5 6 7 8 910111213141516
client// (1).logs// (2).getAdminEvents(AdminEventRequest.builder()// (3).dateFrom("2023-01-01")// (4).dateTo("2023-01-31")// (5).operationType(AdminOperationType.CREATE)// (6).operationType(AdminOperationType.UPDATE).resourceType(AdminResourceType.REALM_ROLE)// (7).resourceType(AdminResourceType.REALM_ROLE_MAPPING).resourcePath("roles/connection_admins_e71551e0-7f59-44bb-989c-e434f2e5bcae")// (8).build()).stream()// (9).limit(1000)// (10).forEach{// (11)// Do something with each event}
From a client...
... access the logs endpoints.
The getAdminEvents() method allows you to filter across all admin events that are logged.
(Optional) You can filter by events only back to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by events only up to a particular point in time (using the format yyyy-MM-dd).
(Optional) You can filter by one or more operations, for example focusing only on creation and updates.
(Optional) You can filter by one or more resource types, for example only new roles or mappings to roles.
(Optional) You can filter by a specific resource, such as the role associated with all admins for a specific connection in Atlan.
Like other paginated resources, you can iterate or stream the results. The access events will be lazily-fetched from Atlan.
When streaming, you can apply any additional constraints such as limiting or further filtering.
And of course, you can then actually do something with each event.
GET /api/service/events/main?dateFrom=2023-01-01&dateTo=2023-01-31&operationTypes=CREATE&operationTypes=UPDATE&resourceTypes=REALM_ROLE&resourceTypes=REALM_ROLE_MAPPING&resourcePath=roles%2Fconnection_admins_e71551e0-7f59-44bb-989c-e434f2e5bcae
1
// (1)!
All parameters for filtering the logs are query parameters sent in the URL itself. (Note that the values should be URL-encoded.)
Common resource types
Some of the common resource types you might want to filter on include:
Type
Meaning
USER
An individual user.
GROUP
Mechanism to cluster together multiple users.
GROUP_MEMBERSHIP
Association between a user and a group.
REALM_ROLE
Object that controls access to potentially multiple resources.
REALM_ROLE_MAPPING
Mapping between user(s) and access control objects (roles).