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
33
data/crud.go
33
data/crud.go
|
|
@ -1,16 +1,33 @@
|
||||||
package data
|
package data
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"log"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
_ "github.com/mattn/go-sqlite3"
|
_ "github.com/mattn/go-sqlite3"
|
||||||
"github.com/jmoiron/sqlx"
|
"github.com/jmoiron/sqlx"
|
||||||
|
"zedshaw.games/webapp/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
func SelectJson[T any](db *sqlx.DB, c *fiber.Ctx, err error, sql string, args ...interface{}) error {
|
var DB *sqlx.DB
|
||||||
|
|
||||||
|
func Setup(driver string, url string) {
|
||||||
|
var err error
|
||||||
|
|
||||||
|
DB, err = sqlx.Connect(driver, url)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalln(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func Shutdown() {
|
||||||
|
DB.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
func SelectJson[T any](c *fiber.Ctx, err error, sql string, args ...interface{}) error {
|
||||||
var result []T
|
var result []T
|
||||||
if err != nil { goto fail }
|
if err != nil { goto fail }
|
||||||
|
|
||||||
err = db.Select(&result, sql, args...)
|
err = DB.Select(&result, sql, args...)
|
||||||
if err != nil { goto fail }
|
if err != nil { goto fail }
|
||||||
|
|
||||||
return c.JSON(&result)
|
return c.JSON(&result)
|
||||||
|
|
@ -18,11 +35,11 @@ func SelectJson[T any](db *sqlx.DB, c *fiber.Ctx, err error, sql string, args ..
|
||||||
fail: return err
|
fail: return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetJson[T any](db *sqlx.DB, c *fiber.Ctx, err error, sql string, args ...interface{}) error {
|
func GetJson[T any](c *fiber.Ctx, err error, sql string, args ...interface{}) error {
|
||||||
var result T
|
var result T
|
||||||
if err != nil { goto fail }
|
if err != nil { goto fail }
|
||||||
|
|
||||||
err = db.Get(&result, sql, args...)
|
err = DB.Get(&result, sql, args...)
|
||||||
if err != nil { goto fail }
|
if err != nil { goto fail }
|
||||||
|
|
||||||
return c.JSON(&result)
|
return c.JSON(&result)
|
||||||
|
|
@ -30,11 +47,9 @@ func GetJson[T any](db *sqlx.DB, c *fiber.Ctx, err error, sql string, args ...in
|
||||||
fail: return err
|
fail: return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func Insert(db *sqlx.DB, err error, sql_query string, args ...interface{}) error {
|
func Insert(err error, sql_query string, args ...interface{}) (error) {
|
||||||
|
defer util.HandlePanic("Insert")
|
||||||
if err != nil { return err }
|
if err != nil { return err }
|
||||||
|
DB.MustExec(sql_query, args...)
|
||||||
db.MustExec(sql_query, args...)
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
2
go.mod
2
go.mod
|
|
@ -88,7 +88,6 @@ require (
|
||||||
github.com/tursodatabase/libsql-client-go v0.0.0-20240902231107-85af5b9d094d // indirect
|
github.com/tursodatabase/libsql-client-go v0.0.0-20240902231107-85af5b9d094d // indirect
|
||||||
github.com/valyala/bytebufferpool v1.0.0 // indirect
|
github.com/valyala/bytebufferpool v1.0.0 // indirect
|
||||||
github.com/valyala/fasthttp v1.62.0 // indirect
|
github.com/valyala/fasthttp v1.62.0 // indirect
|
||||||
github.com/valyala/quicktemplate v1.8.0 // indirect
|
|
||||||
github.com/vertica/vertica-sql-go v1.3.3 // indirect
|
github.com/vertica/vertica-sql-go v1.3.3 // indirect
|
||||||
github.com/ydb-platform/ydb-go-genproto v0.0.0-20241112172322-ea1f63298f77 // indirect
|
github.com/ydb-platform/ydb-go-genproto v0.0.0-20241112172322-ea1f63298f77 // indirect
|
||||||
github.com/ydb-platform/ydb-go-sdk/v3 v3.108.1 // indirect
|
github.com/ydb-platform/ydb-go-sdk/v3 v3.108.1 // indirect
|
||||||
|
|
@ -120,7 +119,6 @@ require (
|
||||||
tool (
|
tool (
|
||||||
github.com/air-verse/air
|
github.com/air-verse/air
|
||||||
github.com/pressly/goose/v3/cmd/goose
|
github.com/pressly/goose/v3/cmd/goose
|
||||||
github.com/valyala/quicktemplate/qtc
|
|
||||||
golang.org/x/pkgsite/cmd/pkgsite
|
golang.org/x/pkgsite/cmd/pkgsite
|
||||||
golang.org/x/tools/cmd/goimports
|
golang.org/x/tools/cmd/goimports
|
||||||
)
|
)
|
||||||
|
|
|
||||||
2
go.sum
2
go.sum
|
|
@ -386,8 +386,6 @@ github.com/valyala/bytebufferpool v1.0.0 h1:GqA5TC/0021Y/b9FG4Oi9Mr3q7XYx6Kllzaw
|
||||||
github.com/valyala/bytebufferpool v1.0.0/go.mod h1:6bBcMArwyJ5K/AmCkWv1jt77kVWyCJ6HpOuEn7z0Csc=
|
github.com/valyala/bytebufferpool v1.0.0/go.mod h1:6bBcMArwyJ5K/AmCkWv1jt77kVWyCJ6HpOuEn7z0Csc=
|
||||||
github.com/valyala/fasthttp v1.62.0 h1:8dKRBX/y2rCzyc6903Zu1+3qN0H/d2MsxPPmVNamiH0=
|
github.com/valyala/fasthttp v1.62.0 h1:8dKRBX/y2rCzyc6903Zu1+3qN0H/d2MsxPPmVNamiH0=
|
||||||
github.com/valyala/fasthttp v1.62.0/go.mod h1:FCINgr4GKdKqV8Q0xv8b+UxPV+H/O5nNFo3D+r54Htg=
|
github.com/valyala/fasthttp v1.62.0/go.mod h1:FCINgr4GKdKqV8Q0xv8b+UxPV+H/O5nNFo3D+r54Htg=
|
||||||
github.com/valyala/quicktemplate v1.8.0 h1:zU0tjbIqTRgKQzFY1L42zq0qR3eh4WoQQdIdqCysW5k=
|
|
||||||
github.com/valyala/quicktemplate v1.8.0/go.mod h1:qIqW8/igXt8fdrUln5kOSb+KWMaJ4Y8QUsfd1k6L2jM=
|
|
||||||
github.com/vertica/vertica-sql-go v1.3.3 h1:fL+FKEAEy5ONmsvya2WH5T8bhkvY27y/Ik3ReR2T+Qw=
|
github.com/vertica/vertica-sql-go v1.3.3 h1:fL+FKEAEy5ONmsvya2WH5T8bhkvY27y/Ik3ReR2T+Qw=
|
||||||
github.com/vertica/vertica-sql-go v1.3.3/go.mod h1:jnn2GFuv+O2Jcjktb7zyc4Utlbu9YVqpHH/lx63+1M4=
|
github.com/vertica/vertica-sql-go v1.3.3/go.mod h1:jnn2GFuv+O2Jcjktb7zyc4Utlbu9YVqpHH/lx63+1M4=
|
||||||
github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI=
|
github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI=
|
||||||
|
|
|
||||||
80
main.go
80
main.go
|
|
@ -5,29 +5,20 @@ import (
|
||||||
"os"
|
"os"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
"syscall"
|
"syscall"
|
||||||
"zedshaw.games/webapp/api"
|
|
||||||
"zedshaw.games/webapp/data"
|
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
"github.com/gofiber/fiber/v2/middleware/logger"
|
"github.com/gofiber/fiber/v2/middleware/logger"
|
||||||
"github.com/gofiber/template/html/v2"
|
"github.com/gofiber/template/html/v2"
|
||||||
|
|
||||||
_ "github.com/mattn/go-sqlite3"
|
_ "github.com/mattn/go-sqlite3"
|
||||||
"github.com/jmoiron/sqlx"
|
|
||||||
sq "github.com/Masterminds/squirrel"
|
|
||||||
recov "github.com/gofiber/fiber/v2/middleware/recover"
|
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() {
|
func main() {
|
||||||
log.SetFlags(log.LstdFlags | log.Lshortfile)
|
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")
|
engine := html.New("./views", ".html")
|
||||||
|
|
||||||
app := fiber.New(fiber.Config{
|
app := fiber.New(fiber.Config{
|
||||||
|
|
@ -38,68 +29,11 @@ func main() {
|
||||||
app.Use(logger.New())
|
app.Use(logger.New())
|
||||||
app.Use(recov.New())
|
app.Use(recov.New())
|
||||||
|
|
||||||
// handler that returns one json from a sql database
|
api.Setup(app)
|
||||||
app.Get("/api/stream/", func (c *fiber.Ctx) error {
|
data.Setup("sqlite3", "db.sqlite3")
|
||||||
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)
|
|
||||||
})
|
|
||||||
|
|
||||||
app.Static("/", "./public")
|
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() {
|
go func() {
|
||||||
if err := app.Listen(":5001"); err != nil {
|
if err := app.Listen(":5001"); err != nil {
|
||||||
log.Panic(err)
|
log.Panic(err)
|
||||||
|
|
@ -113,8 +47,8 @@ func main() {
|
||||||
log.Println("Shutdown now...")
|
log.Println("Shutdown now...")
|
||||||
_ = app.Shutdown()
|
_ = app.Shutdown()
|
||||||
|
|
||||||
log.Println("Running cleanup...")
|
api.Shutdown()
|
||||||
db.Close()
|
data.Shutdown()
|
||||||
|
|
||||||
log.Println("Done.")
|
log.Println("Done.")
|
||||||
}
|
}
|
||||||
|
|
|
||||||
13
util/util.go
Normal file
13
util/util.go
Normal file
|
|
@ -0,0 +1,13 @@
|
||||||
|
package util
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
)
|
||||||
|
|
||||||
|
func HandlePanic(message string) func() {
|
||||||
|
return func() {
|
||||||
|
if r := recover(); r != nil {
|
||||||
|
log.Println(message, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue