{
  "openapi": "3.1.0",
  "info": {
    "title": "ChiefMO API",
    "version": "0.1.0",
    "description": "ChiefMO turns marketing goals into reviewable runs, assets, connector-backed evidence, and approval-ready actions."
  },
  "servers": [
    {
      "url": "https://agent.chiefmo.io"
    }
  ],
  "security": [
    {
      "bearerAuth": []
    }
  ],
  "paths": {
    "/api/health": {
      "get": {
        "summary": "Check API health",
        "security": [],
        "responses": {
          "200": {
            "description": "API health status"
          }
        }
      }
    },
    "/api/config": {
      "get": {
        "summary": "Read public client config",
        "security": [],
        "responses": {
          "200": {
            "description": "Public app configuration"
          }
        }
      }
    },
    "/api/me": {
      "get": {
        "summary": "Read current user and workspace context",
        "responses": {
          "200": {
            "description": "Authenticated user and workspace"
          }
        }
      }
    },
    "/api/runs": {
      "get": {
        "summary": "List ChiefMO runs",
        "responses": {
          "200": {
            "description": "Recent runs"
          }
        }
      },
      "post": {
        "summary": "Create a reviewable marketing run",
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "type": "object",
                "properties": {
                  "goal": {
                    "type": "string"
                  },
                  "workspaceId": {
                    "type": "string"
                  },
                  "projectId": {
                    "type": "string"
                  }
                },
                "required": ["goal"]
              }
            }
          }
        },
        "responses": {
          "200": {
            "description": "Created ChiefMO run"
          }
        }
      }
    },
    "/api/runs/{id}": {
      "get": {
        "summary": "Get a run",
        "parameters": [
          {
            "name": "id",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Run details"
          }
        }
      }
    },
    "/api/runs/{id}/approve": {
      "post": {
        "summary": "Approve a run",
        "parameters": [
          {
            "name": "id",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Approved run"
          }
        }
      }
    },
    "/api/runs/{id}/reject": {
      "post": {
        "summary": "Reject a run",
        "parameters": [
          {
            "name": "id",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Rejected run"
          }
        }
      }
    },
    "/api/assets": {
      "get": {
        "summary": "List generated assets",
        "parameters": [
          {
            "name": "runId",
            "in": "query",
            "required": false,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Generated assets"
          }
        }
      }
    },
    "/api/actions": {
      "get": {
        "summary": "List proposed actions",
        "parameters": [
          {
            "name": "runId",
            "in": "query",
            "required": false,
            "schema": {
              "type": "string"
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Proposed actions"
          }
        }
      }
    },
    "/api/connectors": {
      "get": {
        "summary": "List connector status",
        "responses": {
          "200": {
            "description": "Marketing connector catalog and connection status"
          }
        }
      }
    },
    "/api/connectors/{provider}/oauth/start": {
      "post": {
        "summary": "Start connector OAuth",
        "parameters": [
          {
            "name": "provider",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string",
              "enum": ["google_search_console", "google_analytics", "google_ads"]
            }
          }
        ],
        "responses": {
          "200": {
            "description": "OAuth authorization URL"
          }
        }
      }
    },
    "/api/connectors/{provider}/snapshot": {
      "post": {
        "summary": "Read a connector snapshot",
        "description": "Returns live evidence when the connector is connected. Write-capable connectors still require approval before external action.",
        "parameters": [
          {
            "name": "provider",
            "in": "path",
            "required": true,
            "schema": {
              "type": "string",
              "enum": ["google_search_console", "google_analytics", "google_ads", "meta_ads", "buffer"]
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Connector snapshot or setup guidance"
          }
        }
      }
    },
    "/api/agent/message": {
      "post": {
        "summary": "Send a message to the ChiefMO agent",
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "type": "object",
                "properties": {
                  "message": {
                    "type": "string"
                  }
                },
                "required": ["message"]
              }
            }
          }
        },
        "responses": {
          "200": {
            "description": "Agent response"
          }
        }
      }
    },
    "/api/usage": {
      "get": {
        "summary": "Read usage and cost guardrail data",
        "responses": {
          "200": {
            "description": "Usage data"
          }
        }
      }
    },
    "/api/audit-logs": {
      "get": {
        "summary": "Read audit logs",
        "responses": {
          "200": {
            "description": "Workspace audit logs"
          }
        }
      }
    }
  },
  "components": {
    "securitySchemes": {
      "bearerAuth": {
        "type": "http",
        "scheme": "bearer",
        "bearerFormat": "JWT"
      }
    }
  }
}
