package db import ( "github.com/synctv-org/synctv/internal/model" "github.com/zijiren233/stream" "golang.org/x/crypto/bcrypt" ) type CreateRoomConfig func(r *model.Room) func WithSetting(setting model.Setting) CreateRoomConfig { return func(r *model.Room) { r.Setting = setting } } func WithCreaterID(createrID uint) CreateRoomConfig { return func(r *model.Room) { r.CreatorID = createrID } } func WithRelations(relations []model.RoomUserRelation) CreateRoomConfig { return func(r *model.Room) { r.GroupUserRelations = relations } } func CreateRoom(name, password string, conf ...CreateRoomConfig) (*model.Room, error) { var hashedPassword []byte if password != "" { var err error hashedPassword, err = bcrypt.GenerateFromPassword(stream.StringToBytes(password), bcrypt.DefaultCost) if err != nil { return nil, err } } r := &model.Room{ Name: name, HashedPassword: hashedPassword, } for _, c := range conf { c(r) } return r, db.Create(r).Error } func GetRoomByID(id uint) (*model.Room, error) { r := &model.Room{} err := db.Where("id = ?", id).First(r).Error return r, err } func GetRoomAndCreatorByID(id uint) (*model.Room, error) { r := &model.Room{} err := db.Preload("Creator").Where("id = ?", id).First(r).Error return r, err } func ChangeRoomSetting(roomID uint, setting model.Setting) error { return db.Model(&model.Room{}).Where("id = ?", roomID).Update("setting", setting).Error } func ChangeUserPermission(roomID uint, userID uint, permission model.Permission) error { return db.Model(&model.RoomUserRelation{}).Where("room_id = ? AND user_id = ?", roomID, userID).Update("permissions", permission).Error } func HasPermission(roomID uint, userID uint, permission model.Permission) (bool, error) { ur := &model.RoomUserRelation{} err := db.Where("room_id = ? AND user_id = ?", roomID, userID).First(ur).Error if err != nil { return false, err } return ur.Permissions.Has(permission), nil } func DeleteRoomByID(roomID uint) error { return db.Where("id = ?", roomID).Delete(&model.Room{}).Error } func HasRoom(roomID uint) (bool, error) { r := &model.Room{} err := db.Where("id = ?", roomID).First(r).Error if err != nil { return false, err } return true, nil } func HasRoomByName(name string) (bool, error) { r := &model.Room{} err := db.Where("name = ?", name).First(r).Error if err != nil { return false, err } return true, nil } func SetRoomPassword(roomID uint, password string) error { var hashedPassword []byte if password != "" { var err error hashedPassword, err = bcrypt.GenerateFromPassword(stream.StringToBytes(password), bcrypt.DefaultCost) if err != nil { return err } } return db.Model(&model.Room{}).Where("id = ?", roomID).Update("hashed_password", hashedPassword).Error } func SetRoomHashedPassword(roomID uint, hashedPassword []byte) error { return db.Model(&model.Room{}).Where("id = ?", roomID).Update("hashed_password", hashedPassword).Error } func SetUserRole(roomID uint, userID uint, role model.Role) error { return db.Model(&model.RoomUserRelation{}).Where("room_id = ? AND user_id = ?", roomID, userID).Update("role", role).Error } func SetUserPermission(roomID uint, userID uint, permission model.Permission) error { return db.Model(&model.RoomUserRelation{}).Where("room_id = ? AND user_id = ?", roomID, userID).Update("permissions", permission).Error } func AddUserPermission(roomID uint, userID uint, permission model.Permission) error { return db.Model(&model.RoomUserRelation{}).Where("room_id = ? AND user_id = ?", roomID, userID).Update("permissions", db.Raw("permissions | ?", permission)).Error } func RemoveUserPermission(roomID uint, userID uint, permission model.Permission) error { return db.Model(&model.RoomUserRelation{}).Where("room_id = ? AND user_id = ?", roomID, userID).Update("permissions", db.Raw("permissions & ?", ^permission)).Error } func GetAllRooms() ([]*model.Room, error) { rooms := []*model.Room{} err := db.Find(&rooms).Error return rooms, err } func GetAllRoomsAndCreator() ([]*model.Room, error) { rooms := []*model.Room{} err := db.Preload("Creater").Find(&rooms).Error return rooms, err }