mirror of
https://github.com/ordinary-dev/phoenix
synced 2024-09-20 03:40:29 +05:00
Ivan R.
6d25c4e8af
With the release of Go 1.22, the standard library now has all the necessary functions that allow us to abandon Gin. I hope this rewrite will lower the entry barrier for new developers. As a nice bonus, the size of the program has decreased from 20 to 15.4 MB. To solve issue #81, request logging has been improved. Now all errors are displayed in the logs.
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)
|
|
}
|