openapi: 3.0.3
info:
  title: Nautix Partner Portal API
  version: 1.0.0
  description: Authenticated partner portal APIs for account management, partner apps, and sandbox credentials.
servers:
  - url: /
tags:
  - name: Partner Auth
  - name: Partner Apps
paths:
  /api/partner/v1/auth/register:
    post:
      tags:
        - Partner Auth
      summary: Register a partner portal account
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/PartnerPortalRegisterRequest'
      responses:
        '201':
          description: Partner account registration submitted.
  /api/partner/v1/auth/verify-email:
    post:
      tags:
        - Partner Auth
      summary: Verify partner portal email
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/PartnerPortalVerifyEmailRequest'
      responses:
        '200':
          description: Email verification result.
  /api/partner/v1/auth/login:
    post:
      tags:
        - Partner Auth
      summary: Log in to partner portal
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/PartnerPortalLoginRequest'
      responses:
        '200':
          description: Authenticated partner session.
  /api/partner/v1/auth/me:
    get:
      tags:
        - Partner Auth
      summary: Get current partner user profile
      security:
        - bearerAuth: []
      responses:
        '200':
          description: Current authenticated partner user.
  /api/partner/v1/apps:
    get:
      tags:
        - Partner Apps
      summary: List partner apps for the authenticated organization
      security:
        - bearerAuth: []
      responses:
        '200':
          description: List of partner apps.
    post:
      tags:
        - Partner Apps
      summary: Create a partner app
      security:
        - bearerAuth: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/CreatePartnerAppRequest'
      responses:
        '201':
          description: Partner app created.
  /api/partner/v1/apps/{appId}:
    get:
      tags:
        - Partner Apps
      summary: Get a partner app
      security:
        - bearerAuth: []
      parameters:
        - in: path
          name: appId
          required: true
          schema:
            type: integer
            format: int64
      responses:
        '200':
          description: Partner app returned.
  /api/partner/v1/apps/{appId}/credentials:
    post:
      tags:
        - Partner Apps
      summary: Issue a partner app credential
      description: Issue a sandbox or production-scoped partner app credential.
      security:
        - bearerAuth: []
      parameters:
        - in: path
          name: appId
          required: true
          schema:
            type: integer
            format: int64
      requestBody:
        required: true
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/CreatePartnerAppCredentialRequest'
      responses:
        '201':
          description: Credential issued. Raw API key is returned once.
components:
  securitySchemes:
    bearerAuth:
      type: http
      scheme: bearer
      bearerFormat: JWT
  schemas:
    PartnerPortalRegisterRequest:
      type: object
      required: [email, password, fullName, organizationName]
      properties:
        email:
          type: string
          format: email
        password:
          type: string
        fullName:
          type: string
        organizationName:
          type: string
    PartnerPortalVerifyEmailRequest:
      type: object
      required: [token]
      properties:
        token:
          type: string
    PartnerPortalLoginRequest:
      type: object
      required: [email, password]
      properties:
        email:
          type: string
          format: email
        password:
          type: string
    CreatePartnerAppRequest:
      type: object
      required: [name]
      properties:
        name:
          type: string
        description:
          type: string
    CreatePartnerAppCredentialRequest:
      type: object
      required: [environment]
      properties:
        environment:
          type: string
          enum: [SANDBOX, PRODUCTION]
