- Node group CRUD operations with traffic-based filtering - Three grouping modes: average distribution, subscription-based, and traffic-based - Automatic and manual group recalculation with history tracking - Group assignment preview before applying changes - User subscription group locking to prevent automatic reassignment - Subscribe-to-group mapping configuration - Group calculation history and detailed reports - System configuration for group management (enabled/mode/auto_create) Database: - Add node_group table for group definitions - Add group_history and group_history_detail tables for tracking - Add node_group_ids (JSON) to nodes and subscribe tables - Add node_group_id and group_locked fields to user_subscribe table - Add migration files for schema changes
51 lines
1.9 KiB
Go
51 lines
1.9 KiB
Go
package handler
|
|
|
|
import (
|
|
"github.com/hibiken/asynq"
|
|
"github.com/perfect-panel/server/internal/svc"
|
|
groupLogic "github.com/perfect-panel/server/queue/logic/group"
|
|
orderLogic "github.com/perfect-panel/server/queue/logic/order"
|
|
smslogic "github.com/perfect-panel/server/queue/logic/sms"
|
|
"github.com/perfect-panel/server/queue/logic/subscription"
|
|
"github.com/perfect-panel/server/queue/logic/task"
|
|
"github.com/perfect-panel/server/queue/logic/traffic"
|
|
"github.com/perfect-panel/server/queue/types"
|
|
|
|
emailLogic "github.com/perfect-panel/server/queue/logic/email"
|
|
)
|
|
|
|
func RegisterHandlers(mux *asynq.ServeMux, serverCtx *svc.ServiceContext) {
|
|
// Send email task
|
|
mux.Handle(types.ForthwithSendEmail, emailLogic.NewSendEmailLogic(serverCtx))
|
|
// Send sms task
|
|
mux.Handle(types.ForthwithSendSms, smslogic.NewSendSmsLogic(serverCtx))
|
|
// Defer close order task
|
|
mux.Handle(types.DeferCloseOrder, orderLogic.NewDeferCloseOrderLogic(serverCtx))
|
|
// Forthwith activate order task
|
|
mux.Handle(types.ForthwithActivateOrder, orderLogic.NewActivateOrderLogic(serverCtx))
|
|
|
|
// Forthwith traffic statistics
|
|
mux.Handle(types.ForthwithTrafficStatistics, traffic.NewTrafficStatisticsLogic(serverCtx))
|
|
|
|
// Schedule check subscription
|
|
mux.Handle(types.SchedulerCheckSubscription, subscription.NewCheckSubscriptionLogic(serverCtx))
|
|
|
|
// Schedule total server data
|
|
mux.Handle(types.SchedulerTotalServerData, traffic.NewServerDataLogic(serverCtx))
|
|
|
|
// Schedule reset traffic
|
|
mux.Handle(types.SchedulerResetTraffic, traffic.NewResetTrafficLogic(serverCtx))
|
|
|
|
// ScheduledBatchSendEmail
|
|
mux.Handle(types.ScheduledBatchSendEmail, emailLogic.NewBatchEmailLogic(serverCtx))
|
|
|
|
// ScheduledTrafficStat
|
|
mux.Handle(types.SchedulerTrafficStat, traffic.NewStatLogic(serverCtx))
|
|
|
|
// ForthwithQuotaTask
|
|
mux.Handle(types.ForthwithQuotaTask, task.NewQuotaTaskLogic(serverCtx))
|
|
|
|
// SchedulerRecalculateGroup
|
|
mux.Handle(types.SchedulerRecalculateGroup, groupLogic.NewRecalculateGroupLogic(serverCtx))
|
|
}
|