2020-10-04 20:59:43 -05:00
openapi : 3.0 .1
info :
title : Owncast
2022-06-13 13:27:24 -07:00
description : Owncast is a self-hosted live video and web chat server for use with existing popular broadcasting software.
version : '0.0.12'
2020-10-14 09:38:48 -07:00
contact :
name : Gabe Kangas
email : gabek@real-ity.com
url : http://owncast.online
2020-10-07 17:04:06 -07:00
x-logo :
url : >-

2020-10-04 20:59:43 -05:00
servers : [ ]
tags :
- name : Admin
description : Admin operations requiring authentication.
- name : Chat
description : Endpoints related to the chat interface.
2021-02-18 23:05:52 -08:00
- name : Integrations
description : APIs built to allow 3rd parties to interact with an Owncast server.
2022-01-18 14:33:25 -08:00
- name : Moderation
description : Chat-related actions that can take place by a moderator.
2020-10-04 20:59:43 -05:00
components :
schemas :
2020-10-07 17:04:06 -07:00
ClientArray :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/Client'
2020-10-07 17:04:06 -07:00
2021-07-19 19:22:29 -07:00
UserArray :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/User'
2021-07-19 19:22:29 -07:00
2020-10-29 18:41:21 -07:00
LogEntryArray :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/LogEntry'
FollowerArray :
type : array
items :
$ref : '#/components/schemas/Follower'
2020-10-29 18:41:21 -07:00
2020-10-07 17:04:06 -07:00
Client :
type : object
description : A single representation of a client.
example :
2022-01-18 14:33:25 -08:00
connectedAt : '2020-10-06T23:20:44.588649-07:00'
2020-10-07 17:04:06 -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
2022-01-18 14:33:25 -08:00
ipAddress : '::1'
2020-10-07 17:04:06 -07:00
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
2022-01-18 14:33:25 -08:00
example : 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36'
2020-10-07 17:04:06 -07:00
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
2021-07-19 19:22:29 -07:00
user :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/User'
2020-10-07 17:04:06 -07:00
x-last-modified : 1602052347511
2020-10-04 20:59:43 -05:00
BasicResponse :
type : object
properties :
success :
type : boolean
message :
type : string
InstanceDetails :
type : object
2020-10-07 17:04:06 -07:00
description : User-facing details about this server.
2020-10-04 20:59:43 -05:00
properties :
name :
type : string
2020-10-07 17:04:06 -07:00
description : Displayed as the header in the instance details.
2020-10-04 20:59:43 -05:00
summary :
type : string
description : This is brief summary of whom you are or what the stream is.
logo :
2020-11-17 15:12:54 -08:00
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.
2020-10-04 20:59:43 -05:00
tags :
type : array
2020-10-07 17:04:06 -07:00
description : Categories of the content this instance focuses on.
2020-10-04 20:59:43 -05:00
items :
type : string
socialHandles :
type : array
2020-10-07 17:04:06 -07:00
description : Links to social network urls.
2020-10-04 20:59:43 -05:00
items :
type : object
properties :
platform :
type : string
example : github
url :
type : string
example : http://github.com/owncast/owncast
2020-10-14 09:38:48 -07:00
extraPageContent :
2020-10-04 20:59:43 -05:00
type : string
2020-10-13 16:45:52 -07:00
description : Additional HTML content to render in the body of the web interface.
2022-01-18 14:33:25 -08:00
example : '<p>This page is <strong>super</strong> cool!'
2020-10-04 20:59:43 -05:00
version :
type : string
2020-10-21 22:40:48 -07:00
example : Owncast v0.0.3-macOS (ef3796a033b32a312ebf5b334851cbf9959e7ecb)
2020-10-07 22:42:14 -07:00
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.
2020-10-04 20:59:43 -05:00
S3 :
type : object
2020-10-07 17:04:06 -07:00
description : Configuration of external storage using S3-compatible providers.
2020-10-04 20:59:43 -05:00
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
2021-10-29 02:27:44 +02:00
forcePathStyle :
type : boolean
2020-10-04 20:59:43 -05:00
required :
- enabled
StreamQuality :
type : object
properties :
videoPassthrough :
type : boolean
2020-10-07 17:04:06 -07:00
description : If enabled video transcoding is disabled and the video is passed along in its original format.
2020-10-04 20:59:43 -05:00
audioPassthrough :
type : boolean
2020-10-07 17:04:06 -07:00
description : If enabled audio transcoding is disabled and the audio is passed along in its original format.
2020-10-04 20:59:43 -05:00
videoBitrate :
type : integer
2020-10-07 17:04:06 -07:00
description : The video quality, in kbps.
2020-10-04 20:59:43 -05:00
audioBitrate :
type : integer
2020-10-07 17:04:06 -07:00
description : The audio quality, in kbps.
2020-10-04 20:59:43 -05:00
scaledWidth :
type : integer
2020-10-07 17:04:06 -07:00
description : The resized video width.
2020-10-04 20:59:43 -05:00
scaledHeight :
type : integer
2020-10-07 17:04:06 -07:00
description : The resized video height.
2020-10-04 20:59:43 -05:00
framerate :
type : integer
2020-10-07 17:04:06 -07:00
description : The target frames per second of the video.
2021-04-15 13:55:51 -07:00
cpuUsageLevel :
type : integer
2022-01-18 14:33:25 -08:00
description : 'The amount of hardware utilization selected for this HLS variant.'
2020-10-04 20:59:43 -05:00
TimestampedValue :
type : object
properties :
time :
type : string
format : date-time
value :
type : integer
2021-02-18 23:05:52 -08:00
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
2022-01-18 14:33:25 -08:00
BooleanValue :
description : A wrapper object used to set boolean values in many config endpoints.
type : object
properties :
value :
type : boolean
example :
value : true
2020-10-29 18:41:21 -07:00
LogEntry :
type : object
properties :
time :
type : string
format : date-time
2022-01-18 14:33:25 -08:00
description : 'Timestamp for this log entry'
2020-10-29 18:41:21 -07:00
level :
type : string
2022-01-18 14:33:25 -08:00
description : 'The level of this log entry'
2020-10-29 18:41:21 -07:00
message :
type : string
2022-01-18 14:33:25 -08:00
description : 'The log entry contents'
2021-02-18 23:05:52 -08:00
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.
2020-10-04 20:59:43 -05:00
2021-07-19 19:22:29 -07:00
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
2022-06-28 18:55:21 -07:00
description : Color name number for client rendering. theme-user-colors-n
example : 3
2021-07-19 19:22:29 -07:00
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.
2022-01-18 14:33:25 -08:00
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
2022-06-13 13:27:24 -07:00
enum :
[
FEDIVERSE_ENGAGEMENT_FOLLOW,
FEDIVERSE_ENGAGEMENT_LIKE,
FEDIVERSE_ENGAGEMENT_REPOST,
]
2022-01-18 14:33:25 -08:00
2020-10-04 20:59:43 -05:00
securitySchemes :
AdminBasicAuth :
type : http
scheme : basic
description : The username for admin basic auth is `admin` and the password is the stream key.
2021-02-18 23:05:52 -08:00
AccessToken :
type : http
scheme : bearer
description : 3rd party integration auth where a service user must provide an access token.
2021-07-19 19:22:29 -07:00
UserToken :
type : apiKey
name : accessToken
in : query
2022-01-18 14:33:25 -08:00
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.
2020-10-04 20:59:43 -05:00
responses :
2021-07-19 19:22:29 -07:00
UsersResponse :
description : A collection of users.
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/UserArray'
FollowersResponse :
description : A collection of users.
content :
application/json :
schema :
$ref : '#/components/schemas/FollowerArray'
2021-07-19 19:22:29 -07:00
2020-10-07 17:04:06 -07:00
ClientsResponse :
description : Successful response of an array of clients
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ClientArray'
2020-10-07 17:04:06 -07:00
example :
2022-01-18 14:33:25 -08:00
- connectedAt : '2020-10-06T23:20:44.588649-07:00'
2021-02-18 23:05:52 -08: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
2022-01-18 14:33:25 -08:00
ipAddress : '172.217.164.110'
2021-02-18 23:05:52 -08:00
geo :
countryCode : US
regionName : California
timeZone : America/Los_Angeles
2021-07-19 19:22:29 -07:00
user :
id : yklw5Imng
displayName : awesome-pizza
displayColor : 42
2022-01-18 14:33:25 -08:00
createdAt : '2021-07-08T20:21:25.303402404-07:00'
previousNames : 'awesome-pizza,coolPerson23'
2020-10-07 17:04:06 -07:00
2020-10-29 18:41:21 -07:00
LogsResponse :
description : Response of server log entries
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/LogEntryArray'
2020-10-29 18:41:21 -07:00
examples :
success :
summary : Logs returned
2021-02-18 23:05:52 -08:00
value :
[
{
2022-01-18 14:33:25 -08:00
'message' : 'Owncast v0.0.0-localdev (unknown)' ,
'level' : 'info' ,
'time' : '2020-10-29T18:35:34.422386-07:00' ,
2021-02-18 23:05:52 -08:00
},
{
2022-01-18 14:33:25 -08:00
'message': 'Web server running on port : 8080 ',
'level' : 'info' ,
'time' : '2020-10-29T18:35:35.011731-07:00' ,
2021-02-18 23:05:52 -08:00
},
{
2022-01-18 14:33:25 -08:00
'message': 'RTMP server is listening for incoming stream on port : 1935 ',
'level' : 'info' ,
'time' : '2020-10-29T18:35:35.011823-07:00' ,
2021-02-18 23:05:52 -08:00
},
]
2020-10-29 18:41:21 -07:00
2020-10-04 20:59:43 -05:00
BasicResponse :
description : Operation Success/Failure Response
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/BasicResponse'
2020-10-04 20:59:43 -05:00
examples :
success :
summary : Operation succeeded.
2021-02-18 23:05:52 -08:00
value :
{
2022-01-18 14:33:25 -08:00
'success' : true ,
'message' : 'context specific success message' ,
2021-02-18 23:05:52 -08:00
}
2020-10-04 20:59:43 -05:00
failure :
summary : Operation failed.
2021-02-18 23:05:52 -08:00
value :
{
2022-01-18 14:33:25 -08:00
'success' : false ,
'message' : 'context specific failure message' ,
2021-02-18 23:05:52 -08:00
}
2020-10-04 20:59:43 -05:00
paths :
/api/config :
get :
summary : Information
2020-10-13 16:45:52 -07:00
description : The client configuration. Information useful for the user interface.
2022-01-18 14:33:25 -08:00
tags : [ 'Server' ]
2020-10-04 20:59:43 -05:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2020-10-04 20:59:43 -05:00
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/InstanceDetails'
2020-10-04 20:59:43 -05:00
2021-07-19 19:22:29 -07:00
/api/ping :
get :
summary : Mark the current viewer as active.
description : For tracking viewer count, periodically hit the ping endpoint.
2022-01-18 14:33:25 -08:00
tags : [ 'Server' ]
2021-07-19 19:22:29 -07:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : 'Successful ping'
2021-07-19 19:22:29 -07:00
2020-10-04 20:59:43 -05:00
/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.
2022-01-18 14:33:25 -08:00
tags : [ 'Server' ]
2020-10-04 20:59:43 -05:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2020-10-04 20:59:43 -05:00
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 :
2022-01-18 14:33:25 -08:00
lastConnectTime : '2020-10-03T21:36:22-05:00'
2020-10-04 20:59:43 -05:00
lastDisconnectTime : null
online : true
overallMaxViewerCount : 420
sessionMaxViewerCount : 12
viewerCount : 7
2021-07-19 19:22:29 -07:00
/api/chat/register :
post :
summary : Register a chat user
description : Register a user that returns an access token for accessing chat.
2022-01-18 14:33:25 -08:00
tags : [ 'Chat' ]
2021-07-19 19:22:29 -07:00
security :
2022-01-18 14:33:25 -08:00
- UserToken : [ ]
2021-07-19 19:22:29 -07:00
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 :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2021-07-19 19:22:29 -07:00
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.
2020-10-04 20:59:43 -05:00
/api/chat :
get :
2021-07-19 19:22:29 -07:00
summary : Chat Messages Backlog
description : Used to get chat messages prior to connecting to the websocket.
2022-01-18 14:33:25 -08:00
tags : [ 'Chat' ]
2021-07-19 19:22:29 -07:00
security :
2022-01-18 14:33:25 -08:00
- UserToken : [ ]
2020-10-04 20:59:43 -05:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2020-10-04 20:59:43 -05:00
content :
application/json :
schema :
type : array
items :
type : object
properties :
2021-07-19 22:53:02 -07:00
user :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/User'
2020-10-04 20:59:43 -05:00
body :
type : string
description : Escaped HTML of the chat message content.
id :
type : string
description : Unique ID of the chat message.
visible :
type : boolean
2022-01-18 14:33:25 -08:00
description : 'Should chat message be visibly rendered.'
2020-10-04 20:59:43 -05:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Server' ]
2020-10-04 20:59:43 -05:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2020-10-04 20:59:43 -05:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Chat' ]
2020-10-04 20:59:43 -05:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2020-10-04 20:59:43 -05:00
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
2022-01-18 14:33:25 -08:00
/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/updatemessagevisibility :
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'
2020-11-05 18:40:19 -08:00
/api/admin/status :
2020-10-04 20:59:43 -05:00
get :
2022-01-18 14:33:25 -08:00
summary : 'Server status and broadcaster'
tags : [ 'Admin' ]
2020-10-04 20:59:43 -05:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
2020-11-05 18:40:19 -08:00
description : Server status and broadcaster details
2020-10-04 20:59:43 -05:00
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
2020-11-05 18:40:19 -08:00
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
2020-10-04 20:59:43 -05:00
examples :
connected :
2022-01-18 14:33:25 -08:00
summary : 'Broadcaster Connected'
2020-10-04 20:59:43 -05:00
value :
broadcaster :
2020-10-07 23:27:42 -07:00
remoteAddr : 172.217 .164 .110
2022-01-18 14:33:25 -08:00
time : '2020-10-06T23:20:44.588649-07:00'
2020-10-04 20:59:43 -05:00
streamDetails :
width : 640
height : 480
frameRate : 24
videoBitrate : 1500
2022-01-18 14:33:25 -08:00
videoCodec : 'mp4a'
2020-10-04 20:59:43 -05:00
audioBitrate : 256
2022-01-18 14:33:25 -08:00
audioCodec : 'aac'
encoder : 'obs-output module (libobs version 25.0.8)'
2020-11-05 18:40:19 -08:00
online : true
viewerCount : 3
overallPeakViewerCount : 4
sessionPeakViewerCount : 4
2022-01-18 14:33:25 -08:00
versionNumber : '0.0.3'
2020-10-04 20:59:43 -05:00
/api/admin/disconnect :
post :
summary : Disconnect Broadcaster
description : Disconnect the active inbound stream, if one exists, and terminate the broadcast.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
/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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-10-04 20:59:43 -05:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2020-10-04 20:59:43 -05:00
2021-07-21 17:19:15 -07:00
/api/admin/chat/clients :
2020-10-07 17:04:06 -07:00
get :
summary : Return a list of currently connected clients
description : Return a list of currently connected clients with optional geo details.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-10-07 17:04:06 -07:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
$ref : '#/components/responses/ClientsResponse'
2020-10-07 17:04:06 -07:00
2021-07-19 19:22:29 -07:00
/api/admin/users/disabled :
2022-01-18 14:33:25 -08:00
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'
2021-07-19 19:22:29 -07:00
2020-10-29 18:41:21 -07:00
/api/admin/logs :
get :
summary : Return recent log entries
description : Returns server logs.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-10-29 18:41:21 -07:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
$ref : '#/components/responses/LogsResponse'
2020-10-29 18:41:21 -07:00
/api/admin/logs/warnings :
get :
summary : Return recent warning and error logs.
description : Return recent warning and error logs.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-10-29 18:41:21 -07:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
$ref : '#/components/responses/LogsResponse'
2020-10-29 18:41:21 -07:00
2020-10-04 20:59:43 -05:00
/api/admin/serverconfig :
get :
summary : Server Configuration
description : Get the current configuration of the Owncast server.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-10-04 20:59:43 -05:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2020-10-04 20:59:43 -05:00
content :
application/json :
schema :
type : object
properties :
instanceDetails :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/InstanceDetails'
2020-10-04 20:59:43 -05:00
ffmpegPath :
type : string
2020-10-07 17:04:06 -07:00
description : The path to the copy of ffmpeg that this server is using.
2020-10-04 20:59:43 -05:00
webServerPort :
type : integer
2020-10-07 17:04:06 -07:00
description : The port the public web server is listening on.
2021-02-18 23:05:52 -08:00
rtmpServerPort :
type : integer
description : The port the inbound RTMP broadcast should be sent to.
2020-10-04 20:59:43 -05:00
s3 :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/S3'
2020-10-04 20:59:43 -05:00
videoSettings :
type : object
2020-10-07 17:04:06 -07:00
description : How the different variants of video streams are configured.
2020-10-04 20:59:43 -05:00
properties :
videoQualityVariants :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/StreamQuality'
2021-02-18 23:05:52 -08:00
latencyLevel :
2020-10-04 20:59:43 -05:00
type : integer
2021-02-18 23:05:52 -08:00
description : The level of latency selected for streaming. Lower latency can create more buffering.
2020-10-07 22:42:14 -07:00
yp :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/YP'
2021-02-18 23:05:52 -08:00
2020-12-29 13:35:33 -08:00
/api/admin/chat/messages :
get :
summary : Chat messages, unfiltered.
description : Get a list of all chat messages with no filters applied.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-12-29 13:35:33 -08:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2020-12-29 13:35:33 -08:00
content :
application/json :
schema :
type : array
items :
type : object
properties :
2021-07-19 22:53:02 -07:00
user :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/User'
2020-12-29 13:35:33 -08:00
body :
type : string
description : Escaped HTML of the chat message content.
id :
type : string
description : Unique ID of the chat message.
visible :
type : boolean
2022-01-18 14:33:25 -08:00
description : 'Should chat message be visibly rendered.'
2020-12-29 13:35:33 -08:00
timestamp :
type : string
format : date-time
/api/admin/chat/updatemessagevisibility :
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
2021-02-18 23:05:52 -08:00
description : Are these messages visible.
2020-12-29 13:35:33 -08:00
idArray :
type : array
items :
type : string
description : IDs of the chat messages you wish to change the visibility of.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-12-29 13:35:33 -08:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
$ref : '#/components/responses/BasicResponse'
2021-07-19 19:22:29 -07:00
/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.
2022-01-18 14:33:25 -08:00
example : 'yklw5Imng'
2021-07-19 19:22:29 -07:00
enabled :
type : boolean
description : Set the enabled state of this user.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-07-19 19:22:29 -07:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
$ref : '#/components/responses/BasicResponse'
2021-07-19 19:22:29 -07:00
2021-02-18 23:05:52 -08:00
/api/admin/config/key :
post :
summary : Set the stream key.
description : Set the stream key. Also used as the admin password.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-10-04 20:59:43 -05:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2020-10-04 20:59:43 -05:00
2021-02-18 23:05:52 -08:00
/api/admin/config/pagecontent :
post :
summary : Set the custom page content.
description : Set the custom page content using markdown.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
example : '# Welcome to my cool server!<br><br>I _hope_ you enjoy it.'
2020-10-04 20:59:43 -05:00
2021-02-18 23:05:52 -08:00
/api/admin/config/streamtitle :
post :
summary : Set the stream title.
description : Set the title of the currently streaming content.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
example :
value : Streaming my favorite game, Desert Bus.
2020-10-04 20:59:43 -05:00
2021-02-18 23:05:52 -08:00
/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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2020-10-04 20:59:43 -05:00
2021-02-18 23:05:52 -08:00
/api/admin/config/serversummary :
post :
summary : Set the server summary.
description : Set the summary of your server's streaming content.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2020-10-04 20:59:43 -05:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
example :
2022-01-18 14:33:25 -08:00
value : The best in Desert Bus Streaming
2021-02-18 23:05:52 -08:00
/api/admin/config/logo :
post :
summary : Set the server logo.
description : Set the logo for your server. Path is relative to webroot.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
example :
2022-01-18 14:33:25 -08:00
value : '/img/mylogo.png'
2021-02-18 23:05:52 -08:00
/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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
example :
value :
- games
- music
2022-01-18 14:33:25 -08:00
- streaming
2021-02-18 23:05:52 -08:00
/api/admin/config/ffmpegpath :
post :
summary : Set the ffmpeg binary path
description : Set the path for a specific copy of ffmpeg on your system.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
example :
2022-01-18 14:33:25 -08:00
value : '/home/owncast/ffmpeg'
2021-02-18 23:05:52 -08:00
/api/admin/config/webserverport :
post :
summary : Set the owncast web port.
description : Set the port the owncast web server should listen on.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
example :
value :
- framerate : 30
videoPassthrough : false
videoBitrate : 1800
2021-04-15 13:55:51 -07:00
cpuUsageLevel : 2
2021-02-18 23:05:52 -08:00
audioPassthrough : true
- framerate : 24
videoPassthrough : false
videoBitrate : 1000
2021-04-15 13:55:51 -07:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-04-15 13:55:51 -07:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-04-15 13:55:51 -07:00
requestBody :
content :
application/json :
schema :
type : object
properties :
value :
description : The video codec to change to.
type : string
example :
value : libx264
2021-02-18 23:05:52 -08:00
/api/admin/config/s3 :
2022-01-18 14:33:25 -08:00
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
2021-02-18 23:05:52 -08:00
/api/admin/config/socialhandles :
2022-01-18 14:33:25 -08:00
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
2021-04-11 17:55:57 -07:00
/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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-04-11 17:55:57 -07:00
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-04-11 17:55:57 -07:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-04-11 17:55:57 -07:00
example :
2022-01-18 14:33:25 -08:00
value : 'body { color: orange; background: black; }'
2021-02-18 23:05:52 -08:00
/api/admin/viewersOverTime :
get :
summary : Viewers Over Time
description : Get the tracked viewer count over the collected period.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2021-02-18 23:05:52 -08:00
content :
application/json :
schema :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/TimestampedValue'
2021-02-18 23:05:52 -08:00
examples :
default :
value :
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:41:00.381996-05:00'
2021-02-18 23:05:52 -08:00
value : 50
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:42:00.381996-05:00'
2021-02-18 23:05:52 -08:00
value : 52
/api/admin/hardwarestats :
get :
summary : Hardware Stats
2022-01-18 14:33:25 -08:00
description : 'Get the CPU, Memory and Disk utilization levels over the collected period.'
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
description : ''
2021-02-18 23:05:52 -08:00
content :
application/json :
schema :
type : object
properties :
cpu :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/TimestampedValue'
2021-02-18 23:05:52 -08:00
memory :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/TimestampedValue'
2021-02-18 23:05:52 -08:00
disk :
type : array
items :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/TimestampedValue'
2021-02-18 23:05:52 -08:00
examples :
default :
value :
cpu :
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:41:00.381996-05:00'
2021-02-18 23:05:52 -08:00
value : 23
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:42:00.381996-05:00'
2021-02-18 23:05:52 -08:00
value : 27
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:43:00.381996-05:00'
2021-02-18 23:05:52 -08:00
value : 22
2020-10-04 20:59:43 -05:00
memory :
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:41:00.381996-05:00'
2020-10-04 20:59:43 -05:00
value : 65
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:42:00.381996-05:00'
2020-10-04 20:59:43 -05:00
value : 66
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:43:00.381996-05:00'
2020-10-04 20:59:43 -05:00
value : 72
disk :
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:41:00.381996-05:00'
2020-10-04 20:59:43 -05:00
value : 11
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:42:00.381996-05:00'
2020-10-04 20:59:43 -05:00
value : 11
2022-01-18 14:33:25 -08:00
- time : '2020-10-03T21:43:00.381996-05:00'
2020-10-04 20:59:43 -05:00
value : 11
2021-02-18 23:05:52 -08:00
2022-01-18 14:33:25 -08:00
/api/admin/config/federation/enable :
post :
summary : Enable or disable federated social features.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
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.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
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.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
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.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
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.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
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.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
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.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
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.
2022-06-13 13:27:24 -07:00
tags : [ 'Admin' ]
2022-01-18 14:33:25 -08:00
security :
- AdminBasicAuth : [ ]
responses :
'200' :
description : Actions previously handled.
content :
application/json :
schema :
type : array
items :
$ref : '#/components/schemas/FederatedAction'
2021-02-18 23:05:52 -08:00
/api/integrations/streamtitle :
post :
summary : Set the stream title.
description : Set the title of the currently streaming content.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
security :
- AccessToken : [ ]
responses :
'200' :
2022-01-18 14:33:25 -08:00
$ref : '#/components/responses/BasicResponse'
2021-02-18 23:05:52 -08:00
requestBody :
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/ConfigValue'
2021-02-18 23:05:52 -08:00
example :
value : Streaming my favorite game, Desert Bus.
2021-07-19 19:22:29 -07:00
/api/integrations/chat/send :
2021-02-18 23:05:52 -08:00
post :
2021-07-19 19:22:29 -07:00
summary : Send a chat message.
description : Send a chat message on behalf of a 3rd party integration, bot or service.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
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 :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
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 :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
security :
- AccessToken : [ ]
requestBody :
required : true
content :
application/json :
schema :
type : object
required :
2022-01-18 14:33:25 -08:00
- 'body'
2021-02-18 23:05:52 -08:00
properties :
body :
type : string
description : The message text that will be sent as the system user.
2022-01-18 14:33:25 -08:00
example : 'rolled a 15 on the dice'
2021-02-18 23:05:52 -08:00
author :
type : string
description : An optional user name that performed the action.
2022-01-18 14:33:25 -08:00
example : 'JohnSmith'
2021-02-18 23:05:52 -08:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
description : Message was sent.
content :
application/json :
schema :
type : object
properties :
success :
type : boolean
example : true
message :
type : string
example : sent
2021-09-13 10:26:28 +02:00
/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.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-09-13 10:26:28 +02:00
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 :
2022-01-18 14:33:25 -08:00
- 'body'
2021-09-13 10:26:28 +02:00
properties :
body :
type : string
description : The message text that will be sent to the client.
2022-01-18 14:33:25 -08:00
example : 'What a beautiful day. I love it'
2021-09-13 10:26:28 +02:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
2021-09-13 10:26:28 +02:00
description : Message was sent.
content :
application/json :
schema :
type : object
properties :
success :
type : boolean
example : true
messages :
type : string
example : sent
2022-01-18 14:33:25 -08:00
'500' :
2021-09-13 10:26:28 +02:00
description : Message was not sent to the client
content :
application/json :
schema :
type : object
properties :
2022-01-18 14:33:25 -08:00
error :
2021-09-13 10:26:28 +02:00
type : string
description : message explaining what went wrong sending the message to the client
2021-02-18 23:05:52 -08:00
/api/admin/accesstokens/create :
post :
summary : Create an access token.
description : Create a single access token that has access to the access scopes provided.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
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 :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
description : Token was created.
content :
application/json :
schema :
type : object
properties :
name :
type : string
example : your new token
token :
type : string
2022-01-18 14:33:25 -08:00
example : 'zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI='
2021-02-18 23:05:52 -08:00
/api/admin/accesstokens/delete :
post :
summary : Delete an access token.
description : Delete a single access token.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
requestBody :
required : true
content :
application/json :
schema :
type : object
properties :
token :
type : string
description : The token to delete
responses :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
description : Webhooks are returned
content :
application/json :
schema :
2022-01-18 14:33:25 -08:00
$ref : '#/components/schemas/Webhook'
2021-02-18 23:05:52 -08:00
2021-04-20 18:48:35 -07:00
/api/admin/config/externalactions :
post :
summary : Set external action URLs.
description : Set a collection of external action URLs that are displayed in the UI.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' , 'Integrations' ]
2021-04-20 18:48:35 -07:00
security :
- AdminBasicAuth : [ ]
requestBody :
required : true
content :
application/json :
2022-01-18 14:33:25 -08:00
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.
2021-04-20 18:48:35 -07:00
responses :
2022-01-18 14:33:25 -08:00
'200' :
2021-04-20 18:48:35 -07:00
description : Actions have been updated.
2021-02-18 23:05:52 -08:00
/api/admin/webhooks/delete :
post :
summary : Delete a single webhook.
description : Delete a single webhook by its ID.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
security :
- AdminBasicAuth : [ ]
requestBody :
required : true
content :
application/json :
schema :
type : object
properties :
id :
type : string
description : The webhook id to delete
responses :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
description : Webhook is deleted
/api/admin/webhooks/create :
post :
summary : Create a webhook.
description : Create a single webhook that acts on the requested events.
2022-01-18 14:33:25 -08:00
tags : [ 'Admin' ]
2021-02-18 23:05:52 -08:00
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 :
2022-01-18 14:33:25 -08:00
'200' :
2021-02-18 23:05:52 -08:00
description : Token was created.
content :
application/json :
schema :
type : object
properties :
name :
type : string
example : your new token
token :
type : string
2022-01-18 14:33:25 -08:00
example : 'zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI='
2021-02-18 23:05:52 -08:00
/api/integrations/clients :
get :
summary : Return a list of currently connected clients
description : Return a list of currently connected clients with optional geo details.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
security :
- AccessToken : [ ]
responses :
2022-01-18 14:33:25 -08:00
'200' :
$ref : '#/components/responses/ClientsResponse'
2021-02-18 23:05:52 -08:00
/api/integrations/chat :
2022-01-18 14:33:25 -08:00
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
2021-02-18 23:05:52 -08:00
/api/integrations/chat/updatemessagevisibility :
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.
2022-01-18 14:33:25 -08:00
tags : [ 'Integrations' ]
2021-02-18 23:05:52 -08:00
security :
- AccessToken : [ ]
responses :
2022-01-18 14:33:25 -08:00
'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'
2022-06-13 13:27:24 -07:00
/api/admin/prometheus :
get :
tags : [ 'Admin' ]
security :
- AdminBasicAuth : [ ]
summary : Return Prometheus-compatible scraper metrics.
responses :
'200' :
description : Prometheus-compatible scraper values.