database.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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. Message *MessageQuery
  17. Reaction *ReactionQuery
  18. Attachment *AttachmentQuery
  19. Emoji *EmojiQuery
  20. Guild *GuildQuery
  21. }
  22. func New(dbType, uri string, maxOpenConns, maxIdleConns int, baseLog log.Logger) (*Database, error) {
  23. conn, err := sql.Open(dbType, uri)
  24. if err != nil {
  25. return nil, err
  26. }
  27. if dbType == "sqlite3" {
  28. conn.Exec("PRAGMA foreign_keys = ON")
  29. }
  30. conn.SetMaxOpenConns(maxOpenConns)
  31. conn.SetMaxIdleConns(maxIdleConns)
  32. dbLog := baseLog.Sub("Database")
  33. if err := migrations.Run(conn, dbLog, dbType); err != nil {
  34. return nil, err
  35. }
  36. db := &Database{
  37. DB: conn,
  38. log: dbLog,
  39. dialect: dbType,
  40. }
  41. db.User = &UserQuery{
  42. db: db,
  43. log: db.log.Sub("User"),
  44. }
  45. db.Portal = &PortalQuery{
  46. db: db,
  47. log: db.log.Sub("Portal"),
  48. }
  49. db.Puppet = &PuppetQuery{
  50. db: db,
  51. log: db.log.Sub("Puppet"),
  52. }
  53. db.Message = &MessageQuery{
  54. db: db,
  55. log: db.log.Sub("Message"),
  56. }
  57. db.Reaction = &ReactionQuery{
  58. db: db,
  59. log: db.log.Sub("Reaction"),
  60. }
  61. db.Attachment = &AttachmentQuery{
  62. db: db,
  63. log: db.log.Sub("Attachment"),
  64. }
  65. db.Emoji = &EmojiQuery{
  66. db: db,
  67. log: db.log.Sub("Emoji"),
  68. }
  69. db.Guild = &GuildQuery{
  70. db: db,
  71. log: db.log.Sub("Guild"),
  72. }
  73. return db, nil
  74. }