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" // "github.com/gorilla/mux"
"net/http" "net/http"
// "strconv" // "strconv"
"GoMembership/internal/utils"
"GoMembership/pkg/logger" "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) { func (uc *UserController) RegisterUser(w http.ResponseWriter, r *http.Request) {
logger.Info.Println("registering user") logger.Info.Println("registering user")
rh := utils.NewResponseHandler(w)
var user models.User var user models.User
if err := json.NewDecoder(r.Body).Decode(&user); err != nil { 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) logger.Error.Printf("Couldn't decode Userdata: %v", err)
rh.RespondWithError(http.StatusBadRequest, "Couldn't decode userdata")
return return
} }
if err := uc.service.RegisterUser(&user); err != nil { id, err := uc.service.RegisterUser(&user)
http.Error(w, err.Error(), http.StatusInternalServerError) if err != nil {
// http.Error(w, err.Error(), http.StatusInternalServerError)
logger.Error.Printf("Couldn't register User: %v", err) logger.Error.Printf("Couldn't register User: %v", err)
rh.RespondWithError(http.StatusInternalServerError, "Couldn't register User")
return return
} }
// Send welcome email to the user // Send welcome email to the user
if err := uc.emailService.SendWelcomeEmail(user); err != nil { if err := uc.emailService.SendWelcomeEmail(user); err != nil {
logger.Error.Printf("Failed to send welcome email to user: %v", err) 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 // Notify admin of new user registration
if err := uc.emailService.NotifyAdminOfNewUser(user.Email); err != nil { if err := uc.emailService.NotifyAdminOfNewUser(user.Email); err != nil {
logger.Error.Printf("Failed to notify admin of new user registration: %v", err) 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) { /* func (uc *UserController) LoginUser(w http.ResponseWriter, r *http.Request) {

View File

@@ -7,11 +7,26 @@ import (
) )
type UserRepository interface { type UserRepository interface {
CreateUser(user *models.User) error CreateUser(user *models.User) (int64, error)
FindUserByID(id int) (*models.User, error) FindUserByID(id int) (*models.User, error)
FindUserByEmail(email string) (*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 { type userRepository struct {
db *sql.DB db *sql.DB
} }
@@ -20,12 +35,6 @@ func NewUserRepository(db *sql.DB) UserRepository {
return &userRepository{db} 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) { func (repo *userRepository) FindUserByID(id int) (*models.User, error) {
var user models.User var user models.User
query := "SELECT id, first_name, last_name, email, iban, bic, mandate_reference FROM users WHERE id = ?" 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 { type UserService interface {
RegisterUser(user *models.User) error RegisterUser(user *models.User) (int64, error)
// AuthenticateUser(email, password string) (*models.User, error) // AuthenticateUser(email, password string) (*models.User, error)
} }
@@ -23,16 +23,16 @@ func NewUserService(repo repositories.UserRepository) UserService {
return &userService{repo} return &userService{repo}
} }
func (service *userService) RegisterUser(user *models.User) error { func (service *userService) RegisterUser(user *models.User) (int64, error) {
salt := make([]byte, 16) salt := make([]byte, 16)
if _, err := rand.Read(salt); err != nil { if _, err := rand.Read(salt); err != nil {
return err return -1, err
} }
user.Salt = base64.StdEncoding.EncodeToString(salt) user.Salt = base64.StdEncoding.EncodeToString(salt)
hashedPassword, err := HashPassword(user.Password, user.Salt) hashedPassword, err := HashPassword(user.Password, user.Salt)
if err != nil { if err != nil {
return err return -1, err
} }
user.Password = string(hashedPassword) user.Password = string(hashedPassword)
user.CreatedAt = time.Now() 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)
}