Files
kami_backend/internal/logic/card_redeem_order/order.go
danial 71ca2b3781 feat(card_info_walmart): 添加分组统计功能
在沃尔玛充值卡账户模块中新增了分组统计接口,支持获取各分组的账户统计信息,包括总数、正常状态和异常状态的账户数量及金额。同时,优化了相关数据模型和服务逻辑,提升了系统的统计能力和数据处理效率。这些改进有助于增强用户对账户状态的监控和管理。

feat(card_info_walmart): 更新分组统计功能和数据模型

在沃尔玛充值卡账户模块中,增强了分组统计功能,支持按日期、类别和创建用户ID进行统计。同时,优化了相关数据模型,确保统计结果的准确性和完整性。这些改进提升了系统的统计能力和用户对账户状态的管理效率。

feat(card_info_walmart): 更新分组统计功能以支持数据库配置

在沃尔玛充值卡账户模块中,更新了分组统计功能,新增了数据库配置的支持,确保在不同数据库环境下的正确操作。这些改进提升了系统的灵活性和稳定性。

feat(card_info_walmart): 更新分组统计功能以支持数据库配置

在沃尔玛充值卡账户模块中,修改了分组统计功能,新增了数据库配置支持,确保在不同数据库环境下的正确操作。这些改进提升了系统的灵活性和稳定性。

feat(card_info_walmart): 新增订单导出功能

在沃尔玛充值卡账户模块中,新增了订单导出接口,支持将订单信息导出为Excel文件。此功能包括订单的详细信息,如卡号、卡密、商户订单号等,提升了用户对订单数据的管理和分析能力。

feat(card_info_walmart): 增强订单导出功能的错误处理

在沃尔玛充值卡账户模块中,优化了订单导出功能,新增了错误处理逻辑以确保在获取订单列表失败时能够正确返回错误信息。同时,添加了数据缓冲到本地的注释,提升了代码的可读性和维护性。

feat(card_info_walmart): 新增账户分组导出功能

在沃尔玛充值卡账户模块中,新增了账户分组导出接口,支持将账户分组信息导出为Excel文件。此功能包括上传人昵称、分组名称、正常账户数量等详细信息,提升了用户对账户数据的管理和分析能力。同时,更新了分组统计功能以支持用户权限验证,确保数据安全性。

fix(card_info_walmart): 修正创建用户ID字段名称

在沃尔玛充值卡账户模块中,修正了分组统计功能中创建用户ID字段的名称,从`created_user_id`更改为`create_user_id`,确保SQL查询的正确性。这一改动提升了数据查询的准确性。

feat(card_info_walmart): 更新账户分组和订单导出功能

在沃尔玛充值卡账户模块中,新增了账户分组实体的删除状态字段,并在分组统计和订单导出功能中优化了分页逻辑,确保在当前页和每页大小为零时的处理。同时,增强了对已删除账户的统计,提升了数据的准确性和完整性。这些改进有助于用户更好地管理和分析账户数据。

feat(card_info_walmart): 增强账户分组导出功能

在沃尔玛充值卡账户模块中,更新了账户分组导出功能,新增了已删除账户数量的统计,并将导出文件保存到本地。此改进提升了数据导出的完整性和用户体验,同时优化了导出逻辑,确保用户能够方便地下载所需数据。

feat(card_info_walmart): 更新账户信息模型和导出功能

在沃尔玛充值卡账户模块中,新增了账户分组名称、创建时间、更新时间和删除时间字段,增强了账户信息的完整性。同时,更新了账户导出功能,支持在导出文件中显示分组信息和删除状态,提升了用户对账户数据的管理和分析能力。

feat(card_info_walmart): 增强账户信息模型,新增时间戳字段

在沃尔玛充值卡账户模块中,更新了账户信息模型,新增了创建时间、更新时间和删除时间字段,以提升账户信息的完整性。同时,优化了获取账户摘要的逻辑,确保在处理账户信息时能够正确返回相关时间戳数据。这些改进有助于用户更好地管理和分析账户数据。

feat(card_info_walmart): 优化账户信息和摘要获取逻辑

在沃尔玛充值卡账户模块中,更新了账户信息模型,将`AccountInfo`字段改为指针类型,以提高内存效率。同时,优化了获取账户摘要的逻辑,确保在处理账户信息时能够正确返回相关数据。这些改进提升了代码的可读性和性能。

