2.0 KiB
2.0 KiB
Attio Routing Reference
App name: attio
Base URL proxied: api.attio.com
API Path Pattern
/attio/v2/{resource}
Common Endpoints
List Objects
GET /attio/v2/objects
Get Object
GET /attio/v2/objects/{object}
List Attributes
GET /attio/v2/objects/{object}/attributes
Query Records
POST /attio/v2/objects/{object}/records/query
Content-Type: application/json
{
"limit": 50,
"offset": 0
}
Get Record
GET /attio/v2/objects/{object}/records/{record_id}
Create Record
POST /attio/v2/objects/{object}/records
Content-Type: application/json
{
"data": {
"values": {
"name": [{"first_name": "John", "last_name": "Doe", "full_name": "John Doe"}],
"email_addresses": ["john@example.com"]
}
}
}
Update Record
PATCH /attio/v2/objects/{object}/records/{record_id}
Content-Type: application/json
{
"data": {
"values": {
"job_title": "Engineer"
}
}
}
Delete Record
DELETE /attio/v2/objects/{object}/records/{record_id}
List Tasks
GET /attio/v2/tasks?limit=50
Create Task
POST /attio/v2/tasks
Content-Type: application/json
{
"data": {
"content": "Task description",
"format": "plaintext",
"assignees": [],
"linked_records": []
}
}
List Workspace Members
GET /attio/v2/workspace_members
Identify Self
GET /attio/v2/self
Notes
- Object slugs are lowercase snake_case (e.g.,
people,companies) - Record IDs are UUIDs
- For personal-name attributes, include
full_namewhen creating records - Task creation requires
formatandassigneesfields - Rate limits: 100 read/sec, 25 write/sec
- Pagination uses
limitandoffsetparameters