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. The following APIs represent the state in the development master branch. version: '0.0.3-development' 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. components: schemas: ClientArray: type: array items: $ref: '#/components/schemas/Client' LogEntryArray: type: array items: $ref: '#/components/schemas/LogEntry' 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' username: null 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 ipAddress: description: The public IP address of this client type: string username: description: The username for this client in chat if available 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 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. title: type: string description: Displayed in the document title and header. 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: "
This page is super 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 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. encoderPreset: type: string description: "The [H.264 preset value](https://trac.ffmpeg.org/wiki/Encode/H.264) selected for this HLS variant." TimestampedValue: type: object properties: time: type: string format: date-time value: type: integer 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" securitySchemes: AdminBasicAuth: type: http scheme: basic description: The username for admin basic auth is `admin` and the password is the stream key. responses: 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' username: coolperson42 clientID: 2ba20dd34f911c198df3218ddc64c740 geo: countryCode: US regionName: California timeZone: America/Los_Angeles 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": "inbound stream disconnected"} failure: summary: Operation failed. value: {"success": false, "message": "no inbound stream connected"} 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/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: get: summary: Historical Chat Messages description: Used to get all chat messages prior to connecting to the websocket. tags: ["Chat"] responses: '200': description: "" content: application/json: schema: type: array items: type: object properties: author: type: string description: Username of the chat message poster. 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/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 disableUpgradeChecks: type: boolean description: Turn off checking for owncast releases 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" disableUpgradeChecks: false /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/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/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/changekey: post: summary: Update Stream Key. Pre-release, do not use. description: Change the stream key in memory, but not in the config file. This will require all broadcasters to be reconfigured to connect again. tags: ["Admin", "Pre-release"] security: - AdminBasicAuth: [] requestBody: description: "" required: true content: application/json: schema: type: object properties: key: type: string responses: '200': description: Key was changed. content: application/json: schema: type: object properties: success: type: boolean example: true message: type: string example: changed /api/admin/changeExtraPageContent: post: summary: Change the extra page content. Pre-release, do not use. description: Change the extra page content in memory, but not on disk. tags: ["Admin", "Pre-release"] security: - AdminBasicAuth: [] requestBody: description: "" required: true content: application/json: schema: type: object properties: content: type: string responses: '200': description: Page content was changed. content: application/json: schema: type: object properties: success: type: boolean example: true message: type: string example: changed /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. 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" segmentLengthSeconds: type: integer description: The target number of seconds each HLS video segment of video will last. numberOfPlaylistItems: type: integer description: The maximum number of HLS video segments we will keep referenced in the playlist. yp: $ref: "#/components/schemas/YP" /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