feat(card_info_walmart): 更新账户信息和导出功能

在沃尔玛充值卡账户模块中,优化了账户信息导出功能,新增了分组ID和账户ID字段,以提升导出数据的完整性。同时,更新了相关逻辑以支持根据分组ID进行查询,增强了数据处理的灵活性和准确性。这些改进有助于用户更好地管理和分析账户数据。

feat(card_info_walmart): 优化分组统计逻辑和测试用例

在沃尔玛充值卡账户模块中,优化了分组统计功能,使用了更高效的集合操作以获取唯一的分组ID。同时,更新了相关测试用例,简化了参数传递,提升了代码的可读性和测试的准确性。这些改进有助于提高数据处理的性能和测试的可靠性。

feat(sysUser): 更新获取所有用户接口的描述和逻辑

在用户管理模块中,修改了获取所有用户的请求描述,将“商户”更改为“用户”,以提高接口的准确性。同时,增强了获取用户列表的逻辑,添加了权限验证,确保用户信息的安全性,并在返回数据时过滤掉当前用户的信息。这些改进提升了接口的可用性和安全性。

feat(card_info_walmart): 新增用户ID字段并更新相关逻辑

在沃尔玛充值卡账户模块中,新增了多个请求和响应结构中的用户ID字段,以提升用户信息的管理能力。同时,更新了相关逻辑以支持用户ID的传递,确保在处理账户和分组信息时能够正确识别用户。这些改进增强了系统的灵活性和数据处理的准确性。

feat(card_info_walmart): 新增用户ID字段并更新相关逻辑

在沃尔玛充值卡账户模块中,新增了`UserId`字段到分组统计请求结构体,并在相关逻辑中更新以支持用户ID的传递。这些改进确保在处理分组统计时能够正确识别用户信息,提升了系统的灵活性和数据处理的准确性。
2025-04-29 10:52:58 +08:00

139 lines
4.9 KiB
Go

