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 branch. version: '0.0.11' contact: name: Gabe Kangas email: gabek@real-ity.com url: http://owncast.online x-logo: url: >-  servers: [] tags: - name: Admin description: Admin operations requiring authentication. - name: Chat description: Endpoints related to the chat interface. - name: Integrations description: APIs built to allow 3rd parties to interact with an Owncast server. - name: Moderation description: Chat-related actions that can take place by a moderator. components: schemas: ClientArray: type: array items: $ref: '#/components/schemas/Client' UserArray: type: array items: $ref: '#/components/schemas/User' LogEntryArray: type: array items: $ref: '#/components/schemas/LogEntry' FollowerArray: type: array items: $ref: '#/components/schemas/Follower' Client: type: object description: A single representation of a client. example: connectedAt: '2020-10-06T23:20:44.588649-07:00' messageCount: 0 userAgent: >- Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36 ipAddress: '::1' clientID: 2ba20dd34f911c198df3218ddc64c740 geo: countryCode: US regionName: California timeZone: America/Los_Angeles properties: connectedAt: type: string format: date-time messageCount: description: Number of chat messages sent by user type: integer userAgent: description: The web client used to connect to this server type: string example: 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/91.0.4472.124 Safari/537.36' ipAddress: description: The public IP address of this client type: string clientID: description: The value used to identify this client type: string geo: type: object description: Optional geographic data for the client properties: countryCode: type: string regionName: type: string timeZone: type: string user: $ref: '#/components/schemas/User' x-last-modified: 1602052347511 BasicResponse: type: object properties: success: type: boolean message: type: string InstanceDetails: type: object description: User-facing details about this server. properties: name: type: string description: Displayed as the header in the instance details. summary: type: string description: This is brief summary of whom you are or what the stream is. logo: type: string description: Local file name of your logo image. We recommend a square image (150 x 150px) with ample padding around the important contents of the image, as it will be rendered as a circle. tags: type: array description: Categories of the content this instance focuses on. items: type: string socialHandles: type: array description: Links to social network urls. items: type: object properties: platform: type: string example: github url: type: string example: http://github.com/owncast/owncast extraPageContent: type: string description: Additional HTML content to render in the body of the web interface. example: '

