重构代码结构与认证体系,集成异步任务消费者
This commit is contained in:
@@ -1,18 +0,0 @@
|
||||
package tasks
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"github.com/hibiken/asynq"
|
||||
"log/slog"
|
||||
)
|
||||
|
||||
const RemoveChannel = "channel:remove"
|
||||
|
||||
func NewRemoveChannel(ids []int32) *asynq.Task {
|
||||
bytes, err := json.Marshal(ids)
|
||||
if err != nil {
|
||||
slog.Error("序列化删除通道任务失败", "error", err)
|
||||
return nil
|
||||
}
|
||||
return asynq.NewTask(RemoveChannel, bytes)
|
||||
}
|
||||
@@ -1,33 +0,0 @@
|
||||
package tasks
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"github.com/hibiken/asynq"
|
||||
"log/slog"
|
||||
"time"
|
||||
)
|
||||
|
||||
type RequestLog struct {
|
||||
Type string
|
||||
User int32
|
||||
IP string
|
||||
UA string
|
||||
Method string
|
||||
Path string
|
||||
Status int
|
||||
Error string
|
||||
Latency time.Duration
|
||||
Time time.Time
|
||||
}
|
||||
|
||||
func NewRequestLog(data RequestLog) *asynq.Task {
|
||||
var rs, err = json.Marshal(data)
|
||||
if err != nil {
|
||||
slog.Error("日志数据序列化失败", slog.Any("err", err), slog.Any("data", data))
|
||||
return nil
|
||||
}
|
||||
return asynq.NewTask("logs:request", rs)
|
||||
}
|
||||
|
||||
type LoginLog struct {
|
||||
}
|
||||
41
web/tasks/task.go
Normal file
41
web/tasks/task.go
Normal file
@@ -0,0 +1,41 @@
|
||||
package tasks
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
"fmt"
|
||||
"platform/web/events"
|
||||
s "platform/web/services"
|
||||
"time"
|
||||
|
||||
"github.com/hibiken/asynq"
|
||||
)
|
||||
|
||||
func HandleCancelTrade(_ context.Context, task *asynq.Task) (err error) {
|
||||
data := new(events.CancelTradeData)
|
||||
err = json.Unmarshal(task.Payload(), data)
|
||||
if err != nil {
|
||||
return fmt.Errorf("解析任务参数失败: %w", err)
|
||||
}
|
||||
|
||||
err = s.Trade.CancelTrade(data.TradeNo, data.Method, time.Now())
|
||||
if err != nil {
|
||||
return fmt.Errorf("取消交易失败: %w", err)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func HandleRemoveChannel(_ context.Context, task *asynq.Task) (err error) {
|
||||
data := make([]int32, 0)
|
||||
err = json.Unmarshal(task.Payload(), &data)
|
||||
if err != nil {
|
||||
return fmt.Errorf("解析任务参数失败: %w", err)
|
||||
}
|
||||
|
||||
err = s.Channel.RemoveChannels(data)
|
||||
if err != nil {
|
||||
return fmt.Errorf("删除通道失败: %w", err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
@@ -1,24 +0,0 @@
|
||||
package tasks
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"github.com/hibiken/asynq"
|
||||
"log/slog"
|
||||
trade2 "platform/web/domains/trade"
|
||||
)
|
||||
|
||||
const CancelTrade = "trade:update"
|
||||
|
||||
type CancelTradeData struct {
|
||||
TradeNo string `json:"trade_no" validate:"required"`
|
||||
Method trade2.Method `json:"method" validate:"required"`
|
||||
}
|
||||
|
||||
func NewCancelTrade(data CancelTradeData) *asynq.Task {
|
||||
bytes, err := json.Marshal(data)
|
||||
if err != nil {
|
||||
slog.Error("序列化更新交易任务失败", "error", err)
|
||||
return nil
|
||||
}
|
||||
return asynq.NewTask(CancelTrade, bytes)
|
||||
}
|
||||
Reference in New Issue
Block a user