feat(subscribe): rename stop user subscribe handler to toggle and update logic for status change

This commit is contained in:
Tension 2025-12-29 13:50:50 +08:00
parent 577490749c
commit e8084e9d2c
5 changed files with 28 additions and 18 deletions

View File

@ -184,7 +184,7 @@ type (
GetUserSubscribeByIdRequest { GetUserSubscribeByIdRequest {
Id int64 `form:"id" validate:"required"` Id int64 `form:"id" validate:"required"`
} }
StopUserSubscribeRequest { ToggleUserSubscribeStatusRequest {
UserSubscribeId int64 `json:"user_subscribe_id"` UserSubscribeId int64 `json:"user_subscribe_id"`
} }
ResetUserSubscribeTrafficRequest { ResetUserSubscribeTrafficRequest {
@ -304,8 +304,8 @@ service ppanel {
post /subscribe/reset/token (ResetUserSubscribeTokenRequest) post /subscribe/reset/token (ResetUserSubscribeTokenRequest)
@doc "Stop user subscribe" @doc "Stop user subscribe"
@handler StopUserSubscribe @handler ToggleUserSubscribeStatus
post /subscribe/stop (StopUserSubscribeRequest) post /subscribe/toggle (ToggleUserSubscribeStatusRequest)
@doc "Reset user subscribe traffic" @doc "Reset user subscribe traffic"
@handler ResetUserSubscribeTraffic @handler ResetUserSubscribeTraffic

View File

@ -9,9 +9,9 @@ import (
) )
// Stop user subscribe // Stop user subscribe
func StopUserSubscribeHandler(svcCtx *svc.ServiceContext) func(c *gin.Context) { func ToggleUserSubscribeStatusHandler(svcCtx *svc.ServiceContext) func(c *gin.Context) {
return func(c *gin.Context) { return func(c *gin.Context) {
var req types.StopUserSubscribeRequest var req types.ToggleUserSubscribeStatusRequest
_ = c.ShouldBind(&req) _ = c.ShouldBind(&req)
validateErr := svcCtx.Validate(&req) validateErr := svcCtx.Validate(&req)
if validateErr != nil { if validateErr != nil {
@ -19,8 +19,8 @@ func StopUserSubscribeHandler(svcCtx *svc.ServiceContext) func(c *gin.Context) {
return return
} }
l := user.NewStopUserSubscribeLogic(c.Request.Context(), svcCtx) l := user.NewToggleUserSubscribeStatusLogic(c.Request.Context(), svcCtx)
err := l.StopUserSubscribe(&req) err := l.ToggleUserSubscribeStatus(&req)
result.HttpResult(c, nil, err) result.HttpResult(c, nil, err)
} }
} }

View File

@ -583,7 +583,7 @@ func RegisterHandlers(router *gin.Engine, serverCtx *svc.ServiceContext) {
adminUserGroupRouter.POST("/subscribe/reset/traffic", adminUser.ResetUserSubscribeTrafficHandler(serverCtx)) adminUserGroupRouter.POST("/subscribe/reset/traffic", adminUser.ResetUserSubscribeTrafficHandler(serverCtx))
// Stop user subscribe // Stop user subscribe
adminUserGroupRouter.POST("/subscribe/stop", adminUser.StopUserSubscribeHandler(serverCtx)) adminUserGroupRouter.POST("/subscribe/toggle", adminUser.ToggleUserSubscribeStatusHandler(serverCtx))
// Get user subcribe traffic logs // Get user subcribe traffic logs
adminUserGroupRouter.GET("/subscribe/traffic_logs", adminUser.GetUserSubscribeTrafficLogsHandler(serverCtx)) adminUserGroupRouter.GET("/subscribe/traffic_logs", adminUser.GetUserSubscribeTrafficLogsHandler(serverCtx))

View File

@ -10,28 +10,38 @@ import (
"github.com/pkg/errors" "github.com/pkg/errors"
) )
type StopUserSubscribeLogic struct { type ToggleUserSubscribeStatusLogic struct {
logger.Logger logger.Logger
ctx context.Context ctx context.Context
svcCtx *svc.ServiceContext svcCtx *svc.ServiceContext
} }
// NewStopUserSubscribeLogic Stop user subscribe // NewToggleUserSubscribeStatusLogic Stop user subscribe
func NewStopUserSubscribeLogic(ctx context.Context, svcCtx *svc.ServiceContext) *StopUserSubscribeLogic { func NewToggleUserSubscribeStatusLogic(ctx context.Context, svcCtx *svc.ServiceContext) *ToggleUserSubscribeStatusLogic {
return &StopUserSubscribeLogic{ return &ToggleUserSubscribeStatusLogic{
Logger: logger.WithContext(ctx), Logger: logger.WithContext(ctx),
ctx: ctx, ctx: ctx,
svcCtx: svcCtx, svcCtx: svcCtx,
} }
} }
func (l *StopUserSubscribeLogic) StopUserSubscribe(req *types.StopUserSubscribeRequest) error { func (l *ToggleUserSubscribeStatusLogic) ToggleUserSubscribeStatus(req *types.ToggleUserSubscribeStatusRequest) error {
userSub, err := l.svcCtx.UserModel.FindOneSubscribe(l.ctx, req.UserSubscribeId) userSub, err := l.svcCtx.UserModel.FindOneSubscribe(l.ctx, req.UserSubscribeId)
if err != nil { if err != nil {
l.Errorw("FindOneSubscribe error", logger.Field("error", err.Error()), logger.Field("userSubscribeId", req.UserSubscribeId)) l.Errorw("FindOneSubscribe error", logger.Field("error", err.Error()), logger.Field("userSubscribeId", req.UserSubscribeId))
return errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), " FindOneSubscribe error: %v", err.Error()) return errors.Wrapf(xerr.NewErrCode(xerr.DatabaseQueryError), " FindOneSubscribe error: %v", err.Error())
} }
switch userSub.Status {
case 2: // active
userSub.Status = 5 // set status to stopped userSub.Status = 5 // set status to stopped
case 5: // stopped
userSub.Status = 2 // set status to active
default:
l.Errorw("invalid user subscribe status", logger.Field("userSubscribeId", req.UserSubscribeId), logger.Field("status", userSub.Status))
return errors.Wrapf(xerr.NewErrCodeMsg(xerr.ERROR, "invalid subscribe status"), "invalid user subscribe status: %d", userSub.Status)
}
err = l.svcCtx.UserModel.UpdateSubscribe(l.ctx, userSub) err = l.svcCtx.UserModel.UpdateSubscribe(l.ctx, userSub)
if err != nil { if err != nil {
l.Errorw("UpdateSubscribe error", logger.Field("error", err.Error()), logger.Field("userSubscribeId", req.UserSubscribeId)) l.Errorw("UpdateSubscribe error", logger.Field("error", err.Error()), logger.Field("userSubscribeId", req.UserSubscribeId))

View File

@ -2044,10 +2044,6 @@ type StopBatchSendEmailTaskRequest struct {
Id int64 `json:"id"` Id int64 `json:"id"`
} }
type StopUserSubscribeRequest struct {
UserSubscribeId int64 `json:"user_subscribe_id"`
}
type StripePayment struct { type StripePayment struct {
Method string `json:"method"` Method string `json:"method"`
ClientSecret string `json:"client_secret"` ClientSecret string `json:"client_secret"`
@ -2239,6 +2235,10 @@ type ToggleNodeStatusRequest struct {
Enable *bool `json:"enable"` Enable *bool `json:"enable"`
} }
type ToggleUserSubscribeStatusRequest struct {
UserSubscribeId int64 `json:"user_subscribe_id"`
}
type TosConfig struct { type TosConfig struct {
TosContent string `json:"tos_content"` TosContent string `json:"tos_content"`
} }