This page is super cool!' version: type: string example: Owncast v0.0.3-macOS (ef3796a033b32a312ebf5b334851cbf9959e7ecb) YP: type: object description: Configuration of the instance's registration to the Owncast Directory (YP API) properties: enabled: type: boolean description: If YP support is on or off. Must be enabled to show in the directory. default: false instanceUrl: type: string description: The public URL of this owncast server, used for registration and linking with the directory. Must be publicly available. S3: type: object description: Configuration of external storage using S3-compatible providers. properties: enabled: type: boolean endpoint: type: string servingEndpoint: type: string accessKey: type: string secret: type: string bucket: type: string region: type: string acl: type: string forcePathStyle: type: boolean required: - enabled StreamQuality: type: object properties: videoPassthrough: type: boolean description: If enabled video transcoding is disabled and the video is passed along in its original format. audioPassthrough: type: boolean description: If enabled audio transcoding is disabled and the audio is passed along in its original format. videoBitrate: type: integer description: The video quality, in kbps. audioBitrate: type: integer description: The audio quality, in kbps. scaledWidth: type: integer description: The resized video width. scaledHeight: type: integer description: The resized video height. framerate: type: integer description: The target frames per second of the video. cpuUsageLevel: type: integer description: 'The amount of hardware utilization selected for this HLS variant.' TimestampedValue: type: object properties: time: type: string format: date-time value: type: integer ConfigValue: description: A wrapper object used to set values in many config endpoints. type: object properties: value: oneOf: - type: string - type: integer - type: object - type: boolean BooleanValue: description: A wrapper object used to set boolean values in many config endpoints. type: object properties: value: type: boolean example: value: true LogEntry: type: object properties: time: type: string format: date-time description: 'Timestamp for this log entry' level: type: string description: 'The level of this log entry' message: type: string description: 'The log entry contents' Webhook: type: object properties: id: type: string description: The ID of this webhook. url: type: string description: The URL that events will be sent to. events: type: array items: type: string description: The events that will be sent to this webhook. timestamp: type: string format: date-time description: When this webhook was created. lastUsed: type: string format: date-time description: When this webhook was last used. User: type: object properties: id: type: string description: User ID example: yklw5Imng displayName: type: string description: The user-facing disaplay name for this user. example: awesome-pizza displayColor: type: integer description: Hue value for displaying in the UI. example: 42 createdAt: type: string format: date-time description: When this account was originally registered/created. previousNames: type: string description: Comma separated list of names previously used by this user. example: 'awesome-pizza,user42' scopes: type: array items: description: A specific attribute assigned to this user type: string example: 'MODERATOR' Follower: type: object required: - link - username - timestamp properties: link: type: string description: URL linking to this follower example: https://mastodon.cloud/users/gabektest name: type: string description: Optional display name for this follower example: John Smith image: type: string description: Optional image for this follower example: http://mastodon.cloud/users/gabektest/avatar.png timestamp: type: string format: date-time description: Timestamp of when the follow occured disabledAt: type: string format: date-time description: Timestamp when the follow was removed FederatedAction: type: object properties: iri: type: string description: The unique identifier for this action. example: https://fediverse.server/jfk-3827 actorIRI: type: string description: The identifier for the actor that performed this action. example: https://mastodon.cloud/users/gabektest type: type: string enum: [FEDIVERSE_ENGAGEMENT_FOLLOW, FEDIVERSE_ENGAGEMENT_LIKE, FEDIVERSE_ENGAGEMENT_REPOST] securitySchemes: AdminBasicAuth: type: http scheme: basic description: The username for admin basic auth is `admin` and the password is the stream key. AccessToken: type: http scheme: bearer description: 3rd party integration auth where a service user must provide an access token. UserToken: type: apiKey name: accessToken in: query description: A standard user must provide a valid access token. ModeratorUserToken: type: apiKey name: accessToken in: query description: A moderator user must provide a valid access token. responses: UsersResponse: description: A collection of users. content: application/json: schema: $ref: '#/components/schemas/UserArray' FollowersResponse: description: A collection of users. content: application/json: schema: $ref: '#/components/schemas/FollowerArray' ClientsResponse: description: Successful response of an array of clients content: application/json: schema: $ref: '#/components/schemas/ClientArray' example: - connectedAt: '2020-10-06T23:20:44.588649-07:00' messageCount: 3 userAgent: >- Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36 ipAddress: '172.217.164.110' geo: countryCode: US regionName: California timeZone: America/Los_Angeles user: id: yklw5Imng displayName: awesome-pizza displayColor: 42 createdAt: '2021-07-08T20:21:25.303402404-07:00' previousNames: 'awesome-pizza,coolPerson23' LogsResponse: description: Response of server log entries content: application/json: schema: $ref: '#/components/schemas/LogEntryArray' examples: success: summary: Logs returned value: [ { 'message': 'Owncast v0.0.0-localdev (unknown)', 'level': 'info', 'time': '2020-10-29T18:35:34.422386-07:00', }, { 'message': 'Web server running on port: 8080', 'level': 'info', 'time': '2020-10-29T18:35:35.011731-07:00', }, { 'message': 'RTMP server is listening for incoming stream on port: 1935', 'level': 'info', 'time': '2020-10-29T18:35:35.011823-07:00', }, ] BasicResponse: description: Operation Success/Failure Response content: application/json: schema: $ref: '#/components/schemas/BasicResponse' examples: success: summary: Operation succeeded. value: { 'success': true, 'message': 'context specific success message', } failure: summary: Operation failed. value: { 'success': false, 'message': 'context specific failure message', } paths: /api/config: get: summary: Information description: The client configuration. Information useful for the user interface. tags: ['Server'] responses: '200': description: '' content: application/json: schema: $ref: '#/components/schemas/InstanceDetails' /api/ping: get: summary: Mark the current viewer as active. description: For tracking viewer count, periodically hit the ping endpoint. tags: ['Server'] responses: '200': description: 'Successful ping' /api/status: get: summary: Current Status description: This endpoint is used to discover when a server is broadcasting, the number of active viewers as well as other useful information for updating the user interface. tags: ['Server'] responses: '200': description: '' content: application/json: schema: type: object properties: lastConnectTime: type: string nullable: true format: date-time overallMaxViewerCount: type: integer sessionMaxViewerCount: type: integer online: type: boolean viewerCount: type: integer lastDisconnectTime: type: string nullable: true format: date-time examples: online: value: lastConnectTime: '2020-10-03T21:36:22-05:00' lastDisconnectTime: null online: true overallMaxViewerCount: 420 sessionMaxViewerCount: 12 viewerCount: 7 /api/chat/register: post: summary: Register a chat user description: Register a user that returns an access token for accessing chat. tags: ['Chat'] security: - UserToken: [] requestBody: required: false content: application/json: schema: type: object properties: displayName: type: string description: Optionally provide a display name you want to assign to this user when registering. responses: '200': description: '' content: application/json: schema: type: object properties: id: type: string description: The new user's id. accessToken: type: string description: The access token used for accessing chat. displayName: type: string description: The user-facing name displayed for this user. /api/chat: get: summary: Chat Messages Backlog description: Used to get chat messages prior to connecting to the websocket. tags: ['Chat'] security: - UserToken: [] responses: '200': description: '' content: application/json: schema: type: array items: type: object properties: user: $ref: '#/components/schemas/User' body: type: string description: Escaped HTML of the chat message content. id: type: string description: Unique ID of the chat message. visible: type: boolean description: 'Should chat message be visibly rendered.' timestamp: type: string format: date-time /api/yp: get: summary: Yellow Pages Information description: Information to be used in the Yellow Pages service, a global directory of Owncast servers. tags: ['Server'] responses: '200': description: '' content: application/json: schema: type: object properties: name: type: string description: type: string logo: type: string nsfw: type: boolean tags: type: array items: type: string online: type: boolean viewerCount: type: integer overallMaxViewerCount: type: integer sessionMaxViewerCount: type: integer lastConnectTime: type: string nullable: true format: date-time /api/emoji: get: summary: Get Custom Emoji description: Get a list of custom emoji that are supported in chat. tags: ['Chat'] responses: '200': description: '' content: application/json: schema: type: array items: type: object properties: name: type: string description: The name of the Emoji emoji: type: string description: The relative path to the Emoji image file examples: default: value: items: - name: nicolas_cage_party emoji: /img/emoji/nicolas_cage_party.gif - name: parrot emoji: /img/emoji/parrot.gif /api/followers: get: summary: Get the public followers of this instance responses: '200': description: Followers content: application/json: schema: type: array items: $ref: '#/components/schemas/Follower' /api/remotefollow: post: summary: Return the information needed to redirect a user to a fediverse server to perform a remote follow action. requestBody: content: application/json: schema: type: object properties: account: description: The fediverse username@server.tld account that wants to perform the remote follow action. type: string example: johnsmith@fediverse.biz responses: '200': description: Remote follow redirect details content: application/json: schema: type: object properties: redirectUrl: description: The URL the frontend should redirect to type: string example: https://fediverse.biz/authorize_interaction?uri=https://my.owncast.server/federation/user/streamer /api/chat/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' /api/admin/status: get: summary: 'Server status and broadcaster' tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': description: Server status and broadcaster details content: application/json: schema: type: object properties: broadcaster: type: object properties: remoteAddr: type: string time: type: string format: date-time streamDetails: type: object properties: width: type: integer height: type: integer frameRate: type: integer videoBitrate: type: integer videoCodec: type: string audioBitrate: type: integer audioCodec: type: string encoder: type: string online: type: boolean description: Is a stream currently active viewerCount: type: integer description: The current number of viewers sessionPeakViewerCount: type: integer description: The peak number of viewers this streaming session overallPeakViewerCount: type: integer description: The all-time peak number of viewers versionNumber: type: string description: The current version of the owncast software examples: connected: summary: 'Broadcaster Connected' value: broadcaster: remoteAddr: 172.217.164.110 time: '2020-10-06T23:20:44.588649-07:00' streamDetails: width: 640 height: 480 frameRate: 24 videoBitrate: 1500 videoCodec: 'mp4a' audioBitrate: 256 audioCodec: 'aac' encoder: 'obs-output module (libobs version 25.0.8)' online: true viewerCount: 3 overallPeakViewerCount: 4 sessionPeakViewerCount: 4 versionNumber: '0.0.3' /api/admin/disconnect: post: summary: Disconnect Broadcaster description: Disconnect the active inbound stream, if one exists, and terminate the broadcast. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' /api/admin/yp/reset: post: summary: Reset your YP registration key. description: Used when there is a problem with your registration to the Owncast Directory via the YP APIs. This will reset your local registration key. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' /api/admin/chat/clients: get: summary: Return a list of currently connected clients description: Return a list of currently connected clients with optional geo details. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/ClientsResponse' /api/admin/users/disabled: get: summary: Return a list of currently connected clients description: Return a list of currently connected clients with optional geo details. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/UsersResponse' /api/admin/logs: get: summary: Return recent log entries description: Returns server logs. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/LogsResponse' /api/admin/logs/warnings: get: summary: Return recent warning and error logs. description: Return recent warning and error logs. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/LogsResponse' /api/admin/serverconfig: get: summary: Server Configuration description: Get the current configuration of the Owncast server. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': description: '' content: application/json: schema: type: object properties: instanceDetails: $ref: '#/components/schemas/InstanceDetails' ffmpegPath: type: string description: The path to the copy of ffmpeg that this server is using. webServerPort: type: integer description: The port the public web server is listening on. rtmpServerPort: type: integer description: The port the inbound RTMP broadcast should be sent to. s3: $ref: '#/components/schemas/S3' videoSettings: type: object description: How the different variants of video streams are configured. properties: videoQualityVariants: type: array items: $ref: '#/components/schemas/StreamQuality' latencyLevel: type: integer description: The level of latency selected for streaming. Lower latency can create more buffering. yp: $ref: '#/components/schemas/YP' /api/admin/chat/messages: get: summary: Chat messages, unfiltered. description: Get a list of all chat messages with no filters applied. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': description: '' content: application/json: schema: type: array items: type: object properties: user: $ref: '#/components/schemas/User' body: type: string description: Escaped HTML of the chat message content. id: type: string description: Unique ID of the chat message. visible: type: boolean description: 'Should chat message be visibly rendered.' timestamp: type: string format: date-time /api/admin/chat/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: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' /api/admin/chat/users/setenabled: post: summary: Enable or disable a single user. description: Enable or disable a single user. Disabling will also hide all the user's chat messages. requestBody: content: application/json: schema: type: object properties: userId: type: string description: User ID to act upon. example: 'yklw5Imng' enabled: type: boolean description: Set the enabled state of this user. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' /api/admin/config/key: post: summary: Set the stream key. description: Set the stream key. Also used as the admin password. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' /api/admin/config/pagecontent: post: summary: Set the custom page content. description: Set the custom page content using markdown. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: '# Welcome to my cool server!

