You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
synctv/internal/db/db.go

193 lines
4.6 KiB
Go

package db
import (
"fmt"
log "github.com/sirupsen/logrus"
"github.com/synctv-org/synctv/internal/conf"
"github.com/synctv-org/synctv/internal/model"
"github.com/synctv-org/synctv/utils"
_ "github.com/synctv-org/synctv/utils/fastJSONSerializer"
"gorm.io/gorm"
)
var (
db *gorm.DB
dbType conf.DatabaseType
)
func Init(d *gorm.DB, t conf.DatabaseType) error {
db = d
dbType = t
return AutoMigrate(new(model.Movie), new(model.Room), new(model.User), new(model.RoomUserRelation), new(model.UserProvider), new(model.Setting), new(model.StreamingVendorInfo))
}
func AutoMigrate(dst ...any) error {
var err error
switch conf.Conf.Database.Type {
case conf.DatabaseTypeMysql:
err = db.Set("gorm:table_options", "ENGINE=InnoDB CHARSET=utf8mb4").AutoMigrate(dst...)
case conf.DatabaseTypeSqlite3, conf.DatabaseTypePostgres:
err = db.AutoMigrate(dst...)
default:
log.Fatalf("unknown database type: %s", conf.Conf.Database.Type)
}
return err
}
func DB() *gorm.DB {
return db
}
func Close() {
log.Info("closing db")
sqlDB, err := db.DB()
if err != nil {
log.Errorf("failed to get db: %s", err.Error())
return
}
err = sqlDB.Close()
if err != nil {
log.Errorf("failed to close db: %s", err.Error())
return
}
}
func Paginate(page, pageSize int) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
if page <= 0 {
page = 1
}
if pageSize <= 0 {
pageSize = 10
}
offset := (page - 1) * pageSize
return db.Offset(offset).Limit(pageSize)
}
}
func OrderByAsc(column string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Order(column + " asc")
}
}
func OrderByDesc(column string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Order(column + " desc")
}
}
func OrderByCreatedAtAsc(db *gorm.DB) *gorm.DB {
return db.Order("created_at asc")
}
func OrderByCreatedAtDesc(db *gorm.DB) *gorm.DB {
return db.Order("created_at desc")
}
func OrderByIDAsc(db *gorm.DB) *gorm.DB {
return db.Order("id asc")
}
func OrderByIDDesc(db *gorm.DB) *gorm.DB {
return db.Order("id desc")
}
func WithUser(db *gorm.DB) *gorm.DB {
return db.Preload("User")
}
func WithUserAndProvider(db *gorm.DB) *gorm.DB {
return db.Preload("User").Preload("User.Provider")
}
func WhereRoomID(roomID string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Where("room_id = ?", roomID)
}
}
func WhereUserID(userID string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Where("user_id = ?", userID)
}
}
func WhereCreatorID(creatorID string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Where("creator_id = ?", creatorID)
}
}
// column cannot be a user parameter
func WhereEqual(column string, value interface{}) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Where(fmt.Sprintf("%s = ?", column), value)
}
}
// column cannot be a user parameter
func WhereLike(column string, value string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
switch dbType {
case conf.DatabaseTypePostgres:
return db.Where(fmt.Sprintf("%s ILIKE ?", column), utils.LIKE(value))
default:
return db.Where(fmt.Sprintf("%s LIKE ?", column), utils.LIKE(value))
}
}
}
func WhereRoomNameLikeOrCreatorIn(name string, ids []string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
switch dbType {
case conf.DatabaseTypePostgres:
return db.Where("name ILIKE ? OR creator_id IN ?", utils.LIKE(name), ids)
default:
return db.Where("name LIKE ? OR creator_id IN ?", utils.LIKE(name), ids)
}
}
}
func WhereRoomNameLike(name string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
switch dbType {
case conf.DatabaseTypePostgres:
return db.Where("name ILIKE ?", utils.LIKE(name))
default:
return db.Where("name LIKE ?", utils.LIKE(name))
}
}
}
func WhereUserNameLike(name string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
switch dbType {
case conf.DatabaseTypePostgres:
return db.Where("username ILIKE ?", utils.LIKE(name))
default:
return db.Where("username LIKE ?", utils.LIKE(name))
}
}
}
func WhereCreatorIDIn(ids []string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Where("creator_id IN ?", ids)
}
}
func Select(columns ...string) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Select(columns)
}
}
func WhereStatus(status model.RoomStatus) func(db *gorm.DB) *gorm.DB {
return func(db *gorm.DB) *gorm.DB {
return db.Where("status = ?", status)
}
}