database.go 1.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package database
  2. import (
  3. "database/sql"
  4. _ "github.com/lib/pq"
  5. _ "github.com/mattn/go-sqlite3"
  6. log "maunium.net/go/maulogger/v2"
  7. "gitlab.com/beeper/discord/database/migrations"
  8. )
  9. type Database struct {
  10. *sql.DB
  11. log log.Logger
  12. dialect string
  13. User *UserQuery
  14. Portal *PortalQuery
  15. Puppet *PuppetQuery
  16. }
  17. func New(dbType, uri string, maxOpenConns, maxIdleConns int, baseLog log.Logger) (*Database, error) {
  18. conn, err := sql.Open(dbType, uri)
  19. if err != nil {
  20. return nil, err
  21. }
  22. if dbType == "sqlite3" {
  23. conn.Exec("PRAGMA foreign_keys = ON")
  24. }
  25. conn.SetMaxOpenConns(maxOpenConns)
  26. conn.SetMaxIdleConns(maxIdleConns)
  27. dbLog := baseLog.Sub("Database")
  28. if err := migrations.Run(conn, dbLog); err != nil {
  29. return nil, err
  30. }
  31. db := &Database{
  32. DB: conn,
  33. log: dbLog,
  34. dialect: dbType,
  35. }
  36. db.User = &UserQuery{
  37. db: db,
  38. log: db.log.Sub("User"),
  39. }
  40. db.Portal = &PortalQuery{
  41. db: db,
  42. log: db.log.Sub("Portal"),
  43. }
  44. db.Puppet = &PuppetQuery{
  45. db: db,
  46. log: db.log.Sub("Puppet"),
  47. }
  48. return db, nil
  49. }