feat: 完成

This commit is contained in:
橙子
2024-10-17 00:27:20 +08:00
parent cb1bac25a3
commit 260d87c97e
15 changed files with 361 additions and 59 deletions

View File

@@ -1,4 +1,9 @@
using Volo.Abp.Domain.Services;
using Volo.Abp.EventBus.Local;
using Volo.Abp.Settings;
using Yi.Framework.Bbs.Domain.Shared.Etos;
using Yi.Framework.DigitalCollectibles.Domain.Entities;
using Yi.Framework.SqlSugarCore.Abstractions;
namespace Yi.Framework.DigitalCollectibles.Domain.Managers;
@@ -6,7 +11,109 @@ namespace Yi.Framework.DigitalCollectibles.Domain.Managers;
/// 市场领域服务
/// 处理交易市场相关业务,例如交易等
/// </summary>
public class MarketManager:DomainService
public class MarketManager : DomainService
{
private readonly ISqlSugarRepository<CollectiblesUserStoreAggregateRoot> _collectiblesUserStoreRepository;
private readonly ISqlSugarRepository<MarketGoodsAggregateRoot> _marketGoodsRepository;
private readonly ILocalEventBus _localEventBus;
public readonly ISettingProvider _settingProvider;
public MarketManager(ISqlSugarRepository<CollectiblesUserStoreAggregateRoot> collectiblesUserStoreRepository,
ISqlSugarRepository<MarketGoodsAggregateRoot> marketGoodsRepository, ILocalEventBus localEventBus, ISettingProvider settingProvider)
{
_collectiblesUserStoreRepository = collectiblesUserStoreRepository;
_marketGoodsRepository = marketGoodsRepository;
_localEventBus = localEventBus;
_settingProvider = settingProvider;
}
/// <summary>
/// 上架货物
/// </summary>
/// <param name="userId">上架者</param>
/// <param name="collectiblesId">上架的收藏品id</param>
/// <param name="number">上架数量</param>
/// <param name="money">上架单价</param>
/// <returns></returns>
public async Task ShelvedGoodsAsync(Guid userId, Guid collectiblesId, int number, decimal money)
{
var collectiblesList = await _collectiblesUserStoreRepository._DbQueryable.Where(x => x.IsAtMarketing == false)
.Where(x => x.CollectiblesId == collectiblesId).ToListAsync();
if (collectiblesList.Count < number)
{
throw new UserFriendlyException($"您的藏品不足{number}个,上架失败");
}
//上架收藏品
var shelvedcollectibles = collectiblesList.Take(2);
foreach (var store in shelvedcollectibles)
{
store.ShelvedMarket();
}
await _collectiblesUserStoreRepository.UpdateRangeAsync(shelvedcollectibles.ToList());
await _marketGoodsRepository.InsertAsync(new MarketGoodsAggregateRoot
{
SellUserId = userId,
CollectiblesId = collectiblesId,
SellNumber = number,
UnitPrice = money
});
}
/// <summary>
/// 购买商品
/// </summary>
/// <param name="userId">购买者用户</param>
/// <param name="marketGoodsId">商品id</param>
/// <param name="number">购买数量</param>
/// <returns></returns>
public async Task PurchaseGoodsAsync(Guid userId, Guid marketGoodsId, int number)
{
//1-市场扣减或者关闭该商品
//2-出售者新增钱,购买者扣钱
//3-出售者删除对应库存,购买者新增对应库存
var marketGoods = await _marketGoodsRepository.GetAsync(x => x.Id == marketGoodsId);
//1-市场扣减或者关闭该商品
if (marketGoods.SellNumber == number)
{
await _marketGoodsRepository.DeleteAsync(x => x.Id == marketGoodsId);
}
else if (marketGoods.SellNumber >= number)
{
marketGoods.SellNumber -= number;
await _marketGoodsRepository.UpdateAsync(marketGoods);
}
else
{
throw new UserFriendlyException($"交易失败,当前交易市场库存不足");
}
//2-出售者新增钱,购买者扣钱
//发布一个其他领域的事件-购买者扣钱
await _localEventBus.PublishAsync(new MoneyChangeEventArgs() { UserId = userId, Number = -number },false);
//发布一个其他领域的事件-出售者加钱,同时扣税
var marketTaxRate = decimal.Parse(await _settingProvider.GetOrNullAsync("MarketTaxRate"));
await _localEventBus.PublishAsync(new MoneyChangeEventArgs() { UserId = userId, Number = number*(1-marketTaxRate) },false);
//3-出售者删除对应库存,购买者新增对应库存
var collectiblesList = await _collectiblesUserStoreRepository._DbQueryable.Where(x => x.IsAtMarketing == true)
.Where(x => x.UserId == marketGoods.SellUserId)
.Where(x => x.CollectiblesId == marketGoods.CollectiblesId)
.ToListAsync();
if (collectiblesList.Count < number)
{
throw new UserFriendlyException($"交易失败,当前出售者库存不足");
}
var updateStore = collectiblesList.Take(number);
foreach (var userStore in updateStore)
{
userStore.PurchaseMarket(userId);
}
await _collectiblesUserStoreRepository.UpdateRangeAsync(updateStore.ToList());
}
}

View File

@@ -55,6 +55,20 @@ public class MiningPoolManager : DomainService
return pool;
}
public async Task GetOnHookAsync(Guid userId)
{
var onHook = await _onHookRepository._DbQueryable.Where(x => x.UserId == userId)
.Where(x => x.IsActive == true)
.Where(x => x.EndTime <= DateTime.Now)
.FirstAsync();
if (onHook is not null)
{
throw new UserFriendlyException($"当前你正在进行自动挂机,结束时间:{onHook.EndTime.Value.ToString("MM月dd日HH分mm秒")})");
}
await _onHookRepository.InsertAsync(new OnHookAggregateRoot(userId, 24));
}
/// <summary>
/// 校验挖矿限制