Add lawyer information reporting interface and update routes
This commit is contained in:
@@ -0,0 +1,76 @@
|
||||
package handler
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"strings"
|
||||
"time"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
|
||||
lawyermodel "wx_service/internal/lawyer/model"
|
||||
lawyerservice "wx_service/internal/lawyer/service"
|
||||
"wx_service/internal/model"
|
||||
)
|
||||
|
||||
type LawyerHandler struct {
|
||||
service *lawyerservice.Service
|
||||
}
|
||||
|
||||
func NewLawyerHandler(service *lawyerservice.Service) *LawyerHandler {
|
||||
return &LawyerHandler{service: service}
|
||||
}
|
||||
|
||||
type createLawyerRequest struct {
|
||||
Phone string `json:"phone" binding:"required"`
|
||||
Province string `json:"province"`
|
||||
City string `json:"city"`
|
||||
LawFirm string `json:"law_firm"`
|
||||
URL string `json:"url"`
|
||||
CreateTime *int `json:"create_time"`
|
||||
Domain string `json:"domain"`
|
||||
Name string `json:"name"`
|
||||
Params *string `json:"params"`
|
||||
}
|
||||
|
||||
func (h *LawyerHandler) Create(c *gin.Context) {
|
||||
var req createLawyerRequest
|
||||
if err := c.ShouldBindJSON(&req); err != nil {
|
||||
c.JSON(http.StatusBadRequest, model.Error(http.StatusBadRequest, "请求参数错误"))
|
||||
return
|
||||
}
|
||||
|
||||
phone := strings.TrimSpace(req.Phone)
|
||||
if phone == "" {
|
||||
c.JSON(http.StatusBadRequest, model.Error(http.StatusBadRequest, "手机号不能为空"))
|
||||
return
|
||||
}
|
||||
|
||||
createTime := time.Now().Unix()
|
||||
if req.CreateTime != nil && *req.CreateTime > 0 {
|
||||
createTime = int64(*req.CreateTime)
|
||||
}
|
||||
|
||||
record := &lawyermodel.Lawyer{
|
||||
Phone: phone,
|
||||
Province: strings.TrimSpace(req.Province),
|
||||
City: strings.TrimSpace(req.City),
|
||||
LawFirm: strings.TrimSpace(req.LawFirm),
|
||||
URL: strings.TrimSpace(req.URL),
|
||||
CreateTime: int(createTime),
|
||||
Domain: strings.TrimSpace(req.Domain),
|
||||
Name: strings.TrimSpace(req.Name),
|
||||
}
|
||||
|
||||
if req.Params != nil {
|
||||
record.Params = strings.TrimSpace(*req.Params)
|
||||
}
|
||||
|
||||
if err := h.service.CreateLawyer(c.Request.Context(), record); err != nil {
|
||||
c.JSON(http.StatusInternalServerError, model.Error(http.StatusInternalServerError, "保存失败,请稍后重试"))
|
||||
return
|
||||
}
|
||||
|
||||
c.JSON(http.StatusCreated, model.Success(gin.H{
|
||||
"id": record.ID,
|
||||
}))
|
||||
}
|
||||
@@ -0,0 +1,19 @@
|
||||
package model
|
||||
|
||||
// Lawyer 对应 lawyer 库中的 lawyer 表(无需自动迁移)。
|
||||
type Lawyer struct {
|
||||
ID uint `gorm:"column:id;primaryKey;autoIncrement"`
|
||||
Phone string `gorm:"column:phone"`
|
||||
Province string `gorm:"column:province"`
|
||||
City string `gorm:"column:city"`
|
||||
LawFirm string `gorm:"column:law_firm"`
|
||||
URL string `gorm:"column:url"`
|
||||
CreateTime int `gorm:"column:create_time"`
|
||||
Domain string `gorm:"column:domain"`
|
||||
Name string `gorm:"column:name"`
|
||||
Params string `gorm:"column:params"`
|
||||
}
|
||||
|
||||
func (Lawyer) TableName() string {
|
||||
return "lawyer"
|
||||
}
|
||||
@@ -0,0 +1,21 @@
|
||||
package service
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"gorm.io/gorm"
|
||||
|
||||
lawyermodel "wx_service/internal/lawyer/model"
|
||||
)
|
||||
|
||||
type Service struct {
|
||||
db *gorm.DB
|
||||
}
|
||||
|
||||
func NewService(db *gorm.DB) *Service {
|
||||
return &Service{db: db}
|
||||
}
|
||||
|
||||
func (s *Service) CreateLawyer(ctx context.Context, lawyer *lawyermodel.Lawyer) error {
|
||||
return s.db.WithContext(ctx).Create(lawyer).Error
|
||||
}
|
||||
@@ -10,6 +10,7 @@ import (
|
||||
qiniuhandler "wx_service/internal/common/qiniu/handler"
|
||||
rediscache "wx_service/internal/common/redis/cache"
|
||||
oahandler "wx_service/internal/common/wechat_official/handler"
|
||||
lawyerhandler "wx_service/internal/lawyer/handler"
|
||||
membershiphandler "wx_service/internal/membership/handler"
|
||||
"wx_service/internal/middleware"
|
||||
rmhandler "wx_service/internal/remove_watermark/handler"
|
||||
@@ -26,6 +27,7 @@ func Register(
|
||||
uploadHandler *qiniuhandler.UploadHandler,
|
||||
oaOAuthHandler *oahandler.OAuthHandler,
|
||||
sessionCache *rediscache.SessionUserCache,
|
||||
lawyerHandler *lawyerhandler.LawyerHandler,
|
||||
) {
|
||||
// Register 用来集中注册所有 HTTP 路由,便于工程结构更清晰:
|
||||
// - main 只负责初始化(配置/DB/依赖注入)
|
||||
@@ -38,6 +40,10 @@ func Register(
|
||||
// 公众号网页授权:不需要登录(code 本身来自微信授权回调)
|
||||
registerWeChatOfficialRoutes(api, oaOAuthHandler)
|
||||
|
||||
if lawyerHandler != nil {
|
||||
api.POST("/lawyers", lawyerHandler.Create)
|
||||
}
|
||||
|
||||
// 需要登录的接口组:统一挂载鉴权中间件
|
||||
protected := api.Group("")
|
||||
protected.Use(middleware.AuthMiddleware(db, sessionCache))
|
||||
|
||||
Reference in New Issue
Block a user