> ## Documentation Index
> Fetch the complete documentation index at: https://docs.connvo.app/llms.txt
> Use this file to discover all available pages before exploring further.

# generateParticipantTokenPublic

> authenticated user to join a paid tier meeting. Resolves the user's identity,
generates a token with appropriate permissions, and returns user details for
the GetStream client. Tokens expire after 1 hour for security.



## OpenAPI

````yaml api-reference/convex-openapi.yaml post /api/run/meetings/stream/index/generateParticipantTokenPublic
openapi: 3.0.3
info:
  title: Connvo Convex API
  version: 1.0.0
  description: >-
    HTTP interface for Connvo's Convex backend, exposing vetted query, mutation,
    and action endpoints.
servers:
  - url: https://Connvo-dev.convex.cloud
    description: Dev Convex deployment
  - url: https://Connvo-staging.convex.cloud
    description: Staging Convex deployment
  - url: https://Connvo-prod.convex.cloud
    description: Prod Convex deployment
security:
  - bearerAuth: []
tags:
  - name: Users
    description: Identity, profile, and authentication operations for Connvo users.
  - name: Meetings
    description: Scheduling, managing, and retrieving meeting data.
  - name: Transcripts
    description: Endpoints for accessing call transcripts and transcription controls.
  - name: Insights
    description: AI-generated insights, summaries, and analytics derived from meetings.
  - name: Prompts
    description: Prompt management and AI conversation guidance.
  - name: Notes
    description: Collaborative meeting notes and follow-up documentation.
  - name: WebRTC
    description: Real-time communication, session signalling, and media utilities.
  - name: System
    description: General system endpoints such as health checks and diagnostics.
paths:
  /api/run/meetings/stream/index/generateParticipantTokenPublic:
    post:
      tags:
        - Meetings
      summary: generateParticipantTokenPublic
      description: >-
        authenticated user to join a paid tier meeting. Resolves the user's
        identity,

        generates a token with appropriate permissions, and returns user details
        for

        the GetStream client. Tokens expire after 1 hour for security.
      operationId: postApiRunMeetingsStreamIndexGenerateParticipantTokenPublic
      requestBody:
        content:
          application/json:
            schema:
              $ref: >-
                #/components/schemas/Request_meetings.stream.index.generateParticipantTokenPublic
            example:
              args:
                meetingId: meeting_123example
                role: participant
        required: true
      responses:
        '200':
          description: Convex executed your request and returned a result
          content:
            application/json:
              schema:
                $ref: >-
                  #/components/schemas/Response_meetings.stream.index.generateParticipantTokenPublic
              example:
                status: success
                errorMessage: ''
                errorData: {}
                value:
                  token: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...
                  userId: user_workos_123
                  user:
                    id: user_workos_123
                    name: Alice Johnson
                    image: https://example.com/avatars/alice.jpg
                  expiresAt: 1704070800
                  success: true
        '400':
          description: Failed operation
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/FailedResponse'
        '500':
          description: Convex Internal Error
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/FailedResponse'
      security:
        - bearerAuth: []
components:
  schemas:
    Request_meetings.stream.index.generateParticipantTokenPublic:
      type: object
      required:
        - args
      properties:
        args:
          type: object
          required:
            - meetingId
          properties:
            meetingId:
              type: string
              description: ID from table "meetings"
            role:
              type: string
    Response_meetings.stream.index.generateParticipantTokenPublic:
      type: object
      required:
        - status
      properties:
        status:
          type: string
          enum:
            - success
            - error
        errorMessage:
          type: string
        errorData:
          type: object
        value:
          type: object
          required:
            - expiresAt
            - success
            - token
            - user
            - userId
          properties:
            expiresAt:
              type: number
            success:
              type: boolean
            token:
              type: string
            user:
              type: object
              required:
                - id
                - name
              properties:
                id:
                  type: string
                image:
                  type: string
                name:
                  type: string
            userId:
              type: string
    FailedResponse:
      type: object
      properties: {}
  securitySchemes:
    bearerAuth:
      type: http
      scheme: bearer
      bearerFormat: JWT
      description: >-
        Standard user authentication token issued via WorkOS. Provide as
        `Authorization: Bearer <user-token>`.

````