Now have a basic auth library for doing bcrypt auth.

This commit is contained in:
Zed A. Shaw 2025-06-27 12:02:05 -04:00
parent b0c4144987
commit eaaf309260
4 changed files with 69 additions and 29 deletions

View file

@ -2,36 +2,28 @@ package api
import (
"log"
"github.com/gofiber/fiber/v2"
_ "github.com/mattn/go-sqlite3"
sq "github.com/Masterminds/squirrel"
"github.com/gofiber/fiber/v2/middleware/session"
"github.com/gofiber/fiber/v2"
_ "github.com/mattn/go-sqlite3"
sq "github.com/Masterminds/squirrel"
"github.com/gofiber/fiber/v2/middleware/session"
"zedshaw.games/webapp/data"
)
var STORE *session.Store
func Logout(c *fiber.Ctx) error {
sess, err := STORE.Get(c)
if err != nil { return IfErrNil(err, c) }
sess.Set("authenticated", false)
err = sess.Save()
func GetApiLogout(c *fiber.Ctx) error {
err := LogoutUser(c)
if err != nil { return IfErrNil(err, c) }
return c.Redirect("/")
}
func GetApiStream(c *fiber.Ctx) error {
sess, err := STORE.Get(c)
if err != nil { return IfErrNil(err, c) }
if sess.Get("authenticated") != true {
// NOTE: need my own error thing
return IfErrNil(err, c)
}
authed, _, err := CheckAuthed(c)
if NotAuthed(err, authed) { return IfErrNil(err, c) }
sql, args, err := sq.Select("*").From("stream").ToSql()
err = data.SelectJson[data.Stream](c, err, sql, args...)
@ -58,20 +50,15 @@ func GetApiStreamIdLinks(c *fiber.Ctx) error {
}
func PostApiLogin(c *fiber.Ctx) error {
var result data.User
var user data.User
login, err := ReceivePost[data.Login](c)
if(err != nil) { return IfErrNil(err, c) }
sql, args, err := sq.Select("username, password").
From("user").Where("username=?", login.Username).ToSql()
pass_good, err := LoginUser(&user, login)
if err != nil { return IfErrNil(err, c) }
err = data.DB.Get(&result, sql, args...)
if err != nil { return IfErrNil(err, c) }
if login.Username == result.Username && login.Password == result.Password {
if pass_good {
sess, err := STORE.Get(c)
if err != nil { return IfErrNil(err, c) }
@ -103,12 +90,11 @@ func PostApiLink(c *fiber.Ctx) error {
return IfErrNil(err, c)
}
func Setup(app *fiber.App) {
STORE = session.New()
app.Get("/api/stream/", GetApiStream)
app.Get("/api/logout/", Logout)
app.Get("/api/stream", GetApiStream)
app.Get("/api/logout", GetApiLogout)
app.Get("/api/stream/:id", GetApiStreamId)
app.Get("/api/stream/:id/links", GetApiStreamIdLinks)
app.Post("/api/login", PostApiLogin)