I _hope_ you enjoy it.' /api/admin/config/streamtitle: post: summary: Set the stream title. description: Set the title of the currently streaming content. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: Streaming my favorite game, Desert Bus. /api/admin/config/name: post: summary: Set the server name. description: Set the name associated with your server. Often is your name, username or identity. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' /api/admin/config/serversummary: post: summary: Set the server summary. description: Set the summary of your server's streaming content. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: The best in Desert Bus Streaming /api/admin/config/logo: post: summary: Set the server logo. description: Set the logo for your server. Path is relative to webroot. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: '/img/mylogo.png' /api/admin/config/tags: post: summary: Set the server tags. description: Set the tags displayed for your server and the categories you can show up in on the directory. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: - games - music - streaming /api/admin/config/ffmpegpath: post: summary: Set the ffmpeg binary path description: Set the path for a specific copy of ffmpeg on your system. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: '/home/owncast/ffmpeg' /api/admin/config/webserverport: post: summary: Set the owncast web port. description: Set the port the owncast web server should listen on. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: 8080 /api/admin/config/rtmpserverport: post: summary: Set the inbound rtmp server port. description: Set the port where owncast service will listen for inbound broadcasts. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: 1935 /api/admin/config/nsfw: post: summary: Mark if your stream is not safe for work description: Mark if your stream can be consitered not safe for work. Used in different contexts, including the directory for filtering purposes. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: false /api/admin/config/directoryenabled: post: summary: Set if this server supports the Owncast directory. description: If set to true the server will attempt to register itself with the [Owncast Directory](https://directory.owncast.online). Off by default. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: true /api/admin/config/serverurl: post: summary: Set the public url of this owncast server. description: Set the public url of this owncast server. Used for the directory and optional integrations. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: https://live.mycoolserver.biz /api/admin/config/video/streamlatencylevel: post: summary: Set the latency level for the stream. description: Sets the latency level that determines how much video is buffered between the server and viewer. Less latency can end up with more buffering. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: type: object properties: value: description: The latency level type: integer example: value: 4 /api/admin/config/video/streamoutputvariants: post: summary: Set the configuration of your stream output. description: Sets the detailed configuration for all of the stream variants you support. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: - framerate: 30 videoPassthrough: false videoBitrate: 1800 cpuUsageLevel: 2 audioPassthrough: true - framerate: 24 videoPassthrough: false videoBitrate: 1000 cpuUsageLevel: 3 audioPassthrough: true /api/admin/config/video/codec: post: summary: Set the video codec. description: Sets the specific video codec that will be used for video encoding. Some codecs will support hardware acceleration. Not all codecs will be supported for all systems. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: type: object properties: value: description: The video codec to change to. type: string example: value: libx264 /api/admin/config/s3: post: summary: Set your storage configration. description: Sets your S3 storage provider configuration details to enable external storage. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: enabled: true endpoint: https://s3.us-west-000.backblazeb2.com accessKey: e1ac500y7000500047156bd060 secret: 'H8FH8eSxM2K/S42CUg5K000Tt4WY2fI' bucket: 'video' region: us-west-000 /api/admin/config/socialhandles: post: summary: Set your social handles. description: Sets the external links to social networks and profiles. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: - platform: github url: https://github.com/owncast/owncast - platform: mastodon url: https://mastodon.social/@gabek /api/admin/config/customstyles: post: summary: Custom CSS styles to be used in the web front endpoints. description: Save a string containing CSS to be inserted in to the web frontend page. tags: ['Admin'] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: 'body { color: orange; background: black; }' /api/admin/viewersOverTime: get: summary: Viewers Over Time description: Get the tracked viewer count over the collected period. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': description: '' content: application/json: schema: type: array items: $ref: '#/components/schemas/TimestampedValue' examples: default: value: - time: '2020-10-03T21:41:00.381996-05:00' value: 50 - time: '2020-10-03T21:42:00.381996-05:00' value: 52 /api/admin/hardwarestats: get: summary: Hardware Stats description: 'Get the CPU, Memory and Disk utilization levels over the collected period.' tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': description: '' content: application/json: schema: type: object properties: cpu: type: array items: $ref: '#/components/schemas/TimestampedValue' memory: type: array items: $ref: '#/components/schemas/TimestampedValue' disk: type: array items: $ref: '#/components/schemas/TimestampedValue' examples: default: value: cpu: - time: '2020-10-03T21:41:00.381996-05:00' value: 23 - time: '2020-10-03T21:42:00.381996-05:00' value: 27 - time: '2020-10-03T21:43:00.381996-05:00' value: 22 memory: - time: '2020-10-03T21:41:00.381996-05:00' value: 65 - time: '2020-10-03T21:42:00.381996-05:00' value: 66 - time: '2020-10-03T21:43:00.381996-05:00' value: 72 disk: - time: '2020-10-03T21:41:00.381996-05:00' value: 11 - time: '2020-10-03T21:42:00.381996-05:00' value: 11 - time: '2020-10-03T21:43:00.381996-05:00' value: 11 /api/admin/config/federation/enable: post: summary: Enable or disable federated social features. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/BooleanValue' /api/admin/config/federation/private: post: summary: Enable or disable private federation mode. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/BooleanValue' /api/admin/config/federation/showengagement: post: summary: Enable or disable Federation activity showing in chat. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/BooleanValue' /api/admin/config/federation/username: post: summary: Set the username you are seen as on the fediverse. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' /api/admin/config/federation/livemessage: post: summary: Set the message sent to the fediverse when this instance goes live. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' /api/admin/config/federation/blockdomains: post: summary: Save a collection of domains that should be ignored on the fediverse. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: - guns.eagles.biz - freedom.us /api/admin/federation/send: post: summary: Manually send a message to the fediverse from this instance. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: I'm still streaming, you should come visit. /api/admin/federation/actions: get: summary: Get a list of accepted actions that took place on the Fediverse. tags: ["Admin"] security: - AdminBasicAuth: [] responses: '200': description: Actions previously handled. content: application/json: schema: type: array items: $ref: '#/components/schemas/FederatedAction' /api/integrations/streamtitle: post: summary: Set the stream title. description: Set the title of the currently streaming content. tags: ['Integrations'] security: - AccessToken: [] responses: '200': $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: $ref: '#/components/schemas/ConfigValue' example: value: Streaming my favorite game, Desert Bus. /api/integrations/chat/send: post: summary: Send a chat message. description: Send a chat message on behalf of a 3rd party integration, bot or service. tags: ['Integrations'] security: - AccessToken: [] requestBody: required: true content: application/json: schema: type: object properties: body: type: string description: The message text that will be sent as the user. responses: '200': description: Message was sent. content: application/json: schema: type: object properties: success: type: boolean example: true message: type: string example: sent /api/integrations/chat/system: post: summary: Send a system chat message. description: Send a chat message on behalf of the system/server. tags: ['Integrations'] security: - AccessToken: [] requestBody: required: true content: application/json: schema: type: object properties: body: type: string description: The message text that will be sent as the system user. responses: '200': description: Message was sent. content: application/json: schema: type: object properties: success: type: boolean example: true message: type: string example: sent /api/integrations/chat/action: post: summary: Send a chat action. description: Send an action that took place to the chat. tags: ['Integrations'] security: - AccessToken: [] requestBody: required: true content: application/json: schema: type: object required: - 'body' properties: body: type: string description: The message text that will be sent as the system user. example: 'rolled a 15 on the dice' author: type: string description: An optional user name that performed the action. example: 'JohnSmith' responses: '200': description: Message was sent. content: application/json: schema: type: object properties: success: type: boolean example: true message: type: string example: sent /api/integrations/chat/system/client/{clientId}: post: summary: Send system chat message to a client, identified by its ClientId description: Send a chat message on behalf of the system/server to a single client. tags: ['Integrations'] security: - AccessToken: [] parameters: - name: clientId in: path description: Client ID (a unique numeric Id, identifying the client connection) required: true schema: type: integer format: int64 requestBody: required: true content: application/json: schema: type: object required: - 'body' properties: body: type: string description: The message text that will be sent to the client. example: 'What a beautiful day. I love it' responses: '200': description: Message was sent. content: application/json: schema: type: object properties: success: type: boolean example: true messages: type: string example: sent '500': description: Message was not sent to the client content: application/json: schema: type: object properties: error: type: string description: message explaining what went wrong sending the message to the client /api/admin/accesstokens/create: post: summary: Create an access token. description: Create a single access token that has access to the access scopes provided. tags: ['Integrations'] security: - AdminBasicAuth: [] requestBody: required: true content: application/json: schema: type: object properties: name: type: string description: The human-readable name to give this access token. scopes: type: array items: type: string responses: '200': description: Token was created. content: application/json: schema: type: object properties: name: type: string example: your new token token: type: string example: 'zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI=' /api/admin/accesstokens/delete: post: summary: Delete an access token. description: Delete a single access token. tags: ['Integrations'] security: - AdminBasicAuth: [] requestBody: required: true content: application/json: schema: type: object properties: token: type: string description: The token to delete responses: '200': description: Token was deleted. content: application/json: schema: type: object properties: success: type: boolean example: true message: type: string example: deleted token /api/admin/accesstokens: get: summary: Return all access tokens. description: Return all of the available access tokens. tags: ['Integrations'] security: - AdminBasicAuth: [] responses: '200': description: Tokens are returned content: application/json: schema: type: array items: type: string /api/admin/webhooks: get: summary: Return all webhooks. description: Return all of the configured webhooks for external events. tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': description: Webhooks are returned content: application/json: schema: $ref: '#/components/schemas/Webhook' /api/admin/config/externalactions: post: summary: Set external action URLs. description: Set a collection of external action URLs that are displayed in the UI. tags: ['Admin', 'Integrations'] security: - AdminBasicAuth: [] requestBody: required: true content: application/json: schema: type: array items: type: object properties: url: type: string description: URL of the external action content. title: type: string description: The title to put on the external action button. description: type: string description: Optional additional description to display in the UI. icon: type: string description: The URL to an image to place on the external action button. color: type: string description: Optional color to use for drawing the action button. openExternally: type: boolean description: If set this action will open in a new browser tab instead of an internal modal. responses: '200': description: Actions have been updated. /api/admin/webhooks/delete: post: summary: Delete a single webhook. description: Delete a single webhook by its ID. tags: ['Admin'] security: - AdminBasicAuth: [] requestBody: required: true content: application/json: schema: type: object properties: id: type: string description: The webhook id to delete responses: '200': description: Webhook is deleted /api/admin/webhooks/create: post: summary: Create a webhook. description: Create a single webhook that acts on the requested events. tags: ['Admin'] security: - AdminBasicAuth: [] requestBody: required: true content: application/json: schema: type: object properties: url: type: string description: The url to post the events to. events: description: The events to be notified about. type: array items: type: string responses: '200': description: Token was created. content: application/json: schema: type: object properties: name: type: string example: your new token token: type: string example: 'zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI=' /api/integrations/clients: get: summary: Return a list of currently connected clients description: Return a list of currently connected clients with optional geo details. tags: ['Integrations'] security: - AccessToken: [] responses: '200': $ref: '#/components/responses/ClientsResponse' /api/integrations/chat: get: summary: Historical Chat Messages description: Used to get the backlog of chat messages. tags: ['Integrations'] security: - AccessToken: [] responses: '200': description: '' content: application/json: schema: type: array items: type: object properties: user: $ref: '#/components/schemas/User' body: type: string description: Escaped HTML of the chat message content. id: type: string description: Unique ID of the chat message. visible: type: boolean description: 'Should chat message be visibly rendered.' timestamp: type: string format: date-time /api/integrations/chat/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: ['Integrations'] security: - AccessToken: [] responses: '200': $ref: '#/components/responses/BasicResponse' /api/admin/chat/users/setmoderator: post: summary: Set moderator priviledges on a chat users. description: Give a chat user ID and be able to grant or remove moderator priviledges to this user. requestBody: content: application/json: schema: type: object properties: userId: type: string description: User ID of the chat user you want to change moderation status of. example: xJ84_48Ghj isModerator: type: boolean description: The moderator status of this user. example: true tags: ['Admin', 'Moderation'] security: - AdminBasicAuth: [] responses: '200': $ref: '#/components/responses/BasicResponse' /api/admin/chat/users/moderators: get: tags: ['Admin', 'Moderation'] security: - AdminBasicAuth: [] summary: Get a list of chat moderator users. responses: '200': description: List of moderators content: application/json: schema: type: array items: $ref: '#/components/schemas/User' /api/admin/followers: get: tags: ['Admin'] security: - AdminBasicAuth: [] summary: Get the followers of this instance responses: '200': description: Followers content: application/json: schema: type: array items: $ref: '#/components/schemas/Follower' /api/admin/followers/pending: get: tags: ['Admin'] security: - AdminBasicAuth: [] summary: Get a list of follow requests that are pending. responses: '200': description: Followers $ref: '#/components/schemas/FollowerArray' /api/admin/followers/blocked: get: tags: ['Admin'] security: - AdminBasicAuth: [] summary: Get a list of follow requests that have been blocked/rejected. responses: '200': description: Follower requests that have been rejected or blocked. $ref: '#/components/schemas/FollowerArray' /api/admin/followers/approve: post: tags: ['Admin'] security: - AdminBasicAuth: [] summary: Approve a pending follow request. requestBody: content: application/json: schema: type: object properties: actorIRI: type: string description: The requestor's remote IRI used to identify the user. responses: '200': description: The request has been successfully approved. $ref: '#/components/responses/BasicResponse' /api/admin/config/chat/suggestedusernames: post: tags: ['Admin'] security: - AdminBasicAuth: [] summary: A list of names to select from randomly for new chat users. requestBody: content: application/json: schema: type: object properties: value: type: array items: type: string responses: '200': description: The list of default names have been updated. $ref: '#/components/responses/BasicResponse'