package authhttp import ( responsedomain "legalgo-BE-go/internal/domain/reponse" userdomain "legalgo-BE-go/internal/domain/user" authsvc "legalgo-BE-go/internal/services/auth" "legalgo-BE-go/internal/utilities/response" "legalgo-BE-go/internal/utilities/utils" "net/http" "github.com/go-chi/chi/v5" "github.com/go-playground/validator/v10" "github.com/redis/go-redis/v9" ) func RegisterUser( router chi.Router, validate *validator.Validate, authSvc authsvc.Auth, rdb *redis.Client, ) { router.Post("/user/register", func(w http.ResponseWriter, r *http.Request) { ctx := r.Context() var spec userdomain.UserRegister 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.RegisterUser(spec) 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 { response.ResponseWithErrorCode( ctx, w, err, response.ErrBadRequest.Code, response.ErrBadRequest.HttpCode, err.Error(), ) return } responsePayload := &responsedomain.Auth{ Token: token, } response.RespondJsonSuccess(ctx, w, responsePayload) }) }