using NCC.Common.Core.Manager;
using NCC.Common.Enum;
using NCC.Common.Extension;
using NCC.Common.Filter;
using NCC.Dependency;
using NCC.DynamicApiController;
using NCC.FriendlyException;
using NCC.Extend.Interfaces.UavWalletWithdrawApply;
using Mapster;
using Microsoft.AspNetCore.Mvc;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using NCC.Extend.Entitys;
using NCC.Extend.Entitys.Dto.UavWalletWithdrawApply;
using Yitter.IdGenerator;
using NCC.Common.Helper;
using NCC.JsonSerialization;
using NCC.Extend.Entitys.Enums;
namespace NCC.Extend.UavWalletWithdrawApply
{
///
/// 提现申请服务
///
[ApiDescriptionSettings(Tag = "提现申请服务", Name = "UavWalletWithdrawApply", Order = 200)]
[Route("api/Extend/[controller]")]
public class UavWalletWithdrawApplyService : IUavWalletWithdrawApplyService, IDynamicApiController, ITransient
{
private readonly ISqlSugarRepository _uavWalletWithdrawApplyRepository;
private readonly SqlSugarScope _db;
private readonly IUserManager _userManager;
///
/// 初始化一个类型的新实例
///
public UavWalletWithdrawApplyService(
ISqlSugarRepository uavWalletWithdrawApplyRepository,
IUserManager userManager)
{
_uavWalletWithdrawApplyRepository = uavWalletWithdrawApplyRepository;
_db = _uavWalletWithdrawApplyRepository.Context;
_userManager = userManager;
}
///
/// 获取提现申请
///
/// 参数
///
[HttpGet("{id}")]
public async Task GetInfo(string id)
{
var entity = await _db.Queryable().FirstAsync(p => p.Id == id);
var output = entity.Adapt();
return output;
}
///
/// 获取提现申请列表
///
/// 请求参数
///
[HttpGet("")]
public async Task GetList([FromQuery] UavWalletWithdrawApplyListQueryInput input)
{
var sidx = input.sidx == null ? "id" : input.sidx;
var data = await _db.Queryable()
.WhereIF(!string.IsNullOrEmpty(input.bankAccountNumber), p => p.BankAccountNumber.Contains(input.bankAccountNumber))
.WhereIF(!string.IsNullOrEmpty(input.walletNo), p => p.WalletNo.Contains(input.walletNo))
.WhereIF(input.auditStatus.HasValue, p => p.AuditStatus == input.auditStatus.Value)
.WhereIF(input.transferStatus.HasValue, p => p.TransferStatus == input.transferStatus.Value)
.Select(it => new UavWalletWithdrawApplyListOutput
{
id = it.Id,
amount = it.Amount,
bankAccountName = it.BankAccountName,
bankAccountNumber = it.BankAccountNumber,
bankName = it.BankName,
walletNo = it.WalletNo,
applyTime = it.ApplyTime,
auditStatus = it.AuditStatus,
auditTime = it.AuditTime,
transferStatus = it.TransferStatus,
transferTime = it.TransferTime,
}).MergeTable().OrderBy(sidx + " " + input.sort).ToPagedListAsync(input.currentPage, input.pageSize);
return PageResult.SqlSugarPageResult(data);
}
///
/// 新建提现申请
///
/// 参数
///
[HttpPost("")]
public async Task Create([FromBody] UavWalletWithdrawApplyCrInput input)
{
var userInfo = await _userManager.GetUserInfo();
var entity = input.Adapt();
entity.Id = YitIdHelper.NextId().ToString();
entity.UserId = _userManager.UserId;
entity.Amount = -input.amount;
entity.WalletNo = "TX" + DateTime.Now.ToString("yyyyMMddHHmmssfff");
entity.ApplyTime = DateTime.Now;
entity.AuditStatus = AuditStatusEnum.待审核.GetHashCode();
entity.TransferStatus = TransferStatusEnum.未转账.GetHashCode();
entity.CreateTime = DateTime.Now;
entity.CreateUser = _userManager.UserId;
var isOk = await _db.Insertable(entity).IgnoreColumns(ignoreNullColumn: true).ExecuteCommandAsync();
if (!(isOk > 0)) throw NCCException.Oh(ErrorCode.COM1000);
}
///
/// 获取提现申请审核详情(包含用户余额)
///
/// 参数
///
[HttpGet("{id}/AuditDetail")]
public async Task GetAuditDetail(string id)
{
var entity = await _db.Queryable().FirstAsync(p => p.Id == id);
_ = entity ?? throw NCCException.Oh(ErrorCode.COM1005);
// 获取用户当前余额
var userBalance = await _db.Queryable()
.Where(x => x.UserId == entity.UserId)
.SumAsync(x => x.Amount);
var output = entity.Adapt();
output.userBalance = userBalance;
return output;
}
///
/// 审核提现申请
///
/// 主键
/// 参数
///
[HttpPut("{id}/Audit")]
public async Task Audit(string id, [FromBody] UavWalletWithdrawApplyAuditInput input)
{
var entity = await _db.Queryable().FirstAsync(p => p.Id == id);
_ = entity ?? throw NCCException.Oh(ErrorCode.COM1005);
// 只有待审核状态才能审核
if (entity.AuditStatus != AuditStatusEnum.待审核.GetHashCode())
{
throw NCCException.Oh(ErrorCode.COM1003, "该申请已审核,无法重复审核");
}
// 驳回时必须填写驳回原因
if (input.auditStatus == AuditStatusEnum.审核驳回.GetHashCode() && string.IsNullOrEmpty(input.rejectReason))
{
throw NCCException.Oh(ErrorCode.COM1003, "驳回时必须填写驳回原因");
}
entity.AuditStatus = input.auditStatus;
entity.AuditTime = DateTime.Now;
entity.AuditUserId = _userManager.UserId;
entity.RejectReason = input.rejectReason;
entity.UpdateTime = DateTime.Now;
entity.UpdateUser = _userManager.UserId;
var isOk = await _db.Updateable(entity).ExecuteCommandAsync();
if (!(isOk > 0)) throw NCCException.Oh(ErrorCode.COM1001);
}
///
/// 处理提现申请(转账)
///
/// 主键
/// 参数
///
[HttpPut("{id}/Process")]
public async Task Process(string id, [FromBody] UavWalletWithdrawApplyProcessInput input)
{
var entity = await _db.Queryable().FirstAsync(p => p.Id == id);
_ = entity ?? throw NCCException.Oh(ErrorCode.COM1005);
// 只有审核通过的才能处理
if (entity.AuditStatus != AuditStatusEnum.审核通过.GetHashCode())
{
throw NCCException.Oh(ErrorCode.COM1003, "只有审核通过的申请才能处理");
}
// 只有未转账的才能处理
if (entity.TransferStatus != TransferStatusEnum.未转账.GetHashCode())
{
throw NCCException.Oh(ErrorCode.COM1003, "该申请已处理,无法重复处理");
}
entity.TransferStatus = input.transferStatus;
entity.TransferTime = input.transferTime ?? DateTime.Now;
entity.TransferRemark = input.transferRemark;
entity.UpdateTime = DateTime.Now;
entity.UpdateUser = _userManager.UserId;
var isOk = await _db.Updateable(entity).ExecuteCommandAsync();
if (!(isOk > 0)) throw NCCException.Oh(ErrorCode.COM1001);
}
///
/// 获取提现申请统计数据
///
///
[HttpGet("Statistics")]
public async Task GetStatistics()
{
// 分别查询各个统计数据
var pendingCount = await _db.Queryable()
.Where(p => p.AuditStatus == AuditStatusEnum.待审核.GetHashCode())
.CountAsync();
var approvedCount = await _db.Queryable()
.Where(p => p.AuditStatus == AuditStatusEnum.审核通过.GetHashCode())
.CountAsync();
var transferredCount = await _db.Queryable()
.Where(p => p.TransferStatus == TransferStatusEnum.已转账.GetHashCode())
.CountAsync();
// 查询所有金额数据,然后在内存中处理
var amounts = await _db.Queryable()
.Select(p => p.Amount)
.ToListAsync();
var totalAmount = amounts.Sum(amount => amount < 0 ? -amount : amount);
var stats = new
{
pendingCount = pendingCount,
approvedCount = approvedCount,
transferredCount = transferredCount,
totalAmount = totalAmount
};
return stats;
}
}
}