|
|
@ -16,10 +16,17 @@ func (u *User) CreateRoom(name, password string, conf ...db.CreateRoomConfig) (*
|
|
|
|
if u.IsBanned() {
|
|
|
|
if u.IsBanned() {
|
|
|
|
return nil, errors.New("user banned")
|
|
|
|
return nil, errors.New("user banned")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if !u.IsAdmin() && settings.CreateRoomNeedReview.Get() {
|
|
|
|
if u.IsAdmin() {
|
|
|
|
conf = append(conf, db.WithStatus(model.RoomStatusPending))
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
conf = append(conf, db.WithStatus(model.RoomStatusActive))
|
|
|
|
conf = append(conf, db.WithStatus(model.RoomStatusActive))
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
if password == "" && settings.RoomMustNeedPwd.Get() {
|
|
|
|
|
|
|
|
return nil, errors.New("room must need password")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if settings.CreateRoomNeedReview.Get() {
|
|
|
|
|
|
|
|
conf = append(conf, db.WithStatus(model.RoomStatusPending))
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
conf = append(conf, db.WithStatus(model.RoomStatusActive))
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return db.CreateRoom(name, password, append(conf, db.WithCreator(&u.User))...)
|
|
|
|
return db.CreateRoom(name, password, append(conf, db.WithCreator(&u.User))...)
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -87,6 +94,9 @@ func (u *User) SetRoomPassword(room *Room, password string) error {
|
|
|
|
if !u.HasRoomPermission(room, model.PermissionEditRoom) {
|
|
|
|
if !u.HasRoomPermission(room, model.PermissionEditRoom) {
|
|
|
|
return model.ErrNoPermission
|
|
|
|
return model.ErrNoPermission
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if !u.IsAdmin() && password == "" && settings.RoomMustNeedPwd.Get() {
|
|
|
|
|
|
|
|
return errors.New("room must need password")
|
|
|
|
|
|
|
|
}
|
|
|
|
return room.SetPassword(password)
|
|
|
|
return room.SetPassword(password)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|