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

# Board Ticket

> Marks a ticket as boarded and returns the updated ticket.



## OpenAPI

````yaml /api-reference/driver/openapi.json post /api/v1/driver/trips/{tripId}/tickets/{code}/board
openapi: 3.0.0
info:
  title: DEVMOB Driver API
  description: DEVMOB API
  version: '1.0'
  contact: {}
servers: []
security: []
tags:
  - name: Auth
    description: Authentication and token lifecycle
  - name: Invite
    description: Driver invitation preview and acceptance
  - name: Notification
    description: Driver inbox notifications
  - name: OTP
    description: One-time password flows
  - name: Profile
    description: Authenticated driver profile
  - name: Session
    description: Authenticated sessions
  - name: Storage
    description: Storage uploads
  - name: Trip
    description: Driver trips
  - name: Trip Boarding
    description: Ticket boarding
  - name: Trip Event
    description: Trip operational events
  - name: Trip Manifest
    description: Trip passenger manifest
  - name: Trip Tracking
    description: Driver GPS tracking
paths:
  /api/v1/driver/trips/{tripId}/tickets/{code}/board:
    post:
      tags:
        - Trip Boarding
      summary: Board Ticket
      description: Marks a ticket as boarded and returns the updated ticket.
      operationId: boardDriverTripTicket
      parameters:
        - name: tripId
          required: true
          in: path
          schema:
            type: string
            format: uuid
            description: Trip identifier
            example: 0195e7a1-8b5c-7d3e-9f4a-2c6b8d0e1f3a
        - name: code
          required: true
          in: path
          schema:
            type: string
            description: Readable ticket code
            example: BIL-A1B2C3
        - name: fields
          required: false
          in: query
          description: >-
            Comma-separated list of fields to include in the response. Supports
            dot notation for nested projection (e.g.
            `id,name,user.email,trips.route.id`). Unknown fields are silently
            dropped.
          schema:
            type: string
      responses:
        '200':
          description: OK
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Ticket'
        '400':
          $ref: '#/components/responses/BadRequestError'
        '401':
          $ref: '#/components/responses/UnauthorizedError'
        '404':
          $ref: '#/components/responses/NotFoundError'
        '409':
          $ref: '#/components/responses/ConflictError'
        '422':
          $ref: '#/components/responses/UnprocessableEntityError'
        '500':
          $ref: '#/components/responses/InternalServerError'
      security:
        - bearer: []
components:
  schemas:
    Ticket:
      type: object
      properties:
        ticketId:
          type: string
          format: uuid
          description: Identificador único
        orderId:
          type: string
          format: uuid
          description: Referência ao pedido
        tripId:
          type: string
          format: uuid
          description: Referência à viagem
        tripItineraryId:
          type: string
          format: uuid
          description: Referência ao itinerário
        seatId:
          type: string
          format: uuid
          description: Referência ao assento
        seatTypeId:
          type: string
          format: uuid
          description: Referência ao tipo de assento
        passengerId:
          type: string
          format: uuid
          description: Referência ao [Passenger](/data-modelling/sales/passenger)
        seatPrice:
          type: integer
          description: Preço do tipo de assento no momento da emissão (centavos)
        tripItineraryPrice:
          type: integer
          description: Preço do itinerário no momento da emissão (centavos)
        price:
          type: integer
          description: Preço final pago pela passagem (centavos)
        qrCode:
          type: string
          description: Payload codificado para validação de embarque
        code:
          type: string
          description: Código legível da passagem
        snapshot:
          type: object
          additionalProperties: true
          nullable: true
          description: >-
            Snapshot denormalizado (trip, itinerário, assento, tipo, passageiro)
            para exibição
        boardedAt:
          type: string
          format: date-time
          nullable: true
          description: Data/hora do embarque (null se ainda não embarcou)
        issuedAt:
          type: string
          format: date-time
          description: Data de emissão da passagem
        status:
          type: string
          enum:
            - VALID
            - CANCELLED
          description: Status da passagem (default VALID)
        createdBy:
          type: string
          format: uuid
          nullable: true
          description: Usuário que criou o registro, quando aplicável
        createdAt:
          type: string
          format: date-time
          description: Data de criação
        updatedBy:
          type: string
          format: uuid
          nullable: true
          description: Usuário que fez a última atualização, quando aplicável
        updatedAt:
          type: string
          format: date-time
          description: Data da última atualização
      required:
        - ticketId
        - orderId
        - tripId
        - tripItineraryId
        - seatId
        - seatTypeId
        - passengerId
        - seatPrice
        - tripItineraryPrice
        - price
        - qrCode
        - code
        - snapshot
        - boardedAt
        - issuedAt
        - status
        - createdBy
        - createdAt
        - updatedBy
        - updatedAt
      description: >-
        Passagens emitidas vinculando pedido, viagem, itinerário, assento e
        passageiro
    ValidationError:
      type: object
      properties:
        statusCode:
          type: integer
          description: HTTP status code.
          example: 400
        message:
          type: string
          description: Error message.
          example: Bad Request Error
        errors:
          type: array
          items:
            type: object
            properties:
              code:
                type: string
                description: Validation code.
                example: invalid_type
              message:
                type: string
                description: Validation message.
                example: Required
              path:
                type: string
                description: Invalid field path.
                example: name
            required:
              - code
              - message
              - path
      required:
        - statusCode
        - message
        - errors
      description: Validation error response.
    ApiError:
      type: object
      properties:
        statusCode:
          type: integer
          description: HTTP status code.
          example: 404
        error:
          type: string
          description: HTTP error name.
          example: Not Found
        message:
          type: string
          description: Machine-readable error code.
          example: resource.not_found
      required:
        - statusCode
        - error
        - message
      description: Domain error response.
  responses:
    BadRequestError:
      description: Validation failed.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/ValidationError'
    UnauthorizedError:
      description: Authentication required.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/ApiError'
    NotFoundError:
      description: Resource not found.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/ApiError'
    ConflictError:
      description: State conflict.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/ApiError'
    UnprocessableEntityError:
      description: Business rule violation.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/ApiError'
    InternalServerError:
      description: Internal server error.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/ApiError'
  securitySchemes:
    bearer:
      scheme: bearer
      bearerFormat: JWT
      type: http

````