Overview
By the end of this guide you will have:- Confirmed your buyer account and accepted the platform Terms of Service.
- Created an advertiser, linked to a brand identity.
- Configured measurement and (optionally) registered event sources for performance optimization.
- Run a discovery to find products that match your brief.
- Created, executed, and monitored your first campaign.
Prefer to drive everything through an AI agent? You can do every step below by talking to a connected MCP agent (Claude, ChatGPT, Cursor) — the agent will call these endpoints for you. See the Quick Start for connector setup.
Prerequisites
Pick how you’ll authenticate
Pick one — you don’t need both.OAuth (recommended for AI agents)
Connecting through Claude (Team/Enterprise/Desktop), ChatGPT MCP Connectors, or any OAuth-aware AI tool. Auth is handled automatically via the connector — no API key to manage. See Built for Agents for connector setup.
API key
Required only for CLI tools, Cursor, custom MCP/HTTP clients, or programmatic backend integrations. Generate at agentic.scope3.com/user-api-keys; keys start with
scope3_. See Authentication for full details.curl examples with Authorization: Bearer $SCOPE3_API_KEY. If you’re using OAuth via Claude/ChatGPT, replace each step with the equivalent natural-language prompt — the connected agent will call the same endpoints for you.
Optional
SSO
If your organization uses SAML SSO, ask your admin to configure it via the SSO Setup guide before inviting team members.
Private storefront credentials
Some storefronts gate inventory behind per-source credentials (API key, OAuth, JWT). Register those at the storefront-source level — see the Storefront object guide for the walkthrough.
End-to-End Flow
Step 1: Confirm your account
Verify the API key resolves to the customer (account) you expect. The current account is the “seat” that will own the advertisers and campaigns you create.Response:
Step 2: Accept the Terms of Service
If your customer record does not yet have an active contract, the API will block writes until the latest Platform Service Agreement is accepted. Accept it once per customer:
Discovering the current
psaVersion: use the psaVersion returned in the TOS_ACCEPTANCE_REQUIRED error response from any blocked write, or check the most recent agreement posted at scope3.com.After acceptance, writes unblock immediately on the next request — no token refresh or re-auth is needed. If you signed up through the web app at agentic.scope3.com you have likely already accepted ToS and this step will be a no-op.
Step 3: Create an advertiser
An advertiser is the top-level container for campaigns. It carries brand identity, default optimization mode, default budget type, and (optionally) UTM parameters and frequency caps that flow down to its campaigns.Key fields:
| Field | Description |
|---|---|
name | Display name for the advertiser (1–255 chars). |
brand | Domain (e.g. acme.com) or full manifest URL. Identity is resolved from /.well-known/brand.json or the AdCP brand registry. |
optimizationApplyMode | AUTO applies Scope3 AI optimizations automatically; MANUAL requires approval. Defaults to MANUAL. |
campaignBudgetType | total_budget — the campaign budget covers media spend and Scope3 fees. |
sandbox | When true, all downstream ADCP calls run against sandbox-flagged accounts — no real spend. Immutable after creation. |
linkedAccounts | Optional partner-platform accounts to link at creation (e.g. Snap, Google). |
utmConfig | Default UTM parameters appended to landing-page redirects. |
frequencyCaps | Buyer-side frequency caps Scope3 enforces across publishers. |
Step 4: Configure measurement (recommended)
Measurement configuration lives on the advertiser and is shared across all of its campaigns. You can opt into MMM, incrementality testing, brand lift, and other measurement programs.To optimize campaigns against your own conversion events, register one or more event sources for the advertiser. This pushes ADCP-spec event source definitions into Scope3:Once registered, an event source can be referenced from a campaign’s
Each event source must include a buyer-assigned
event_source_id (1–255 chars). You’ll reference it later when sending conversion events via the Conversion API.performanceConfig.optimizationGoals to drive bid optimization.Full conversion-tagging and measurement setup is covered in the Measurement guide.
Step 5: Discover products
Discovery turns a natural-language brief and budget into a session of candidate products from every reachable sales agent.The response contains a
discoveryId (e.g. disc_abc123), grouped products (e.g. prod_xyz789), agent results, and (optionally) curated proposals you can apply directly to a campaign.The full discovery workflow — refinement, proposals, manual product selection — is covered in the Discovery guide.Step 6: Create your first campaign
A campaign references an advertiser and a (preselected) discovery session. The minimum required fields are Response:Capture the
The campaign is created in
advertiserId, name, flightDates, budget, and campaignType.campaignId from the response — we’ll use this cmp_* id in Steps 7–8.Key choices:| Field | Notes |
|---|---|
campaignType | DECISIONED — Scope3 optimizes media buys. ROUTED — pass-through to the sales agent using your linked credentials. Immutable after creation. |
discoveryId + productIds | Attach a discovery session and pre-select products. Optional but typical. |
performanceConfig | Add optimization goals tied to event sources or pacing metrics. |
pacingPeriods | Time-based pacing schedule with weight or fixed budget per period. |
audienceConfig | Target / suppress audience IDs from the signals catalog. |
DRAFT status — nothing has been sent to a sales agent yet.Step 7: Add creatives
Before a campaign can launch, every product format selected on the campaign needs at least one creative that satisfies it. The creative endpoint is a single multipart request — a JSON Inspecting
metadata field plus one or more files parts:GET /api/buyer/campaigns/:id returns a creativeFormats summary so you can see which formats are still missing creatives before launch. See the Creatives guide for the full lifecycle.Step 8: Execute the campaign
Executing a campaign sends media-buy requests to every selected sales agent and transitions the campaign from Response:If any media buys fail at the sales agent,
DRAFT to ACTIVE.success is false and errors[] lists the per-buy failures. After fixing the issue, you can re-run POST /api/buyer/campaigns/:id/execute while the campaign is still DRAFT.execute and reactivate are different endpoints. Use POST /api/buyer/campaigns/:id/execute to launch a DRAFT (or COMPLETED) campaign. To resume a PAUSED campaign, use POST /api/buyer/campaigns/:id/reactivate instead.Monitoring
Once a campaign isACTIVE, poll the live status of its media buys:
Sandbox Testing
Setsandbox: true when creating an advertiser to run the entire flow above with no real spend. All downstream ADCP calls are tagged sandbox and routed to test accounts on the storefront’s inventory sources. Sandbox mode is immutable after creation — you cannot promote a sandbox advertiser to production.
See Sandbox mode for the full sandbox capability matrix.
Next Steps
Advertiser object
Linked accounts, brand resolution, UTM templates, and frequency caps.
Campaign object
Performance config, pacing, audience targeting, and execution lifecycle.
Discovery workflow
Briefs, refinement, proposals, and product selection.
Measurement workflow
Conversion events, MMM, incrementality, and brand lift.
Reporting
Delivery, pacing, spend, and performance reporting endpoints.
Storefronts
Browse storefronts and connect credentials per inventory source.