Skip to main content

Audit logs event reference

Audit log event schema

Hex audit logs are emitted in JSON format. Some notable fields in the schema are:

  • action: type of action taken
  • actor: identifies the user or client (e.g. API) making the request
  • context: the location (IP address) and user agent of the actor
  • targets: Hex resources that are affected or created by this action

The following is an example event object:

{
"actor": {
"id": "b44446e6-8264-4af5-a856-fdc2fa8fe132",
"type": "USER",
"metadata": {
"email": "[email protected]",
"workspace": "Hex",
"workspaceId": "57c59cf9-c943-4386-afb5-75df1af3b2f7"
}
},
"action": "RUN_CELL",
"context": {
"location": "1.1.1.1",
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/117.0.0.0 Safari/537.36"
},
"targets": [
{
"id": "f426633a-0993-4bbc-be6a-740e28da2596",
"type": "project",
"metadata": {
"representation": "{\"id\":\"f426633a-0993-4bbc-be6a-740e28da2596\",\"createdDate\":\"2024-04-08T20:15:06.337Z\",\"updatedDate\":\"2024-04-12T15:38:25.265Z\",\"archivedDate\":null,\"creatorId\":\"b44446e6-8264-4af5-a856-fdc2fa8fe132\",\"canEditorsShare\":true,\"projectLanguage\":\"PYTHON\",\"hexType\":\"PROJECT\",\"organizationRole\":null,\"publicRole\":null}"
}
},
{
"id": "60d9ac4d-7eb2-4638-9423-61bdf8a331ef",
"type": "project_version",
"metadata": {
"representation": "{\"id\":\"60d9ac4d-7eb2-4638-9423-61bdf8a331ef\",\"createdDate\":\"2024-04-08T20:15:06.337Z\",\"updatedDate\":\"2024-04-12T15:38:25.127Z\",\"title\":\"Sample Project\",\"description\":\"\",\"hexId\":\"f426633a-0993-4bbc-be6a-740e28da2596\",\"creatorId\":\"b44446e6-8264-4af5-a856-fdc2fa8fe132\",\"timezone\":null,\"version\":\"draft\",\"published\":false,\"import\":false,\"kernelSize\":\"medium\",\"autoRerun\":true,\"cacheAppState\":true}"
}
},
{
"id": "340ba95d-465a-44d2-8b04-8a83c6c5b1e5",
"type": "cell",
"metadata": {
"representation": "{\"id\":\"2e56c683-8151-4071-918f-0050ce854637\",\"createdDate\":\"2024-04-08T20:15:17.810Z\",\"updatedDate\":\"2024-04-08T20:15:17.810Z\",\"cellType\":\"SQL\"}"
}
}
],
"version": 1,
"metadata": {
"result": "SUCCESS",
"requestArgs": "{\"hexId\":\"f426633a-0993-4bbc-be6a-740e28da2596\",\"hexVersionId\":\"60d9ac4d-7eb2-4638-9423-61bdf8a331ef\",\"cellId\":\"2e56c683-8151-4071-918f-0050ce854637\"}",
"failureReason": ""
},
"occurred_at": "2024-04-12T15:38:27.073Z"
}

Audit log target resource types

The following resource types appear as target resources in audit log events:

Resource typeNotes
CellA cell in a Hex project
CollectionA collection of Hex projects and components
Data connectionA connection to an external data warehouse
DomainA domain allowed to be associated with your Hex workspace
External file integrationAn integration with a cloud storage provider like AWS S3 or Google Drive
FileA file uploaded to a Hex project
GroupA group of Hex users that can be granted access to resources
ProjectA Hex project, component, or explore object
Project grantA role (viewer, editor, etc.) given to a user or group for access to a Hex project
Project versionA specific version of a Hex project
Project viewAn object that represents an instance of a user viewing a project
Scheduled runA cron-like schedule on which a project is run periodically
Scheduled run notificationA notification configured on a scheduled run, to send emails and/or Slack messages when a scheduled run completes or fails
SecretA secret value containing sensitive information that can be referenced in Hex projects
TemplateA Hex-provided project template
UserA Hex user (could be email user, API user, etc.)
WorkspaceA representation of your Hex workspace

