Compliance API - Chat Management Endpoints
Trust: ★★★☆☆ (0.90) · 0 validations · developer_reference
Published: 2026-05-11 · Source: crawler_authoritative
Tình huống
API reference for compliance Reviews of Claude.ai chat data, covering chat listing with filtering, message retrieval, and file management endpoints for authorized administrators.
Insight
The Compliance API provides three main chat-related endpoints: (1) GET /v1/compliance/apps/chats - lists chat metadata with filtering by user_ids (required, 1-10 IDs), organization_ids, project_ids, created_at (RFC 3339 range filters), updated_at (RFC 3339 range filters), with pagination via after_id/before_id cursors and limit (default 100, max 1000). Results are sorted chronologically by created_at with ties broken by id. (2) DELETE /v1/compliance/apps/chats/{claude_chat_id} - permanently deletes a chat and all associated messages and files; returns {id, type: ‘claude_chat_deleted’}. (3) GET /v1/compliance/apps/chats/{claude_chat_id}/messages - retrieves message history with pagination and limit (max 1000, returns full set by default). Response includes chat_messages array with id, artifacts (with id, artifact_type like ‘application/vnd.ant.code’, title, version_id), content blocks, files (id, filename, mime_type), generated_files (assistant-created files), role (‘user’|‘assistant’), and timestamps. Pagination cursors are opaque strings - clients must not parse them. File operations include: GET /v1/compliance/apps/chats/files/{claude_file_id} returns metadata (id, created_at, filename, message_ids, mime_type, size_bytes); DELETE removes files permanently; GET /content downloads binary bytes. Generated files from GET /v1/compliance/apps/chats/generated-files/{claude_gen_file_id}/content downloads assistant-created file content. All endpoints accept optional x-api-key header or Bearer token in Authorization header.
Hành động
Use GET /v1/compliance/apps/chats to list chats by passing required user_ids array. Filter by organization_ids (org_… or UUID), project_ids (claude_proj_…), or time ranges using created_at.gt/gte/lt/lte and updated_at.gt/gte/lt/lte in RFC 3339 format. Paginate using after_id (last_id from response) to go backwards in time, or before_id (first_id) to go forwards. Retrieve messages for a specific chat via GET /v1/compliance/apps/chats/{claude_chat_id}/messages. Delete chats permanently using DELETE /v1/compliance/apps/chats/{claude_chat_id}. Access file metadata via GET /v1/compliance/apps/chats/files/{claude_file_id}, download content via /content endpoint, and delete files via DELETE. Download generated files using the claude_gen_file_abc123 ID from chat_messages[].generated_files[].id. Authenticate with Bearer $ANTHROPIC_COMPLIANCE_API_KEY.
Kết quả
List endpoint returns ChatListResponse with data array containing id, created_at, deleted_at, href, model, name, organization_id, organization_uuid, project_id, updated_at, user object with id and email_address, plus first_id, last_id, and has_more for pagination. Delete returns ChatDeleteResponse with id and type ‘claude_chat_deleted’. Messages returns ChatMessagesResponse with chat_messages array and pagination cursors. File retrieve returns FileRetrieveResponse with metadata; file content returns binary bytes. Deletion operations cannot be undone.
Điều kiện áp dụng
Compliance API requires authorized admin access. user_ids parameter is required for list endpoint, accepting 1-10 IDs per request. Chat IDs use tagged format (e.g., claude_chat_abc123), file IDs use claude_file_abc123 format, generated file IDs use claude_gen_file_abc123 format.
Nội dung gốc (Original)
Chats
List
get /v1/compliance/apps/chats
Lists chat metadata with filtering capabilities for targeted compliance review. Results are sorted chronologically (time ascending) by created_at, with ties broken by id.
Query Parameters
-
user_ids: array of stringFilter to chats created by specific users. Required; pass 1–10 user IDs per request. Enumerate IDs via
GET /v1/compliance/organizations/{org_uuid}/users. -
after_id: optional stringPagination cursor for retrieving the next page of results (heading backwards in time). To paginate, pass the
last_idvalue from the most recent response. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
before_id: optional stringPagination cursor for retrieving the previous page of results (heading forwards in time). To paginate, pass the
first_idvalue from the most recent response. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
created_at: optional object { gt, gte, lt, lte }-
gt: optional stringFilter chats created after this time (RFC 3339 format)
-
gte: optional stringFilter chats created at or after this time (RFC 3339 format)
-
lt: optional stringFilter chats created before this time (RFC 3339 format)
-
lte: optional stringFilter chats created at or before this time (RFC 3339 format)
-
-
limit: optional numberMaximum results (default: 100, max: 1000)
-
organization_ids: optional array of stringFilter by organization IDs (accepts
org_...or organization UUID). Enumerate IDs viaGET /v1/compliance/organizations. -
project_ids: optional array of stringFilter by project IDs (accepts
claude_proj_...). Enumerate IDs viaGET /v1/compliance/apps/projects. -
updated_at: optional object { gt, gte, lt, lte }-
gt: optional stringFilter chats updated after this time (RFC 3339 format)
-
gte: optional stringFilter chats updated at or after this time (RFC 3339 format)
-
lt: optional stringFilter chats updated before this time (RFC 3339 format)
-
lte: optional stringFilter chats updated at or before this time (RFC 3339 format)
-
Header Parameters
"x-api-key": optional string
Returns
-
data: array of object { id, created_at, deleted_at, 8 more }List of chat metadata sorted chronologically by created_at, tie break by id
-
id: stringChat ID
-
created_at: stringCreation timestamp
-
deleted_at: stringDeletion timestamp if deleted
-
href: stringURL to view this chat in claude.ai
-
model: stringModel selected for this chat (e.g. ‘claude-opus-4-7’). May be null for legacy chats that never had a model recorded.
-
name: stringChat name/title
-
organization_id: stringOrganization ID this chat belongs to
-
organization_uuid: stringOrganization UUID this chat belongs to
-
project_id: stringProject ID this chat belongs to
-
updated_at: stringLast update timestamp
-
user: object { id, email_address }User information for the chat creator
-
id: stringUser identifier
-
email_address: stringUser’s email address
-
-
-
first_id: stringFirst chat ID in the current result set. To get the previous page, use this as before_id in your next request
-
has_more: booleanWhether more records exist beyond the current result set
-
last_id: stringLast chat ID in the current result set. To get the next page, use this as after_id in your next request
Example
curl https://api.anthropic.com/v1/compliance/apps/chats \
-H "Authorization: Bearer $ANTHROPIC_COMPLIANCE_API_KEY"Delete
delete /v1/compliance/apps/chats/{claude_chat_id}
Permanently deletes a chat and all associated messages and files. This is a destructive operation that cannot be undone.
Path Parameters
-
claude_chat_id: stringThe chat ID (tagged ID, e.g., claude_chat_abc123)
Header Parameters
"x-api-key": optional string
Returns
-
id: stringThe ID of the Claude chat that was deleted
-
type: optional "claude_chat_deleted"Constant string confirming deletion
"claude_chat_deleted"
Example
curl https://api.anthropic.com/v1/compliance/apps/chats/$CLAUDE_CHAT_ID \
-X DELETE \
-H "Authorization: Bearer $ANTHROPIC_COMPLIANCE_API_KEY"Messages
get /v1/compliance/apps/chats/{claude_chat_id}/messages
Retrieves message history and file metadata for a specific chat.
Path Parameters
-
claude_chat_id: stringThe chat ID (tagged ID, e.g., claude_chat_abc123)
Query Parameters
-
after_id: optional stringPagination cursor for retrieving the next page of results (heading backwards in time). To paginate, pass the
last_idvalue from the most recent response. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
before_id: optional stringPagination cursor for retrieving the previous page of results (heading forwards in time). To paginate, pass the
first_idvalue from the most recent response. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
limit: optional numberMaximum results (max: 1000). When omitted, the full result set is returned in one response.
Header Parameters
"x-api-key": optional string
Returns
-
id: stringChat ID
-
chat_messages: array of object { id, artifacts, content, 4 more }Array of chat messages in order of created_at
-
id: stringUnique identifier for the message e.g. ‘claude_chat_msg_abcd1234’
-
artifacts: array of object { id, artifact_type, title, version_id }Artifacts generated or updated by this message
-
id: stringArtifact ID e.g. ‘claude_artifact_abc123’
-
artifact_type: stringMIME-like artifact type e.g. ‘application/vnd.ant.code’
-
title: stringArtifact title
-
version_id: stringArtifact version ID e.g. ‘claude_artifact_version_abc123’
-
-
content: array of object { text, type }Content blocks within the message
-
text: stringText content from human or assistant
-
type: "text""text"
-
-
created_at: stringMessage creation timestamp - For human: when they sent the message, For assistant: when it completed the last content block
-
files: array of object { id, filename, mime_type }File attachments
-
id: stringFile ID
-
filename: stringDisplay name of the file
-
mime_type: stringMIME type of the file when it was uploaded (e.g. ‘application/pdf’)
-
-
generated_files: array of object { id, filename, mime_type }Downloadable files the assistant created via tool use (e.g. PDF, spreadsheet, slide deck). Distinct from
files, which are uploads attached to the message.-
id: stringOpaque generated-file id, e.g. ‘claude_gen_file_abc123’. Treat as an opaque string; the encoding may change without notice.
-
filename: stringDisplay name of the generated file
-
mime_type: stringMIME type reported by the tool that produced the file
-
-
role: "user" or "assistant"Message sender (user or assistant)
-
"user" -
"assistant"
-
-
-
created_at: stringCreation timestamp
-
deleted_at: stringDeletion timestamp if deleted
-
first_id: stringOpaque pagination cursor for the first message in the current result set. Pass as
before_idon the next request to page backwards. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
has_more: booleanWhether more chat messages exist beyond the current result set. Use
last_idasafter_idin a follow-up request to page forward. -
href: stringURL to view this chat in claude.ai
-
last_id: stringOpaque pagination cursor for the last message in the current result set. Pass as
after_idon the next request to page forwards. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
model: stringModel selected for this chat (e.g. ‘claude-opus-4-7’). May be null for legacy chats that never had a model recorded.
-
name: stringChat name
-
organization_id: stringOrganization ID this chat belongs to
-
organization_uuid: stringOrganization UUID this chat belongs to
-
project_id: stringProject ID this chat belongs to
-
updated_at: stringLast update timestamp
-
user: object { id, email_address }User information
-
id: stringUser identifier
-
email_address: stringUser’s email address
-
Example
curl https://api.anthropic.com/v1/compliance/apps/chats/$CLAUDE_CHAT_ID/messages \
-H "Authorization: Bearer $ANTHROPIC_COMPLIANCE_API_KEY"Domain Types
Chat List Response
-
ChatListResponse = object { id, created_at, deleted_at, 8 more }Chat metadata for listing chats (without messages).
-
id: stringChat ID
-
created_at: stringCreation timestamp
-
deleted_at: stringDeletion timestamp if deleted
-
href: stringURL to view this chat in claude.ai
-
model: stringModel selected for this chat (e.g. ‘claude-opus-4-7’). May be null for legacy chats that never had a model recorded.
-
name: stringChat name/title
-
organization_id: stringOrganization ID this chat belongs to
-
organization_uuid: stringOrganization UUID this chat belongs to
-
project_id: stringProject ID this chat belongs to
-
updated_at: stringLast update timestamp
-
user: object { id, email_address }User information for the chat creator
-
id: stringUser identifier
-
email_address: stringUser’s email address
-
-
Chat Delete Response
-
ChatDeleteResponse = object { id, type }Response for deleting a Claude chat.
-
id: stringThe ID of the Claude chat that was deleted
-
type: optional "claude_chat_deleted"Constant string confirming deletion
"claude_chat_deleted"
-
Chat Messages Response
-
ChatMessagesResponse = object { id, chat_messages, created_at, 12 more }Complete chat conversation data for compliance purposes.
-
id: stringChat ID
-
chat_messages: array of object { id, artifacts, content, 4 more }Array of chat messages in order of created_at
-
id: stringUnique identifier for the message e.g. ‘claude_chat_msg_abcd1234’
-
artifacts: array of object { id, artifact_type, title, version_id }Artifacts generated or updated by this message
-
id: stringArtifact ID e.g. ‘claude_artifact_abc123’
-
artifact_type: stringMIME-like artifact type e.g. ‘application/vnd.ant.code’
-
title: stringArtifact title
-
version_id: stringArtifact version ID e.g. ‘claude_artifact_version_abc123’
-
-
content: array of object { text, type }Content blocks within the message
-
text: stringText content from human or assistant
-
type: "text""text"
-
-
created_at: stringMessage creation timestamp - For human: when they sent the message, For assistant: when it completed the last content block
-
files: array of object { id, filename, mime_type }File attachments
-
id: stringFile ID
-
filename: stringDisplay name of the file
-
mime_type: stringMIME type of the file when it was uploaded (e.g. ‘application/pdf’)
-
-
generated_files: array of object { id, filename, mime_type }Downloadable files the assistant created via tool use (e.g. PDF, spreadsheet, slide deck). Distinct from
files, which are uploads attached to the message.-
id: stringOpaque generated-file id, e.g. ‘claude_gen_file_abc123’. Treat as an opaque string; the encoding may change without notice.
-
filename: stringDisplay name of the generated file
-
mime_type: stringMIME type reported by the tool that produced the file
-
-
role: "user" or "assistant"Message sender (user or assistant)
-
"user" -
"assistant"
-
-
-
created_at: stringCreation timestamp
-
deleted_at: stringDeletion timestamp if deleted
-
first_id: stringOpaque pagination cursor for the first message in the current result set. Pass as
before_idon the next request to page backwards. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
has_more: booleanWhether more chat messages exist beyond the current result set. Use
last_idasafter_idin a follow-up request to page forward. -
href: stringURL to view this chat in claude.ai
-
last_id: stringOpaque pagination cursor for the last message in the current result set. Pass as
after_idon the next request to page forwards. Clients should treat this value as an opaque string and not attempt to parse or interpret its contents, as the format may change without notice. -
model: stringModel selected for this chat (e.g. ‘claude-opus-4-7’). May be null for legacy chats that never had a model recorded.
-
name: stringChat name
-
organization_id: stringOrganization ID this chat belongs to
-
organization_uuid: stringOrganization UUID this chat belongs to
-
project_id: stringProject ID this chat belongs to
-
updated_at: stringLast update timestamp
-
user: object { id, email_address }User information
-
id: stringUser identifier
-
email_address: stringUser’s email address
-
-
Files
Retrieve
get /v1/compliance/apps/chats/files/{claude_file_id}
Retrieves metadata for a file referenced in chat messages, without
downloading the file content. Use the sibling /content endpoint to
download the bytes.
Path Parameters
-
claude_file_id: stringThe file ID (tagged ID, e.g., claude_file_abc123)
Header Parameters
"x-api-key": optional string
Returns
-
id: stringFile ID
-
created_at: stringFile creation timestamp
-
filename: stringDisplay name of the file, if set
-
message_ids: array of stringChat message IDs this file is attached to. A file can be referenced by multiple messages.
-
mime_type: stringMIME type of the file’s preferred downloadable variant (e.g. ‘application/pdf’). May be null for files with no downloadable content (e.g. code-interpreter outputs).
-
size_bytes: numberSize in bytes of the file’s preferred downloadable variant, if known
Example
curl https://api.anthropic.com/v1/compliance/apps/chats/files/$CLAUDE_FILE_ID \
-H "Authorization: Bearer $ANTHROPIC_COMPLIANCE_API_KEY"Delete
delete /v1/compliance/apps/chats/files/{claude_file_id}
Permanently deletes a specific file. This is a destructive operation that cannot be undone.
Path Parameters
-
claude_file_id: stringThe file ID (tagged ID, e.g., claude_file_abc123)
Header Parameters
"x-api-key": optional string
Returns
-
id: stringThe ID of the file that was deleted
-
type: optional "claude_file_deleted"Constant string confirming deletion
"claude_file_deleted"
Example
curl https://api.anthropic.com/v1/compliance/apps/chats/files/$CLAUDE_FILE_ID \
-X DELETE \
-H "Authorization: Bearer $ANTHROPIC_COMPLIANCE_API_KEY"Content
get /v1/compliance/apps/chats/files/{claude_file_id}/content
Downloads the binary content of a file referenced in chat messages.
Path Parameters
-
claude_file_id: stringThe file ID (tagged ID, e.g., claude_file_abc123)
Header Parameters
"x-api-key": optional string
Example
curl https://api.anthropic.com/v1/compliance/apps/chats/files/$CLAUDE_FILE_ID/content \
-H "Authorization: Bearer $ANTHROPIC_COMPLIANCE_API_KEY"Domain Types
File Retrieve Response
-
FileRetrieveResponse = object { id, created_at, filename, 3 more }File metadata for GET /v1/compliance/apps/chats/files/{claude_file_id}.
Returns metadata only. Use the sibling
/contentendpoint to download the file bytes.-
id: stringFile ID
-
created_at: stringFile creation timestamp
-
filename: stringDisplay name of the file, if set
-
message_ids: array of stringChat message IDs this file is attached to. A file can be referenced by multiple messages.
-
mime_type: stringMIME type of the file’s preferred downloadable variant (e.g. ‘application/pdf’). May be null for files with no downloadable content (e.g. code-interpreter outputs).
-
size_bytes: numberSize in bytes of the file’s preferred downloadable variant, if known
-
File Delete Response
-
FileDeleteResponse = object { id, type }Response for deleting a compliance file.
-
id: stringThe ID of the file that was deleted
-
type: optional "claude_file_deleted"Constant string confirming deletion
"claude_file_deleted"
-
File Content Response
FileContentResponse = unknown
Generated Files
Content
get /v1/compliance/apps/chats/generated-files/{claude_gen_file_id}/content
Downloads the binary content of a file the assistant created via tool use.
Path Parameters
-
claude_gen_file_id: stringThe generated-file id (e.g., ‘claude_gen_file_abc123’) as returned in
chat_messages[].generated_files[].idfrom GET /apps/chats/{claude_chat_id}/messages.
Header Parameters
"x-api-key": optional string
Example
curl https://api.anthropic.com/v1/compliance/apps/chats/generated-files/$CLAUDE_GEN_FILE_ID/content \
-H "Authorization: Bearer $ANTHROPIC_COMPLIANCE_API_KEY"Domain Types
Generated File Content Response
GeneratedFileContentResponse = unknown
Liên kết
- Nền tảng: Dev Framework · Anthropic
- Nguồn: https://platform.claude.com/docs/en/api/compliance/apps/chats.md
Xem thêm: