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
This commit is contained in:
parent
d7c3991b59
commit
64a85e68aa
@ -36,7 +36,7 @@ type InstanceDetails struct {
|
|||||||
SocialHandles []socialHandle `yaml:"socialHandles" json:"socialHandles"`
|
SocialHandles []socialHandle `yaml:"socialHandles" json:"socialHandles"`
|
||||||
Version string `json:"version"`
|
Version string `json:"version"`
|
||||||
NSFW bool `yaml:"nsfw" json:"nsfw"`
|
NSFW bool `yaml:"nsfw" json:"nsfw"`
|
||||||
ExtraUserContent string `json:"extraUserContent"`
|
ExtraPageContent string `json:"extraPageContent"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type logo struct {
|
type logo struct {
|
||||||
@ -122,7 +122,7 @@ func (c *config) load(filePath string) error {
|
|||||||
customContentMarkdownData, err := ioutil.ReadFile(ExtraInfoFile)
|
customContentMarkdownData, err := ioutil.ReadFile(ExtraInfoFile)
|
||||||
if err == nil {
|
if err == nil {
|
||||||
customContentMarkdownString := string(customContentMarkdownData)
|
customContentMarkdownString := string(customContentMarkdownData)
|
||||||
c.InstanceDetails.ExtraUserContent = utils.RenderSimpleMarkdown(customContentMarkdownString)
|
c.InstanceDetails.ExtraPageContent = utils.RenderSimpleMarkdown(customContentMarkdownString)
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
35
controllers/admin/changePageContent.go
Normal file
35
controllers/admin/changePageContent.go
Normal file
@ -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"`
|
||||||
|
}
|
46
openapi.yaml
46
openapi.yaml
File diff suppressed because one or more lines are too long
@ -57,6 +57,9 @@ func Start() error {
|
|||||||
// Change the current streaming key in memory
|
// Change the current streaming key in memory
|
||||||
http.HandleFunc("/api/admin/changekey", middleware.RequireAdminAuth(admin.ChangeStreamKey))
|
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
|
// Server config
|
||||||
http.HandleFunc("/api/admin/serverconfig", middleware.RequireAdminAuth(admin.GetServerConfig))
|
http.HandleFunc("/api/admin/serverconfig", middleware.RequireAdminAuth(admin.GetServerConfig))
|
||||||
|
|
||||||
|
@ -55,7 +55,7 @@ export default class App extends Component {
|
|||||||
generateAvatar(`${this.username}${Date.now()}`),
|
generateAvatar(`${this.username}${Date.now()}`),
|
||||||
|
|
||||||
configData: {},
|
configData: {},
|
||||||
extraUserContent: '',
|
extraPageContent: '',
|
||||||
|
|
||||||
playerActive: false, // player object is active
|
playerActive: false, // player object is active
|
||||||
streamOnline: false, // stream is active/online
|
streamOnline: false, // stream is active/online
|
||||||
@ -347,7 +347,7 @@ export default class App extends Component {
|
|||||||
summary,
|
summary,
|
||||||
tags = [],
|
tags = [],
|
||||||
title,
|
title,
|
||||||
extraUserContent,
|
extraPageContent,
|
||||||
} = configData;
|
} = configData;
|
||||||
const {
|
const {
|
||||||
small: smallLogo = TEMP_IMAGE,
|
small: smallLogo = TEMP_IMAGE,
|
||||||
@ -485,7 +485,7 @@ export default class App extends Component {
|
|||||||
<div
|
<div
|
||||||
id="extra-user-content"
|
id="extra-user-content"
|
||||||
class="extra-user-content px-8"
|
class="extra-user-content px-8"
|
||||||
dangerouslySetInnerHTML=${{ __html: extraUserContent }}
|
dangerouslySetInnerHTML=${{ __html: extraPageContent }}
|
||||||
></div>
|
></div>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user