Merge branch 'companies-users' into 'main'

Fixed qor admin companies users

See merge request ukacorp/mesari/backend!25
This commit was merged in pull request #25.
This commit is contained in:
2023-11-14 10:10:10 +00:00
5 changed files with 18 additions and 11 deletions

View File

@@ -130,7 +130,12 @@ func Login(c *gin.Context) {
if usr.CheckPassword(user.Password, req.Password) { if usr.CheckPassword(user.Password, req.Password) {
if user.IsActive && user.LoginAttempts < 10 { if user.IsActive && user.LoginAttempts < 10 {
// Proceed with creating JWT token and resetting login attempts // Proceed with creating JWT token and resetting login attempts
token, err := usr.CreateSessionToken(user.ID, user.CompanyID) if len(user.Companies) == 0 {
c.JSON(http.StatusInternalServerError, gin.H{"error": "User is not connected to a company"})
return
}
token, err := usr.CreateSessionToken(user.ID, user.Companies[0].ID)
if err != nil { if err != nil {
c.JSON(http.StatusInternalServerError, gin.H{"error": "Could not create JWT token"}) c.JSON(http.StatusInternalServerError, gin.H{"error": "Could not create JWT token"})
return return

View File

@@ -44,7 +44,7 @@ func main() {
Admin.AddResource(&models.User{}) Admin.AddResource(&models.User{})
Admin.AddResource(&models.Device{}) Admin.AddResource(&models.Device{})
Admin.AddResource(&models.ProductTemplate{}) Admin.AddResource(&models.ProductTemplate{})
company.Meta(&admin.Meta{Name: "Users", Config: &admin.SelectManyConfig{SelectMode: "select"}}) company.Meta(&admin.Meta{Name: "Users", Config: &admin.SelectManyConfig{SelectMode: "bottom_sheet"}})
company.Meta(&admin.Meta{Name: "Devices", Config: &admin.SelectManyConfig{SelectMode: "bottom_sheet"}}) company.Meta(&admin.Meta{Name: "Devices", Config: &admin.SelectManyConfig{SelectMode: "bottom_sheet"}})
// // Initialize HTTP request multiplexe // // Initialize HTTP request multiplexe
mux := http.NewServeMux() mux := http.NewServeMux()

View File

@@ -18,7 +18,7 @@ type Company struct {
Address string `json:"address"` Address string `json:"address"`
Email string `json:"email"` Email string `json:"email"`
Phone string `json:"phone"` Phone string `json:"phone"`
Users []User `json:"users"` Users []User `gorm:"many2many:user_companies;"`
Devices []Device `json:"devices"` Devices []Device `json:"devices"`
} }

View File

@@ -5,7 +5,7 @@ type SessionToken struct {
UserID uint `json:"userId"` UserID uint `json:"userId"`
Token string `json:"token"` Token string `json:"token"`
IsActive bool `json:"isActive"` IsActive bool `json:"isActive"`
CompanyID uint `json:"userId"` CompanyID uint `json:"companyID"`
} }
func (SessionToken) Update() (bool, error) { func (SessionToken) Update() (bool, error) {

View File

@@ -2,13 +2,15 @@ package models
type User struct { type User struct {
BaseModel BaseModel
Username string `json:"username"` Username string `json:"username"`
Password string `json:"password"` Password string `json:"password"`
Email string `json:"email"` Email string `json:"email"`
Avatar string `json:"avatar"` Avatar string `json:"avatar"`
IsActive bool `json:"isActive" gorm:"default:false"` IsActive bool `json:"isActive" gorm:"default:false"`
CompanyID uint `json:"companyId"` // CompanyID uint `json:"companyId"`
LoginAttempts int `gorm:"default:0"` // Company Company
Companies []Company `gorm:"many2many:user_companies;"`
LoginAttempts int `gorm:"default:0"`
} }
type ResetPasswordRequest struct { type ResetPasswordRequest struct {