From 055f4468a0b5e0ed492170ed789ef8d9d847cbb6 Mon Sep 17 00:00:00 2001 From: Gabe Kangas Date: Tue, 18 Jan 2022 14:33:25 -0800 Subject: [PATCH] Update API spec for 0.0.11. Closes #1666 --- openapi.yaml | 1090 ++++++++++++++++++++++++++++++++++---------------- 1 file changed, 748 insertions(+), 342 deletions(-) diff --git a/openapi.yaml b/openapi.yaml index 1bc448636..c82c4ef29 100644 --- a/openapi.yaml +++ b/openapi.yaml @@ -2,7 +2,7 @@ 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.10-dev' + version: '0.0.11' contact: name: Gabe Kangas email: gabek@real-ity.com @@ -11,7 +11,6 @@ info: url: >-  servers: [] - tags: - name: Admin description: Admin operations requiring authentication. @@ -19,34 +18,41 @@ tags: 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" + $ref: '#/components/schemas/Client' UserArray: type: array items: - $ref: "#/components/schemas/User" + $ref: '#/components/schemas/User' LogEntryArray: type: array items: - $ref: "#/components/schemas/LogEntry" + $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" + 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" + ipAddress: '::1' clientID: 2ba20dd34f911c198df3218ddc64c740 geo: countryCode: US @@ -62,7 +68,7 @@ components: 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" + 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 @@ -80,7 +86,7 @@ components: timeZone: type: string user: - $ref: "#/components/schemas/User" + $ref: '#/components/schemas/User' x-last-modified: 1602052347511 BasicResponse: @@ -123,7 +129,7 @@ components: extraPageContent: type: string description: Additional HTML content to render in the body of the web interface. - example: "

This page is super cool!" + example: '

