Abit of refactoring into a more classic layout for an MVC style app.

This commit is contained in:
Zed A. Shaw 2025-06-24 23:55:38 -04:00
parent db58b38917
commit 0c47f02201
5 changed files with 44 additions and 86 deletions

80
main.go
View file

@ -5,29 +5,20 @@ import (
"os"
"os/signal"
"syscall"
"zedshaw.games/webapp/api"
"zedshaw.games/webapp/data"
"github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/middleware/logger"
"github.com/gofiber/template/html/v2"
_ "github.com/mattn/go-sqlite3"
"github.com/jmoiron/sqlx"
sq "github.com/Masterminds/squirrel"
recov "github.com/gofiber/fiber/v2/middleware/recover"
"github.com/gofiber/fiber/v2/middleware/session"
"zedshaw.games/webapp/api"
"zedshaw.games/webapp/data"
)
func main() {
log.SetFlags(log.LstdFlags | log.Lshortfile)
db, err := sqlx.Connect("sqlite3", "db.sqlite3")
if err != nil {
log.Fatalln(err)
}
store := session.New()
engine := html.New("./views", ".html")
app := fiber.New(fiber.Config{
@ -38,68 +29,11 @@ func main() {
app.Use(logger.New())
app.Use(recov.New())
// handler that returns one json from a sql database
app.Get("/api/stream/", func (c *fiber.Ctx) error {
sess, err := store.Get(c)
sess.Set("fuck", "off")
sql, args, err := sq.Select("*").From("stream").ToSql()
err = data.SelectJson[data.Stream](db, c, err, sql, args...)
return api.IfErrNil(err, c)
})
app.Get("/api/stream/:id", func (c *fiber.Ctx) error {
sql, args, err := sq.Select("*").From("stream").Where("id", c.Params("id")).ToSql()
err = data.GetJson[data.Stream](db, c, err, sql, args...)
return api.IfErrNil(err, c)
})
app.Get("/api/stream/:id/links", func (c *fiber.Ctx) error {
sql, args, err := sq.Select("*").From("stream_link").Where("stream_id", c.Params("id")).ToSql()
err = data.SelectJson[data.Link](db, c, err, sql, args...)
return api.IfErrNil(err, c)
})
app.Post("/api/login", func (c *fiber.Ctx) error {
login, err := api.ReceivePost[data.Login](c)
if(err != nil) { goto fail }
log.Printf("username: %s; password: %s", login.Username, login.Password);
return c.Redirect("/")
fail:
return api.IfErrNil(err, c)
})
app.Post("/api/link", func (c *fiber.Ctx) error {
var sql string
var args []interface{}
link, err := api.ReceivePost[data.Link](c)
if err != nil { goto fail }
sql, args, err = sq.Insert("stream_link").Columns("stream_id", "url", "description").Values(link.StreamId, link.Url, link.Description).ToSql()
err = data.Insert(db, err, sql, args...)
return c.Redirect("/live/")
fail:
return api.IfErrNil(err, c)
})
api.Setup(app)
data.Setup("sqlite3", "db.sqlite3")
app.Static("/", "./public")
app.Get("/test/:name/", func (c *fiber.Ctx) error {
return c.Render(c.Params("name"), fiber.Map{
"Title": "Hello, World!",
})
})
go func() {
if err := app.Listen(":5001"); err != nil {
log.Panic(err)
@ -113,8 +47,8 @@ func main() {
log.Println("Shutdown now...")
_ = app.Shutdown()
log.Println("Running cleanup...")
db.Close()
api.Shutdown()
data.Shutdown()
log.Println("Done.")
}