update url routing, simplify; new templates
parent
60eefa3915
commit
93b0ab8dd9
|
@ -4,6 +4,7 @@ import (
|
|||
"io/ioutil"
|
||||
"net/http"
|
||||
"os"
|
||||
"strings"
|
||||
|
||||
"github.com/hacdias/caddy-hugo/page"
|
||||
"github.com/spf13/hugo/commands"
|
||||
|
@ -15,7 +16,9 @@ type fileInfo struct {
|
|||
}
|
||||
|
||||
// Execute sth
|
||||
func Execute(w http.ResponseWriter, r *http.Request, filename string) (int, error) {
|
||||
func Execute(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||
filename := strings.Replace(r.URL.Path, "edit/", "", 1)
|
||||
|
||||
if r.Method == "POST" {
|
||||
r.ParseForm()
|
||||
err := ioutil.WriteFile(filename, []byte(r.Form["content"][0]), 0666)
|
||||
|
|
55
hugo.go
55
hugo.go
|
@ -15,15 +15,6 @@ import (
|
|||
"github.com/spf13/hugo/commands"
|
||||
)
|
||||
|
||||
const (
|
||||
mainURL string = "/admin"
|
||||
contentURL string = mainURL + "/content"
|
||||
browseURL string = mainURL + "/browse"
|
||||
editURL string = mainURL + "/edit"
|
||||
settingsURL string = mainURL + "/settings"
|
||||
assetsURL string = mainURL + "/assets"
|
||||
)
|
||||
|
||||
// Setup function
|
||||
func Setup(c *setup.Controller) (middleware.Middleware, error) {
|
||||
commands.Execute()
|
||||
|
@ -44,21 +35,9 @@ func (h handler) ServeHTTP(w http.ResponseWriter, r *http.Request) (int, error)
|
|||
}
|
||||
|
||||
func route(w http.ResponseWriter, r *http.Request) (int, error) {
|
||||
if urlMatch(r, contentURL) {
|
||||
// content folder management
|
||||
w.Write([]byte("Show Content Folder"))
|
||||
} else if urlMatch(r, browseURL) {
|
||||
// browse files
|
||||
w.Write([]byte("Show Data Folder"))
|
||||
} else if urlMatch(r, editURL) {
|
||||
// edit file
|
||||
return edit.Execute(w, r, strings.Replace(r.URL.Path, editURL+"/", "", 1))
|
||||
} else if urlMatch(r, settingsURL) {
|
||||
// edit settings
|
||||
w.Write([]byte("Settings Page"))
|
||||
page := parseComponents(r)[1]
|
||||
|
||||
} else if urlMatch(r, assetsURL) {
|
||||
// assets like css, javascript and images
|
||||
if page == "assets" {
|
||||
filename := strings.Replace(r.URL.Path, assetsURL, "static", 1)
|
||||
file, err := assets.Asset(filename)
|
||||
|
||||
|
@ -73,9 +52,14 @@ func route(w http.ResponseWriter, r *http.Request) (int, error) {
|
|||
header.Set("Content-Type", mime)
|
||||
|
||||
w.Write(file)
|
||||
} else if r.URL.Path == mainURL || r.URL.Path == mainURL+"/" {
|
||||
// dashboard
|
||||
w.Write([]byte("Dashboard"))
|
||||
} else if page == "content" {
|
||||
w.Write([]byte("Content Page"))
|
||||
} else if page == "browse" {
|
||||
w.Write([]byte("Show Data Folder"))
|
||||
} else if page == "edit" {
|
||||
return edit.Execute(w, r)
|
||||
} else if page == "settings" {
|
||||
w.Write([]byte("Settings Page"))
|
||||
} else {
|
||||
return 404, nil
|
||||
}
|
||||
|
@ -83,6 +67,21 @@ func route(w http.ResponseWriter, r *http.Request) (int, error) {
|
|||
return 200, nil
|
||||
}
|
||||
|
||||
func urlMatch(r *http.Request, str string) bool {
|
||||
return middleware.Path(r.URL.Path).Matches(str)
|
||||
func parseComponents(r *http.Request) []string {
|
||||
//The URL that the user queried.
|
||||
path := r.URL.Path
|
||||
path = strings.TrimSpace(path)
|
||||
//Cut off the leading and trailing forward slashes, if they exist.
|
||||
//This cuts off the leading forward slash.
|
||||
if strings.HasPrefix(path, "/") {
|
||||
path = path[1:]
|
||||
}
|
||||
//This cuts off the trailing forward slash.
|
||||
if strings.HasSuffix(path, "/") {
|
||||
cutOffLastCharLen := len(path) - 1
|
||||
path = path[:cutOffLastCharLen]
|
||||
}
|
||||
//We need to isolate the individual components of the path.
|
||||
components := strings.Split(path, "/")
|
||||
return components
|
||||
}
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
$("textarea").resizable();
|
|
@ -5,7 +5,7 @@
|
|||
|
||||
<h1>Editing {{ .Name }}</h1>
|
||||
|
||||
<form id="editForm" method="POST" action="">
|
||||
<form method="POST" action="">
|
||||
<textarea name="content">{{ .Content }}</textarea>
|
||||
<input type="submit" value="Save">
|
||||
</form>
|
||||
|
|
Loading…
Reference in New Issue