From 64a85e68aa25b8ba2a70f2cd93abba7fdd484fc5 Mon Sep 17 00:00:00 2001 From: Gabe Kangas Date: Wed, 14 Oct 2020 09:38:48 -0700 Subject: [PATCH] Update extra page content API (#240) * Mark change stream key api as pre-release * Add API for changing extra page content. Renanme usercontent -> pagecontent. closes #236 --- config/config.go | 4 +-- controllers/admin/changePageContent.go | 35 ++++++++++++++++++++ openapi.yaml | 46 +++++++++++++++++++++++--- router/router.go | 3 ++ webroot/js/app.js | 6 ++-- 5 files changed, 84 insertions(+), 10 deletions(-) create mode 100644 controllers/admin/changePageContent.go diff --git a/config/config.go b/config/config.go index 4dcec84c0..de389ea59 100644 --- a/config/config.go +++ b/config/config.go @@ -36,7 +36,7 @@ type InstanceDetails struct { SocialHandles []socialHandle `yaml:"socialHandles" json:"socialHandles"` Version string `json:"version"` NSFW bool `yaml:"nsfw" json:"nsfw"` - ExtraUserContent string `json:"extraUserContent"` + ExtraPageContent string `json:"extraPageContent"` } type logo struct { @@ -122,7 +122,7 @@ func (c *config) load(filePath string) error { customContentMarkdownData, err := ioutil.ReadFile(ExtraInfoFile) if err == nil { customContentMarkdownString := string(customContentMarkdownData) - c.InstanceDetails.ExtraUserContent = utils.RenderSimpleMarkdown(customContentMarkdownString) + c.InstanceDetails.ExtraPageContent = utils.RenderSimpleMarkdown(customContentMarkdownString) } return nil diff --git a/controllers/admin/changePageContent.go b/controllers/admin/changePageContent.go new file mode 100644 index 000000000..f99634aee --- /dev/null +++ b/controllers/admin/changePageContent.go @@ -0,0 +1,35 @@ +package admin + +import ( + "encoding/json" + "net/http" + + "github.com/owncast/owncast/config" + "github.com/owncast/owncast/controllers" + + log "github.com/sirupsen/logrus" +) + +// ChangeExtraPageContent will change the optional page content +func ChangeExtraPageContent(w http.ResponseWriter, r *http.Request) { + if r.Method != "POST" { + controllers.WriteSimpleResponse(w, false, r.Method+" not supported") + return + } + + decoder := json.NewDecoder(r.Body) + var request changeExtraPageContentRequest + err := decoder.Decode(&request) + if err != nil { + log.Errorln(err) + controllers.WriteSimpleResponse(w, false, "") + return + } + + config.Config.InstanceDetails.ExtraPageContent = request.Key + controllers.WriteSimpleResponse(w, true, "changed") +} + +type changeExtraPageContentRequest struct { + Key string `json:"content"` +} diff --git a/openapi.yaml b/openapi.yaml index 8ab5692da..8d0fab8b1 100644 --- a/openapi.yaml +++ b/openapi.yaml @@ -1,8 +1,12 @@ 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. - version: '0.0.3' + description: Owncast is a self-hosted live video and web chat server for use with existing popular broadcasting software. The following APIs represent the state in the development master branch. + version: '0.0.3-development' + contact: + name: Gabe Kangas + email: gabek@real-ity.com + url: http://owncast.online x-logo: url: >-  @@ -112,7 +116,7 @@ components: url: type: string example: http://github.com/owncast/owncast - extraUserContent: + extraPageContent: type: string description: Additional HTML content to render in the body of the web interface. example: "

This page is super cool!" @@ -482,7 +486,7 @@ paths: /api/admin/changekey: post: - summary: Update Stream Key + summary: Update Stream Key. Pre-release, do not use. description: Change the stream key in memory, but not in the config file. This will require all broadcasters to be reconfigured to connect again. tags: ["Admin"] security: @@ -499,7 +503,39 @@ paths: type: string responses: '200': - description: Stream was disconnected. + description: Key was changed. + content: + application/json: + schema: + type: object + properties: + success: + type: boolean + example: true + message: + type: string + example: changed + + /api/admin/changeExtraPageContent: + post: + summary: Change the extra page content. Pre-release, do not use. + description: Change the extra page content in memory, but not on disk. + tags: ["Admin"] + security: + - AdminBasicAuth: [] + requestBody: + description: "" + required: true + content: + application/json: + schema: + type: object + properties: + content: + type: string + responses: + '200': + description: Page content was changed. content: application/json: schema: diff --git a/router/router.go b/router/router.go index 9fb6b555b..b199a80c3 100644 --- a/router/router.go +++ b/router/router.go @@ -57,6 +57,9 @@ func Start() error { // Change the current streaming key in memory http.HandleFunc("/api/admin/changekey", middleware.RequireAdminAuth(admin.ChangeStreamKey)) + // Change the extra page content in memory + http.HandleFunc("/api/admin/changeextrapagecontent", middleware.RequireAdminAuth(admin.ChangeExtraPageContent)) + // Server config http.HandleFunc("/api/admin/serverconfig", middleware.RequireAdminAuth(admin.GetServerConfig)) diff --git a/webroot/js/app.js b/webroot/js/app.js index 71beb289f..3fa1453a7 100644 --- a/webroot/js/app.js +++ b/webroot/js/app.js @@ -55,7 +55,7 @@ export default class App extends Component { generateAvatar(`${this.username}${Date.now()}`), configData: {}, - extraUserContent: '', + extraPageContent: '', playerActive: false, // player object is active streamOnline: false, // stream is active/online @@ -347,7 +347,7 @@ export default class App extends Component { summary, tags = [], title, - extraUserContent, + extraPageContent, } = configData; const { small: smallLogo = TEMP_IMAGE, @@ -485,7 +485,7 @@ export default class App extends Component {