package Database import ( "errors" "git.tovijaeschke.xyz/tovi/SuddenImpactRecords/Models" "gorm.io/gorm" "gorm.io/gorm/clause" ) func GetUserById(id string) (Models.User, error) { var ( userData Models.User err error ) err = DB.Preload(clause.Associations). First(&userData, "id = ?", id). Error userData.Password = "" return userData, err } func GetUserByEmail(email string) (Models.User, error) { var ( userData Models.User err error ) err = DB.Preload(clause.Associations). First(&userData, "email = ?", email). Error return userData, err } func GetUsers(page, pageSize int) ([]Models.User, error) { var ( users []Models.User i int err error ) if page == 0 { page = 1 } switch { case pageSize > 100: pageSize = 100 case pageSize <= 0: pageSize = 10 } err = DB.Offset(page). Limit(pageSize). Find(&users). Error for i, _ = range users { users[i].Password = "" } return users, err } func CheckUniqueEmail(email string) error { var ( exists bool err error ) err = DB.Model(Models.User{}). Select("count(*) > 0"). Where("email = ?", email). Find(&exists). Error if err != nil { return err } if exists { return errors.New("Invalid email") } return nil } func CreateUser(userData *Models.User) error { var ( err error ) err = DB.Session(&gorm.Session{FullSaveAssociations: true}). Create(userData). Error userData.Password = "" return err } func UpdateUser(id string, userData *Models.User) error { var ( err error ) err = DB.Model(&Models.User{}). Select("*"). Omit("id", "created_at", "updated_at", "deleted_at"). Where("id = ?", id). Updates(userData). Error userData.Password = "" return err } func DeleteUser(userData *Models.User) error { return DB.Session(&gorm.Session{FullSaveAssociations: true}). Delete(userData). Error }