openapi: 3.0.1
info:
  title: Owncast
  description: Owncast is a self-hosted live video and web chat server for use with existing popular broadcasting software.
  version: '0.0.12'
  contact:
    name: Gabe Kangas
    email: gabek@real-ity.com
    url: http://owncast.online
  x-logo:
    url: >-
      
servers: []
tags:
  - name: Admin
    description: Admin operations requiring authentication.
  - name: Chat
    description: Endpoints related to the chat interface.
  - name: Integrations
    description: APIs built to allow 3rd parties to interact with an Owncast server.
  - name: Moderation
    description: Chat-related actions that can take place by a moderator.

components:
  schemas:
    ClientArray:
      type: array
      items:
        $ref: '#/components/schemas/Client'

    UserArray:
      type: array
      items:
        $ref: '#/components/schemas/User'

    LogEntryArray:
      type: array
      items:
        $ref: '#/components/schemas/LogEntry'

    FollowerArray:
      type: array
      items:
        $ref: '#/components/schemas/Follower'

    Client:
      type: object
      description: A single representation of a client.
      example:
        connectedAt: '2020-10-06T23:20:44.588649-07:00'
        messageCount: 0
        userAgent: >-
          Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36
          (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36
        ipAddress: '::1'
        clientID: 2ba20dd34f911c198df3218ddc64c740
        geo:
          countryCode: US
          regionName: California
          timeZone: America/Los_Angeles
      properties:
        connectedAt:
          type: string
          format: date-time
        messageCount:
          description: Number of chat messages sent by user
          type: integer
        userAgent:
          description: The web client used to connect to this server
          type: string
          example: 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36'
        ipAddress:
          description: The public IP address of this client
          type: string
        clientID:
          description: The value used to identify this client
          type: string
        geo:
          type: object
          description: Optional geographic data for the client
          properties:
            countryCode:
              type: string
            regionName:
              type: string
            timeZone:
              type: string
        user:
          $ref: '#/components/schemas/User'
      x-last-modified: 1602052347511

    BasicResponse:
      type: object
      properties:
        success:
          type: boolean
        message:
          type: string
    InstanceDetails:
      type: object
      description: User-facing details about this server.
      properties:
        name:
          type: string
          description: Displayed as the header in the instance details.
        summary:
          type: string
          description: This is brief summary of whom you are or what the stream is.
        logo:
          type: string
          description: Local file name of your logo image. We recommend a square image (150 x 150px) with ample padding around the important contents of the image, as it will be rendered as a circle.
        tags:
          type: array
          description: Categories of the content this instance focuses on.
          items:
            type: string
        socialHandles:
          type: array
          description: Links to social network urls.
          items:
            type: object
            properties:
              platform:
                type: string
                example: github
              url:
                type: string
                example: http://github.com/owncast/owncast
        extraPageContent:
          type: string
          description: Additional HTML content to render in the body of the web interface.
          example: '<p>This page is <strong>super</strong> cool!'
        version:
          type: string
          example: Owncast v0.0.3-macOS (ef3796a033b32a312ebf5b334851cbf9959e7ecb)

    YP:
      type: object
      description: Configuration of the instance's registration to the Owncast Directory (YP API)
      properties:
        enabled:
          type: boolean
          description: If YP support is on or off.  Must be enabled to show in the directory.
          default: false
        instanceUrl:
          type: string
          description: The public URL of this owncast server, used for registration and linking with the directory.  Must be publicly available.

    S3:
      type: object
      description: Configuration of external storage using S3-compatible providers.
      properties:
        enabled:
          type: boolean
        endpoint:
          type: string
        servingEndpoint:
          type: string
        accessKey:
          type: string
        secret:
          type: string
        bucket:
          type: string
        region:
          type: string
        acl:
          type: string
        forcePathStyle:
          type: boolean
      required:
        - enabled
    StreamQuality:
      type: object
      properties:
        videoPassthrough:
          type: boolean
          description: If enabled video transcoding is disabled and the video is passed along in its original format.
        audioPassthrough:
          type: boolean
          description: If enabled audio transcoding is disabled and the audio is passed along in its original format.
        videoBitrate:
          type: integer
          description: The video quality, in kbps.
        audioBitrate:
          type: integer
          description: The audio quality, in kbps.
        scaledWidth:
          type: integer
          description: The resized video width.
        scaledHeight:
          type: integer
          description: The resized video height.
        framerate:
          type: integer
          description: The target frames per second of the video.
        cpuUsageLevel:
          type: integer
          description: 'The amount of hardware utilization selected for this HLS variant.'

    TimestampedValue:
      type: object
      properties:
        time:
          type: string
          format: date-time
        value:
          type: integer

    ConfigValue:
      description: A wrapper object used to set values in many config endpoints.
      type: object
      properties:
        value:
          oneOf:
            - type: string
            - type: integer
            - type: object
            - type: boolean

    BooleanValue:
      description: A wrapper object used to set boolean values in many config endpoints.
      type: object
      properties:
        value:
          type: boolean
      example:
        value: true

    LogEntry:
      type: object
      properties:
        time:
          type: string
          format: date-time
          description: 'Timestamp for this log entry'
        level:
          type: string
          description: 'The level of this log entry'
        message:
          type: string
          description: 'The log entry contents'
    Webhook:
      type: object
      properties:
        id:
          type: string
          description: The ID of this webhook.
        url:
          type: string
          description: The URL that events will be sent to.
        events:
          type: array
          items:
            type: string
            description: The events that will be sent to this webhook.
        timestamp:
          type: string
          format: date-time
          description: When this webhook was created.
        lastUsed:
          type: string
          format: date-time
          description: When this webhook was last used.

    User:
      type: object
      properties:
        id:
          type: string
          description: User ID
          example: yklw5Imng
        displayName:
          type: string
          description: The user-facing disaplay name for this user.
          example: awesome-pizza
        displayColor:
          type: integer
          description: Color name number for client rendering.  theme-user-colors-n
          example: 3
        createdAt:
          type: string
          format: date-time
          description: When this account was originally registered/created.
        previousNames:
          type: string
          description: Comma separated list of names previously used by this user.
          example: 'awesome-pizza,user42'
        scopes:
          type: array
          items:
            description: A specific attribute assigned to this user
            type: string
            example: 'MODERATOR'

    Follower:
      type: object
      required:
        - link
        - username
        - timestamp
      properties:
        link:
          type: string
          description: URL linking to this follower
          example: https://mastodon.cloud/users/gabektest
        name:
          type: string
          description: Optional display name for this follower
          example: John Smith
        image:
          type: string
          description: Optional image for this follower
          example: http://mastodon.cloud/users/gabektest/avatar.png
        timestamp:
          type: string
          format: date-time
          description: Timestamp of when the follow occured
        disabledAt:
          type: string
          format: date-time
          description: Timestamp when the follow was removed

    FederatedAction:
      type: object
      properties:
        iri:
          type: string
          description: The unique identifier for this action.
          example: https://fediverse.server/jfk-3827
        actorIRI:
          type: string
          description: The identifier for the actor that performed this action.
          example: https://mastodon.cloud/users/gabektest
        type:
          type: string
          enum:
            [
              FEDIVERSE_ENGAGEMENT_FOLLOW,
              FEDIVERSE_ENGAGEMENT_LIKE,
              FEDIVERSE_ENGAGEMENT_REPOST,
            ]

  securitySchemes:
    AdminBasicAuth:
      type: http
      scheme: basic
      description: The username for admin basic auth is `admin` and the password is the stream key.
    AccessToken:
      type: http
      scheme: bearer
      description: 3rd party integration auth where a service user must provide an access token.
    UserToken:
      type: apiKey
      name: accessToken
      in: query
      description: A standard user must provide a valid access token.
    ModeratorUserToken:
      type: apiKey
      name: accessToken
      in: query
      description: A moderator user must provide a valid access token.

  responses:
    UsersResponse:
      description: A collection of users.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/UserArray'

    FollowersResponse:
      description: A collection of users.
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/FollowerArray'

    ClientsResponse:
      description: Successful response of an array of clients
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/ClientArray'
          example:
            - connectedAt: '2020-10-06T23:20:44.588649-07:00'
              messageCount: 3
              userAgent: >-
                Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36
                (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36
              ipAddress: '172.217.164.110'
              geo:
                countryCode: US
                regionName: California
                timeZone: America/Los_Angeles
              user:
                id: yklw5Imng
                displayName: awesome-pizza
                displayColor: 42
                createdAt: '2021-07-08T20:21:25.303402404-07:00'
                previousNames: 'awesome-pizza,coolPerson23'

    LogsResponse:
      description: Response of server log entries
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/LogEntryArray'
          examples:
            success:
              summary: Logs returned
              value:
                [
                  {
                    'message': 'Owncast v0.0.0-localdev (unknown)',
                    'level': 'info',
                    'time': '2020-10-29T18:35:34.422386-07:00',
                  },
                  {
                    'message': 'Web server running on port: 8080',
                    'level': 'info',
                    'time': '2020-10-29T18:35:35.011731-07:00',
                  },
                  {
                    'message': 'RTMP server is listening for incoming stream on port: 1935',
                    'level': 'info',
                    'time': '2020-10-29T18:35:35.011823-07:00',
                  },
                ]

    BasicResponse:
      description: Operation Success/Failure Response
      content:
        application/json:
          schema:
            $ref: '#/components/schemas/BasicResponse'
          examples:
            success:
              summary: Operation succeeded.
              value:
                {
                  'success': true,
                  'message': 'context specific success message',
                }
            failure:
              summary: Operation failed.
              value:
                {
                  'success': false,
                  'message': 'context specific failure message',
                }

paths:
  /api/config:
    get:
      summary: Information
      description: The client configuration. Information useful for the user interface.
      tags: ['Server']
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/InstanceDetails'

  /api/ping:
    get:
      summary: Mark the current viewer as active.
      description: For tracking viewer count, periodically hit the ping endpoint.
      tags: ['Server']
      responses:
        '200':
          description: 'Successful ping'

  /api/status:
    get:
      summary: Current Status
      description: This endpoint is used to discover when a server is broadcasting, the number of active viewers as well as other useful information for updating the user interface.
      tags: ['Server']
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: object
                properties:
                  lastConnectTime:
                    type: string
                    nullable: true
                    format: date-time
                  overallMaxViewerCount:
                    type: integer
                  sessionMaxViewerCount:
                    type: integer
                  online:
                    type: boolean
                  viewerCount:
                    type: integer
                  lastDisconnectTime:
                    type: string
                    nullable: true
                    format: date-time
              examples:
                online:
                  value:
                    lastConnectTime: '2020-10-03T21:36:22-05:00'
                    lastDisconnectTime: null
                    online: true
                    overallMaxViewerCount: 420
                    sessionMaxViewerCount: 12
                    viewerCount: 7

  /api/chat/register:
    post:
      summary: Register a chat user
      description: Register a user that returns an access token for accessing chat.
      tags: ['Chat']
      security:
        - UserToken: []
      requestBody:
        required: false
        content:
          application/json:
            schema:
              type: object
              properties:
                displayName:
                  type: string
                  description: Optionally provide a display name you want to assign to this user when registering.
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: object
                properties:
                  id:
                    type: string
                    description: The new user's id.
                  accessToken:
                    type: string
                    description: The access token used for accessing chat.
                  displayName:
                    type: string
                    description: The user-facing name displayed for this user.

  /api/chat:
    get:
      summary: Chat Messages Backlog
      description: Used to get chat messages prior to connecting to the websocket.
      tags: ['Chat']
      security:
        - UserToken: []
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: array
                items:
                  type: object
                  properties:
                    user:
                      $ref: '#/components/schemas/User'
                    body:
                      type: string
                      description: Escaped HTML of the chat message content.
                    id:
                      type: string
                      description: Unique ID of the chat message.
                    visible:
                      type: boolean
                      description: 'Should chat message be visibly rendered.'
                    timestamp:
                      type: string
                      format: date-time

  /api/yp:
    get:
      summary: Yellow Pages Information
      description: Information to be used in the Yellow Pages service, a global directory of Owncast servers.
      tags: ['Server']
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: object
                properties:
                  name:
                    type: string
                  description:
                    type: string
                  logo:
                    type: string
                  nsfw:
                    type: boolean
                  tags:
                    type: array
                    items:
                      type: string
                  online:
                    type: boolean
                  viewerCount:
                    type: integer
                  overallMaxViewerCount:
                    type: integer
                  sessionMaxViewerCount:
                    type: integer
                  lastConnectTime:
                    type: string
                    nullable: true
                    format: date-time

  /api/emoji:
    get:
      summary: Get Custom Emoji
      description: Get a list of custom emoji that are supported in chat.
      tags: ['Chat']
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: array
                items:
                  type: object
                  properties:
                    name:
                      type: string
                      description: The name of the Emoji
                    emoji:
                      type: string
                      description: The relative path to the Emoji image file
              examples:
                default:
                  value:
                    items:
                      - name: nicolas_cage_party
                        emoji: /img/emoji/nicolas_cage_party.gif
                      - name: parrot
                        emoji: /img/emoji/parrot.gif

  /api/followers:
    get:
      summary: Get the public followers of this instance
      responses:
        '200':
          description: Followers
          content:
            application/json:
              schema:
                type: array
                items:
                  $ref: '#/components/schemas/Follower'

  /api/remotefollow:
    post:
      summary: Return the information needed to redirect a user to a fediverse server to perform a remote follow action.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                account:
                  description: The fediverse username@server.tld account that wants to perform the remote follow action.
                  type: string
                  example: johnsmith@fediverse.biz
      responses:
        '200':
          description: Remote follow redirect details
          content:
            application/json:
              schema:
                type: object
                properties:
                  redirectUrl:
                    description: The URL the frontend should redirect to
                    type: string
                    example: https://fediverse.biz/authorize_interaction?uri=https://my.owncast.server/federation/user/streamer

  /api/chat/messagevisibility:
    post:
      summary: Update the visibility of chat messages.
      description: Pass an array of IDs you want to change the chat visibility of.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                visible:
                  type: boolean
                  description: Are these messages visible.
                idArray:
                  type: array
                  items:
                    type: string
                    description: IDs of the chat messages you wish to change the visibility of.
      tags: ['Moderation']
      security:
        - ModeratorUserToken: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/chat/users/setenabled:
    post:
      summary: Disable (block) or re-enable a chat user.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                userId:
                  type: string
                  description: User ID of the chat user you're changing.
                enabled:
                  type: boolean
                  description: State of this user. False to block/disable.
      tags: ['Moderation']
      security:
        - ModeratorUserToken: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/admin/status:
    get:
      summary: 'Server status and broadcaster'
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: Server status and broadcaster details
          content:
            application/json:
              schema:
                type: object
                properties:
                  broadcaster:
                    type: object
                    properties:
                      remoteAddr:
                        type: string
                      time:
                        type: string
                        format: date-time
                      streamDetails:
                        type: object
                        properties:
                          width:
                            type: integer
                          height:
                            type: integer
                          frameRate:
                            type: integer
                          videoBitrate:
                            type: integer
                          videoCodec:
                            type: string
                          audioBitrate:
                            type: integer
                          audioCodec:
                            type: string
                          encoder:
                            type: string
                  online:
                    type: boolean
                    description: Is a stream currently active
                  viewerCount:
                    type: integer
                    description: The current number of viewers
                  sessionPeakViewerCount:
                    type: integer
                    description: The peak number of viewers this streaming session
                  overallPeakViewerCount:
                    type: integer
                    description: The all-time peak number of viewers
                  versionNumber:
                    type: string
                    description: The current version of the owncast software
              examples:
                connected:
                  summary: 'Broadcaster Connected'
                  value:
                    broadcaster:
                      remoteAddr: 172.217.164.110
                      time: '2020-10-06T23:20:44.588649-07:00'
                      streamDetails:
                        width: 640
                        height: 480
                        frameRate: 24
                        videoBitrate: 1500
                        videoCodec: 'mp4a'
                        audioBitrate: 256
                        audioCodec: 'aac'
                        encoder: 'obs-output module (libobs version 25.0.8)'
                    online: true
                    viewerCount: 3
                    overallPeakViewerCount: 4
                    sessionPeakViewerCount: 4
                    versionNumber: '0.0.3'

  /api/admin/disconnect:
    post:
      summary: Disconnect Broadcaster
      description: Disconnect the active inbound stream, if one exists, and terminate the broadcast.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/admin/yp/reset:
    post:
      summary: Reset your YP registration key.
      description: Used when there is a problem with your registration to the Owncast Directory via the YP APIs.  This will reset your local registration key.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/admin/chat/clients:
    get:
      summary: Return a list of currently connected clients
      description: Return a list of currently connected clients with optional geo details.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/ClientsResponse'

  /api/admin/users/disabled:
    get:
      summary: Return a list of currently connected clients
      description: Return a list of currently connected clients with optional geo details.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/UsersResponse'

  /api/admin/logs:
    get:
      summary: Return recent log entries
      description: Returns server logs.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/LogsResponse'

  /api/admin/logs/warnings:
    get:
      summary: Return recent warning and error logs.
      description: Return recent warning and error logs.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/LogsResponse'

  /api/admin/serverconfig:
    get:
      summary: Server Configuration
      description: Get the current configuration of the Owncast server.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: object
                properties:
                  instanceDetails:
                    $ref: '#/components/schemas/InstanceDetails'
                  ffmpegPath:
                    type: string
                    description: The path to the copy of ffmpeg that this server is using.
                  webServerPort:
                    type: integer
                    description: The port the public web server is listening on.
                  rtmpServerPort:
                    type: integer
                    description: The port the inbound RTMP broadcast should be sent to.
                  s3:
                    $ref: '#/components/schemas/S3'
                  videoSettings:
                    type: object
                    description: How the different variants of video streams are configured.
                    properties:
                      videoQualityVariants:
                        type: array
                        items:
                          $ref: '#/components/schemas/StreamQuality'
                      latencyLevel:
                        type: integer
                        description: The level of latency selected for streaming.  Lower latency can create more buffering.
                  yp:
                    $ref: '#/components/schemas/YP'

  /api/admin/chat/messages:
    get:
      summary: Chat messages, unfiltered.
      description: Get a list of all chat messages with no filters applied.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: array
                items:
                  type: object
                  properties:
                    user:
                      $ref: '#/components/schemas/User'
                    body:
                      type: string
                      description: Escaped HTML of the chat message content.
                    id:
                      type: string
                      description: Unique ID of the chat message.
                    visible:
                      type: boolean
                      description: 'Should chat message be visibly rendered.'
                    timestamp:
                      type: string
                      format: date-time

  /api/admin/chat/messagevisibility:
    post:
      summary: Update the visibility of chat messages.
      description: Pass an array of IDs you want to change the chat visibility of.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                visible:
                  type: boolean
                  description: Are these messages visible.
                idArray:
                  type: array
                  items:
                    type: string
                    description: IDs of the chat messages you wish to change the visibility of.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/admin/chat/users/setenabled:
    post:
      summary: Enable or disable a single user.
      description: Enable or disable a single user. Disabling will also hide all the user's chat messages.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                userId:
                  type: string
                  description: User ID to act upon.
                  example: 'yklw5Imng'
                enabled:
                  type: boolean
                  description: Set the enabled state of this user.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/admin/config/key:
    post:
      summary: Set the stream key.
      description: Set the stream key.  Also used as the admin password.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'

  /api/admin/config/pagecontent:
    post:
      summary: Set the custom page content.
      description: Set the custom page content using markdown.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example: '# Welcome to my cool server!<br><br>I _hope_ you enjoy it.'

  /api/admin/config/streamtitle:
    post:
      summary: Set the stream title.
      description: Set the title of the currently streaming content.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: Streaming my favorite game, Desert Bus.

  /api/admin/config/name:
    post:
      summary: Set the server name.
      description: Set the name associated with your server.  Often is your name, username or identity.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'

  /api/admin/config/serversummary:
    post:
      summary: Set the server summary.
      description: Set the summary of your server's streaming content.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: The best in Desert Bus Streaming

  /api/admin/config/logo:
    post:
      summary: Set the server logo.
      description: Set the logo for your server.  Path is relative to webroot.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: '/img/mylogo.png'

  /api/admin/config/tags:
    post:
      summary: Set the server tags.
      description: Set the tags displayed for your server and the categories you can show up in on the directory.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value:
                - games
                - music
                - streaming

  /api/admin/config/ffmpegpath:
    post:
      summary: Set the ffmpeg binary path
      description: Set the path for a specific copy of ffmpeg on your system.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: '/home/owncast/ffmpeg'

  /api/admin/config/webserverport:
    post:
      summary: Set the owncast web port.
      description: Set the port the owncast web server should listen on.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: 8080

  /api/admin/config/rtmpserverport:
    post:
      summary: Set the inbound rtmp server port.
      description: Set the port where owncast service will listen for inbound broadcasts.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: 1935

  /api/admin/config/nsfw:
    post:
      summary: Mark if your stream is not safe for work
      description: Mark if your stream can be consitered not safe for work.  Used in different contexts, including the directory for filtering purposes.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: false

  /api/admin/config/directoryenabled:
    post:
      summary: Set if this server supports the Owncast directory.
      description: If set to true the server will attempt to register itself with the [Owncast Directory](https://directory.owncast.online).  Off by default.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: true

  /api/admin/config/serverurl:
    post:
      summary: Set the public url of this owncast server.
      description: Set the public url of this owncast server.  Used for the directory and optional integrations.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: https://live.mycoolserver.biz

  /api/admin/config/video/streamlatencylevel:
    post:
      summary: Set the latency level for the stream.
      description: Sets the latency level that determines how much video is buffered between the server and viewer.  Less latency can end up with more buffering.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                value:
                  description: The latency level
                  type: integer
              example:
                value: 4

  /api/admin/config/video/streamoutputvariants:
    post:
      summary: Set the configuration of your stream output.
      description: Sets the detailed configuration for all of the stream variants you support.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value:
                - framerate: 30
                  videoPassthrough: false
                  videoBitrate: 1800
                  cpuUsageLevel: 2
                  audioPassthrough: true
                - framerate: 24
                  videoPassthrough: false
                  videoBitrate: 1000
                  cpuUsageLevel: 3
                  audioPassthrough: true

  /api/admin/config/video/codec:
    post:
      summary: Set the video codec.
      description: Sets the specific video codec that will be used for video encoding. Some codecs will support hardware acceleration. Not all codecs will be supported for all systems.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                value:
                  description: The video codec to change to.
                  type: string
              example:
                value: libx264

  /api/admin/config/s3:
    post:
      summary: Set your storage configration.
      description: Sets your S3 storage provider configuration details to enable external storage.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value:
                enabled: true
                endpoint: https://s3.us-west-000.backblazeb2.com
                accessKey: e1ac500y7000500047156bd060
                secret: 'H8FH8eSxM2K/S42CUg5K000Tt4WY2fI'
                bucket: 'video'
                region: us-west-000

  /api/admin/config/socialhandles:
    post:
      summary: Set your social handles.
      description: Sets the external links to social networks and profiles.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value:
                - platform: github
                  url: https://github.com/owncast/owncast
                - platform: mastodon
                  url: https://mastodon.social/@gabek
  /api/admin/config/customstyles:
    post:
      summary: Custom CSS styles to be used in the web front endpoints.
      description: Save a string containing CSS to be inserted in to the web frontend page.
      tags: ['Admin']
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: 'body { color: orange; background: black; }'

  /api/admin/viewersOverTime:
    get:
      summary: Viewers Over Time
      description: Get the tracked viewer count over the collected period.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: array
                items:
                  $ref: '#/components/schemas/TimestampedValue'
              examples:
                default:
                  value:
                    - time: '2020-10-03T21:41:00.381996-05:00'
                      value: 50
                    - time: '2020-10-03T21:42:00.381996-05:00'
                      value: 52

  /api/admin/hardwarestats:
    get:
      summary: Hardware Stats
      description: 'Get the CPU, Memory and Disk utilization levels over the collected period.'
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: object
                properties:
                  cpu:
                    type: array
                    items:
                      $ref: '#/components/schemas/TimestampedValue'
                  memory:
                    type: array
                    items:
                      $ref: '#/components/schemas/TimestampedValue'
                  disk:
                    type: array
                    items:
                      $ref: '#/components/schemas/TimestampedValue'
              examples:
                default:
                  value:
                    cpu:
                      - time: '2020-10-03T21:41:00.381996-05:00'
                        value: 23
                      - time: '2020-10-03T21:42:00.381996-05:00'
                        value: 27
                      - time: '2020-10-03T21:43:00.381996-05:00'
                        value: 22
                    memory:
                      - time: '2020-10-03T21:41:00.381996-05:00'
                        value: 65
                      - time: '2020-10-03T21:42:00.381996-05:00'
                        value: 66
                      - time: '2020-10-03T21:43:00.381996-05:00'
                        value: 72
                    disk:
                      - time: '2020-10-03T21:41:00.381996-05:00'
                        value: 11
                      - time: '2020-10-03T21:42:00.381996-05:00'
                        value: 11
                      - time: '2020-10-03T21:43:00.381996-05:00'
                        value: 11

  /api/admin/config/federation/enable:
    post:
      summary: Enable or disable federated social features.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/BooleanValue'

  /api/admin/config/federation/private:
    post:
      summary: Enable or disable private federation mode.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/BooleanValue'

  /api/admin/config/federation/showengagement:
    post:
      summary: Enable or disable Federation activity showing in chat.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/BooleanValue'

  /api/admin/config/federation/username:
    post:
      summary: Set the username you are seen as on the fediverse.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'

  /api/admin/config/federation/livemessage:
    post:
      summary: Set the message sent to the fediverse when this instance goes live.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'

  /api/admin/config/federation/blockdomains:
    post:
      summary: Save a collection of domains that should be ignored on the fediverse.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value:
                - guns.eagles.biz
                - freedom.us

  /api/admin/federation/send:
    post:
      summary: Manually send a message to the fediverse from this instance.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: I'm still streaming, you should come visit.

  /api/admin/federation/actions:
    get:
      summary: Get a list of accepted actions that took place on the Fediverse.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: Actions previously handled.
          content:
            application/json:
              schema:
                type: array
                items:
                  $ref: '#/components/schemas/FederatedAction'

  /api/integrations/streamtitle:
    post:
      summary: Set the stream title.
      description: Set the title of the currently streaming content.
      tags: ['Integrations']
      security:
        - AccessToken: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'
      requestBody:
        content:
          application/json:
            schema:
              $ref: '#/components/schemas/ConfigValue'
            example:
              value: Streaming my favorite game, Desert Bus.

  /api/integrations/chat/send:
    post:
      summary: Send a chat message.
      description: Send a chat message on behalf of a 3rd party integration, bot or service.
      tags: ['Integrations']
      security:
        - AccessToken: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                body:
                  type: string
                  description: The message text that will be sent as the user.
      responses:
        '200':
          description: Message was sent.
          content:
            application/json:
              schema:
                type: object
                properties:
                  success:
                    type: boolean
                    example: true
                  message:
                    type: string
                    example: sent

  /api/integrations/chat/system:
    post:
      summary: Send a system chat message.
      description: Send a chat message on behalf of the system/server.
      tags: ['Integrations']
      security:
        - AccessToken: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                body:
                  type: string
                  description: The message text that will be sent as the system user.
      responses:
        '200':
          description: Message was sent.
          content:
            application/json:
              schema:
                type: object
                properties:
                  success:
                    type: boolean
                    example: true
                  message:
                    type: string
                    example: sent

  /api/integrations/chat/action:
    post:
      summary: Send a chat action.
      description: Send an action that took place to the chat.
      tags: ['Integrations']
      security:
        - AccessToken: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              required:
                - 'body'
              properties:
                body:
                  type: string
                  description: The message text that will be sent as the system user.
                  example: 'rolled a 15 on the dice'
                author:
                  type: string
                  description: An optional user name that performed the action.
                  example: 'JohnSmith'
      responses:
        '200':
          description: Message was sent.
          content:
            application/json:
              schema:
                type: object
                properties:
                  success:
                    type: boolean
                    example: true
                  message:
                    type: string
                    example: sent

  /api/integrations/chat/system/client/{clientId}:
    post:
      summary: Send system chat message to a client, identified by its ClientId
      description: Send a chat message on behalf of the system/server to a single client.
      tags: ['Integrations']
      security:
        - AccessToken: []
      parameters:
        - name: clientId
          in: path
          description: Client ID (a unique numeric Id, identifying the client connection)
          required: true
          schema:
            type: integer
            format: int64
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              required:
                - 'body'
              properties:
                body:
                  type: string
                  description: The message text that will be sent to the client.
                  example: 'What a beautiful day. I love it'
      responses:
        '200':
          description: Message was sent.
          content:
            application/json:
              schema:
                type: object
                properties:
                  success:
                    type: boolean
                    example: true
                  messages:
                    type: string
                    example: sent
        '500':
          description: Message was not sent to the client
          content:
            application/json:
              schema:
                type: object
                properties:
                  error:
                    type: string
                    description: message explaining what went wrong sending the message to the client

  /api/admin/accesstokens/create:
    post:
      summary: Create an access token.
      description: Create a single access token that has access to the access scopes provided.
      tags: ['Integrations']
      security:
        - AdminBasicAuth: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                name:
                  type: string
                  description: The human-readable name to give this access token.
                scopes:
                  type: array
                  items:
                    type: string

      responses:
        '200':
          description: Token was created.
          content:
            application/json:
              schema:
                type: object
                properties:
                  name:
                    type: string
                    example: your new token
                  token:
                    type: string
                    example: 'zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI='

  /api/admin/accesstokens/delete:
    post:
      summary: Delete an access token.
      description: Delete a single access token.
      tags: ['Integrations']
      security:
        - AdminBasicAuth: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                token:
                  type: string
                  description: The token to delete

      responses:
        '200':
          description: Token was deleted.
          content:
            application/json:
              schema:
                type: object
                properties:
                  success:
                    type: boolean
                    example: true
                  message:
                    type: string
                    example: deleted token

  /api/admin/accesstokens:
    get:
      summary: Return all access tokens.
      description: Return all of the available access tokens.
      tags: ['Integrations']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: Tokens are returned
          content:
            application/json:
              schema:
                type: array
                items:
                  type: string

  /api/admin/webhooks:
    get:
      summary: Return all webhooks.
      description: Return all of the configured webhooks for external events.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          description: Webhooks are returned
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/Webhook'

  /api/admin/config/externalactions:
    post:
      summary: Set external action URLs.
      description: Set a collection of external action URLs that are displayed in the UI.
      tags: ['Admin', 'Integrations']
      security:
        - AdminBasicAuth: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: array
              items:
                type: object
                properties:
                  url:
                    type: string
                    description: URL of the external action content.
                  title:
                    type: string
                    description: The title to put on the external action button.
                  description:
                    type: string
                    description: Optional additional description to display in the UI.
                  icon:
                    type: string
                    description: The URL to an image to place on the external action button.
                  color:
                    type: string
                    description: Optional color to use for drawing the action button.
                  openExternally:
                    type: boolean
                    description: If set this action will open in a new browser tab instead of an internal modal.
      responses:
        '200':
          description: Actions have been updated.

  /api/admin/webhooks/delete:
    post:
      summary: Delete a single webhook.
      description: Delete a single webhook by its ID.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                id:
                  type: string
                  description: The webhook id to delete
      responses:
        '200':
          description: Webhook is deleted

  /api/admin/webhooks/create:
    post:
      summary: Create a webhook.
      description: Create a single webhook that acts on the requested events.
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      requestBody:
        required: true
        content:
          application/json:
            schema:
              type: object
              properties:
                url:
                  type: string
                  description: The url to post the events to.
                events:
                  description: The events to be notified about.
                  type: array
                  items:
                    type: string

      responses:
        '200':
          description: Token was created.
          content:
            application/json:
              schema:
                type: object
                properties:
                  name:
                    type: string
                    example: your new token
                  token:
                    type: string
                    example: 'zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI='

  /api/integrations/clients:
    get:
      summary: Return a list of currently connected clients
      description: Return a list of currently connected clients with optional geo details.
      tags: ['Integrations']
      security:
        - AccessToken: []
      responses:
        '200':
          $ref: '#/components/responses/ClientsResponse'

  /api/integrations/chat:
    get:
      summary: Historical Chat Messages
      description: Used to get the backlog of chat messages.
      tags: ['Integrations']
      security:
        - AccessToken: []
      responses:
        '200':
          description: ''
          content:
            application/json:
              schema:
                type: array
                items:
                  type: object
                  properties:
                    user:
                      $ref: '#/components/schemas/User'
                    body:
                      type: string
                      description: Escaped HTML of the chat message content.
                    id:
                      type: string
                      description: Unique ID of the chat message.
                    visible:
                      type: boolean
                      description: 'Should chat message be visibly rendered.'
                    timestamp:
                      type: string
                      format: date-time

  /api/integrations/chat/messagevisibility:
    post:
      summary: Update the visibility of chat messages.
      description: Pass an array of IDs you want to change the chat visibility of.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                visible:
                  type: boolean
                  description: Are these messages visible.
                idArray:
                  type: array
                  items:
                    type: string
                    description: IDs of the chat messages you wish to change the visibility of.
      tags: ['Integrations']
      security:
        - AccessToken: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/admin/chat/users/setmoderator:
    post:
      summary: Set moderator priviledges on a chat users.
      description: Give a chat user ID and be able to grant or remove moderator priviledges to this user.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                userId:
                  type: string
                  description: User ID of the chat user you want to change moderation status of.
                  example: xJ84_48Ghj
                isModerator:
                  type: boolean
                  description: The moderator status of this user.
                  example: true
      tags: ['Admin', 'Moderation']
      security:
        - AdminBasicAuth: []
      responses:
        '200':
          $ref: '#/components/responses/BasicResponse'

  /api/admin/chat/users/moderators:
    get:
      tags: ['Admin', 'Moderation']
      security:
        - AdminBasicAuth: []
      summary: Get a list of chat moderator users.
      responses:
        '200':
          description: List of moderators
          content:
            application/json:
              schema:
                type: array
                items:
                  $ref: '#/components/schemas/User'

  /api/admin/followers:
    get:
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      summary: Get the followers of this instance
      responses:
        '200':
          description: Followers
          content:
            application/json:
              schema:
                type: array
                items:
                  $ref: '#/components/schemas/Follower'

  /api/admin/followers/pending:
    get:
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      summary: Get a list of follow requests that are pending.
      responses:
        '200':
          description: Followers
          $ref: '#/components/schemas/FollowerArray'

  /api/admin/followers/blocked:
    get:
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      summary: Get a list of follow requests that have been blocked/rejected.
      responses:
        '200':
          description: Follower requests that have been rejected or blocked.
          $ref: '#/components/schemas/FollowerArray'

  /api/admin/followers/approve:
    post:
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      summary: Approve a pending follow request.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                actorIRI:
                  type: string
                  description: The requestor's remote IRI used to identify the user.
      responses:
        '200':
          description: The request has been successfully approved.
          $ref: '#/components/responses/BasicResponse'

  /api/admin/config/chat/suggestedusernames:
    post:
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      summary: A list of names to select from randomly for new chat users.
      requestBody:
        content:
          application/json:
            schema:
              type: object
              properties:
                value:
                  type: array
                  items:
                    type: string
      responses:
        '200':
          description: The list of default names have been updated.
          $ref: '#/components/responses/BasicResponse'

  /api/admin/prometheus:
    get:
      tags: ['Admin']
      security:
        - AdminBasicAuth: []
      summary: Return Prometheus-compatible scraper metrics.
      responses:
        '200':
          description: Prometheus-compatible scraper values.