Some event types include target resources with a type of principal. This indicates that this object can be one of multiple types. For instance, the UPDATE_PROJECT_ACCESS event type includes a principal resource which is either a Group or a User.

Audit log event types

Event typeDescriptionTarget resource types
CREATE_PROJECT
  • Project
CREATE_PROJECT_FROM_TEMPLATECreate a project from a template
  • Project
  • Template
DUPLICATE_PROJECT
  • Project
COPY_PROJECT_FROM_EXTERNAL_WORKSPACECreate a project by copying one from a different workspace
  • Project
IMPORT_PROJECTImport a project from a project yaml file
  • Project
CREATE_EXPLORE_FROM_PROJECT_CELLCreate an "explore from app" from a project cell
  • Project
CREATE_EXPLORECreate an Explore
  • Project
  • Cell
CONVERT_EXPLORE_TO_PROJECTCreate a project from data created while exploring from an app
  • Project
VIEW_PROJECT
  • Project
  • Project version
  • Project view
RUN_PROJECTRun a project top to bottom
  • Project
  • Project version
RUN_CELLRun a single cell within a project
  • Project
  • Project version
  • Cell
UPLOAD_FILE_TO_PROJECT
  • Project
  • File
DOWNLOAD_FILE_FROM_PROJECT
  • Project
  • File
PUBLISH_PROJECT
  • Project
DELETE_PROJECTMove project to trash
  • Project
PERMANENTLY_DELETE_PROJECT
  • Project
REQUEST_PROJECT_ROLEA user request for an access role to a project
  • Project
  • User
GRANT_USERS_PROJECT_ACCESSGrant a set of users an access role to a project
  • Project
  • User
  • Project grant
GRANT_GROUPS_PROJECT_ACCESSGrant a set of groups an access role to a project
  • Project
  • Group
  • Project grant
GRANT_ADMIN_PROJECT_ACCESSSame as GRANT_USERS_PROJECT_ACCESS, but only for admins
  • Project
  • User
  • Project grant
UPDATE_PROJECT_ACCESSUpdate the access role to a project for a set of users and/or groups
  • Project
  • Principal
  • Project grant
Principal here refers to either a Group or a User
REMOVE_PROJECT_ACCESSRemove a user or group's access to a project
  • Project
  • Principal
SHARE_PROJECT_WITH_SUPPORT
  • Project
SHARE_PROJECT_WITH_ORG
  • Project
SHARE_PROJECT_WITH_PUBLIC
  • Project
UPDATE_PROJECT_PUBLIC_DUPLICATION_ALLOWEDChange whether or not a project can be duplicated by users in another workspace
  • Project
CREATE_SCHEDULED_RUN
  • Project
  • Scheduled run
EDIT_SCHEDULED_RUN
  • Project
  • Scheduled run
DELETE_SCHEDULED_RUN
  • Project
  • Scheduled run
CREATE_COLLECTION
  • Collection
EDIT_COLLECTION
  • Collection
ADD_PROJECTS_TO_COLLECTIONAdd a set of projects to a collection
  • Collection
  • Project
UPDATE_COLLECTION_ROLE_IN_PROJECTUpdate the access role that a collection has for a project
  • Collection
  • Project
CREATE_WORKSPACE_DATA_CONNECTIONCreate a data connection usable across the workspace
  • Data connection
CREATE_PROJECT_DATA_CONNECTIONCreate a data connection within a project
  • Data connection
  • Project
EDIT_DATA_CONNECTION
  • Data connection
REFRESH_DATA_CONNECTION_SCHEMATrigger a refresh of the data schema for a data connection
  • Data connection
UPDATE_DATA_CONNECTION_MAGIC_USAGEUpdate whether or not a data connection should be used for Magic generation
  • Data connection
IMPORT_DATA_CONNECTIONImport a data connection in a project
  • Data connection
  • Project
REMOVE_DATA_CONNECTION_IMPORTUnimport a data connection from a project
  • Data connection
  • Project
