The audit trail is an append-only record of every privileged action performed in your Gateway organization. Use it for compliance reviews, incident investigation, and to answer “who changed this?” questions about routing policies, API keys, members, and security settings.
Mutations to org-scoped resources emit an audit event. Read-only API calls and inference traffic (request logs are a separate surface) are not audited.
The complete catalog is also surfaced in the event-type dropdown in the dashboard.
Each audit row stores a denormalized snapshot of the actor and target so the entry stays interpretable even if the user, role, or organization is later deleted.
The table is append-only. There is no updated_at column and entries are never modified after they’re written.
The audit trail is designed so that secret values (API keys, credential secrets, SSO client secrets, passwords) never reach an audit row in the first place:
request_body=None when emitting their audit event. The event records that the action happened (with the entity name in the description) but never persists the request payload.compute_changes) runs against the pre-mutation instance and the validated request body. Fields that contain secret values are summarized as "changed" rather than rendering 'old' to 'new', so the rendered description in the audit row contains no secret material.event_description, so long blobs (e.g., raw JSON config) don’t bloat the audit row even when they’re not sensitive.Non-auth-adjacent UPDATE handlers persist the validated request body to request_body as-is. Treat that column as containing the raw payload, and review your audit feed if you handle especially sensitive non-auth data.
UPDATE events combine an identifying prefix with a per-field diff. The description shape is:
List-valued fields render as added/removed sets:
This makes it possible to scan the audit feed and immediately see what changed in any update, without having to fetch the resource history separately.
Open Settings → Audit trail in the Merge Gateway dashboard. The page shows a paginated, filterable table of events with:
AUDIT_LOG_EXPORTED event so you have a trail of who pulled what)The CSV export contains: Timestamp, User Name, User Email, Role, IP Address, Event Type, Event Description. Cells starting with =, +, -, @, \t, or \r are prefixed with a single quote to neutralize CSV injection.
Listing and exporting the audit trail requires the View audit trail permission on the caller’s role. All four built-in roles (Admin, Developer, Security, Read Only) include this permission. See Roles and permissions for the full permission matrix.
Audit entries are append-only and persist indefinitely on the org. There is no automatic TTL or archival. Once written, an event is permanent. The dashboard supports arbitrary date ranges if you need to pull long-windowed compliance reports.
No. Inference traffic flows through a separate request-log surface (and the Security alerts feed). The audit trail covers administrative mutations only, such as settings changes, role assignments, and key creation.
Use the CSV export from the dashboard and forward it to your SIEM. There is no native webhook stream today.
Entries are denormalized at write time, so user_name, user_email, role_name, organization_name remain populated on the row even after the referenced entity is deleted. The FK columns (user_id, organization_id) are set to null via ON DELETE SET NULL.
No. The table is append-only and write-time only. Events are emitted during the mutation that triggers them and cannot be inserted retroactively.
Failed logins emit LOGIN_FAILED. Most other failed mutations do not write an audit entry because the mutation never began. The audit row commits in the same transaction as the mutation. Check your application logs for failures that didn’t make it past authorization.