You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
670 lines
33 KiB
670 lines
33 KiB
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' |
|
|
|
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: object |
|
properties: |
|
large: |
|
type: string |
|
small: |
|
type: string |
|
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.2-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 |
|
|
|
|
|
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 |
|
|
|
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. |
|
image: |
|
type: string |
|
description: URL of the chat user avatar. |
|
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/broadcaster: |
|
get: |
|
summary: "Broadcaster Details" |
|
tags: ["Admin"] |
|
security: |
|
- AdminBasicAuth: [] |
|
responses: |
|
'200': |
|
description: Connected Broadcaster Details |
|
content: |
|
application/json: |
|
schema: |
|
type: object |
|
properties: |
|
success: |
|
type: boolean |
|
message: |
|
type: string |
|
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 |
|
examples: |
|
connected: |
|
summary: "Broadcaster Connected" |
|
value: |
|
success: true |
|
message: "" |
|
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)" |
|
not-connected: |
|
summary: "Broadcaster Not Connected" |
|
value: |
|
success: false |
|
message: "no broadcaster connected" |
|
|
|
/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/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"] |
|
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"] |
|
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
|
|
|