mirror of
https://github.com/owncast/owncast.git
synced 2024-11-22 04:40:37 +03:00
57f2e4b567
Remove Chat Avatars Thanks for the cleanup! Looks great.
667 lines
33 KiB
YAML
667 lines
33 KiB
YAML
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.
|
|
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
|