diff options
-rw-r--r-- | management/editor/editor.go | 9 | ||||
-rw-r--r-- | system/admin/handlers.go | 62 |
2 files changed, 69 insertions, 2 deletions
diff --git a/management/editor/editor.go b/management/editor/editor.go index 404e7cd..66a0a7d 100644 --- a/management/editor/editor.go +++ b/management/editor/editor.go @@ -149,12 +149,15 @@ func Form(post Editable, fields ...Field) ([]byte, error) { del = form.find('button.delete-post'), external = form.find('.post-controls.external'), id = form.find('input[name=id]'), - timestamp = $('.__ponzu.content-only'); + timestamp = $('.__ponzu.content-only'), + slug = $('input[name=slug]'), + hiddenInput = $('input[type=hidden]'); // hide if this is a new post, or a non-post editor page if (id.val() === '-1' || form.attr('action') !== '/admin/edit') { del.hide(); external.hide(); + hiddenInput.parent().hide(); } // hide approval if not on a pending content item @@ -162,9 +165,11 @@ func Form(post Editable, fields ...Field) ([]byte, error) { external.hide(); } - // no timestamp on addons + // no timestamp, slug or hidden input parents visible on addons if (form.attr('action') === '/admin/addon') { timestamp.hide(); + slug.hide(); + hiddenInput.parent().hide(); } save.on('click', function(e) { diff --git a/system/admin/handlers.go b/system/admin/handlers.go index a8ca681..a7d367b 100644 --- a/system/admin/handlers.go +++ b/system/admin/handlers.go @@ -2181,6 +2181,68 @@ func addonHandler(res http.ResponseWriter, req *http.Request) { res.Write(addonView) case http.MethodPost: + // save req.Form + err := req.ParseMultipartForm(1024 * 1024 * 4) // maxMemory 4MB + if err != nil { + log.Println(err) + res.WriteHeader(http.StatusInternalServerError) + errView, err := Error500() + if err != nil { + return + } + + res.Write(errView) + return + } + + name := req.FormValue("addon_name") + id := req.FormValue("addon_reverse_dns") + + at, ok := addon.Types[id] + if !ok { + log.Println("Error: addon", name, "has no record in addon.Types map at", id) + res.WriteHeader(http.StatusBadRequest) + errView, err := Error400() + if err != nil { + return + } + + res.Write(errView) + return + } + + // if Hookable, call BeforeSave prior to saving + h, ok := at().(item.Hookable) + if ok { + err := h.BeforeSave(req) + if err != nil { + log.Println(err) + res.WriteHeader(http.StatusInternalServerError) + errView, err := Error500() + if err != nil { + return + } + + res.Write(errView) + return + } + } + + err := db.SetAddon(req.Form) + if err != nil { + log.Println("Error saving addon:", name, err) + res.WriteHeader(http.StatusInternalServerError) + errView, err := Error500() + if err != nil { + return + } + + res.Write(errView) + return + } + + http.Redirect(res, req, "/admin/addon?id="+id, http.StatusFound) + default: res.WriteHeader(http.StatusBadRequest) errView, err := Error405() |