mirror of
https://github.com/ordinary-dev/phoenix
synced 2024-09-20 03:40:29 +05:00
44 lines
1,004 B
Go
44 lines
1,004 B
Go
|
package pages
|
||
|
|
||
|
import (
|
||
|
"net/http"
|
||
|
|
||
|
log "github.com/sirupsen/logrus"
|
||
|
|
||
|
"github.com/ordinary-dev/phoenix/database"
|
||
|
"github.com/ordinary-dev/phoenix/jwttoken"
|
||
|
)
|
||
|
|
||
|
func ShowSignInForm(w http.ResponseWriter, _ *http.Request) {
|
||
|
err := Render("auth.html.tmpl", w, map[string]any{
|
||
|
"title": "Sign in",
|
||
|
"description": "Authorization is required to view this page.",
|
||
|
"button": "Sign in",
|
||
|
"formAction": "/signin",
|
||
|
})
|
||
|
if err != nil {
|
||
|
log.Error(err)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func AuthorizeUser(w http.ResponseWriter, r *http.Request) {
|
||
|
// Check credentials.
|
||
|
username := r.FormValue("username")
|
||
|
password := r.FormValue("password")
|
||
|
_, err := database.AuthorizeAdmin(username, password)
|
||
|
if err != nil {
|
||
|
ShowError(w, http.StatusUnauthorized, err)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
// Generate an access token.
|
||
|
token, err := jwttoken.GetJWTToken()
|
||
|
if err != nil {
|
||
|
ShowError(w, http.StatusInternalServerError, err)
|
||
|
return
|
||
|
}
|
||
|
http.SetCookie(w, jwttoken.TokenToCookie(token))
|
||
|
|
||
|
http.Redirect(w, r, "/", http.StatusFound)
|
||
|
}
|