slightly less basic routing
This commit is contained in:
parent
364f98cbce
commit
0be3507b63
41
main.go
41
main.go
@ -3,6 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -22,18 +23,43 @@ type RootHandler struct {
|
|||||||
Pages PageProvider
|
Pages PageProvider
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type AdminHandler struct {
|
||||||
|
Sessions SessionProvider
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *AdminHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
|
w.Write([]byte("admin route"))
|
||||||
|
}
|
||||||
|
|
||||||
func (h *RootHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
func (h *RootHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||||
if r.URL.Path == "/admin" {
|
if strings.HasPrefix(r.URL.Path, "/admin") {
|
||||||
w.Write([]byte("admin route"))
|
(&AdminHandler{
|
||||||
|
Sessions: h.Sessions,
|
||||||
|
}).ServeHTTP(w, r)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
// attempt to serve from the managed pages
|
||||||
page, err := h.Pages.Page(r.URL.Path)
|
page, err := h.Pages.Page(r.URL.Path)
|
||||||
if err == ErrPageNotFound {
|
if err == nil {
|
||||||
w.WriteHeader(http.StatusNotFound)
|
w.Write(page.Contents)
|
||||||
w.Write([]byte("not found"))
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
w.Write(page.Contents)
|
// fall back to serving out of the static directory, but:
|
||||||
|
// 1. prevent the generated indexes from rendering
|
||||||
|
if strings.HasSuffix(r.URL.Path, "/") {
|
||||||
|
http.NotFound(w, r)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
// 2. prevent hidden paths from rendering
|
||||||
|
for _, seg := range strings.Split(r.URL.Path, "/") {
|
||||||
|
if strings.HasPrefix(seg, ".") {
|
||||||
|
http.NotFound(w, r)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// finally, use the built-in fileserver to serve
|
||||||
|
fs := http.FileServer(http.Dir("./static"))
|
||||||
|
fs.ServeHTTP(w, r)
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
@ -44,6 +70,9 @@ func main() {
|
|||||||
handler.Pages.Save("foo", &Page{
|
handler.Pages.Save("foo", &Page{
|
||||||
Contents: []byte("foobar"),
|
Contents: []byte("foobar"),
|
||||||
})
|
})
|
||||||
|
handler.Pages.Save("index", &Page{
|
||||||
|
Contents: []byte("root"),
|
||||||
|
})
|
||||||
|
|
||||||
err := http.ListenAndServe(":8080", handler)
|
err := http.ListenAndServe(":8080", handler)
|
||||||
log.Fatalf("server error: %v", err)
|
log.Fatalf("server error: %v", err)
|
||||||
|
4
model.go
4
model.go
@ -59,11 +59,11 @@ func (i *Index) Page(key string) (*Page, error) {
|
|||||||
// overwriting any that may have existed before.
|
// overwriting any that may have existed before.
|
||||||
// `foo/` is stored as a page named 'foo' in the current index;
|
// `foo/` is stored as a page named 'foo' in the current index;
|
||||||
// default 'index' files should be explicitly passed as such.
|
// default 'index' files should be explicitly passed as such.
|
||||||
// The empty key or `/` are invalid and result in an error.
|
// The empty key or `/` are turned into the "index" key.
|
||||||
// Leading slashes are stripped.
|
// Leading slashes are stripped.
|
||||||
func (i *Index) Save(key string, page *Page) error {
|
func (i *Index) Save(key string, page *Page) error {
|
||||||
if key == "" || key == "/" {
|
if key == "" || key == "/" {
|
||||||
return fmt.Errorf("invalid page key")
|
key = "index"
|
||||||
}
|
}
|
||||||
if key[0] == '/' { // strip leading slash
|
if key[0] == '/' { // strip leading slash
|
||||||
key = key[1:]
|
key = key[1:]
|
||||||
|
4
static/.gitignore
vendored
Normal file
4
static/.gitignore
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
# Ignore all files in this dir...
|
||||||
|
*
|
||||||
|
# ... except for this one.
|
||||||
|
!.gitignore
|
Loading…
Reference in New Issue
Block a user