2020-11-14 13:03:06 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"github.com/bouncepaw/mycorrhiza/templates"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/user"
|
2021-02-17 18:41:35 +00:00
|
|
|
"github.com/bouncepaw/mycorrhiza/util"
|
2020-11-14 13:03:06 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
http.HandleFunc("/login", handlerLogin)
|
|
|
|
http.HandleFunc("/login-data", handlerLoginData)
|
|
|
|
http.HandleFunc("/logout", handlerLogout)
|
|
|
|
http.HandleFunc("/logout-confirm", handlerLogoutConfirm)
|
|
|
|
}
|
|
|
|
|
|
|
|
func handlerLogout(w http.ResponseWriter, rq *http.Request) {
|
|
|
|
var (
|
|
|
|
u = user.FromRequest(rq)
|
|
|
|
can = u != nil
|
|
|
|
)
|
|
|
|
w.Header().Set("Content-Type", "text/html;charset=utf-8")
|
|
|
|
if can {
|
|
|
|
log.Println("User", u.Name, "tries to log out")
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
} else {
|
|
|
|
log.Println("Unknown user tries to log out")
|
|
|
|
w.WriteHeader(http.StatusForbidden)
|
|
|
|
}
|
2021-01-24 07:30:14 +00:00
|
|
|
w.Write([]byte(base("Logout?", templates.LogoutHTML(can), u)))
|
2020-11-14 13:03:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func handlerLogoutConfirm(w http.ResponseWriter, rq *http.Request) {
|
|
|
|
user.LogoutFromRequest(w, rq)
|
|
|
|
http.Redirect(w, rq, "/", http.StatusSeeOther)
|
|
|
|
}
|
|
|
|
|
|
|
|
func handlerLoginData(w http.ResponseWriter, rq *http.Request) {
|
|
|
|
log.Println(rq.URL)
|
|
|
|
var (
|
2021-02-17 18:41:35 +00:00
|
|
|
username = util.CanonicalName(rq.PostFormValue("username"))
|
2020-11-14 13:03:06 +00:00
|
|
|
password = rq.PostFormValue("password")
|
|
|
|
err = user.LoginDataHTTP(w, rq, username, password)
|
|
|
|
)
|
|
|
|
if err != "" {
|
2021-01-24 07:30:14 +00:00
|
|
|
w.Write([]byte(base(err, templates.LoginErrorHTML(err), user.EmptyUser())))
|
2020-11-14 13:03:06 +00:00
|
|
|
} else {
|
|
|
|
http.Redirect(w, rq, "/", http.StatusSeeOther)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func handlerLogin(w http.ResponseWriter, rq *http.Request) {
|
|
|
|
log.Println(rq.URL)
|
|
|
|
w.Header().Set("Content-Type", "text/html;charset=utf-8")
|
|
|
|
if user.AuthUsed {
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
|
|
} else {
|
|
|
|
w.WriteHeader(http.StatusForbidden)
|
|
|
|
}
|
2021-01-24 07:30:14 +00:00
|
|
|
w.Write([]byte(base("Login", templates.LoginHTML(), user.EmptyUser())))
|
2020-11-14 13:03:06 +00:00
|
|
|
}
|