Files
Yi.Admin/Yi.Abp.Net8/module/bbs/Yi.Framework.Bbs.Application/Services/Analyses/BbsUserAnalyseService.cs

294 lines
12 KiB
C#
Raw Normal View History

using Mapster;
2023-12-25 21:41:37 +08:00
using Microsoft.AspNetCore.Mvc;
2023-12-25 17:49:30 +08:00
using SqlSugar;
using Volo.Abp.Application.Dtos;
using Volo.Abp.Application.Services;
using Yi.Framework.Bbs.Application.Contracts.Dtos.Analyse;
2023-12-25 17:49:30 +08:00
using Yi.Framework.Bbs.Application.Contracts.Dtos.BbsUser;
2024-01-15 15:47:36 +08:00
using Yi.Framework.Bbs.Domain.Entities;
2024-08-09 00:39:39 +08:00
using Yi.Framework.Bbs.Domain.Entities.Integral;
2023-12-25 17:49:30 +08:00
using Yi.Framework.Bbs.Domain.Managers;
2024-08-09 00:39:39 +08:00
using Yi.Framework.Bbs.Domain.Shared.Enums;
2024-11-13 19:01:23 +08:00
using Yi.Framework.DigitalCollectibles.Application.Contracts.IServices;
using Yi.Framework.Rbac.Application.Contracts.IServices;
2024-01-22 18:30:01 +08:00
using Yi.Framework.Rbac.Domain.Authorization;
2023-12-25 17:49:30 +08:00
using Yi.Framework.Rbac.Domain.Shared.Consts;
using Yi.Framework.Rbac.Domain.Shared.Model;
2023-12-25 17:49:30 +08:00
namespace Yi.Framework.Bbs.Application.Services.Analyses
{
2023-12-25 21:41:37 +08:00
public class BbsUserAnalyseService : ApplicationService, IApplicationService
2023-12-25 17:49:30 +08:00
{
2023-12-25 21:41:37 +08:00
private BbsUserManager _bbsUserManager;
private IOnlineService _onlineService;
2024-11-13 19:01:23 +08:00
private readonly IPointAnalyseService _pointAnalyseService;
private readonly IValueAnalyseService _valueAnalyseService;
2024-08-09 22:39:27 +08:00
2024-11-13 19:01:23 +08:00
public BbsUserAnalyseService(BbsUserManager bbsUserManager, IOnlineService onlineService,
IPointAnalyseService pointAnalyseService, IValueAnalyseService valueAnalyseService)
2023-12-25 17:49:30 +08:00
{
2023-12-25 21:41:37 +08:00
_bbsUserManager = bbsUserManager;
2024-01-04 20:58:45 +08:00
_onlineService = onlineService;
2024-11-13 19:01:23 +08:00
_pointAnalyseService = pointAnalyseService;
_valueAnalyseService = valueAnalyseService;
2023-12-25 17:49:30 +08:00
}
/// <summary>
/// 人数注册统计(近3个月)
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
[HttpGet("analyse/bbs-user/register")]
2024-08-10 17:44:42 +08:00
public async Task<List<RegisterAnalyseDto>> GetRegisterAsync()
{
using (DataFilter.DisablePermissionHandler())
{
var users = await _bbsUserManager._userRepository._DbQueryable
2024-08-10 17:44:42 +08:00
.Where(u => u.CreationTime >= DateTime.Now.AddMonths(-3))
.LeftJoin<BbsUserExtraInfoEntity>((u, info) => u.Id == info.UserId)
.Select((u, info) => new BbsUserGetListOutputDto()
{
Id = u.Id,
Icon = u.Icon,
Level = info.Level,
UserLimit = info.UserLimit,
Money = info.Money,
Experience = info.Experience,
CreationTime = u.CreationTime
})
.ToListAsync();
var minCreateUser = users.MinBy(x => x.CreationTime);
var userCreateTimeDic = users.OrderBy(x => x.CreationTime)
.GroupBy(x => x.CreationTime.Date)
.ToDictionary(x => x.Key.Date, y => y.Count());
DateTime startDate = minCreateUser.CreationTime.Date;
DateTime endDate = DateTime.Today;
List<RegisterAnalyseDto> output = new List<RegisterAnalyseDto>();
// 计算从起始日期到今天的所有天数
for (DateTime date = startDate; date <= endDate; date = date.AddDays(1))
{
var count = 0;
userCreateTimeDic.TryGetValue(date, out count);
RegisterAnalyseDto dayInfo = new RegisterAnalyseDto(date, count);
output.Add(dayInfo);
}
return output;
}
}
2024-08-09 00:39:39 +08:00
/// <summary>
/// 财富排行榜
/// </summary>
/// <returns></returns>
2024-08-10 17:44:42 +08:00
[HttpGet("analyse/bbs-user/money-top/{userId?}")]
public async Task<PagedResultDto<MoneyTopUserDto>> GetMoneyTopAsync([FromQuery] PagedResultRequestDto input,
[FromRoute] Guid? userId)
2024-08-09 00:39:39 +08:00
{
using (DataFilter.DisablePermissionHandler())
{
2024-08-10 17:44:42 +08:00
var pageIndex = input.SkipCount;
2024-08-09 00:39:39 +08:00
RefAsync<int> total = 0;
var output = await _bbsUserManager._userRepository._DbQueryable
2024-08-09 22:39:27 +08:00
.LeftJoin<BbsUserExtraInfoEntity>((u, info) => u.Id == info.UserId)
.OrderByDescending((u, info) => info.Money)
2024-08-09 00:39:39 +08:00
.Select((u, info) =>
new MoneyTopUserDto
{
UserName = u.UserName,
2024-08-09 22:39:27 +08:00
Nick = u.Nick,
2024-08-09 00:39:39 +08:00
Money = info.Money,
Icon = u.Icon,
Level = info.Level,
2024-08-09 22:39:27 +08:00
UserLimit = info.UserLimit,
2024-08-10 17:44:42 +08:00
Order = SqlFunc.RowNumber(SqlFunc.Desc(info.Money))
2024-08-09 00:39:39 +08:00
}
)
2024-08-10 17:44:42 +08:00
.ToPageListAsync(pageIndex, input.MaxResultCount, total);
2024-08-09 22:39:27 +08:00
2024-12-08 03:43:04 +08:00
var levelCache = await _bbsUserManager.GetLevelCacheMapAsync();
output.ForEach(x => { x.LevelName = levelCache[x.Level].Name; });
2024-08-09 00:39:39 +08:00
return new PagedResultDto<MoneyTopUserDto>
{
Items = output,
TotalCount = total
};
}
}
2023-12-25 17:49:30 +08:00
/// <summary>
2023-12-25 21:41:37 +08:00
/// 推荐好友,随机返回好友列表
2023-12-25 17:49:30 +08:00
/// </summary>
/// <returns></returns>
2023-12-25 21:41:37 +08:00
[HttpGet("analyse/bbs-user/random")]
public async Task<List<BbsUserGetListOutputDto>> GetRandomUserAsync([FromQuery] PagedResultRequestDto input)
2023-12-25 17:49:30 +08:00
{
2024-01-22 20:06:39 +08:00
using (DataFilter.DisablePermissionHandler())
2024-01-22 18:30:01 +08:00
{
var randUserIds = await _bbsUserManager._userRepository._DbQueryable
2024-08-09 22:39:27 +08:00
//.Where(x => x.UserName != UserConst.Admin)
.OrderBy(x => SqlFunc.GetRandom())
.Select(x => x.Id).ToPageListAsync(input.SkipCount, input.MaxResultCount);
2024-01-22 18:30:01 +08:00
var output = await _bbsUserManager.GetBbsUserInfoAsync(randUserIds);
return output.Adapt<List<BbsUserGetListOutputDto>>();
2024-01-22 20:06:39 +08:00
//这里关闭了数据权限,所有用户都能查询的到
2024-01-22 18:30:01 +08:00
}
2024-01-22 20:06:39 +08:00
//这里有数据权限,会根据用户角色进行过滤
2023-12-25 17:49:30 +08:00
}
/// <summary>
/// 用户分析
/// </summary>
/// <returns></returns>
[HttpGet("analyse/bbs-user")]
public async Task<BbsUserAnalyseGetOutput> GetUserAnalyseAsync()
{
2024-01-22 20:06:39 +08:00
using (DataFilter.DisablePermissionHandler())
2024-01-22 18:30:01 +08:00
{
2024-08-09 22:39:27 +08:00
var sss = DataFilter.IsEnabled<IDataPermission>();
2024-01-22 18:30:01 +08:00
var registerUser = await _bbsUserManager._userRepository._DbQueryable.CountAsync();
2024-01-22 18:30:01 +08:00
DateTime now = DateTime.Now;
DateTime yesterday = now.AddDays(-1);
DateTime startTime = new DateTime(yesterday.Year, yesterday.Month, yesterday.Day, 0, 0, 0);
DateTime endTime = startTime.AddHours(24);
var yesterdayNewUser = await _bbsUserManager._userRepository._DbQueryable
2024-08-09 22:39:27 +08:00
.Where(x => x.CreationTime >= startTime && x.CreationTime <= endTime).CountAsync();
2024-01-04 20:58:45 +08:00
2024-01-22 18:30:01 +08:00
var userOnline = (await _onlineService.GetListAsync(new OnlineUserModel { })).TotalCount;
2024-01-04 20:58:45 +08:00
2024-08-09 22:39:27 +08:00
var output = new BbsUserAnalyseGetOutput()
{ OnlineNumber = userOnline, RegisterNumber = registerUser, YesterdayNewUser = yesterdayNewUser };
2024-01-04 20:58:45 +08:00
2024-01-22 18:30:01 +08:00
return output;
}
}
2024-11-13 19:01:23 +08:00
/// <summary>
/// 积分排行榜
/// </summary>
/// <returns></returns>
[HttpGet("analyse/dc-user/points-top/{userId?}")]
public async Task<PagedResultDto<PointsTopUserDto>> GetPointsTopAsync([FromQuery] PagedResultRequestDto input,
[FromRoute] Guid? userId)
{
var result = await _pointAnalyseService.GetValueTopAsync(input, null);
var userIds = result.Items.Select(x => x.UserId).ToList();
var baseOutput = await _bbsUserManager._userRepository._DbQueryable
.Where(u => userIds.Contains(u.Id))
.LeftJoin<BbsUserExtraInfoEntity>((u, info) => u.Id == info.UserId)
.Select((u, info) =>
new BaseAnalyseTopUserDto
{
UserName = u.UserName,
Nick = u.Nick,
Icon = u.Icon,
Level = info.Level,
UserLimit = info.UserLimit,
UserId = info.UserId
}
).ToListAsync();
var output = new List<PointsTopUserDto>();
2024-12-10 00:08:04 +08:00
var levelCache = await _bbsUserManager.GetLevelCacheMapAsync();
2024-11-13 19:01:23 +08:00
result.Items.ToList().ForEach(x =>
{
var currentUserInfo = baseOutput.Where(u => u.UserId == x.UserId).FirstOrDefault();
if (currentUserInfo is not null)
{
output.Add(new PointsTopUserDto
{
UserName = currentUserInfo.UserName,
Nick = currentUserInfo.Nick,
Order = x.Order,
Icon = currentUserInfo.Icon,
Level = currentUserInfo.Level,
2024-12-10 00:08:04 +08:00
LevelName = levelCache[currentUserInfo.Level].Name,
2024-11-13 19:01:23 +08:00
UserLimit = UserLimitEnum.Normal,
Points = x.Points
});
}
});
return new PagedResultDto<PointsTopUserDto>
{
Items = output,
TotalCount = result.TotalCount
};
}
/// <summary>
/// 价值排行榜
/// </summary>
/// <returns></returns>
[HttpGet("analyse/dc-user/value-top/{userId?}")]
public async Task<PagedResultDto<ValueTopUserDto>> GetValueTopAsync([FromQuery] PagedResultRequestDto input,
[FromRoute] Guid? userId)
{
var result = await _valueAnalyseService.GetValueTopAsync(input, null);
2024-12-10 00:08:04 +08:00
2024-11-13 19:01:23 +08:00
var userIds = result.Items.Select(x => x.UserId).ToList();
var baseOutput = await _bbsUserManager._userRepository._DbQueryable
.Where(u => userIds.Contains(u.Id))
.LeftJoin<BbsUserExtraInfoEntity>((u, info) => u.Id == info.UserId)
.Select((u, info) =>
new BaseAnalyseTopUserDto
{
UserName = u.UserName,
Nick = u.Nick,
Icon = u.Icon,
Level = info.Level,
UserLimit = info.UserLimit,
UserId = info.UserId
}
).ToListAsync();
var output = new List<ValueTopUserDto>();
2024-12-10 00:08:04 +08:00
var levelCache = await _bbsUserManager.GetLevelCacheMapAsync();
2024-11-13 19:01:23 +08:00
result.Items.ToList().ForEach(x =>
{
var currentUserInfo = baseOutput.Where(u => u.UserId == x.UserId).FirstOrDefault();
if (currentUserInfo is not null)
{
output.Add(new ValueTopUserDto
{
UserName = currentUserInfo.UserName,
Nick = currentUserInfo.Nick,
Order = x.Order,
Icon = currentUserInfo.Icon,
Level = currentUserInfo.Level,
2024-12-10 00:08:04 +08:00
LevelName =levelCache[currentUserInfo.Level].Name,
2024-11-13 19:01:23 +08:00
UserLimit = UserLimitEnum.Normal,
Value = x.Value
});
}
});
return new PagedResultDto<ValueTopUserDto>
{
Items = output,
TotalCount = result.TotalCount
};
}
2023-12-25 17:49:30 +08:00
}
2024-08-09 22:39:27 +08:00
}