save_business_profile

Google Ads Write

๐Ÿšจ **IF THIS TOOL RETURNS A QUOTA ERROR:** - The error message will include a clickable upgrade link - Show the FULL error message to the user (it contains the upgrade link) - DO NOT attempt to work ar

Endpoint

POST https://api.adspirer.ai/api/v1/tools/save_business_profile/execute

Headers

Description

๐Ÿšจ **IF THIS TOOL RETURNS A QUOTA ERROR:** - The error message will include a clickable upgrade link - Show the FULL error message to the user (it contains the upgrade link) - DO NOT attempt to work around the error or use alternative data - DO NOT create campaigns or perform actions without valid tool data - STOP and direct the user to upgrade via the provided link Save or update the user's business profile with provided details. โš ๏ธ IMPORTANT: This tool WRITES data. Use when user confirms their business profile. ๐ŸŽฏ **What This Tool Does (Performance Agent - Phase 1 Feature 5):** - Saves user's business profile to database - Updates existing profile if one exists - Sets profile source as 'user_confirmed' or 'user_mcp' - Enables personalized recommendations going forward **Required Parameters:** - **business_vertical**: retail, services, technology, healthcare, finance, education, travel, food_beverage, automotive, real_estate - **business_size**: small (<$50K/month), medium ($50K-$500K/month), large (>$500K/month) - **primary_goal**: leads, sales, awareness, traffic, engagement, app_installs **Optional Parameters:** - **target_audience**: Free-text description (e.g., "B2B enterprise clients") - **geographic_focus**: local, regional, national, international - **seasonality**: none, holiday_heavy, summer_peak, winter_peak, q4_heavy, back_to_school - **customer_id**: Optional (uses connected account if omitted) **Use this tool when:** - User provides their business details - User confirms an inferred profile - User wants to update their business profile - After asking user clarifying questions about their business **Example Usage:** User: "I run a small local plumbing business targeting homeowners" โ†’ Call save_business_profile with: - business_vertical: "services" - business_size: "small" - primary_goal: "leads" - target_audience: "homeowners" - geographic_focus: "local" **Execution time:** 1-2 seconds (database write)

Request body

All tool arguments are wrapped in an arguments object.

FieldTypeDescription
business_verticalstring requiredBusiness vertical (e.g., 'retail', 'services', 'technology', 'healthcare', 'finance', 'education', 'travel', 'food_beverage', 'automotive', 'real_estate')
business_sizestring requiredBusiness size: 'small' (<$50K/month ad spend), 'medium' ($50K-$500K/month), 'large' (>$500K/month)
primary_goalstring requiredPrimary advertising goal: 'leads', 'sales', 'awareness', 'traffic', 'engagement', 'app_installs'
target_audiencestring optionalTarget audience description (e.g., 'B2B enterprise clients', 'young professionals 25-35')
geographic_focusstring optionalGeographic focus: 'local', 'regional', 'national', 'international'
seasonalitystring optionalSeasonality pattern: 'none', 'holiday_heavy', 'summer_peak', 'winter_peak', 'q4_heavy', 'back_to_school'
customer_idstring optionalGoogle Ads customer ID. Required for multi-account users. Get from list_connected_accounts.

Example request

{
  "arguments": {
    "business_vertical": "string",
    "business_size": "string",
    "primary_goal": "string",
    "target_audience": "string",
    "geographic_focus": "string",
    "seasonality": "string",
    "customer_id": "string"
  }
}

Example responses

200 โ€” Success

{
  "success": true,
  "data": {
    "text": "(tool-specific textual output for save_business_profile)",
    "quota": {
      "used": 42,
      "limit": 150,
      "tier": "plus",
      "period_end": "2026-05-01"
    }
  },
  "tool": "save_business_profile"
}

400 โ€” Tool-level error (bad arguments / multi-account selection)

{
  "success": false,
  "error": "You have 25 meta_ads accounts connected. Please specify which account to use by passing the ad_account_id parameter:\n  - Acme Holdings (ad_account_id=\"act_123456789\")\n  - Acme EU (ad_account_id=\"act_987654321\")",
  "is_error": true,
  "tool": "save_business_profile"
}

402 โ€” Quota exhausted

{
  "success": false,
  "error": "\ud83d\udea8 Monthly limit reached (150/150 tool calls on Plus tier).\nUpgrade to Pro at https://adspirer.ai to keep building.",
  "is_error": true,
  "tool": "save_business_profile",
  "quota": {
    "used": 150,
    "limit": 150,
    "tier": "plus",
    "period_end": "2026-05-01",
    "upgrade_url": "https://adspirer.ai"
  }
}

Try it live


Adspirer REST API โ€” get an API key at adspirer.ai/keys ยท adspirer.ai