package auth import ( errs "backend/pkg/library/errors" "backend/pkg/library/errors/code" "net/http" "backend/internal/logic/auth" "backend/internal/svc" "backend/internal/types" "github.com/zeromicro/go-zero/rest/httpx" ) // 執行密碼重設 func ResetPasswordHandler(svcCtx *svc.ServiceContext) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { var req types.ResetPasswordReq if err := httpx.Parse(r, &req); err != nil { e := errs.InputInvalidFormatError(err.Error()) httpx.WriteJsonCtx(r.Context(), w, e.HTTPStatus(), types.Resp{ Code: e.DisplayCode(), Message: err.Error(), }) return } // //if err := svcCtx.Validate.ValidateAll(req); err != nil { // e := errs.InvalidFormat(err.Error()) // httpx.WriteJsonCtx(r.Context(), w, e.HTTPStatus(), types.Status{ // Code: int64(e.FullCode()), // Message: err.Error(), // }) // // return //} l := auth.NewResetPasswordLogic(r.Context(), svcCtx) resp, err := l.ResetPassword(&req) if err != nil { e := errs.FromError(err) httpx.WriteJsonCtx(r.Context(), w, e.HTTPStatus(), types.Resp{ Code: e.DisplayCode(), Message: e.Error(), Error: e.Unwrap(), }) } else { httpx.WriteJsonCtx(r.Context(), w, http.StatusOK, types.Resp{ Code: code.SUCCESSCode, Message: code.SUCCESSMessage, Data: resp, }) } } }