mirror of
https://github.com/zitadel/zitadel.git
synced 2025-02-28 20:47:22 +00:00
docs(concepts): Describe audit trail feature (#5747)
* docs(concepts): Audit Trail * event viewer * event api * future plans * fix broken links * external system * link to logs (dependency) * correct link * Apply suggestions from code review Co-authored-by: Florian Forster <florian@zitadel.com> * service user link * replace image --------- Co-authored-by: Florian Forster <florian@zitadel.com>
This commit is contained in:
parent
9c3f149cd7
commit
696fb390ae
64
docs/docs/concepts/features/audit-trail.md
Normal file
64
docs/docs/concepts/features/audit-trail.md
Normal file
@ -0,0 +1,64 @@
|
||||
---
|
||||
title: Audit Trail
|
||||
---
|
||||
|
||||
ZITADEL provides you with an built-in audit trail to track all changes and events over an unlimited period of time.
|
||||
Most other solutions replace a historic record and track changes in a separate log when information is updated.
|
||||
ZITADEL only ever appends data in an [Eventstore](https://zitadel.com/docs/concepts/eventstore), keeping all historic record.
|
||||
The audit trail itself is identical to the state, since ZITADEL calculates the state from all the past changes.
|
||||
|
||||
data:image/s3,"s3://crabby-images/798cb/798cb137355121bcb29ea8b623f2e7cbd88759b8" alt="Example of events that happen for a profile change and a login"
|
||||
|
||||
This form of audit log has several benefits over storing classic audit logs.
|
||||
You can view past data in-context of the whole system at a single point in time.
|
||||
Reviewing a past state of the application can be important when tracing an incident that happened months back. Moreover the eventstore provides a truly complete and clean audit log.
|
||||
|
||||
## Accessing the Audit Log
|
||||
|
||||
### Last changes of an object
|
||||
|
||||
You can check the last changes of most objects in the [Console](/docs/guides/manage/console/overview).
|
||||
In the following screenshot you can see an example of last changes on an [user](/docs/guides/manage/console/users).
|
||||
The same view is available on several other objects such as organization or project.
|
||||
|
||||
data:image/s3,"s3://crabby-images/a1327/a132725a1962b3987023d44aa8c131eaeeb9e1eb" alt="Profile Self Manage"
|
||||
|
||||
### Event View
|
||||
|
||||
Administrators can see all events across an instance and filter them directly in [Console](/docs/guides/manage/console/overview).
|
||||
Go to your instance settings and then click on the Tab **Events** to open the Event Viewer or browse to $YOUR_DOMAIN/ui/console/events
|
||||
|
||||
data:image/s3,"s3://crabby-images/4e5f1/4e5f11ee46ad18f30cf53cb206643f1d10442a92" alt="Event viewer"
|
||||
|
||||
### Event API
|
||||
|
||||
Since everything that is available in Console can also be called with our APIs, you can access all events and audit data trough our APIs:
|
||||
|
||||
- [Event API Guide](/docs/guides/integrate/event-api)
|
||||
- [API Documentation](/docs/category/apis/admin/events)
|
||||
|
||||
Access to the API is possible with a [Service User](/docs/guides/integrate/serviceusers) account, allowing you to integrate the events with your own business logic.
|
||||
|
||||
## Using logs in external systems
|
||||
|
||||
You can use the [Event API](#event-api) to pull data and ingest it in an external system.
|
||||
|
||||
[Actions](actions.md) can be used to write events to the stdout and [process the events as logs](../../self-hosting/manage/production#logging).
|
||||
Please refer to the zitadel/actions repository for a [code sample](https://github.com/zitadel/actions/blob/main/examples/post_auth_log.js).
|
||||
You can use your log processing pipeline to parse and ingest the events in your favorite analytics tool.
|
||||
|
||||
It is possible to send events directly with an http request to an external tool.
|
||||
We don't recommend this approach since this would create back-pressure and increase the overall processing time for requests.
|
||||
|
||||
:::info Scope of Actions
|
||||
At this moment Actions can be invoked on certain events, but not generally on every event.
|
||||
This is not a technical limitation, but a [feature on our backlog](https://github.com/zitadel/zitadel/issues/5101).
|
||||
:::
|
||||
|
||||
## Future plans
|
||||
|
||||
There will be three major areas for future development on the audit data
|
||||
|
||||
- [Metrics](https://github.com/zitadel/zitadel/issues/4458) and [standard reports](https://github.com/zitadel/zitadel/discussions/2162#discussioncomment-1153259)
|
||||
- [Feedback loop](https://github.com/zitadel/zitadel/issues/5102) and threat detection
|
||||
- Forensics and replay of events
|
@ -281,6 +281,7 @@ module.exports = {
|
||||
"concepts/features/identity-brokering",
|
||||
"concepts/structure/jwt_idp",
|
||||
"concepts/features/actions",
|
||||
"concepts/features/audit-trail",
|
||||
"concepts/features/selfservice",
|
||||
]
|
||||
},
|
||||
|
BIN
docs/static/img/concepts/audit-trail/audit-log-events.png
vendored
Normal file
BIN
docs/static/img/concepts/audit-trail/audit-log-events.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 410 KiB |
BIN
docs/static/img/concepts/audit-trail/event-viewer.png
vendored
Normal file
BIN
docs/static/img/concepts/audit-trail/event-viewer.png
vendored
Normal file
Binary file not shown.
After Width: | Height: | Size: 583 KiB |
Loading…
x
Reference in New Issue
Block a user