This page is super cool!' version: type: string example: Owncast v0.0.3-macOS (ef3796a033b32a312ebf5b334851cbf9959e7ecb) @@ -190,8 +196,8 @@ components: description: The target frames per second of the video. cpuUsageLevel: type: integer - description: "The amount of hardware utilization selected for this HLS variant." - + description: 'The amount of hardware utilization selected for this HLS variant.' + TimestampedValue: type: object properties: @@ -212,19 +218,28 @@ components: - 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" + description: 'Timestamp for this log entry' level: type: string - description: "The level of this log entry" + description: 'The level of this log entry' message: type: string - description: "The log entry contents" + description: 'The log entry contents' Webhook: type: object properties: @@ -270,8 +285,57 @@ components: previousNames: type: string description: Comma separated list of names previously used by this user. - example: "awesome-pizza,user42" - + 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 @@ -285,7 +349,12 @@ components: type: apiKey name: accessToken in: query - description: 3rd party integration auth where a service user must provide an access token. + 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: @@ -293,21 +362,28 @@ components: content: application/json: schema: - $ref: "#/components/schemas/UserArray" + $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" + $ref: '#/components/schemas/ClientArray' example: - - connectedAt: "2020-10-06T23:20:44.588649-07:00" + - 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" + ipAddress: '172.217.164.110' geo: countryCode: US regionName: California @@ -316,34 +392,34 @@ components: id: yklw5Imng displayName: awesome-pizza displayColor: 42 - createdAt: "2021-07-08T20:21:25.303402404-07:00" - previousNames: "awesome-pizza,coolPerson23" + 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" + $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': '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': '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", + 'message': 'RTMP server is listening for incoming stream on port: 1935', + 'level': 'info', + 'time': '2020-10-29T18:35:35.011823-07:00', }, ] @@ -352,21 +428,21 @@ components: content: application/json: schema: - $ref: "#/components/schemas/BasicResponse" + $ref: '#/components/schemas/BasicResponse' examples: success: summary: Operation succeeded. value: { - "success": true, - "message": "context specific success message", + 'success': true, + 'message': 'context specific success message', } failure: summary: Operation failed. value: { - "success": false, - "message": "context specific failure message", + 'success': false, + 'message': 'context specific failure message', } paths: @@ -374,32 +450,32 @@ paths: get: summary: Information description: The client configuration. Information useful for the user interface. - tags: ["Server"] + tags: ['Server'] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: - $ref: "#/components/schemas/InstanceDetails" + $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"] + tags: ['Server'] responses: - "200": - description: "Successful ping" + '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"] + tags: ['Server'] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: @@ -424,7 +500,7 @@ paths: examples: online: value: - lastConnectTime: "2020-10-03T21:36:22-05:00" + lastConnectTime: '2020-10-03T21:36:22-05:00' lastDisconnectTime: null online: true overallMaxViewerCount: 420 @@ -435,9 +511,9 @@ paths: post: summary: Register a chat user description: Register a user that returns an access token for accessing chat. - tags: ["Chat"] + tags: ['Chat'] security: - - UserToken: [] + - UserToken: [] requestBody: required: false content: @@ -449,8 +525,8 @@ paths: type: string description: Optionally provide a display name you want to assign to this user when registering. responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: @@ -470,12 +546,12 @@ paths: get: summary: Chat Messages Backlog description: Used to get chat messages prior to connecting to the websocket. - tags: ["Chat"] + tags: ['Chat'] security: - - UserToken: [] + - UserToken: [] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: @@ -484,7 +560,7 @@ paths: type: object properties: user: - $ref: "#/components/schemas/User" + $ref: '#/components/schemas/User' body: type: string description: Escaped HTML of the chat message content. @@ -493,7 +569,7 @@ paths: description: Unique ID of the chat message. visible: type: boolean - description: "Should chat message be visibly rendered." + description: 'Should chat message be visibly rendered.' timestamp: type: string format: date-time @@ -502,10 +578,10 @@ paths: get: summary: Yellow Pages Information description: Information to be used in the Yellow Pages service, a global directory of Owncast servers. - tags: ["Server"] + tags: ['Server'] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: @@ -540,10 +616,10 @@ paths: get: summary: Get Custom Emoji description: Get a list of custom emoji that are supported in chat. - tags: ["Chat"] + tags: ['Chat'] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: @@ -566,14 +642,100 @@ paths: - 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"] + summary: 'Server status and broadcaster' + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": + '200': description: Server status and broadcaster details content: application/json: @@ -624,109 +786,109 @@ paths: description: The current version of the owncast software examples: connected: - summary: "Broadcaster Connected" + summary: 'Broadcaster Connected' value: broadcaster: remoteAddr: 172.217.164.110 - time: "2020-10-06T23:20:44.588649-07:00" + time: '2020-10-06T23:20:44.588649-07:00' streamDetails: width: 640 height: 480 frameRate: 24 videoBitrate: 1500 - videoCodec: "mp4a" + videoCodec: 'mp4a' audioBitrate: 256 - audioCodec: "aac" - encoder: "obs-output module (libobs version 25.0.8)" + audioCodec: 'aac' + encoder: 'obs-output module (libobs version 25.0.8)' online: true viewerCount: 3 overallPeakViewerCount: 4 sessionPeakViewerCount: 4 - versionNumber: "0.0.3" + 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - $ref: "#/components/responses/BasicResponse" + '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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - $ref: "#/components/responses/ClientsResponse" + '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" + 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - $ref: "#/components/responses/LogsResponse" + '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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - $ref: "#/components/responses/LogsResponse" + '200': + $ref: '#/components/responses/LogsResponse' /api/admin/serverconfig: get: summary: Server Configuration description: Get the current configuration of the Owncast server. - tags: ["Admin"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: type: object properties: instanceDetails: - $ref: "#/components/schemas/InstanceDetails" + $ref: '#/components/schemas/InstanceDetails' ffmpegPath: type: string description: The path to the copy of ffmpeg that this server is using. @@ -737,7 +899,7 @@ paths: type: integer description: The port the inbound RTMP broadcast should be sent to. s3: - $ref: "#/components/schemas/S3" + $ref: '#/components/schemas/S3' videoSettings: type: object description: How the different variants of video streams are configured. @@ -745,23 +907,23 @@ paths: videoQualityVariants: type: array items: - $ref: "#/components/schemas/StreamQuality" + $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" + $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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: @@ -770,7 +932,7 @@ paths: type: object properties: user: - $ref: "#/components/schemas/User" + $ref: '#/components/schemas/User' body: type: string description: Escaped HTML of the chat message content. @@ -779,7 +941,7 @@ paths: description: Unique ID of the chat message. visible: type: boolean - description: "Should chat message be visibly rendered." + description: 'Should chat message be visibly rendered.' timestamp: type: string format: date-time @@ -802,13 +964,12 @@ paths: items: type: string description: IDs of the chat messages you wish to change the visibility of. - tags: ["Admin"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - $ref: "#/components/responses/BasicResponse" - + '200': + $ref: '#/components/responses/BasicResponse' /api/admin/chat/users/setenabled: post: @@ -823,67 +984,65 @@ paths: userId: type: string description: User ID to act upon. - example: "yklw5Imng" + example: 'yklw5Imng' enabled: type: boolean description: Set the enabled state of this user. - tags: ["Admin"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - $ref: "#/components/responses/BasicResponse" - + '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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" - example: - "# Welcome to my cool server!

