{ "openapi": "3.0.2", "info": { "title": "Klaviyo API (Beta)", "version": "2026-04-15.pre", "description": "The Klaviyo REST API. Please visit https://developers.klaviyo.com for more details.", "contact": { "name": "Klaviyo Developer Experience Team", "email": "developers@klaviyo.com", "url": "https://developers.klaviyo.com" }, "termsOfService": "https://www.klaviyo.com/legal/api-terms", "license": { "name": "License", "url": "https://www.klaviyo.com/legal" } }, "servers": [ { "url": "https://a.klaviyo.com", "description": "Production" } ], "security": [ { "Klaviyo-API-Key": [] } ], "paths": { "/api/object-schemas/{id}/relationships/profile-object-schemas": { "post": { "operationId": "create_profile_schema_relationship_beta", "summary": "Create Profile Schema Relationship", "description": "\n > \ud83d\udea7 This endpoint is in beta and subject to change.\n >\n > A beta revision header (2026-01-15.pre) is required to use our beta APIs. Klaviyo APIs in beta are not intended for use in production. See our [versioning and deprecation policy](https://developers.klaviyo.com/en/docs/api_versioning_and_deprecation_policy) for more information.\n\nCreate a relationship between an object schema and a profile

*Rate limits*:
Burst: `3/s`
Steady: `60/m`\n\n**Scopes:**\n`custom-objects:write`\n\n[OpenAPI Spec](https://raw.githubusercontent.com/klaviyo/openapi/main/openapi/beta/apis/create_profile_schema_relationship_beta.json)", "parameters": [ { "name": "id", "in": "path", "description": "The ULID ID of the object schema.", "required": true, "schema": { "description": "The ULID ID of the object schema.", "type": "string", "example": "01K61DKJ7EKJ0ES9VE456XF5JG" } }, { "name": "revision", "in": "header", "description": "API endpoint revision (format: YYYY-MM-DD[.suffix])", "required": true, "schema": { "type": "string", "default": "2026-01-15.pre" } } ], "requestBody": { "description": "Create a relationship between an object schema and a profile.", "required": true, "content": { "application/vnd.api+json": { "schema": { "$ref": "#/components/schemas/ProfileObjectSchemaRelationshipCreateQuery" } } } }, "responses": { "204": { "description": "Success" }, "4XX": { "$ref": "#/components/responses/ClientError" }, "5XX": { "$ref": "#/components/responses/ServerError" } }, "tags": [ "Beta APIs" ], "x-klaviyo-operation-aliases": [ "add_profile_object_schemas_to_object_schema", "create_object_schema_relationships_profile_object_schemas" ], "x-klaviyo-pre-release": "BETA", "x-klaviyo-ratelimit": { "burst": "3/s", "steady": "60/m" }, "x-klaviyo-scopes": [ "custom-objects:write" ], "x-klaviyo-subtag": "Custom Objects" } } }, "components": { "responses": { "ClientError": { "description": "Client Error", "content": { "application/vnd.api+json": { "schema": { "type": "object", "properties": { "errors": { "type": "array", "items": { "type": "object", "required": [ "id", "code", "title", "detail" ], "properties": { "id": { "type": "string" }, "code": { "type": "string" }, "title": { "type": "string" }, "detail": { "type": "string" }, "source": { "type": "object", "properties": { "pointer": { "type": "string" }, "parameter": { "type": "string" } } } } } } }, "required": [ "errors" ] } } } }, "ServerError": { "description": "Server Error", "content": { "application/vnd.api+json": { "schema": { "type": "object", "properties": { "errors": { "type": "array", "items": { "type": "object", "required": [ "id", "code", "title", "detail" ], "properties": { "id": { "type": "string" }, "code": { "type": "string" }, "title": { "type": "string" }, "detail": { "type": "string" }, "source": { "type": "object", "properties": { "pointer": { "type": "string" }, "parameter": { "type": "string" } } } } } } }, "required": [ "errors" ] } } } } }, "schemas": { "ObjectSchemaRelationshipCreateMeta": { "type": "object", "properties": { "name": { "description": "The name of the relationship", "type": "string", "example": "related_items" }, "description": { "description": "The description of the relationship", "type": "string", "example": "Items related to this schema", "default": "", "nullable": true } }, "required": [ "name" ] }, "ProfileObjectSchemaEnum": { "type": "string", "enum": [ "profile-object-schema" ] }, "ProfileObjectSchemaRelationshipCreateQuery": { "type": "object", "properties": { "data": { "type": "array", "items": { "type": "object", "required": [ "type", "id" ], "properties": { "type": { "$ref": "#/components/schemas/ProfileObjectSchemaEnum" }, "id": { "description": "The ID of the profile schema. The profile schema does not exist as a persisted resource, so this value is always \"profile\".", "type": "string", "example": "profile" }, "meta": { "$ref": "#/components/schemas/ObjectSchemaRelationshipCreateMeta", "nullable": true } } } } }, "required": [ "data" ] } }, "securitySchemes": { "Klaviyo-API-Key": { "type": "apiKey", "in": "header", "name": "Authorization", "description": "Private key authentication for /api/ endpoints is performed by setting the `Authorization` header to `Klaviyo-API-Key your-private-api-key`
For more information please visit https://developers.klaviyo.com/en/v2026-04-15.pre/reference/api-overview#authentication", "x-default": "Klaviyo-API-Key your-private-api-key" } } }, "tags": [ { "name": "Beta APIs", "description": "beta apis" } ] }