diff options
author | Alex Scerba <alex@scerba.org> | 2024-09-27 18:56:29 -0400 |
---|---|---|
committer | Alex Scerba <alex@scerba.org> | 2024-09-27 18:56:29 -0400 |
commit | 2782bafcfdb69ef7b69a51a717a6bd35095e9369 (patch) | |
tree | 32d69f68fe2dbc6b9cc5a5ac8ff970d79f348156 /cmd/http/main.go | |
parent | 1208c2e7e7e79cfe122f8d5f38160a0611cc9dfe (diff) |
Add base files
Diffstat (limited to 'cmd/http/main.go')
-rw-r--r-- | cmd/http/main.go | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/cmd/http/main.go b/cmd/http/main.go new file mode 100644 index 0000000..661e6fc --- /dev/null +++ b/cmd/http/main.go @@ -0,0 +1,79 @@ +package main + +import ( + "flag" + "log" + "net/http" + "os" + "strings" +) + +var ( + fullchain = "/etc/letsencrypt/live/alexscerba.com/fullchain.pem" + privkey = "/etc/letsencrypt/live/alexscerba.com/privkey.pem" +) + +type application struct { + errorLog *log.Logger + infoLog *log.Logger +} + +func (app *application) httpsRedirect(w http.ResponseWriter, req *http.Request) { + // remove/add not default ports from req.Host + target := "https://" + req.Host + req.URL.Path + if len(req.URL.RawQuery) > 0 { + target += "?" + req.URL.RawQuery + } + app.infoLog.Printf("redirect to: %s", target) + http.Redirect(w, req, target, + // see comments below and consider the codes 308, 302, or 301 + http.StatusMovedPermanently) +} + +func (app *application) wwwRedirect(h http.Handler) http.Handler { + return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { + if !strings.HasPrefix(r.Host, "www.") { + http.Redirect(w, r, "https://www."+r.Host+r.RequestURI, 302) + return + } + + h.ServeHTTP(w, r) + }) +} + +func main() { + addr := flag.String("addr", ":4000", "HTTP Network Address") + flag.Parse() // required before flag is used + + infoLog := log.New(os.Stdout, "INFO\t", log.Ldate|log.Ltime) + errorLog := log.New(os.Stderr, "ERROR\t", log.Ldate|log.Ltime|log.Lshortfile) + + app := &application{ + errorLog: errorLog, + infoLog: infoLog, + } + + mux := http.NewServeMux() + + fs := http.FileServer(http.Dir("./static")) + mux.Handle("/static/", http.StripPrefix("/static/", fs)) + + mux.HandleFunc("/about", app.about) + mux.HandleFunc("/about/", app.about) + mux.HandleFunc("/projects", app.post) + mux.HandleFunc("/projects/", app.post) + mux.HandleFunc("/", app.home) + + if *addr == ":443" { + www := app.wwwRedirect(mux) + + infoLog.Printf("Starting TLS server on %s...\n", *addr) + go http.ListenAndServe(":80", www) + err := http.ListenAndServeTLS(*addr, fullchain, privkey, gzipHandler(www)) + log.Fatal(err) + } else { + infoLog.Printf("Starting server on %s...\n", *addr) + err := http.ListenAndServe(*addr, gzipHandler(mux)) + log.Fatal(err) + } +} |