package user import ( "fmt" "npm/internal/database" "npm/internal/entity" "npm/internal/logger" "npm/internal/model" ) // GetByID finds a user by ID func GetByID(id uint) (Model, error) { var m Model err := m.LoadByID(id) return m, err } // GetByEmail finds a user by email func GetByEmail(email string) (Model, error) { var m Model err := m.LoadByEmail(email) return m, err } // IsEnabled is used by middleware to ensure the user is still enabled // returns (userExist, isEnabled, error) func IsEnabled(userID uint) (bool, bool, error) { var user Model db := database.GetDB() if result := db.First(&user, userID); result.Error != nil { return false, false, result.Error } return true, !user.IsDisabled, nil } // List will return a list of users func List(pageInfo model.PageInfo, filters []model.Filter, expand []string) (entity.ListResponse, error) { var result entity.ListResponse defaultSort := model.Sort{ Field: "name", Direction: "ASC", } dbo := entity.ListQueryBuilder(&pageInfo, filters, entity.GetFilterMap(Model{}, true)) // Get count of items in this search var totalRows int64 if res := dbo.Model(&Model{}).Count(&totalRows); res.Error != nil { return result, res.Error } // Get rows dbo = entity.AddOffsetLimitToList(dbo, &pageInfo) dbo = entity.AddOrderToList(dbo, pageInfo.Sort, defaultSort) items := make([]Model, 0) if res := dbo.Find(&items); res.Error != nil { return result, res.Error } for idx := range items { items[idx].generateGravatar() } if expand != nil { for idx := range items { expandErr := items[idx].Expand(expand) if expandErr != nil { logger.Error("UsersExpansionError", expandErr) } } } result = entity.ListResponse{ Items: items, Total: totalRows, Limit: pageInfo.Limit, Offset: pageInfo.Offset, Sort: pageInfo.GetSort(defaultSort), Filter: filters, } return result, nil } // DeleteAll will do just that, and should only be used for testing purposes. func DeleteAll() error { db := database.GetDB() // nolint errcheck result := db.Exec(fmt.Sprintf(`DELETE FROM %s WHERE is_system = ?`, database.QuoteTableName("user")), false) return result.Error } // GetCapabilities gets capabilities for a user func GetCapabilities(userID uint) ([]string, error) { capabilities := make([]string, 0) var hasCapabilities []UserHasCapabilityModel db := database.GetDB() if result := db.Where("user_id = ?", userID).Find(&hasCapabilities); result.Error != nil { return nil, result.Error } for _, obj := range hasCapabilities { capabilities = append(capabilities, obj.CapabilityName) } return capabilities, nil }