I _hope_ you enjoy it." + $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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: Streaming my favorite game, Desert Bus. @@ -891,108 +1050,108 @@ paths: post: summary: Set the server name. description: Set the name associated with your server. Often is your name, username or identity. - tags: ["Admin"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: - value: The best in Desert Bus Streaming + 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: - value: "/img/mylogo.png" + 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: - games - music - - streaming + - 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: - value: "/home/owncast/ffmpeg" + 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: 8080 @@ -1000,17 +1159,17 @@ paths: post: summary: Set the inbound rtmp server port. description: Set the port where owncast service will listen for inbound broadcasts. - tags: ["Admin"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: 1935 @@ -1018,17 +1177,17 @@ paths: 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: false @@ -1036,17 +1195,17 @@ paths: 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: true @@ -1054,17 +1213,17 @@ paths: 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: https://live.mycoolserver.biz @@ -1072,12 +1231,12 @@ paths: 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: @@ -1089,23 +1248,22 @@ paths: 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: value: - framerate: 30 @@ -1123,12 +1281,12 @@ paths: 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: @@ -1142,100 +1300,100 @@ paths: 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"] + 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" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $ref: '#/components/schemas/ConfigValue' example: - value: "body { color: orange; background: black; }" - + 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"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: type: array items: - $ref: "#/components/schemas/TimestampedValue" + $ref: '#/components/schemas/TimestampedValue' examples: default: value: - - time: "2020-10-03T21:41:00.381996-05:00" + - time: '2020-10-03T21:41:00.381996-05:00' value: 50 - - time: "2020-10-03T21:42:00.381996-05:00" + - 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"] + description: 'Get the CPU, Memory and Disk utilization levels over the collected period.' + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": - description: "" + '200': + description: '' content: application/json: schema: @@ -1244,64 +1402,193 @@ paths: cpu: type: array items: - $ref: "#/components/schemas/TimestampedValue" + $ref: '#/components/schemas/TimestampedValue' memory: type: array items: - $ref: "#/components/schemas/TimestampedValue" + $ref: '#/components/schemas/TimestampedValue' disk: type: array items: - $ref: "#/components/schemas/TimestampedValue" + $ref: '#/components/schemas/TimestampedValue' examples: default: value: cpu: - - time: "2020-10-03T21:41:00.381996-05:00" + - time: '2020-10-03T21:41:00.381996-05:00' value: 23 - - time: "2020-10-03T21:42:00.381996-05:00" + - time: '2020-10-03T21:42:00.381996-05:00' value: 27 - - time: "2020-10-03T21:43:00.381996-05:00" + - time: '2020-10-03T21:43:00.381996-05:00' value: 22 memory: - - time: "2020-10-03T21:41:00.381996-05:00" + - time: '2020-10-03T21:41:00.381996-05:00' value: 65 - - time: "2020-10-03T21:42:00.381996-05:00" + - time: '2020-10-03T21:42:00.381996-05:00' value: 66 - - time: "2020-10-03T21:43:00.381996-05:00" + - time: '2020-10-03T21:43:00.381996-05:00' value: 72 disk: - - time: "2020-10-03T21:41:00.381996-05:00" + - time: '2020-10-03T21:41:00.381996-05:00' value: 11 - - time: "2020-10-03T21:42:00.381996-05:00" + - time: '2020-10-03T21:42:00.381996-05:00' value: 11 - - time: "2020-10-03T21:43:00.381996-05:00" + - 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"] + tags: ['Integrations'] security: - AccessToken: [] responses: '200': - $ref: "#/components/responses/BasicResponse" + $ref: '#/components/responses/BasicResponse' requestBody: content: application/json: schema: - $ref: "#/components/schemas/ConfigValue" + $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"] + tags: ['Integrations'] security: - AccessToken: [] requestBody: @@ -1315,7 +1602,7 @@ paths: type: string description: The message text that will be sent as the user. responses: - "200": + '200': description: Message was sent. content: application/json: @@ -1333,7 +1620,7 @@ paths: post: summary: Send a system chat message. description: Send a chat message on behalf of the system/server. - tags: ["Integrations"] + tags: ['Integrations'] security: - AccessToken: [] requestBody: @@ -1347,7 +1634,7 @@ paths: type: string description: The message text that will be sent as the system user. responses: - "200": + '200': description: Message was sent. content: application/json: @@ -1365,7 +1652,7 @@ paths: post: summary: Send a chat action. description: Send an action that took place to the chat. - tags: ["Integrations"] + tags: ['Integrations'] security: - AccessToken: [] requestBody: @@ -1375,18 +1662,18 @@ paths: schema: type: object required: - - "body" + - 'body' properties: body: type: string description: The message text that will be sent as the system user. - example: "rolled a 15 on the dice" + example: 'rolled a 15 on the dice' author: type: string description: An optional user name that performed the action. - example: "JohnSmith" + example: 'JohnSmith' responses: - "200": + '200': description: Message was sent. content: application/json: @@ -1404,7 +1691,7 @@ paths: 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"] + tags: ['Integrations'] security: - AccessToken: [] parameters: @@ -1422,14 +1709,14 @@ paths: schema: type: object required: - - "body" + - 'body' properties: body: type: string description: The message text that will be sent to the client. - example: "What a beautiful day. I love it" + example: 'What a beautiful day. I love it' responses: - "200": + '200': description: Message was sent. content: application/json: @@ -1442,14 +1729,14 @@ paths: messages: type: string example: sent - "500": + '500': description: Message was not sent to the client content: application/json: schema: type: object properties: - error: + error: type: string description: message explaining what went wrong sending the message to the client @@ -1457,7 +1744,7 @@ paths: post: summary: Create an access token. description: Create a single access token that has access to the access scopes provided. - tags: ["Integrations"] + tags: ['Integrations'] security: - AdminBasicAuth: [] requestBody: @@ -1476,7 +1763,7 @@ paths: type: string responses: - "200": + '200': description: Token was created. content: application/json: @@ -1488,13 +1775,13 @@ paths: example: your new token token: type: string - example: "zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI=" + example: 'zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI=' /api/admin/accesstokens/delete: post: summary: Delete an access token. description: Delete a single access token. - tags: ["Integrations"] + tags: ['Integrations'] security: - AdminBasicAuth: [] requestBody: @@ -1509,7 +1796,7 @@ paths: description: The token to delete responses: - "200": + '200': description: Token was deleted. content: application/json: @@ -1527,11 +1814,11 @@ paths: get: summary: Return all access tokens. description: Return all of the available access tokens. - tags: ["Integrations"] + tags: ['Integrations'] security: - AdminBasicAuth: [] responses: - "200": + '200': description: Tokens are returned content: application/json: @@ -1544,60 +1831,60 @@ paths: get: summary: Return all webhooks. description: Return all of the configured webhooks for external events. - tags: ["Admin"] + tags: ['Admin'] security: - AdminBasicAuth: [] responses: - "200": + '200': description: Webhooks are returned content: application/json: schema: - $ref: "#/components/schemas/Webhook" + $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"] + 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. + 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": + '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"] + tags: ['Admin'] security: - AdminBasicAuth: [] requestBody: @@ -1611,14 +1898,14 @@ paths: type: string description: The webhook id to delete responses: - "200": + '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"] + tags: ['Admin'] security: - AdminBasicAuth: [] requestBody: @@ -1638,7 +1925,7 @@ paths: type: string responses: - "200": + '200': description: Token was created. content: application/json: @@ -1650,51 +1937,50 @@ paths: example: your new token token: type: string - example: "zG2xO-mHTFnelCp5xaIkYEFWcPhoOswOSRmFC1BkI=" - + 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"] + tags: ['Integrations'] security: - AccessToken: [] responses: - "200": - $ref: "#/components/responses/ClientsResponse" + '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 + 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: @@ -1714,9 +2000,129 @@ paths: items: type: string description: IDs of the chat messages you wish to change the visibility of. - tags: ["Integrations"] + tags: ['Integrations'] security: - AccessToken: [] responses: - "200": - $ref: "#/components/responses/BasicResponse" \ No newline at end of file + '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'