first commit
This commit is contained in:
		| @@ -0,0 +1,99 @@ | ||||
| package admin_order | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"database/sql" | ||||
| 	"fmt" | ||||
| 	"time" | ||||
|  | ||||
| 	"znc-server/app/main/api/internal/svc" | ||||
| 	"znc-server/app/main/api/internal/types" | ||||
| 	"znc-server/app/main/model" | ||||
| 	"znc-server/common/xerr" | ||||
|  | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/zeromicro/go-zero/core/logx" | ||||
| 	"github.com/zeromicro/go-zero/core/stores/sqlx" | ||||
| ) | ||||
|  | ||||
| type AdminCreateOrderLogic struct { | ||||
| 	logx.Logger | ||||
| 	ctx    context.Context | ||||
| 	svcCtx *svc.ServiceContext | ||||
| } | ||||
|  | ||||
| func NewAdminCreateOrderLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AdminCreateOrderLogic { | ||||
| 	return &AdminCreateOrderLogic{ | ||||
| 		Logger: logx.WithContext(ctx), | ||||
| 		ctx:    ctx, | ||||
| 		svcCtx: svcCtx, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (l *AdminCreateOrderLogic) AdminCreateOrder(req *types.AdminCreateOrderReq) (resp *types.AdminCreateOrderResp, err error) { | ||||
| 	// 生成订单号 | ||||
| 	orderNo := fmt.Sprintf("%dADMIN", time.Now().UnixNano()) | ||||
|  | ||||
| 	// 根据产品名称查询产品ID | ||||
| 	builder := l.svcCtx.ProductModel.SelectBuilder() | ||||
| 	builder = builder.Where("product_name = ? AND del_state = ?", req.ProductName, 0) | ||||
| 	products, err := l.svcCtx.ProductModel.FindAll(l.ctx, builder, "") | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminCreateOrder, 查询产品失败 err: %v", err) | ||||
| 	} | ||||
| 	if len(products) == 0 { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrMsg(fmt.Sprintf("产品不存在: %s", req.ProductName)), "AdminCreateOrder, 查询产品失败 err: %v", err) | ||||
| 	} | ||||
| 	product := products[0] | ||||
|  | ||||
| 	// 创建订单对象 | ||||
| 	order := &model.Order{ | ||||
| 		OrderNo:         orderNo, | ||||
| 		PlatformOrderId: sql.NullString{String: req.PlatformOrderId, Valid: req.PlatformOrderId != ""}, | ||||
| 		ProductId:       product.Id, | ||||
| 		PaymentPlatform: req.PaymentPlatform, | ||||
| 		PaymentScene:    req.PaymentScene, | ||||
| 		Amount:          req.Amount, | ||||
| 		Status:          req.Status, | ||||
| 	} | ||||
|  | ||||
| 	// 使用事务处理订单创建 | ||||
| 	var orderId int64 | ||||
| 	err = l.svcCtx.OrderModel.Trans(l.ctx, func(ctx context.Context, session sqlx.Session) error { | ||||
| 		// 插入订单 | ||||
| 		result, err := l.svcCtx.OrderModel.Insert(ctx, session, order) | ||||
| 		if err != nil { | ||||
| 			return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminCreateOrder, 创建订单失败 err: %v", err) | ||||
| 		} | ||||
|  | ||||
| 		// 获取订单ID | ||||
| 		orderId, err = result.LastInsertId() | ||||
| 		if err != nil { | ||||
| 			return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminCreateOrder, 获取订单ID失败 err: %v", err) | ||||
| 		} | ||||
|  | ||||
| 		// 如果是推广订单,创建推广订单记录 | ||||
| 		if req.IsPromotion == 1 { | ||||
| 			promotionOrder := &model.AdminPromotionOrder{ | ||||
| 				OrderId:    orderId, | ||||
| 				Version:    1, | ||||
| 				CreateTime: time.Now(), | ||||
| 				UpdateTime: time.Now(), | ||||
| 			} | ||||
| 			_, err = l.svcCtx.AdminPromotionOrderModel.Insert(ctx, session, promotionOrder) | ||||
| 			if err != nil { | ||||
| 				return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminCreateOrder, 创建推广订单失败 err: %v", err) | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return nil | ||||
| 	}) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	return &types.AdminCreateOrderResp{ | ||||
| 		Id: orderId, | ||||
| 	}, nil | ||||
| } | ||||
| @@ -0,0 +1,63 @@ | ||||
| package admin_order | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
|  | ||||
| 	"znc-server/app/main/api/internal/svc" | ||||
| 	"znc-server/app/main/api/internal/types" | ||||
| 	"znc-server/common/xerr" | ||||
|  | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/zeromicro/go-zero/core/logx" | ||||
| 	"github.com/zeromicro/go-zero/core/stores/sqlx" | ||||
| ) | ||||
|  | ||||
| type AdminDeleteOrderLogic struct { | ||||
| 	logx.Logger | ||||
| 	ctx    context.Context | ||||
| 	svcCtx *svc.ServiceContext | ||||
| } | ||||
|  | ||||
| func NewAdminDeleteOrderLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AdminDeleteOrderLogic { | ||||
| 	return &AdminDeleteOrderLogic{ | ||||
| 		Logger: logx.WithContext(ctx), | ||||
| 		ctx:    ctx, | ||||
| 		svcCtx: svcCtx, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (l *AdminDeleteOrderLogic) AdminDeleteOrder(req *types.AdminDeleteOrderReq) (resp *types.AdminDeleteOrderResp, err error) { | ||||
| 	// 获取订单信息 | ||||
| 	order, err := l.svcCtx.OrderModel.FindOne(l.ctx, req.Id) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminDeleteOrder, 查询订单失败 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	// 使用事务删除订单 | ||||
| 	err = l.svcCtx.OrderModel.Trans(l.ctx, func(ctx context.Context, session sqlx.Session) error { | ||||
| 		// 软删除订单 | ||||
| 		err := l.svcCtx.OrderModel.DeleteSoft(ctx, session, order) | ||||
| 		if err != nil { | ||||
| 			return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminDeleteOrder, 删除订单失败 err: %v", err) | ||||
| 		} | ||||
|  | ||||
| 		// 删除关联的推广订单记录 | ||||
| 		promotionOrder, err := l.svcCtx.AdminPromotionOrderModel.FindOneByOrderId(ctx, order.Id) | ||||
| 		if err == nil && promotionOrder != nil { | ||||
| 			err = l.svcCtx.AdminPromotionOrderModel.DeleteSoft(ctx, session, promotionOrder) | ||||
| 			if err != nil { | ||||
| 				return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminDeleteOrder, 删除推广订单失败 err: %v", err) | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return nil | ||||
| 	}) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	return &types.AdminDeleteOrderResp{ | ||||
| 		Success: true, | ||||
| 	}, nil | ||||
| } | ||||
| @@ -0,0 +1,104 @@ | ||||
| package admin_order | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
|  | ||||
| 	"znc-server/app/main/api/internal/svc" | ||||
| 	"znc-server/app/main/api/internal/types" | ||||
| 	"znc-server/app/main/model" | ||||
| 	"znc-server/common/globalkey" | ||||
| 	"znc-server/common/xerr" | ||||
|  | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/zeromicro/go-zero/core/logx" | ||||
| ) | ||||
|  | ||||
| type AdminGetOrderDetailLogic struct { | ||||
| 	logx.Logger | ||||
| 	ctx    context.Context | ||||
| 	svcCtx *svc.ServiceContext | ||||
| } | ||||
|  | ||||
| func NewAdminGetOrderDetailLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AdminGetOrderDetailLogic { | ||||
| 	return &AdminGetOrderDetailLogic{ | ||||
| 		Logger: logx.WithContext(ctx), | ||||
| 		ctx:    ctx, | ||||
| 		svcCtx: svcCtx, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (l *AdminGetOrderDetailLogic) AdminGetOrderDetail(req *types.AdminGetOrderDetailReq) (resp *types.AdminGetOrderDetailResp, err error) { | ||||
| 	// 获取订单信息 | ||||
| 	order, err := l.svcCtx.OrderModel.FindOne(l.ctx, req.Id) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderDetail, 查询订单失败 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	// 获取产品信息 | ||||
| 	product, err := l.svcCtx.ProductModel.FindOne(l.ctx, order.ProductId) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderDetail, 查询产品失败 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	// 判断是否为推广订单 | ||||
| 	var isPromotion int64 | ||||
| 	promotionOrder, err := l.svcCtx.AdminPromotionOrderModel.FindOneByOrderId(l.ctx, order.Id) | ||||
| 	if err == nil && promotionOrder != nil { | ||||
| 		isPromotion = 1 | ||||
| 	} | ||||
|  | ||||
| 	// 获取查询状态 | ||||
| 	var queryState string | ||||
| 	builder := l.svcCtx.QueryModel.SelectBuilder().Where("order_id = ?", order.Id).Columns("query_state") | ||||
| 	queries, err := l.svcCtx.QueryModel.FindAll(l.ctx, builder, "") | ||||
| 	if err != nil && !errors.Is(err, model.ErrNotFound) { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderDetail, 查询查询状态失败 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	if len(queries) > 0 { | ||||
| 		queryState = queries[0].QueryState | ||||
| 	} else { | ||||
| 		// 查询清理日志 | ||||
| 		cleanupBuilder := l.svcCtx.QueryCleanupDetailModel.SelectBuilder(). | ||||
| 			Where("order_id = ?", order.Id). | ||||
| 			Where("del_state = ?", globalkey.DelStateNo). | ||||
| 			OrderBy("create_time DESC"). | ||||
| 			Limit(1) | ||||
| 		cleanupDetails, err := l.svcCtx.QueryCleanupDetailModel.FindAll(l.ctx, cleanupBuilder, "") | ||||
| 		if err != nil && !errors.Is(err, model.ErrNotFound) { | ||||
| 			return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderDetail, 查询清理日志失败 err: %v", err) | ||||
| 		} | ||||
|  | ||||
| 		if len(cleanupDetails) > 0 { | ||||
| 			queryState = model.QueryStateCleaned | ||||
| 		} else { | ||||
| 			queryState = "" | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// 构建响应 | ||||
| 	resp = &types.AdminGetOrderDetailResp{ | ||||
| 		Id:              order.Id, | ||||
| 		OrderNo:         order.OrderNo, | ||||
| 		PlatformOrderId: order.PlatformOrderId.String, | ||||
| 		ProductName:     product.ProductName, | ||||
| 		PaymentPlatform: order.PaymentPlatform, | ||||
| 		PaymentScene:    order.PaymentScene, | ||||
| 		Amount:          order.Amount, | ||||
| 		Status:          order.Status, | ||||
| 		CreateTime:      order.CreateTime.Format("2006-01-02 15:04:05"), | ||||
| 		UpdateTime:      order.UpdateTime.Format("2006-01-02 15:04:05"), | ||||
| 		IsPromotion:     isPromotion, | ||||
| 		QueryState:      queryState, | ||||
| 	} | ||||
|  | ||||
| 	// 处理可选字段 | ||||
| 	if order.PayTime.Valid { | ||||
| 		resp.PayTime = order.PayTime.Time.Format("2006-01-02 15:04:05") | ||||
| 	} | ||||
| 	if order.RefundTime.Valid { | ||||
| 		resp.RefundTime = order.RefundTime.Time.Format("2006-01-02 15:04:05") | ||||
| 	} | ||||
|  | ||||
| 	return resp, nil | ||||
| } | ||||
| @@ -0,0 +1,229 @@ | ||||
| package admin_order | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"sync" | ||||
|  | ||||
| 	"znc-server/app/main/api/internal/svc" | ||||
| 	"znc-server/app/main/api/internal/types" | ||||
| 	"znc-server/app/main/model" | ||||
| 	"znc-server/common/globalkey" | ||||
| 	"znc-server/common/xerr" | ||||
|  | ||||
| 	"github.com/Masterminds/squirrel" | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/zeromicro/go-zero/core/logx" | ||||
| 	"github.com/zeromicro/go-zero/core/mr" | ||||
| ) | ||||
|  | ||||
| type AdminGetOrderListLogic struct { | ||||
| 	logx.Logger | ||||
| 	ctx    context.Context | ||||
| 	svcCtx *svc.ServiceContext | ||||
| } | ||||
|  | ||||
| func NewAdminGetOrderListLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AdminGetOrderListLogic { | ||||
| 	return &AdminGetOrderListLogic{ | ||||
| 		Logger: logx.WithContext(ctx), | ||||
| 		ctx:    ctx, | ||||
| 		svcCtx: svcCtx, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (l *AdminGetOrderListLogic) AdminGetOrderList(req *types.AdminGetOrderListReq) (resp *types.AdminGetOrderListResp, err error) { | ||||
| 	// 构建查询条件 | ||||
| 	builder := l.svcCtx.OrderModel.SelectBuilder() | ||||
| 	if req.OrderNo != "" { | ||||
| 		builder = builder.Where("order_no = ?", req.OrderNo) | ||||
| 	} | ||||
| 	if req.PlatformOrderId != "" { | ||||
| 		builder = builder.Where("platform_order_id = ?", req.PlatformOrderId) | ||||
| 	} | ||||
| 	if req.ProductName != "" { | ||||
| 		builder = builder.Where("product_id IN (SELECT id FROM product WHERE product_name LIKE ?)", "%"+req.ProductName+"%") | ||||
| 	} | ||||
| 	if req.PaymentPlatform != "" { | ||||
| 		builder = builder.Where("payment_platform = ?", req.PaymentPlatform) | ||||
| 	} | ||||
| 	if req.PaymentScene != "" { | ||||
| 		builder = builder.Where("payment_scene = ?", req.PaymentScene) | ||||
| 	} | ||||
| 	if req.Amount > 0 { | ||||
| 		builder = builder.Where("amount = ?", req.Amount) | ||||
| 	} | ||||
| 	if req.Status != "" { | ||||
| 		builder = builder.Where("status = ?", req.Status) | ||||
| 	} | ||||
| 	if req.IsPromotion != -1 { | ||||
| 		builder = builder.Where("id IN (SELECT order_id FROM admin_promotion_order WHERE del_state = 0)") | ||||
| 	} | ||||
| 	// 时间范围查询 | ||||
| 	if req.CreateTimeStart != "" { | ||||
| 		builder = builder.Where("create_time >= ?", req.CreateTimeStart) | ||||
| 	} | ||||
| 	if req.CreateTimeEnd != "" { | ||||
| 		builder = builder.Where("create_time <= ?", req.CreateTimeEnd) | ||||
| 	} | ||||
| 	if req.PayTimeStart != "" { | ||||
| 		builder = builder.Where("pay_time >= ?", req.PayTimeStart) | ||||
| 	} | ||||
| 	if req.PayTimeEnd != "" { | ||||
| 		builder = builder.Where("pay_time <= ?", req.PayTimeEnd) | ||||
| 	} | ||||
| 	if req.RefundTimeStart != "" { | ||||
| 		builder = builder.Where("refund_time >= ?", req.RefundTimeStart) | ||||
| 	} | ||||
| 	if req.RefundTimeEnd != "" { | ||||
| 		builder = builder.Where("refund_time <= ?", req.RefundTimeEnd) | ||||
| 	} | ||||
|  | ||||
| 	// 并发获取总数和列表 | ||||
| 	var total int64 | ||||
| 	var orders []*model.Order | ||||
| 	err = mr.Finish(func() error { | ||||
| 		var err error | ||||
| 		total, err = l.svcCtx.OrderModel.FindCount(l.ctx, builder, "id") | ||||
| 		if err != nil { | ||||
| 			return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderList, 查询订单总数失败 err: %v", err) | ||||
| 		} | ||||
| 		return nil | ||||
| 	}, func() error { | ||||
| 		var err error | ||||
| 		orders, err = l.svcCtx.OrderModel.FindPageListByPage(l.ctx, builder, req.Page, req.PageSize, "id DESC") | ||||
| 		if err != nil { | ||||
| 			return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderList, 查询订单列表失败 err: %v", err) | ||||
| 		} | ||||
| 		return nil | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	// 并发获取产品信息和查询状态 | ||||
| 	productMap := make(map[int64]string) | ||||
| 	queryStateMap := make(map[int64]string) | ||||
| 	var mu sync.Mutex | ||||
|  | ||||
| 	// 批量获取查询状态 | ||||
| 	if len(orders) > 0 { | ||||
| 		orderIds := make([]int64, 0, len(orders)) | ||||
| 		for _, order := range orders { | ||||
| 			orderIds = append(orderIds, order.Id) | ||||
| 		} | ||||
|  | ||||
| 		// 1. 先查询当前查询状态 | ||||
| 		builder := l.svcCtx.QueryModel.SelectBuilder(). | ||||
| 			Where(squirrel.Eq{"order_id": orderIds}). | ||||
| 			Columns("order_id", "query_state") | ||||
| 		queries, err := l.svcCtx.QueryModel.FindAll(l.ctx, builder, "") | ||||
| 		if err != nil && !errors.Is(err, model.ErrNotFound) { | ||||
| 			return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderList, 批量查询查询状态失败 err: %v", err) | ||||
| 		} | ||||
|  | ||||
| 		// 2. 记录已找到查询状态的订单ID | ||||
| 		foundOrderIds := make(map[int64]bool) | ||||
| 		for _, query := range queries { | ||||
| 			queryStateMap[query.OrderId] = query.QueryState | ||||
| 			foundOrderIds[query.OrderId] = true | ||||
| 		} | ||||
|  | ||||
| 		// 3. 查找未找到查询状态的订单是否在清理日志中 | ||||
| 		notFoundOrderIds := make([]int64, 0) | ||||
| 		for _, orderId := range orderIds { | ||||
| 			if !foundOrderIds[orderId] { | ||||
| 				notFoundOrderIds = append(notFoundOrderIds, orderId) | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if len(notFoundOrderIds) > 0 { | ||||
| 			// 查询清理日志 | ||||
| 			cleanupBuilder := l.svcCtx.QueryCleanupDetailModel.SelectBuilder(). | ||||
| 				Where(squirrel.Eq{"order_id": notFoundOrderIds}). | ||||
| 				Where("del_state = ?", globalkey.DelStateNo). | ||||
| 				OrderBy("create_time DESC") | ||||
| 			cleanupDetails, err := l.svcCtx.QueryCleanupDetailModel.FindAll(l.ctx, cleanupBuilder, "") | ||||
| 			if err != nil && !errors.Is(err, model.ErrNotFound) { | ||||
| 				return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderList, 查询清理日志失败 err: %v", err) | ||||
| 			} | ||||
|  | ||||
| 			// 记录已清理的订单状态 | ||||
| 			for _, detail := range cleanupDetails { | ||||
| 				if _, exists := queryStateMap[detail.OrderId]; !exists { | ||||
| 					queryStateMap[detail.OrderId] = model.QueryStateCleaned // 使用常量标记为已清除状态 | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			// 对于既没有查询状态也没有清理记录的订单,不设置状态(保持为空字符串) | ||||
| 			for _, orderId := range notFoundOrderIds { | ||||
| 				if _, exists := queryStateMap[orderId]; !exists { | ||||
| 					queryStateMap[orderId] = "" // 未知状态保持为空字符串 | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// 并发获取产品信息 | ||||
| 	err = mr.MapReduceVoid(func(source chan<- interface{}) { | ||||
| 		for _, order := range orders { | ||||
| 			source <- order | ||||
| 		} | ||||
| 	}, func(item interface{}, writer mr.Writer[struct{}], cancel func(error)) { | ||||
| 		order := item.(*model.Order) | ||||
|  | ||||
| 		// 获取产品信息 | ||||
| 		product, err := l.svcCtx.ProductModel.FindOne(l.ctx, order.ProductId) | ||||
| 		if err != nil && !errors.Is(err, model.ErrNotFound) { | ||||
| 			cancel(errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminGetOrderList, 查询产品信息失败 err: %v", err)) | ||||
| 			return | ||||
| 		} | ||||
| 		mu.Lock() | ||||
| 		if product != nil { | ||||
| 			productMap[product.Id] = product.ProductName | ||||
| 		} else { | ||||
| 			productMap[order.ProductId] = "" // 产品不存在时设置为空字符串 | ||||
| 		} | ||||
| 		mu.Unlock() | ||||
| 		writer.Write(struct{}{}) | ||||
| 	}, func(pipe <-chan struct{}, cancel func(error)) { | ||||
| 		for range pipe { | ||||
| 		} | ||||
| 	}) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	// 构建响应 | ||||
| 	resp = &types.AdminGetOrderListResp{ | ||||
| 		Total: total, | ||||
| 		Items: make([]types.OrderListItem, 0, len(orders)), | ||||
| 	} | ||||
|  | ||||
| 	for _, order := range orders { | ||||
| 		item := types.OrderListItem{ | ||||
| 			Id:              order.Id, | ||||
| 			OrderNo:         order.OrderNo, | ||||
| 			PlatformOrderId: order.PlatformOrderId.String, | ||||
| 			ProductName:     productMap[order.ProductId], | ||||
| 			PaymentPlatform: order.PaymentPlatform, | ||||
| 			PaymentScene:    order.PaymentScene, | ||||
| 			Amount:          order.Amount, | ||||
| 			Status:          order.Status, | ||||
| 			CreateTime:      order.CreateTime.Format("2006-01-02 15:04:05"), | ||||
| 			QueryState:      queryStateMap[order.Id], | ||||
| 		} | ||||
| 		if order.PayTime.Valid { | ||||
| 			item.PayTime = order.PayTime.Time.Format("2006-01-02 15:04:05") | ||||
| 		} | ||||
| 		if order.RefundTime.Valid { | ||||
| 			item.RefundTime = order.RefundTime.Time.Format("2006-01-02 15:04:05") | ||||
| 		} | ||||
| 		// 判断是否为推广订单 | ||||
| 		promotionOrder, err := l.svcCtx.AdminPromotionOrderModel.FindOneByOrderId(l.ctx, order.Id) | ||||
| 		if err == nil && promotionOrder != nil { | ||||
| 			item.IsPromotion = 1 | ||||
| 		} | ||||
| 		resp.Items = append(resp.Items, item) | ||||
| 	} | ||||
|  | ||||
| 	return resp, nil | ||||
| } | ||||
| @@ -0,0 +1,92 @@ | ||||
| package admin_order | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"database/sql" | ||||
| 	"fmt" | ||||
| 	"time" | ||||
|  | ||||
| 	"znc-server/app/main/api/internal/svc" | ||||
| 	"znc-server/app/main/api/internal/types" | ||||
| 	"znc-server/app/main/model" | ||||
| 	"znc-server/common/xerr" | ||||
|  | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/zeromicro/go-zero/core/logx" | ||||
| 	"github.com/zeromicro/go-zero/core/stores/sqlx" | ||||
| ) | ||||
|  | ||||
| type AdminRefundOrderLogic struct { | ||||
| 	logx.Logger | ||||
| 	ctx    context.Context | ||||
| 	svcCtx *svc.ServiceContext | ||||
| } | ||||
|  | ||||
| func NewAdminRefundOrderLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AdminRefundOrderLogic { | ||||
| 	return &AdminRefundOrderLogic{ | ||||
| 		Logger: logx.WithContext(ctx), | ||||
| 		ctx:    ctx, | ||||
| 		svcCtx: svcCtx, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (l *AdminRefundOrderLogic) AdminRefundOrder(req *types.AdminRefundOrderReq) (resp *types.AdminRefundOrderResp, err error) { | ||||
| 	// 获取订单信息 | ||||
| 	order, err := l.svcCtx.OrderModel.FindOne(l.ctx, req.Id) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminRefundOrder, 查询订单失败 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	// 检查订单状态 | ||||
| 	if order.Status != "paid" { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrMsg("订单状态不正确,无法退款"), "AdminRefundOrder, 订单状态不正确,无法退款 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	// 检查退款金额 | ||||
| 	if req.RefundAmount > order.Amount { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrMsg("退款金额不能大于订单金额"), "AdminRefundOrder, 退款金额不能大于订单金额 err: %v", err) | ||||
| 	} | ||||
| 	refundResp, err := l.svcCtx.AlipayService.AliRefund(l.ctx, order.OrderNo, req.RefundAmount) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "AdminRefundOrder, 退款失败 err: %v", err) | ||||
| 	} | ||||
| 	if refundResp.IsSuccess() { | ||||
| 		err = l.svcCtx.OrderModel.Trans(l.ctx, func(ctx context.Context, session sqlx.Session) error { | ||||
| 			// 创建退款记录 | ||||
| 			refund := &model.OrderRefund{ | ||||
| 				RefundNo:         fmt.Sprintf("refund-%s", order.OrderNo), | ||||
| 				PlatformRefundId: sql.NullString{String: refundResp.TradeNo, Valid: true}, | ||||
| 				OrderId:          order.Id, | ||||
| 				UserId:           order.UserId, | ||||
| 				ProductId:        order.ProductId, | ||||
| 				RefundAmount:     req.RefundAmount, | ||||
| 				RefundReason:     sql.NullString{String: req.RefundReason, Valid: true}, | ||||
| 				Status:           model.OrderRefundStatusPending, | ||||
| 				RefundTime:       sql.NullTime{Time: time.Now(), Valid: true}, | ||||
| 			} | ||||
|  | ||||
| 			if _, err := l.svcCtx.OrderRefundModel.Insert(ctx, session, refund); err != nil { | ||||
| 				return fmt.Errorf("创建退款记录失败: %v", err) | ||||
| 			} | ||||
|  | ||||
| 			// 更新订单状态 | ||||
| 			order.Status = model.OrderStatusRefunded | ||||
| 			order.RefundTime = sql.NullTime{Time: time.Now(), Valid: true} | ||||
| 			if _, err := l.svcCtx.OrderModel.Update(ctx, session, order); err != nil { | ||||
| 				return fmt.Errorf("更新订单状态失败: %v", err) | ||||
| 			} | ||||
| 			return nil | ||||
| 		}) | ||||
| 		if err != nil { | ||||
| 			return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "AdminRefundOrder, 退款失败 err: %v", err) | ||||
| 		} | ||||
| 		return &types.AdminRefundOrderResp{ | ||||
| 			Status:   model.OrderStatusRefunded, | ||||
| 			RefundNo: fmt.Sprintf("refund-%s", order.OrderNo), | ||||
| 			Amount:   req.RefundAmount, | ||||
| 		}, nil | ||||
| 	} else { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrMsg(fmt.Sprintf("退款失败, : %v", refundResp.Msg)), "AdminRefundOrder, 退款失败 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										113
									
								
								app/main/api/internal/logic/admin_order/adminupdateorderlogic.go
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								app/main/api/internal/logic/admin_order/adminupdateorderlogic.go
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,113 @@ | ||||
| package admin_order | ||||
|  | ||||
| import ( | ||||
| 	"context" | ||||
| 	"database/sql" | ||||
| 	"time" | ||||
|  | ||||
| 	"znc-server/app/main/api/internal/svc" | ||||
| 	"znc-server/app/main/api/internal/types" | ||||
| 	"znc-server/app/main/model" | ||||
| 	"znc-server/common/xerr" | ||||
|  | ||||
| 	"github.com/pkg/errors" | ||||
| 	"github.com/zeromicro/go-zero/core/logx" | ||||
| 	"github.com/zeromicro/go-zero/core/stores/sqlx" | ||||
| ) | ||||
|  | ||||
| type AdminUpdateOrderLogic struct { | ||||
| 	logx.Logger | ||||
| 	ctx    context.Context | ||||
| 	svcCtx *svc.ServiceContext | ||||
| } | ||||
|  | ||||
| func NewAdminUpdateOrderLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AdminUpdateOrderLogic { | ||||
| 	return &AdminUpdateOrderLogic{ | ||||
| 		Logger: logx.WithContext(ctx), | ||||
| 		ctx:    ctx, | ||||
| 		svcCtx: svcCtx, | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (l *AdminUpdateOrderLogic) AdminUpdateOrder(req *types.AdminUpdateOrderReq) (resp *types.AdminUpdateOrderResp, err error) { | ||||
| 	// 获取原订单信息 | ||||
| 	order, err := l.svcCtx.OrderModel.FindOne(l.ctx, req.Id) | ||||
| 	if err != nil { | ||||
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminUpdateOrder, 查询订单失败 err: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	// 更新订单字段 | ||||
| 	if req.OrderNo != nil { | ||||
| 		order.OrderNo = *req.OrderNo | ||||
| 	} | ||||
| 	if req.PlatformOrderId != nil { | ||||
| 		order.PlatformOrderId = sql.NullString{String: *req.PlatformOrderId, Valid: true} | ||||
| 	} | ||||
| 	if req.PaymentPlatform != nil { | ||||
| 		order.PaymentPlatform = *req.PaymentPlatform | ||||
| 	} | ||||
| 	if req.PaymentScene != nil { | ||||
| 		order.PaymentScene = *req.PaymentScene | ||||
| 	} | ||||
| 	if req.Amount != nil { | ||||
| 		order.Amount = *req.Amount | ||||
| 	} | ||||
| 	if req.Status != nil { | ||||
| 		order.Status = *req.Status | ||||
| 	} | ||||
| 	if req.PayTime != nil { | ||||
| 		payTime, err := time.Parse("2006-01-02 15:04:05", *req.PayTime) | ||||
| 		if err == nil { | ||||
| 			order.PayTime = sql.NullTime{Time: payTime, Valid: true} | ||||
| 		} | ||||
| 	} | ||||
| 	if req.RefundTime != nil { | ||||
| 		refundTime, err := time.Parse("2006-01-02 15:04:05", *req.RefundTime) | ||||
| 		if err == nil { | ||||
| 			order.RefundTime = sql.NullTime{Time: refundTime, Valid: true} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// 使用事务更新订单 | ||||
| 	err = l.svcCtx.OrderModel.Trans(l.ctx, func(ctx context.Context, session sqlx.Session) error { | ||||
| 		// 更新订单 | ||||
| 		_, err := l.svcCtx.OrderModel.Update(ctx, session, order) | ||||
| 		if err != nil { | ||||
| 			return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminUpdateOrder, 更新订单失败 err: %v", err) | ||||
| 		} | ||||
|  | ||||
| 		// 处理推广订单状态 | ||||
| 		if req.IsPromotion != nil { | ||||
| 			promotionOrder, err := l.svcCtx.AdminPromotionOrderModel.FindOneByOrderId(ctx, order.Id) | ||||
| 			if err == nil && promotionOrder != nil { | ||||
| 				// 如果存在推广订单记录但不需要推广,则删除 | ||||
| 				if *req.IsPromotion == 0 { | ||||
| 					err = l.svcCtx.AdminPromotionOrderModel.DeleteSoft(ctx, session, promotionOrder) | ||||
| 					if err != nil { | ||||
| 						return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminUpdateOrder, 删除推广订单失败 err: %v", err) | ||||
| 					} | ||||
| 				} | ||||
| 			} else if *req.IsPromotion == 1 { | ||||
| 				// 如果需要推广但不存在记录,则创建 | ||||
| 				newPromotionOrder := &model.AdminPromotionOrder{ | ||||
| 					OrderId: order.Id, | ||||
| 					Version: 1, | ||||
| 				} | ||||
| 				_, err = l.svcCtx.AdminPromotionOrderModel.Insert(ctx, session, newPromotionOrder) | ||||
| 				if err != nil { | ||||
| 					return errors.Wrapf(xerr.NewErrCode(xerr.DB_ERROR), "AdminUpdateOrder, 创建推广订单失败 err: %v", err) | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return nil | ||||
| 	}) | ||||
|  | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	return &types.AdminUpdateOrderResp{ | ||||
| 		Success: true, | ||||
| 	}, nil | ||||
| } | ||||
		Reference in New Issue
	
	Block a user