DELETE_DATA_CONNECTION
  • Data connection
SET_WORKSPACE_DEFAULT_DATA_CONNECTIONSet a data connection as the default for the workspace
  • Data connection
CREATE_USERS
  • User
CREATE_PASSWORD_USERCreate a user who is allowed to login using a password
  • User
INVITE_USERSInvite users to join the workspace by email
  • Workspace
INVITE_USER_AS_ADMINInvite a user to join the workspace as an admin
  • Workspace
ACTIVATE_USER
  • User
DEACTIVATE_USER
  • User
EDIT_USERUpdate user metadata (excluding their workspace role)
  • User
UPDATE_USER_ROLEUpdate a user's workspace role
  • User
REQUEST_ORG_ROLEA user's request for a specific role in the workspace
  • User
GRANT_USER_API_ACCESSAllow a user to generate API tokens and use them in requessts
  • User
REVOKE_USER_API_ACCESSPrevent user from creating API tokens and reject requests containing tokens attributed to this user
  • User
CREATE_GROUP
  • Group
UPDATE_GROUPUpdate metadata about a group (not its users)
  • Group
UPDATE_GROUP_MEMBERSAdd or remove users from a group
  • User
  • Group
DELETE_GROUP
  • Group
CREATE_EXTERNAL_FILE_INTEGRATION
  • External file integration
EDIT_EXTERNAL_FILE_INTEGRATION
  • External file integration
DELETE_EXTERNAL_FILE_INTEGRATION
  • External file integration
DOWNLOAD_FILE_FROM_EXTERNAL_FILE_INTEGRATION
  • External file integration
ADD_WORKSPACE_DOMAINAdd an allowed domain to workspace
  • Domain
DELETE_WORKSPACE_DOMAIN
  • Domain
UPDATE_SSO_CONFIGURATIONConfigure SSO auth for the workspace
  • Workspace
UPDATE_PUBLIC_SHARING_SETTINGUpdate whether or not projects in the workspace can be shared publicly
  • Workspace
UPDATE_API_TOKEN_EXPIRATION_POLICYConfigure expiration policy for API tokens
  • Workspace
UPDATE_ALLOW_NOTION_PREVIEW
  • Workspace
UPDATE_ALLOW_CSV_DOWNLOADS
  • Workspace
UPDATE_ALLOW_FILE_UPLOADS
  • Workspace
SET_DIRECTORY_SYNC_ADMIN_GROUPSet a group of users from Directory Sync to be workspace admins
  • Workspace
SET_DIRECTORY_SYNC_AUTHOR_GROUPSet a group of users from Directory Sync to be workspace editors
  • Workspace
SET_DATA_RETENTION_CELL_OUTPUTSSet the data retention period for cell outputs
  • Workspace
SET_DATA_RETENTION_QUERY_CACHESet the data retention period for query cache entries
  • Workspace
CREATE_WORKSPACE_SECRETCreate a shared workspace secret
  • Secret
EDIT_WORKSPACE_SECRETModify properties of a shared workspace secret
  • Secret
DELETE_WORKSPACE_SECRET
  • Secret
IMPORT_WORKSPACE_SECRETImport a shared workspace secret into a project
  • Secret
UNIMPORT_WORKSPACE_SECRETUnimport a shared workspace secret from a project
  • Secret
CREATE_PROJECT_SECRETCreate a secret usable within a single project
  • Secret
EDIT_PROJECT_SECRETModify properties of a project-scoped secret
  • Secret
DELETE_PROJECT_SECRET
  • Secret
CREATE_SCHEDULED_RUN_NOTIFICATIONCreate a new notification for a scheduled run
  • Scheduled Run
  • Scheduled Run Notification
  • Project
EDIT_SCHEDULED_RUN_NOTIFICATIONEdit an existing notification for a scheduled run
  • Scheduled Run
  • Scheduled Run Notification
  • Project
DELETE_SCHEDULED_RUN_NOTIFICATIONDelete an existing notification for a scheduled run
  • Scheduled Run
  • Scheduled Run Notification