package card_redeem_order
import (
"context"
"fmt"
"kami/internal/consts"
"kami/internal/dao"
"kami/internal/model"
"kami/internal/model/do"
"kami/internal/model/entity"
"kami/internal/service"
"kami/utility/config"
"kami/utility/utils"
"github.com/duke-git/lancet/v2/slice"
"github.com/gogf/gf/container/gset"
"github.com/gogf/gf/v2/database/gdb"
"github.com/gogf/gf/v2/text/gstr"
)
// AddOne 添加一条充值记录
func (h *sCardRedeemOrder) AddOne(ctx context.Context, input *model.RedeemCardSubmitInput) (orderNo string, err error) {
orderNo = utils.GenerateRandomUUID()
_, err = dao.V1CardRedeemOrderInfo.Ctx(ctx).DB(config.GetDatabaseV1()).
InsertAndGetId(do.V1CardRedeemOrderInfo{
OrderNo: orderNo,
CardNo: input.CardNo,
GiftCardPwd: input.GiftCardPwd,
NotifyUrl: input.NotifyUrl,
MerchantId: input.MerchantId,
Attach: input.Attach,
Status: consts.RedeemOrderPending,
OrderAmount: input.Amount,
Category: input.Category,
})
_ = h.AddHistory(ctx, &model.RedeemCardOrderAddHistory{
Amount: input.Amount,
OrderNo: orderNo,
Remark: "新增订单",
OperationStatus: consts.RedeemOrderOperationAdd,
}, nil)
return orderNo, err
}
func (h *sCardRedeemOrder) GetOrderOneByOrderNo(ctx context.Context, orderNo string, tx gdb.TX) (data *entity.V1CardRedeemOrderInfo, err error) {
data = &entity.V1CardRedeemOrderInfo{}
m := dao.V1CardRedeemOrderInfo.Ctx(ctx).DB(config.GetDatabaseV1())
if tx != nil {
m = m.TX(tx)
}
err = m.Where(dao.V1CardRedeemOrderInfo.Columns().OrderNo, orderNo).
Scan(&data)
err = utils.HandleNoRowsError(err)
return
}
// List 获取充值列表
func (h *sCardRedeemOrder) List(ctx context.Context, input *model.RedeemCardListInput) (total int, data []*entity.V1CardRedeemOrderInfo, err error) {
data = make([]*entity.V1CardRedeemOrderInfo, 0)
m := dao.V1CardRedeemOrderInfo.Ctx(ctx).DB(config.GetDatabaseV1())
if input.UserId != "" {
m = m.Where(dao.V1CardRedeemOrderInfo.Columns().CreatedUserId, input.UserId)
}
if input.GiftCardPwd != "" {
m = m.WhereLike(dao.V1CardRedeemOrderInfo.Columns().GiftCardPwd, utils.OrmLike(gstr.TrimAll(input.GiftCardPwd)))
}
if input.MerchantId != "" {
m = m.WhereLike(dao.V1CardRedeemOrderInfo.Columns().MerchantId, utils.OrmLike(gstr.TrimAll(input.MerchantId)))
}
if input.Attach != "" {
m = m.WhereLike(dao.V1CardRedeemOrderInfo.Columns().Attach, utils.OrmLike(gstr.TrimAll(input.Attach)))
}
if len(input.DateRange) == 2 {
m = m.WhereBetween(fmt.Sprintf("DATE(`%s`)", dao.V1CardRedeemOrderInfo.Columns().CreatedAt), input.DateRange[0].StartOfDay(), input.DateRange[1].EndOfDay())
}
if input.AccountCk != "" || input.AccountNickName != "" || input.GroupId != 0 {
accountIds := gset.NewStrSet()
if input.AccountNickName != "" {
if accountList, _ := service.CardRedeemAccount().Query(ctx, &model.RedeemAccountQueryInput{
NickName: input.AccountNickName,
Ck: input.AccountCk,
GroupId: input.GroupId,
}, nil); len(accountList) > 0 {
slice.ForEach(accountList, func(_ int, item *entity.V1CardRedeemAccountInfo) {
accountIds.Add(item.Id)
})
}
}
m = m.WhereIn(dao.V1CardRedeemOrderInfo.Columns().AccountId, accountIds.Slice())
}
if input.Category != "" {
m = m.Where(dao.V1CardRedeemOrderInfo.Columns().Category, input.Category)
}
if input.Current != 0 && input.PageSize != 0 {
m = m.Page(input.Current, input.PageSize)
}
err = m.OrderDesc(dao.V1CardRedeemOrderInfo.Columns().CreatedAt).
ScanAndCount(&data, &total, false)
err = utils.HandleNoRowsError(err)
return
}
// IsCardPassRepeated 当前卡号是否重复
func (h *sCardRedeemOrder) IsCardPassRepeated(ctx context.Context, cardNo, CardPass string, tx gdb.TX) (isRepeated bool) {
m := dao.V1CardRedeemOrderInfo.Ctx(ctx).DB(config.GetDatabaseV1())
if tx != nil {
m = m.TX(tx)
}
count, _ := m.Where(dao.V1CardRedeemOrderInfo.Columns().CardNo, cardNo).
Where(dao.V1CardRedeemOrderInfo.Columns().GiftCardPwd, CardPass).Count(1)
return count > 1
}
func (h *sCardRedeemOrder) GetOneByMerchantId(ctx context.Context, merchantId string, tx gdb.TX) (entity *entity.V1CardRedeemOrderInfo, err error) {
m := dao.V1CardRedeemOrderInfo.Ctx(ctx).DB(config.GetDatabaseV1())
if tx != nil {
m = m.TX(tx)
}
err = m.Where(dao.V1CardRedeemOrderInfo.Columns().Attach, merchantId).Scan(&entity)
return
}
// GetRandomOneById 随机获取一个失败订单
func (h *sCardRedeemOrder) GetRandomOneById(ctx context.Context, accountId string, status consts.RedeemOrderStatus, category consts.CardRedeemAccountCategory, tx gdb.TX) (entity *entity.V1CardRedeemOrderInfo, err error) {
m := dao.V1CardRedeemOrderInfo.Ctx(ctx).DB(config.GetDatabaseV1())
if tx != nil {
m = m.TX(tx)
}
err = m.Where(dao.V1CardRedeemOrderInfo.Columns().AccountId, accountId).
Where(dao.V1CardRedeemOrderInfo.Columns().OrderStatus, status).
Where(dao.V1CardRedeemOrderInfo.Columns().Category, category).OrderRandom().Limit(1).Scan(&entity)
return
}
//随机获取一个