add: user_service GetUserByID Function
This commit is contained in:
@@ -1,7 +1,6 @@
|
|||||||
package services
|
package services
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
@@ -20,6 +19,7 @@ import (
|
|||||||
type UserServiceInterface interface {
|
type UserServiceInterface interface {
|
||||||
RegisterUser(user *models.User) (int64, string, error)
|
RegisterUser(user *models.User) (int64, string, error)
|
||||||
GetUserByEmail(email string) (*models.User, error)
|
GetUserByEmail(email string) (*models.User, error)
|
||||||
|
GetUserByID(id int64) (*models.User, error)
|
||||||
GetUsers(where map[string]interface{}) (*[]models.User, error)
|
GetUsers(where map[string]interface{}) (*[]models.User, error)
|
||||||
VerifyUser(token *string) (*models.User, error)
|
VerifyUser(token *string) (*models.User, error)
|
||||||
}
|
}
|
||||||
@@ -69,14 +69,7 @@ func (service *UserService) Update(user *models.User) (int64, string, error) {
|
|||||||
return http.StatusNotAcceptable, "", err
|
return http.StatusNotAcceptable, "", err
|
||||||
}
|
}
|
||||||
|
|
||||||
if user.Password == "" && user.RoleID != constants.Roles.Member {
|
setPassword(user.Password, user)
|
||||||
return http.StatusNotAcceptable, "", fmt.Errorf("No password provided")
|
|
||||||
}
|
|
||||||
hash, err := utils.HashPassword(user.Password)
|
|
||||||
if err != nil {
|
|
||||||
return http.StatusInternalServerError, "", err
|
|
||||||
}
|
|
||||||
user.Password = hash
|
|
||||||
|
|
||||||
user.Status = constants.UnverifiedStatus
|
user.Status = constants.UnverifiedStatus
|
||||||
user.CreatedAt = time.Now()
|
user.CreatedAt = time.Now()
|
||||||
@@ -106,6 +99,12 @@ func (service *UserService) Update(user *models.User) (int64, string, error) {
|
|||||||
|
|
||||||
return id, token, nil
|
return id, token, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (service *UserService) GetUserByID(id int64) (*models.User, error) {
|
||||||
|
|
||||||
|
return service.Repo.GetUserByID(id)
|
||||||
|
}
|
||||||
|
|
||||||
func (service *UserService) GetUserByEmail(email string) (*models.User, error) {
|
func (service *UserService) GetUserByEmail(email string) (*models.User, error) {
|
||||||
return service.Repo.GetUserByEmail(email)
|
return service.Repo.GetUserByEmail(email)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user