2025-09-21 18:27:25 +08:00
|
|
|
|
package auth
|
|
|
|
|
|
|
|
|
|
|
|
import (
|
2026-02-28 12:29:30 +08:00
|
|
|
|
"context"
|
2025-09-21 18:27:25 +08:00
|
|
|
|
"net/http"
|
|
|
|
|
|
|
2025-09-30 17:44:18 +08:00
|
|
|
|
"tydata-server/app/main/api/internal/logic/auth"
|
|
|
|
|
|
"tydata-server/app/main/api/internal/svc"
|
|
|
|
|
|
"tydata-server/app/main/api/internal/types"
|
|
|
|
|
|
"tydata-server/common/result"
|
2026-02-28 12:29:30 +08:00
|
|
|
|
"tydata-server/pkg/captcha"
|
2025-09-30 17:44:18 +08:00
|
|
|
|
"tydata-server/pkg/lzkit/validator"
|
2025-09-21 18:27:25 +08:00
|
|
|
|
|
|
|
|
|
|
"github.com/zeromicro/go-zero/rest/httpx"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
func SendSmsHandler(svcCtx *svc.ServiceContext) http.HandlerFunc {
|
|
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
|
var req types.SendSmsReq
|
|
|
|
|
|
if err := httpx.Parse(r, &req); err != nil {
|
|
|
|
|
|
result.ParamErrorResult(r, w, err)
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
|
|
|
|
|
if err := validator.Validate(req); err != nil {
|
|
|
|
|
|
result.ParamValidateErrorResult(r, w, err)
|
|
|
|
|
|
return
|
|
|
|
|
|
}
|
2026-02-28 12:29:30 +08:00
|
|
|
|
// 将 request 注入 context,供 captcha 包判断微信等环境时跳过图形验证
|
|
|
|
|
|
ctx := context.WithValue(r.Context(), captcha.HTTPRequestContextKey, r)
|
|
|
|
|
|
l := auth.NewSendSmsLogic(ctx, svcCtx)
|
2025-09-21 18:27:25 +08:00
|
|
|
|
err := l.SendSms(&req)
|
|
|
|
|
|
result.HttpResult(r, w, nil, err)
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|