{
  "openapi": "3.1.0",
  "info": {
    "title": "Qyvora Public Storefront API",
    "version": "1.0.0",
    "description": "Read-only and assistant endpoints for catalog discovery, reviews, shipping offices, and Alfret (Qyvora Assistant). Write endpoints are rate-limited; browser checkout and account APIs require a session. Agent-native commerce (MPP/ACP/UCP) is documented at /openapi.json."
  },
  "servers": [
    {
      "url": "https://qyvora.store"
    }
  ],
  "externalDocs": {
    "description": "Agent commerce API (MPP payment discovery)",
    "url": "https://qyvora.store/openapi.json"
  },
  "paths": {
    "/api/health": {
      "get": {
        "summary": "Service health",
        "operationId": "getHealth",
        "responses": {
          "200": {
            "description": "Liveness payload"
          }
        }
      }
    },
    "/api/catalog/reels": {
      "get": {
        "summary": "Product reel feed",
        "operationId": "listCatalogReels",
        "responses": {
          "200": {
            "description": "Reel metadata for catalog products"
          }
        }
      }
    },
    "/api/reviews": {
      "get": {
        "summary": "Approved product reviews",
        "operationId": "listReviews",
        "parameters": [
          {
            "name": "slug",
            "in": "query",
            "schema": {
              "type": "string"
            },
            "description": "Optional product slug filter"
          }
        ],
        "responses": {
          "200": {
            "description": "Review list"
          }
        }
      }
    },
    "/api/shipping/offices": {
      "get": {
        "summary": "Courier office locations",
        "operationId": "listShippingOffices",
        "parameters": [
          {
            "name": "carrier",
            "in": "query",
            "required": true,
            "schema": {
              "type": "string",
              "enum": [
                "econt",
                "speedy"
              ]
            }
          }
        ],
        "responses": {
          "200": {
            "description": "Office list"
          }
        }
      }
    },
    "/api/assistant/voice-status": {
      "get": {
        "summary": "Assistant voice (TTS/STT) availability",
        "operationId": "getAssistantVoiceStatus",
        "responses": {
          "200": {
            "description": "Capability flags"
          }
        }
      }
    },
    "/api/assistant/chat": {
      "post": {
        "summary": "Alfret assistant chat (streaming)",
        "operationId": "postAssistantChat",
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "type": "object",
                "required": [
                  "messages"
                ],
                "properties": {
                  "messages": {
                    "type": "array",
                    "items": {
                      "type": "object",
                      "required": [
                        "role",
                        "content"
                      ],
                      "properties": {
                        "role": {
                          "type": "string",
                          "enum": [
                            "user",
                            "assistant"
                          ]
                        },
                        "content": {
                          "type": "string"
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "responses": {
          "200": {
            "description": "Streaming assistant response"
          }
        }
      }
    },
    "/api/assistant/perfume-suggest": {
      "post": {
        "summary": "Perfume recommendations from catalog",
        "operationId": "postPerfumeSuggest",
        "responses": {
          "200": {
            "description": "Suggested products"
          }
        }
      }
    },
    "/api/assistant/order-lookup": {
      "post": {
        "summary": "Order status lookup",
        "operationId": "postOrderLookup",
        "responses": {
          "200": {
            "description": "Order summary when found"
          }
        }
      }
    },
    "/llms.txt": {
      "get": {
        "summary": "LLM site guide (markdown)",
        "operationId": "getLlmsTxt",
        "responses": {
          "200": {
            "description": "text/markdown site guide"
          }
        }
      }
    },
    "/llms-full.txt": {
      "get": {
        "summary": "Full product catalog for LLMs (markdown)",
        "operationId": "getLlmsFullTxt",
        "responses": {
          "200": {
            "description": "text/markdown catalog"
          }
        }
      }
    }
  }
}