added more general response handler

This commit is contained in:
$(pass /github/name)
2024-07-07 15:49:28 +02:00
parent ea29ec22bf
commit 90edd26ae0
4 changed files with 70 additions and 16 deletions

View File

@@ -7,6 +7,7 @@ import (
// "github.com/gorilla/mux"
"net/http"
// "strconv"
"GoMembership/internal/utils"
"GoMembership/pkg/logger"
)
@@ -20,29 +21,38 @@ func NewUserController(service services.UserService, emailService *services.Emai
}
func (uc *UserController) RegisterUser(w http.ResponseWriter, r *http.Request) {
logger.Info.Println("registering user")
rh := utils.NewResponseHandler(w)
var user models.User
if err := json.NewDecoder(r.Body).Decode(&user); err != nil {
http.Error(w, err.Error(), http.StatusBadRequest)
// http.Error(w, err.Error(), http.StatusBadRequest)
logger.Error.Printf("Couldn't decode Userdata: %v", err)
rh.RespondWithError(http.StatusBadRequest, "Couldn't decode userdata")
return
}
if err := uc.service.RegisterUser(&user); err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError)
id, err := uc.service.RegisterUser(&user)
if err != nil {
// http.Error(w, err.Error(), http.StatusInternalServerError)
logger.Error.Printf("Couldn't register User: %v", err)
rh.RespondWithError(http.StatusInternalServerError, "Couldn't register User")
return
}
// Send welcome email to the user
if err := uc.emailService.SendWelcomeEmail(user); err != nil {
logger.Error.Printf("Failed to send welcome email to user: %v", err)
// rh.RespondWithError(http.StatusServiceUnavailable, "User creation succeeded, but failed to send welcome email to user")
}
// Notify admin of new user registration
if err := uc.emailService.NotifyAdminOfNewUser(user.Email); err != nil {
logger.Error.Printf("Failed to notify admin of new user registration: %v", err)
// rh.RespondWithError(http.StatusServiceUnavailable, "User creation succeeded, but failed to notify admin of new user registration")
}
w.WriteHeader(http.StatusCreated)
rh.RespondWithJSON(http.StatusCreated, map[string]interface{}{
"status": "success",
"id": id,
})
}
/* func (uc *UserController) LoginUser(w http.ResponseWriter, r *http.Request) {

View File

@@ -7,11 +7,26 @@ import (
)
type UserRepository interface {
CreateUser(user *models.User) error
CreateUser(user *models.User) (int64, error)
FindUserByID(id int) (*models.User, error)
FindUserByEmail(email string) (*models.User, error)
}
func (repo *userRepository) CreateUser(user *models.User) (int64, error) {
query := "INSERT INTO users (first_name, last_name, email, password, salt, iban, bic, mandate_reference, mandate_date_signed, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)"
result, err := repo.db.Exec(query, user.FirstName, user.LastName, user.Email, user.Password, user.Salt, user.IBAN, user.BIC, user.MandateReference, user.MandateDateSigned, user.CreatedAt, user.UpdatedAt)
if err != nil {
return -1, err
}
lastInsertID, err := result.LastInsertId()
if err != nil {
return -1, err
}
return lastInsertID, err
}
type userRepository struct {
db *sql.DB
}
@@ -20,12 +35,6 @@ func NewUserRepository(db *sql.DB) UserRepository {
return &userRepository{db}
}
func (repo *userRepository) CreateUser(user *models.User) error {
query := "INSERT INTO users (first_name, last_name, email, password, salt, iban, bic, mandate_reference, mandate_date_signed, created_at, updated_at) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)"
_, err := repo.db.Exec(query, user.FirstName, user.LastName, user.Email, user.Password, user.Salt, user.IBAN, user.BIC, user.MandateReference, user.MandateDateSigned, user.CreatedAt, user.UpdatedAt)
return err
}
func (repo *userRepository) FindUserByID(id int) (*models.User, error) {
var user models.User
query := "SELECT id, first_name, last_name, email, iban, bic, mandate_reference FROM users WHERE id = ?"

View File

@@ -11,7 +11,7 @@ import (
)
type UserService interface {
RegisterUser(user *models.User) error
RegisterUser(user *models.User) (int64, error)
// AuthenticateUser(email, password string) (*models.User, error)
}
@@ -23,16 +23,16 @@ func NewUserService(repo repositories.UserRepository) UserService {
return &userService{repo}
}
func (service *userService) RegisterUser(user *models.User) error {
func (service *userService) RegisterUser(user *models.User) (int64, error) {
salt := make([]byte, 16)
if _, err := rand.Read(salt); err != nil {
return err
return -1, err
}
user.Salt = base64.StdEncoding.EncodeToString(salt)
hashedPassword, err := HashPassword(user.Password, user.Salt)
if err != nil {
return err
return -1, err
}
user.Password = string(hashedPassword)
user.CreatedAt = time.Now()

View File

@@ -0,0 +1,35 @@
package utils
import (
"encoding/json"
"net/http"
)
type ResponseHandler struct {
Writer http.ResponseWriter
}
type Response struct {
Status string `json:"status"`
Message string `json:"message"`
}
func NewResponseHandler(w http.ResponseWriter) *ResponseHandler {
return &ResponseHandler{Writer: w}
}
func (rh *ResponseHandler) RespondWithError(code int, message string) {
response := Response{
Status: "error",
Message: message,
}
rh.Writer.Header().Set("Content-Type", "application/json")
rh.Writer.WriteHeader(code)
json.NewEncoder(rh.Writer).Encode(response)
}
func (rh *ResponseHandler) RespondWithJSON(code int, payload interface{}) {
rh.Writer.Header().Set("Content-Type", "application/json")
rh.Writer.WriteHeader(code)
json.NewEncoder(rh.Writer).Encode(payload)
}