using Microsoft.AspNetCore.Mvc; using SqlSugar; using TencentCloud.Tcr.V20190924.Models; using Volo.Abp; using Volo.Abp.Application.Dtos; using Volo.Abp.Caching; using Volo.Abp.EventBus.Local; using Volo.Abp.Users; using Yi.Framework.Ddd.Application; using Yi.Framework.Rbac.Application.Contracts.Dtos.User; using Yi.Framework.Rbac.Application.Contracts.IServices; using Yi.Framework.Rbac.Domain.Authorization; using Yi.Framework.Rbac.Domain.Entities; using Yi.Framework.Rbac.Domain.Managers; using Yi.Framework.Rbac.Domain.Repositories; using Yi.Framework.Rbac.Domain.Shared.Caches; using Yi.Framework.Rbac.Domain.Shared.Consts; using Yi.Framework.Rbac.Domain.Shared.Etos; using Yi.Framework.Rbac.Domain.Shared.OperLog; using Yi.Framework.SqlSugarCore.Abstractions; namespace Yi.Framework.Rbac.Application.Services.System { /// /// User服务实现 /// public class UserService : YiCrudAppService,IUserService //IUserService { public UserService(ISqlSugarRepository repository, UserManager userManager, IUserRepository userRepository, ICurrentUser currentUser, IDeptService deptService, ILocalEventBus localEventBus, IDistributedCache userCache) : base(repository) => (_userManager, _userRepository, _currentUser, _deptService, _repository, _localEventBus, _userCache) = (userManager, userRepository, currentUser, deptService, repository, localEventBus, userCache); private UserManager _userManager { get; set; } private ISqlSugarRepository _repository; private IUserRepository _userRepository { get; set; } private IDeptService _deptService { get; set; } private ICurrentUser _currentUser { get; set; } private ILocalEventBus _localEventBus; /// /// 查询用户 /// /// /// [Permission("system:user:list")] public override async Task> GetListAsync(UserGetListInputVo input) { RefAsync total = 0; List deptIds = null; if (input.DeptId is not null) { deptIds = await _deptService.GetChildListAsync(input.DeptId ?? Guid.Empty); } List ids = input.Ids?.Split(",").Select(x => Guid.Parse(x)).ToList(); var outPut = await _repository._DbQueryable.WhereIF(!string.IsNullOrEmpty(input.UserName), x => x.UserName.Contains(input.UserName!)) .WhereIF(input.Phone is not null, x => x.Phone.ToString()!.Contains(input.Phone.ToString()!)) .WhereIF(!string.IsNullOrEmpty(input.Name), x => x.Name!.Contains(input.Name!)) .WhereIF(input.State is not null, x => x.State == input.State) .WhereIF(input.StartTime is not null && input.EndTime is not null, x => x.CreationTime >= input.StartTime && x.CreationTime <= input.EndTime) //这个为过滤当前部门,加入数据权限后,将由数据权限控制 .WhereIF(input.DeptId is not null, x => deptIds.Contains(x.DeptId ?? Guid.Empty)) .WhereIF(ids is not null, x => ids.Contains(x.Id)) .LeftJoin((user, dept) => user.DeptId == dept.Id) .OrderByDescending(user => user.CreationTime) .Select((user, dept) => new UserGetListOutputDto(), true) .ToPageListAsync(input.SkipCount, input.MaxResultCount, total); var result = new PagedResultDto(); result.Items = outPut; result.TotalCount = total; return result; } protected override UserEntity MapToEntity(UserCreateInputVo createInput) { var output= base.MapToEntity(createInput); output.EncryPassword = new Domain.Entities.ValueObjects.EncryPasswordValueObject(createInput.Password); return output; } /// /// 添加用户 /// /// /// [OperLog("添加用户", OperEnum.Insert)] [Permission("system:user:add")] public async override Task CreateAsync(UserCreateInputVo input) { if (input.UserName == UserConst.Admin || input.UserName == UserConst.TenantAdmin) { throw new UserFriendlyException(UserConst.Name_Not_Allowed); } if (string.IsNullOrEmpty(input.Password)) { throw new UserFriendlyException(UserConst.Login_Passworld_Error); } if (await _repository.IsAnyAsync(u => input.UserName.Equals(u.UserName))) { throw new UserFriendlyException(UserConst.User_Exist); } var entitiy = await MapToEntityAsync(input); entitiy.BuildPassword(); //using (var uow = _unitOfWorkManager.CreateContext()) //{ var returnEntity = await _repository.InsertReturnEntityAsync(entitiy); await _userManager.GiveUserSetRoleAsync(new List { returnEntity.Id }, input.RoleIds); await _userManager.GiveUserSetPostAsync(new List { returnEntity.Id }, input.PostIds); //uow.Commit(); var result = await MapToGetOutputDtoAsync(returnEntity); await _localEventBus.PublishAsync(new UserCreateEventArgs(returnEntity.Id)); return result; //} } /// /// 单查 /// /// /// public override async Task GetAsync(Guid id) { //使用导航树形查询 var entity = await _repository._DbQueryable.Includes(u => u.Roles).Includes(u => u.Posts).Includes(u => u.Dept).InSingleAsync(id); return await MapToGetOutputDtoAsync(entity); } /// /// 更新用户 /// /// /// /// [OperLog("更新用户", OperEnum.Update)] [Permission("system:user:update")] public async override Task UpdateAsync(Guid id, UserUpdateInputVo input) { if (input.UserName == UserConst.Admin || input.UserName == UserConst.TenantAdmin) { throw new UserFriendlyException(UserConst.Name_Not_Allowed); } if (await _repository.IsAnyAsync(u => input.UserName!.Equals(u.UserName) && !id.Equals(u.Id))) { throw new UserFriendlyException("用户已经存在,更新失败"); } var entity = await _repository.GetByIdAsync(id); //更新密码,特殊处理 if (input.Password is not null) { entity.EncryPassword.Password = input.Password; entity.BuildPassword(); } await MapToEntityAsync(input, entity); var res1 = await _repository.UpdateAsync(entity); await _userManager.GiveUserSetRoleAsync(new List { id }, input.RoleIds); await _userManager.GiveUserSetPostAsync(new List { id }, input.PostIds); return await MapToGetOutputDtoAsync(entity); } /// /// 更新个人中心 /// /// /// [OperLog("更新个人信息", OperEnum.Update)] public async Task UpdateProfileAsync(ProfileUpdateInputVo input) { var entity = await _repository.GetByIdAsync(_currentUser.Id); ObjectMapper.Map(input, entity); await _repository.UpdateAsync(entity); var dto = await MapToGetOutputDtoAsync(entity); await _userCache.RefreshAsync(new UserInfoCacheKey(_currentUser.GetId())); return dto; } /// /// 更新状态 /// /// /// /// [Route("user/{id}/{state}")] [OperLog("更新用户状态", OperEnum.Update)] [Permission("system:user:update")] public async Task UpdateStateAsync([FromRoute] Guid id, [FromRoute] bool state) { var entity = await _repository.GetByIdAsync(id); if (entity is null) { throw new ApplicationException("用户未存在"); } entity.State = state; await _repository.UpdateAsync(entity); await _userCache.RefreshAsync(new UserInfoCacheKey(id)); return await MapToGetOutputDtoAsync(entity); } [OperLog("删除用户", OperEnum.Delete)] [Permission("system:user:delete")] public override async Task DeleteAsync(Guid id) { await base.DeleteAsync(id); await _userCache.RefreshAsync(new UserInfoCacheKey(id)); } [Permission("system:user:export")] public override Task GetExportExcelAsync(UserGetListInputVo input) { return base.GetExportExcelAsync(input); } [Permission("system:user:import")] public override Task PostImportExcelAsync(List input) { return base.PostImportExcelAsync(input); } } }