feat: 支持自动下架商品
This commit is contained in:
@@ -0,0 +1,32 @@
|
|||||||
|
using Microsoft.Extensions.Logging;
|
||||||
|
using Quartz;
|
||||||
|
using Volo.Abp.BackgroundWorkers.Quartz;
|
||||||
|
using Yi.Framework.DigitalCollectibles.Domain.Managers;
|
||||||
|
|
||||||
|
namespace Yi.Framework.DigitalCollectibles.Application.Jobs;
|
||||||
|
/// <summary>
|
||||||
|
/// 自动下架商品
|
||||||
|
/// </summary>
|
||||||
|
public class AutoPassInGoodsJob: QuartzBackgroundWorkerBase
|
||||||
|
{
|
||||||
|
private readonly MarketManager _marketManager;
|
||||||
|
private readonly ILogger<AutoPassInGoodsJob> _logger;
|
||||||
|
public AutoPassInGoodsJob(MarketManager marketManager, ILogger<AutoPassInGoodsJob> logger)
|
||||||
|
{
|
||||||
|
_marketManager = marketManager;
|
||||||
|
_logger = logger;
|
||||||
|
JobDetail = JobBuilder.Create<AutoPassInGoodsJob>().WithIdentity(nameof(AutoPassInGoodsJob))
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
//每小时,第10分钟执行一次
|
||||||
|
Trigger = TriggerBuilder.Create().WithIdentity(nameof(AutoPassInGoodsJob))
|
||||||
|
.WithCronSchedule("0 10 * * * ?")
|
||||||
|
.Build();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public override async Task Execute(IJobExecutionContext context)
|
||||||
|
{
|
||||||
|
await _marketManager.AutoPassInGoodsAsync();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -28,7 +28,10 @@ namespace Yi.Abp.Domain.Shared.Settings
|
|||||||
new SettingDefinition("MarketTaxRate", "0.02"),
|
new SettingDefinition("MarketTaxRate", "0.02"),
|
||||||
|
|
||||||
//矿池刷新内容
|
//矿池刷新内容
|
||||||
new SettingDefinition("PoolData", "60,26,10,3,1")
|
new SettingDefinition("PoolData", "60,26,10,3,1"),
|
||||||
|
|
||||||
|
//自动下架多久天前的商品
|
||||||
|
new SettingDefinition("AutoPassInGoodsDay","3")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -19,9 +19,11 @@ public class MarketManager : DomainService
|
|||||||
private readonly ISqlSugarRepository<MarketGoodsAggregateRoot> _marketGoodsRepository;
|
private readonly ISqlSugarRepository<MarketGoodsAggregateRoot> _marketGoodsRepository;
|
||||||
|
|
||||||
private readonly ILocalEventBus _localEventBus;
|
private readonly ILocalEventBus _localEventBus;
|
||||||
public readonly ISettingProvider _settingProvider;
|
private readonly ISettingProvider _settingProvider;
|
||||||
|
|
||||||
public MarketManager(ISqlSugarRepository<CollectiblesUserStoreAggregateRoot> collectiblesUserStoreRepository,
|
public MarketManager(ISqlSugarRepository<CollectiblesUserStoreAggregateRoot> collectiblesUserStoreRepository,
|
||||||
ISqlSugarRepository<MarketGoodsAggregateRoot> marketGoodsRepository, ILocalEventBus localEventBus, ISettingProvider settingProvider)
|
ISqlSugarRepository<MarketGoodsAggregateRoot> marketGoodsRepository, ILocalEventBus localEventBus,
|
||||||
|
ISettingProvider settingProvider)
|
||||||
{
|
{
|
||||||
_collectiblesUserStoreRepository = collectiblesUserStoreRepository;
|
_collectiblesUserStoreRepository = collectiblesUserStoreRepository;
|
||||||
_marketGoodsRepository = marketGoodsRepository;
|
_marketGoodsRepository = marketGoodsRepository;
|
||||||
@@ -29,6 +31,35 @@ public class MarketManager : DomainService
|
|||||||
_settingProvider = settingProvider;
|
_settingProvider = settingProvider;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 商品自动流拍,自动下架
|
||||||
|
/// </summary>
|
||||||
|
public async Task AutoPassInGoodsAsync()
|
||||||
|
{
|
||||||
|
var autoPassInGoodsDay = (await _settingProvider.GetOrNullAsync("AutoPassInGoodsDay")).To<int>();
|
||||||
|
//下架3天前的商品
|
||||||
|
var endTine = DateTime.Now.AddDays(-autoPassInGoodsDay);
|
||||||
|
//获取所有需要下架商品
|
||||||
|
var marketGoods = await _marketGoodsRepository._DbQueryable.Where(x => x.CreationTime >= endTine).ToListAsync();
|
||||||
|
|
||||||
|
//单独处理每一个下架的商品
|
||||||
|
foreach (var goods in marketGoods)
|
||||||
|
{
|
||||||
|
//用户库存
|
||||||
|
var userStore = await _collectiblesUserStoreRepository._DbQueryable
|
||||||
|
.Where(x => x.CollectiblesId == goods.CollectiblesId)
|
||||||
|
.Where(x => x.IsAtMarketing == true).FirstAsync();
|
||||||
|
if (userStore is not null)
|
||||||
|
{
|
||||||
|
userStore.IsAtMarketing = false;
|
||||||
|
await _collectiblesUserStoreRepository.UpdateAsync(userStore);
|
||||||
|
//删除商品
|
||||||
|
await _marketGoodsRepository.DeleteByIdAsync(goods.Id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 上架货物
|
/// 上架货物
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -39,13 +70,13 @@ public class MarketManager : DomainService
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task ShelvedGoodsAsync(Guid userId, Guid collectiblesId, int number, decimal money)
|
public async Task ShelvedGoodsAsync(Guid userId, Guid collectiblesId, int number, decimal money)
|
||||||
{
|
{
|
||||||
if (number<=0)
|
if (number <= 0)
|
||||||
{
|
{
|
||||||
throw new UserFriendlyException("上架藏品数量需大于0");
|
throw new UserFriendlyException("上架藏品数量需大于0");
|
||||||
}
|
}
|
||||||
|
|
||||||
var collectiblesList = await _collectiblesUserStoreRepository._DbQueryable
|
var collectiblesList = await _collectiblesUserStoreRepository._DbQueryable
|
||||||
.Where(x=>x.UserId==userId)
|
.Where(x => x.UserId == userId)
|
||||||
.Where(x => x.IsAtMarketing == false)
|
.Where(x => x.IsAtMarketing == false)
|
||||||
.Where(x => x.CollectiblesId == collectiblesId).ToListAsync();
|
.Where(x => x.CollectiblesId == collectiblesId).ToListAsync();
|
||||||
if (collectiblesList.Count < number)
|
if (collectiblesList.Count < number)
|
||||||
@@ -80,10 +111,11 @@ public class MarketManager : DomainService
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public async Task PurchaseGoodsAsync(Guid userId, Guid marketGoodsId, int number)
|
public async Task PurchaseGoodsAsync(Guid userId, Guid marketGoodsId, int number)
|
||||||
{
|
{
|
||||||
if (number<=0)
|
if (number <= 0)
|
||||||
{
|
{
|
||||||
throw new UserFriendlyException("交易藏品数量需大于0");
|
throw new UserFriendlyException("交易藏品数量需大于0");
|
||||||
}
|
}
|
||||||
|
|
||||||
//1-市场扣减或者关闭该商品
|
//1-市场扣减或者关闭该商品
|
||||||
//2-出售者新增钱,购买者扣钱
|
//2-出售者新增钱,购买者扣钱
|
||||||
//3-出售者删除对应库存,购买者新增对应库存
|
//3-出售者删除对应库存,购买者新增对应库存
|
||||||
@@ -103,17 +135,19 @@ public class MarketManager : DomainService
|
|||||||
{
|
{
|
||||||
throw new UserFriendlyException($"交易失败,当前交易市场库存不足");
|
throw new UserFriendlyException($"交易失败,当前交易市场库存不足");
|
||||||
}
|
}
|
||||||
|
|
||||||
//2-出售者新增钱,购买者扣钱
|
//2-出售者新增钱,购买者扣钱
|
||||||
//发布一个其他领域的事件-购买者扣钱
|
//发布一个其他领域的事件-购买者扣钱
|
||||||
await _localEventBus.PublishAsync(new MoneyChangeEventArgs() { UserId = userId, Number = -(number*marketGoods.UnitPrice) },false);
|
await _localEventBus.PublishAsync(
|
||||||
|
new MoneyChangeEventArgs() { UserId = userId, Number = -(number * marketGoods.UnitPrice) }, false);
|
||||||
//发布一个其他领域的事件-出售者加钱,同时扣税
|
//发布一个其他领域的事件-出售者加钱,同时扣税
|
||||||
var marketTaxRate = decimal.Parse(await _settingProvider.GetOrNullAsync("MarketTaxRate"));
|
var marketTaxRate = decimal.Parse(await _settingProvider.GetOrNullAsync("MarketTaxRate"));
|
||||||
//价格*扣减税
|
//价格*扣减税
|
||||||
var realTotalPrice = (number*marketGoods.UnitPrice) * (1 - marketTaxRate);
|
var realTotalPrice = (number * marketGoods.UnitPrice) * (1 - marketTaxRate);
|
||||||
//出售者实际加钱
|
//出售者实际加钱
|
||||||
await _localEventBus.PublishAsync(new MoneyChangeEventArgs() { UserId = marketGoods.SellUserId, Number = realTotalPrice },false);
|
await _localEventBus.PublishAsync(
|
||||||
|
new MoneyChangeEventArgs() { UserId = marketGoods.SellUserId, Number = realTotalPrice }, false);
|
||||||
|
|
||||||
//3-出售者删除对应库存,购买者新增对应库存(只需更改用户者即可)
|
//3-出售者删除对应库存,购买者新增对应库存(只需更改用户者即可)
|
||||||
var collectiblesList = await _collectiblesUserStoreRepository._DbQueryable.Where(x => x.IsAtMarketing == true)
|
var collectiblesList = await _collectiblesUserStoreRepository._DbQueryable.Where(x => x.IsAtMarketing == true)
|
||||||
.Where(x => x.UserId == marketGoods.SellUserId)
|
.Where(x => x.UserId == marketGoods.SellUserId)
|
||||||
@@ -129,8 +163,9 @@ public class MarketManager : DomainService
|
|||||||
{
|
{
|
||||||
userStore.PurchaseMarket(userId);
|
userStore.PurchaseMarket(userId);
|
||||||
}
|
}
|
||||||
|
|
||||||
await _collectiblesUserStoreRepository.UpdateRangeAsync(updateStore);
|
await _collectiblesUserStoreRepository.UpdateRangeAsync(updateStore);
|
||||||
|
|
||||||
//发布一个成功交易事件
|
//发布一个成功交易事件
|
||||||
await _localEventBus.PublishAsync(new SuccessMarketEto
|
await _localEventBus.PublishAsync(new SuccessMarketEto
|
||||||
{
|
{
|
||||||
@@ -139,7 +174,7 @@ public class MarketManager : DomainService
|
|||||||
CollectiblesId = marketGoods.CollectiblesId,
|
CollectiblesId = marketGoods.CollectiblesId,
|
||||||
SellNumber = marketGoods.SellNumber,
|
SellNumber = marketGoods.SellNumber,
|
||||||
UnitPrice = marketGoods.UnitPrice,
|
UnitPrice = marketGoods.UnitPrice,
|
||||||
RealTotalPrice =realTotalPrice
|
RealTotalPrice = realTotalPrice
|
||||||
},false);
|
}, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user