AdCP 3.0 Proposal - This specification is under development for AdCP 3.0. Feedback welcome via GitHub Discussions.
Abstract
The Creative Protocol defines a standard interface for creative format discovery, manifest validation, creative generation, and preview rendering. This protocol enables AI agents to discover format specifications, build compliant creative assets, and generate previews across advertising platforms.Protocol Overview
The Creative Protocol provides:- Format discovery with full technical specifications
- Manifest validation against format requirements
- AI-powered creative generation and transformation
- Preview rendering for creative verification
- Universal macros for cross-platform tracking
Transport Requirements
Creative agents MUST support at least one of the following transports:| Transport | Protocol | Description |
|---|---|---|
| MCP | Model Context Protocol | Tool-based interaction via JSON-RPC |
| A2A | Agent-to-Agent | Message-based interaction |
get_adcp_capabilities:
Core Concepts
Creative Agents
Creative agents are authoritative sources for format definitions. A creative agent:- Defines and documents formats it owns
- Validates manifests against format requirements
- Generates previews showing how creatives will render
- Optionally generates or transforms creatives from natural language briefs
Format Authority
Each format has exactly one authoritative creative agent, identified by theagent_url in the format ID:
Formats
Formats define how assets are assembled and rendered. A format specifies:- Media family (display, video, audio, dooh)
- Required and optional asset types
- Technical constraints (dimensions, duration, file size, codecs)
- Rendering behavior and interaction expectations
Assets
Assets are the building blocks of creatives. Asset types include:- image: Static images (JPEG, PNG, WebP, GIF)
- video: Video files (MP4, WebM, MOV) or VAST tags
- audio: Audio files (MP3, M4A) or DAAST tags
- text: Headlines, descriptions, CTAs
- html: HTML5 creatives or third-party tags
- javascript: JavaScript tags
- url: Tracking pixels, clickthrough URLs
Manifests
Manifests pair format specifications with actual asset content. A manifest provides:- Format reference (agent_url + id)
- Asset values keyed by asset_id from the format
- Tracking URLs and macros
Universal Macros
AdCP defines universal macros for cross-platform tracking. Creative agents MUST support these macros in tracking URLs:{TIMESTAMP}: Unix timestamp{CACHEBUSTER}: Random cache-busting value{CLICK_URL}: Click tracking URL{REDIRECT_URL}: Final destination URL
Tasks
The Creative Protocol defines three tasks. See task reference pages for complete request/response schemas and examples.list_creative_formats
Reference:list_creative_formats task
Discover creative formats and their specifications.
Requirements:
- Creative agents MUST return full format specifications for formats they own
- Creative agents MUST include
agent_urlidentifying the authoritative agent for each format - Creative agents MUST include technical constraints (dimensions, duration, file types) in format definitions
- Creative agents MAY include references to other creative agents providing additional formats
- When filtering by
format_ids, creative agents MUST return only the requested formats
build_creative
Reference:build_creative task
Transform or generate creative manifests.
Requirements:
- Creative agents MUST validate input manifests against format requirements
- Creative agents MUST return a valid manifest for the target format on success
- Creative agents MUST return validation errors if the transformation cannot be completed
- Creative agents SHOULD preserve tracking URLs and macros during transformation
- Creative agents MAY use AI/LLM processing for generation tasks
preview_creative
Reference:preview_creative task
Generate preview renderings of creative manifests.
Requirements:
- Creative agents MUST validate manifests before generating previews
- Creative agents MUST return preview URLs or HTML for valid manifests
- Creative agents MUST include
expires_atfor preview URLs - Creative agents SHOULD support batch preview for multiple creatives
- Creative agents MAY support multiple output formats (URL, HTML, image)
Error Handling
Creative agents MUST return errors using the standard AdCP error schema. Common error codes:FORMAT_NOT_FOUND: Requested format does not existVALIDATION_ERROR: Manifest failed format validationASSET_MISSING: Required asset not provided in manifestASSET_INVALID: Asset does not meet format constraintsGENERATION_FAILED: Creative generation could not be completed
Security Considerations
Transport Security
All Creative Protocol communications MUST use HTTPS with TLS 1.2 or higher.Asset Security
- Creative agents SHOULD validate that asset URLs are accessible
- Creative agents SHOULD scan assets for malware and malicious content
- Creative agents MUST NOT execute untrusted JavaScript during validation
Preview Security
- Preview URLs SHOULD be time-limited (indicated by
expires_at) - Creative agents SHOULD sandbox HTML previews to prevent script execution
- Consumers of
output_format: "html"MUST only use trusted creative agents
Conformance
Creative Agent Conformance
A conformant Creative Protocol agent MUST:- Support at least one specified transport (MCP or A2A)
- Implement
list_creative_formatsfor format discovery - Return authoritative format definitions only for formats it owns
- Validate manifests against format specifications
- Use specified error codes
- Implement
build_creativefor creative generation - Implement
preview_creativefor preview rendering - Support universal macros in tracking URLs
Consumer Conformance
A conformant Creative Protocol consumer MUST:- Use the
agent_urlfrom format IDs to identify the authoritative creative agent - Validate manifests against format specifications before submission
- Handle validation errors appropriately
- Track visited URLs when recursively discovering formats to avoid infinite loops
Implementation Notes
Response Time Expectations
Creative agents SHOULD target the following response times:| Operation Type | Target Latency |
|---|---|
| Format listing (list_creative_formats) | < 1 second |
| Preview generation (preview_creative) | < 5 seconds |
| Batch preview (10 creatives) | < 10 seconds |
| Creative generation (build_creative) | < 60 seconds |
Recursive Format Discovery
Creative agents MAY reference other creative agents in theirlist_creative_formats response:
Format-Aware Validation
Manifest validation MUST be performed in the context of the format specification:- Look up the format definition from the authoritative creative agent
- For each asset in the manifest, find the corresponding entry in the format’s
assetsarray - Validate the asset value against the type and constraints defined in the format
Standard vs Custom Formats
- Standard formats: Based on IAB specifications, hosted by the reference creative agent (
https://creative.adcontextprotocol.org) - Custom formats: Defined by individual publishers or creative platforms for specialized inventory
agent_url field identifies which agent is authoritative for each format.
Schema Reference
| Schema | Description |
|---|---|
core/format.json | Format definition |
core/creative-manifest.json | Creative manifest |
core/creative-asset.json | Asset definition |
media-buy/list-creative-formats-request.json | list_creative_formats request |
media-buy/list-creative-formats-response.json | list_creative_formats response |