add https only forwarding
parent
c8e09a989d
commit
fc7451ab40
Binary file not shown.
21
main.go
21
main.go
|
|
@ -33,6 +33,7 @@ func main() {
|
||||||
fs.Append(args.STRING, "p", "port to serve", "8100")
|
fs.Append(args.STRING, "p", "port to serve", "8100")
|
||||||
fs.Append(args.BOOL, "md", "whether to render markdown as html", true)
|
fs.Append(args.BOOL, "md", "whether to render markdown as html", true)
|
||||||
fs.Append(args.BOOL, "ro", "read only mode", false)
|
fs.Append(args.BOOL, "ro", "read only mode", false)
|
||||||
|
fs.Append(args.BOOL, "https", "https only", false)
|
||||||
fs.Append(args.STRING, "md-css", "css to load for md", "/dev/null")
|
fs.Append(args.STRING, "md-css", "css to load for md", "/dev/null")
|
||||||
fs.Append(args.STRING, "md-class", "class to wrap md", "phb")
|
fs.Append(args.STRING, "md-class", "class to wrap md", "phb")
|
||||||
fs.Append(args.STRING, "d", "static path to serve", "./public")
|
fs.Append(args.STRING, "d", "static path to serve", "./public")
|
||||||
|
|
@ -43,6 +44,7 @@ func main() {
|
||||||
d := fs.Get("d").GetString()
|
d := fs.Get("d").GetString()
|
||||||
md := fs.Get("md").GetBool()
|
md := fs.Get("md").GetBool()
|
||||||
ro := fs.Get("ro").GetBool()
|
ro := fs.Get("ro").GetBool()
|
||||||
|
https := fs.Get("https").GetBool()
|
||||||
mdCss := fs.Get("md-css").GetString()
|
mdCss := fs.Get("md-css").GetString()
|
||||||
mdClass := fs.Get("md-class").GetString()
|
mdClass := fs.Get("md-class").GetString()
|
||||||
if mdCss != "" {
|
if mdCss != "" {
|
||||||
|
|
@ -91,15 +93,15 @@ func main() {
|
||||||
}
|
}
|
||||||
p := strings.TrimPrefix(fs.Get("p").GetString(), ":")
|
p := strings.TrimPrefix(fs.Get("p").GetString(), ":")
|
||||||
|
|
||||||
http.Handle("/", http.HandlerFunc(handler(ro, d, md, mdCss, mdClass)))
|
http.Handle("/", http.HandlerFunc(handler(https, ro, d, md, mdCss, mdClass)))
|
||||||
|
|
||||||
log.Printf("Serving %s on HTTP port: %s\n", d, p)
|
log.Printf("Serving %s on HTTP port: %s\n", d, p)
|
||||||
|
|
||||||
log.Fatal(http.ListenAndServe(":"+p, nil))
|
log.Fatal(http.ListenAndServe(":"+p, nil))
|
||||||
}
|
}
|
||||||
|
|
||||||
func handler(ro bool, d string, md bool, mdCss, mdClass string) http.HandlerFunc {
|
func handler(https, ro bool, d string, md bool, mdCss, mdClass string) http.HandlerFunc {
|
||||||
return gzip(endpoints(ro, withDel(ro, withMD(d, md, mdCss, mdClass, fserve(d)))))
|
return httpsOnly(https, gzip(endpoints(ro, withDel(ro, withMD(d, md, mdCss, mdClass, fserve(d))))))
|
||||||
}
|
}
|
||||||
|
|
||||||
func writeMeta(w http.ResponseWriter) {
|
func writeMeta(w http.ResponseWriter) {
|
||||||
|
|
@ -120,6 +122,17 @@ func writeForm(w http.ResponseWriter) {
|
||||||
`, ENDPOINT_UPLOAD)
|
`, ENDPOINT_UPLOAD)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func httpsOnly(https bool, foo http.HandlerFunc) http.HandlerFunc {
|
||||||
|
return func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if https && r.URL.Scheme != "https" {
|
||||||
|
r.URL.Scheme = "https"
|
||||||
|
http.Redirect(w, r, r.URL.String(), http.StatusSeeOther)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
foo(w, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func gzip(foo http.HandlerFunc) http.HandlerFunc {
|
func gzip(foo http.HandlerFunc) http.HandlerFunc {
|
||||||
return func(w http.ResponseWriter, r *http.Request) {
|
return func(w http.ResponseWriter, r *http.Request) {
|
||||||
if gziphttp.Can(r) {
|
if gziphttp.Can(r) {
|
||||||
|
|
@ -208,7 +221,7 @@ func withDel(ro bool, foo http.HandlerFunc) http.HandlerFunc {
|
||||||
foo(w, r)
|
foo(w, r)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
fmt.Fprintln(w, `<a href=".."><input type="button" style="padding: .15em 4em .35em 4em" value=".."/></a>`+"\n")
|
fmt.Fprintln(w, `<a href=".."><input type="button" style="padding: .15em 4em .35em 4em" value=".."/></a>`)
|
||||||
w2 := httptest.NewRecorder()
|
w2 := httptest.NewRecorder()
|
||||||
foo(w2, r)
|
foo(w2, r)
|
||||||
b := bytes.Split(w2.Body.Bytes(), []byte("\n"))
|
b := bytes.Split(w2.Body.Bytes(), []byte("\n"))
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue