Skip to main content

Pinterest

The Pinterest agent connector is a Python package that equips AI agents to interact with Pinterest through strongly typed, well-documented tools. It's ready to use directly in your Python app, in an agent framework, or exposed through an MCP.

Connector for the Pinterest API v5, enabling access to Pinterest advertising and content management data. Supports reading ad accounts, boards, campaigns, ad groups, ads, board sections, board pins, catalogs, catalog feeds, catalog product groups, audiences, conversion tags, customer lists, and keywords.

Example questions

The Pinterest connector is optimized to handle prompts like these.

  • List all my Pinterest ad accounts
  • List all my Pinterest boards
  • Show me all campaigns in my ad account
  • List all ads in my ad account
  • Show me all ad groups in my ad account
  • List all audiences for my ad account
  • Show me my catalog feeds
  • Which campaigns are currently active?
  • What are the top boards by pin count?
  • Show me ads that have been rejected
  • Find campaigns with the highest daily spend cap

Unsupported questions

The Pinterest connector isn't currently able to handle prompts like these.

  • Create a new Pinterest board
  • Update a campaign budget
  • Delete an ad group
  • Post a new pin
  • Show me campaign analytics or performance metrics

Installation

uv pip install airbyte-agent-pinterest

Usage

Connectors can run in open source or hosted mode.

Open source

In open source mode, you provide API credentials directly to the connector.

from airbyte_agent_pinterest import PinterestConnector
from airbyte_agent_pinterest.models import PinterestAuthConfig

connector = PinterestConnector(
auth_config=PinterestAuthConfig(
refresh_token="<Pinterest OAuth2 refresh token.>",
client_id="<Pinterest OAuth2 client ID.>",
client_secret="<Pinterest OAuth2 client secret.>"
)
)

@agent.tool_plain # assumes you're using Pydantic AI
@PinterestConnector.tool_utils
async def pinterest_execute(entity: str, action: str, params: dict | None = None):
return await connector.execute(entity, action, params or {})

Hosted

In hosted mode, API credentials are stored securely in Airbyte Cloud. You provide your Airbyte credentials instead. If your Airbyte client can access multiple organizations, also set organization_id.

This example assumes you've already authenticated your connector with Airbyte. See Authentication to learn more about authenticating. If you need a step-by-step guide, see the hosted execution tutorial.

from airbyte_agent_pinterest import PinterestConnector, AirbyteAuthConfig

connector = PinterestConnector(
auth_config=AirbyteAuthConfig(
customer_name="<your_customer_name>",
organization_id="<your_organization_id>", # Optional for multi-org clients
airbyte_client_id="<your-client-id>",
airbyte_client_secret="<your-client-secret>"
)
)

@agent.tool_plain # assumes you're using Pydantic AI
@PinterestConnector.tool_utils
async def pinterest_execute(entity: str, action: str, params: dict | None = None):
return await connector.execute(entity, action, params or {})

Full documentation

Entities and actions

This connector supports the following entities and actions. For more details, see this connector's full reference documentation.

EntityActions
Ad AccountsList, Get, Search
BoardsList, Get, Search
CampaignsList, Search
Ad GroupsList, Search
AdsList, Search
Board SectionsList, Search
Board PinsList, Search
CatalogsList, Search
Catalogs FeedsList, Search
Catalogs Product GroupsList, Search
AudiencesList, Search
Conversion TagsList, Search
Customer ListsList, Search
KeywordsList, Search

Authentication

For all authentication options, see the connector's authentication documentation.

Pinterest API docs

See the official Pinterest API reference.

Version information

  • Package version: 0.1.0
  • Connector version: 0.1.1
  • Generated with Connector SDK commit SHA: 4b20ee21004f24a2a47a27bfb70eae1b0fe1656c
  • Changelog: View changelog