feat(subscribe): rename stop user subscribe handler to toggle and update logic for status change
This commit is contained in:
parent
577490749c
commit
e8084e9d2c
@ -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
|
||||||
|
|||||||
@ -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)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -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))
|
||||||
|
|||||||
@ -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))
|
||||||
@ -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"`
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user