legalgo-BE-go/internal/api/http/auth/register_staff.go

83 lines
1.7 KiB
Go
Raw Normal View History

2025-02-24 16:48:20 +08:00
package authhttp
import (
"net/http"
responsedomain "legalgo-BE-go/internal/domain/reponse"
staffdomain "legalgo-BE-go/internal/domain/staff"
authsvc "legalgo-BE-go/internal/services/auth"
"legalgo-BE-go/internal/utilities/response"
"legalgo-BE-go/internal/utilities/utils"
2025-02-24 16:48:20 +08:00
"github.com/go-chi/chi/v5"
"github.com/go-playground/validator/v10"
"github.com/redis/go-redis/v9"
2025-02-24 16:48:20 +08:00
)
func RegisterStaff(
2025-02-24 16:48:20 +08:00
router chi.Router,
validate *validator.Validate,
authSvc authsvc.Auth,
rdb *redis.Client,
2025-02-24 16:48:20 +08:00
) {
router.Post("/staff/register", func(w http.ResponseWriter, r *http.Request) {
2025-02-24 16:48:20 +08:00
ctx := r.Context()
var spec staffdomain.StaffRegister
2025-02-24 16:48:20 +08:00
if err := utils.UnmarshalBody(r, &spec); err != nil {
response.ResponseWithErrorCode(
ctx,
w,
err,
response.ErrBadRequest.Code,
response.ErrBadRequest.HttpCode,
"failed to unmarshal request",
)
return
}
if err := validate.Struct(spec); err != nil {
response.ResponseWithErrorCode(
ctx,
w,
err,
response.ErrBadRequest.Code,
response.ErrBadRequest.HttpCode,
err.(validator.ValidationErrors).Error(),
)
return
}
token, err := authSvc.RegisterStaff(spec)
2025-02-24 16:48:20 +08:00
if err != nil {
response.ResponseWithErrorCode(
ctx,
w,
err,
response.ErrBadRequest.Code,
response.ErrBadRequest.HttpCode,
err.Error(),
)
return
}
if err := utils.StoreTokenRedis(ctx, rdb, token, spec.Email); err != nil {
2025-02-24 16:48:20 +08:00
response.ResponseWithErrorCode(
ctx,
w,
err,
response.ErrBadRequest.Code,
response.ErrBadRequest.HttpCode,
err.Error(),
)
return
}
responsePayload := &responsedomain.Auth{
2025-02-25 11:07:17 +08:00
Token: token,
}
response.RespondJsonSuccess(ctx, w, responsePayload)
2025-02-24 16:48:20 +08:00
})
}