Abit of refactoring into a more classic layout for an MVC style app.
This commit is contained in:
parent
db58b38917
commit
0c47f02201
5 changed files with 44 additions and 86 deletions
80
main.go
80
main.go
|
@ -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.")
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue