You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
74 lines
1.7 KiB
74 lines
1.7 KiB
|
4 days ago
|
package auth
|
||
|
2 months ago
|
|
||
|
|
import (
|
||
|
|
"github.com/gofiber/fiber/v2"
|
||
|
|
_ "github.com/mattn/go-sqlite3"
|
||
|
|
sq "github.com/Masterminds/squirrel"
|
||
|
|
|
||
|
2 months ago
|
"MY/webapp/data"
|
||
|
2 months ago
|
. "MY/webapp/common"
|
||
|
2 months ago
|
)
|
||
|
|
|
||
|
4 days ago
|
func GetApiAuthCheck(c *fiber.Ctx) error {
|
||
|
4 days ago
|
_, err := Check(c, false)
|
||
|
4 days ago
|
// auth failure or not authed is determined by err, with nil meaning YES AUTHED
|
||
|
|
return c.JSON(fiber.Map{"is_authed": err == nil})
|
||
|
|
}
|
||
|
|
|
||
|
2 months ago
|
func GetApiLogout(c *fiber.Ctx) error {
|
||
|
|
err := LogoutUser(c)
|
||
|
|
if err != nil { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
return c.Redirect("/")
|
||
|
|
}
|
||
|
|
|
||
|
|
func PostApiRegister(c *fiber.Ctx) error {
|
||
|
|
user, err := ReceivePost[data.User](c)
|
||
|
|
if err != nil { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
err = SetUserPassword(user)
|
||
|
|
if err != nil { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
sql, args, err := sq.Insert("user").
|
||
|
|
Columns("username", "email", "password").
|
||
|
|
Values(user.Username, user.Email, user.Password).ToSql()
|
||
|
|
|
||
|
|
_, err = data.Exec(err, sql, args...)
|
||
|
|
if err != nil { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
return c.Redirect("/login/")
|
||
|
|
}
|
||
|
|
|
||
|
|
func PostApiLogin(c *fiber.Ctx) error {
|
||
|
|
var user data.User
|
||
|
|
|
||
|
|
login, err := ReceivePost[data.Login](c)
|
||
|
|
if(err != nil) { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
pass_good, err := LoginUser(&user, login)
|
||
|
|
if err != nil { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
if pass_good {
|
||
|
|
sess, err := STORE.Get(c)
|
||
|
|
if err != nil { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
sess.Set("user_id", user.Id)
|
||
|
|
sess.Set("authenticated", true)
|
||
|
|
sess.Set("admin", IsAdmin(&user))
|
||
|
|
err = sess.Save()
|
||
|
|
if err != nil { return IfErrNil(err, c) }
|
||
|
|
|
||
|
|
return c.Redirect("/")
|
||
|
|
} else {
|
||
|
|
return c.Redirect("/login/")
|
||
|
|
}
|
||
|
|
}
|
||
|
4 days ago
|
|
||
|
|
|
||
|
|
func Setup(app *fiber.App) {
|
||
|
|
app.Get("/api/authcheck", GetApiAuthCheck)
|
||
|
|
app.Get("/api/logout", GetApiLogout)
|
||
|
|
app.Post("/api/register", PostApiRegister)
|
||
|
|
app.Post("/api/login", PostApiLogin)
|
||
|
|
}
|