using DS.Module.Core; using DS.Module.Core.Constants; using DS.Module.Core.Data; using DS.Module.Core.Extensions; using DS.Module.Core.Helpers; using DS.Module.SqlSugar; using DS.Module.UserModule; using DS.WMS.Core.Code.Dtos; using DS.WMS.Core.Code.Entity; using DS.WMS.Core.Sys.Dtos; using DS.WMS.Core.Sys.Entity; using DS.WMS.Core.Sys.Interface; using DS.WMS.Core.TaskPlat.Dtos; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.DependencyInjection; using MiniExcelLibs; using Org.BouncyCastle.Ocsp; using SqlSugar; using System.Data; namespace DS.WMS.Core.Sys.Method; /// /// /// public class UserService : IUserService { private readonly IServiceProvider _serviceProvider; private readonly ISqlSugarClient db; private readonly IUser user; private readonly ICommonService _commonService; /// /// /// /// public UserService(IServiceProvider serviceProvider) { _serviceProvider = serviceProvider; db = _serviceProvider.GetRequiredService(); user = _serviceProvider.GetRequiredService(); _commonService = _serviceProvider.GetRequiredService(); } /// /// 列表查询 /// /// /// public DataResult> GetListByPage(PageRequest request) { var query = _commonService.GetDataRuleFilter(); //序列化查询条件 var whereList = db.ConfigQuery.Context.Utilities.JsonToConditionalModels(request.QueryCondition); var data = query .Where(x => x.UserCode != "admin") .Where(whereList).Select() .Mapper(it => { var roleStr = string.Empty; var roleIds = db.Queryable().Where(x => x.UserId == it.Id).Select(x => x.RoleId).ToArray(); if (roleIds.Count()>0) { var roles = db.Queryable().Where(x => roleIds.Contains(x.Id)).Select(x => x.RoleName).ToArray(); roleStr = roles.ToJoin(","); } it.RoleName = roleStr; }) .ToQueryPage(request.PageCondition); return data; } /// /// 获取单个用户信息 /// /// /// public DataResult GetUserInfo(string id) { var roleIds = db.Queryable().Where(x => x.UserId == long.Parse(id)).Select(x => x.RoleId).ToArray(); var orgIds = db.Queryable().Where(x => x.UserId == long.Parse(id)).Select(x => x.OrgId).ToArray(); var data = db.Queryable() .Where(x => x.Id == long.Parse(id)) .Select() .Mapper(it => { it.RoleIds = roleIds; it.OrgIds = orgIds; }) .First(); return DataResult.Success(data,MultiLanguageConst.DataQuerySuccess); } public async Task CheckUserCode(string code) { var isExist = await db.Queryable().Filter(null, true).Where(x => x.UserCode == code.Trim()).FirstAsync(); if (isExist != null) { return await Task.FromResult(DataResult.Failed("用户唯一编码已存在!", MultiLanguageConst.UserCodeExist)); } return await Task.FromResult(DataResult.Successed("用户唯一编码检测成功!", MultiLanguageConst.DataQuerySuccess)); } /// /// 编辑用户信息 /// /// /// public DataResult EditUser(UserReq model) { if (model.Id == 0) { var isExist = db.Queryable().Filter(null,true).Where(x => x.UserCode == model.UserCode).First(); if (isExist != null) { return DataResult.Failed("用户唯一编码已存在!",MultiLanguageConst.UserCodeExist); } #region 用户数量检测 var tenant = db.Queryable().Where(x=>x.Id ==long.Parse(user.TenantId)).First(); var userAuth = db.Queryable().First(); if (userAuth.IsNotNull()) { var authNum = EncrypteHelper.DecryptData(userAuth.AuthNum, tenant.AppSecret); var userCount = db.Queryable().Where(x=>x.IsUseSystem == true).Count(); if (userCount>= int.Parse(authNum)) { return DataResult.Failed(string.Format("用户数量超出授权数量{0}", int.Parse(authNum)),MultiLanguageConst.UserAuthNumLimit); } } #endregion var data = model.MapTo(); data.PinYinCode = data.UserName + "(" + PinYinUtil.GetFristLetter(data.UserName) + ")"; data.MD5Password = MD5Helper.MD5Encrypt(data.Password); var entity = db.Insertable(data).RemoveDataCache($"{SqlSugarCacheConst.User}{user.TenantId}").ExecuteReturnEntity(); if (model.RoleIds.IsNotNull() && model.RoleIds.Count() > 0) { foreach (var item in model.RoleIds) { var roleUser = new SysRoleUser { RoleId = item, UserId = entity.Id, }; db.Insertable(roleUser).ExecuteCommand(); } } if (model.OrgIds.IsNotNull() && model.OrgIds.Count() > 0) { foreach (var item in model.OrgIds) { var orgUser = new SysOrgUser { OrgId = item, UserId = entity.Id, }; db.Insertable(orgUser).ExecuteCommand(); } } return DataResult.Successed("添加成功!", entity.Id,MultiLanguageConst.DataCreateSuccess); } else { var userId = model.Id; var info = db.Queryable().Where(x => x.Id == userId).First(); info = model.MapTo(); info.PinYinCode = info.UserName + "(" + PinYinUtil.GetFristLetter(info.UserName) + ")"; db.Updateable(info).RemoveDataCache($"{SqlSugarCacheConst.User}{user.TenantId}").IgnoreColumns(it => new { it.TenantId,it.TenantName, it.Password,it.MD5Password }).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommand(); #region 处理用户角色 var existRoles = db.Queryable().Where(x => x.UserId == userId).Select(n => n.RoleId) .ToArray(); IEnumerable delRoles = existRoles.AsQueryable().Except(model.RoleIds); if (delRoles.Count() > 0) { db.Deleteable() .Where(it => it.UserId == userId && delRoles.Contains(it.RoleId)) .ExecuteCommand(); } IEnumerable addRoles = model.RoleIds.AsQueryable().Except(existRoles); if (addRoles.Count() > 0) { foreach (var item in addRoles) { var roleUser = new SysRoleUser { RoleId = item, UserId = model.Id, }; db.Insertable(roleUser).ExecuteCommand(); } } #endregion 处理用户角色 #region 处理用户机构 var existOrgs = db.Queryable().Where(x => x.UserId == userId).Select(n => n.OrgId) .ToArray(); IEnumerable delOrgs = existOrgs.AsQueryable().Except(model.OrgIds); if (delOrgs.Count() > 0) { db.Deleteable() .Where(it => it.UserId == userId && delOrgs.Contains(it.OrgId)) .ExecuteCommand(); } IEnumerable addOrgs = model.OrgIds.AsQueryable().Except(existOrgs); if (addOrgs.Count() > 0) { foreach (var item in addOrgs) { var orgUser = new SysOrgUser { OrgId = item, UserId = model.Id, }; db.Insertable(orgUser).ExecuteCommand(); } } #endregion 处理用户机构 return DataResult.Successed("更新成功!",MultiLanguageConst.DataUpdateSuccess); } } /// /// 删除用户 /// /// /// public async Task BatchDelUser(IdModel req) { if (req.Ids.Contains(long.Parse(user.UserId))) { return await Task.FromResult(DataResult.Failed("不能删除本人账号!")); } var list = await db.Queryable().Where(x => req.Ids.Contains(x.Id)).ToListAsync(); if (list.Count > 0) { foreach (var item in list) { var roleUsers = await db.Queryable().Where(x => x.UserId == item.Id).ToListAsync(); if (roleUsers.Count > 0) await db.Deleteable(roleUsers).ExecuteCommandAsync(); var orgUsers = await db.Queryable().Where(x => x.UserId == item.Id).ToListAsync(); if (orgUsers.Count > 0) await db.Deleteable(orgUsers).ExecuteCommandAsync(); } await db.Deleteable(list).RemoveDataCache($"{SqlSugarCacheConst.User}{user.TenantId}").ExecuteCommandAsync(); } return await Task.FromResult(DataResult.Successed("删除成功!", MultiLanguageConst.DataDelSuccess)); } /// /// 查询客户端 用户拥有的菜单权限 /// /// public async Task>> GetClientUserPermissions() { List list = new List(); var userId = long.Parse(user.UserId); var userInfo = await db.Queryable().Where(x => x.Id == userId).FirstAsync(); var roleIds = await db.Queryable().Where(x => x.UserId == userId).Select(x => x.RoleId).ToListAsync(); if (roleIds.Count == 0) { return await Task.FromResult(DataResult>.Failed("该用户未绑定角色!")); } var permissions = await db.Queryable().Where(x => roleIds.Contains(x.RoleId)) .Select(x => x.PermissionId).Distinct().ToListAsync(); var perlist = await db.Queryable() .Where(x => x.MenuType == 1 && x.IsHidden == false && permissions.Contains(x.PermissionId) && (x.PermissionType == 1 || x.PermissionType == 0)) .OrderBy(x => x.SortCode) .Select(a => new RouteItem { Id = a.Id, ParentId = a.PermissionId, Path = a.Url, Name = a.PermissionName, EnName = a.PermissionEnName, Component = a.Component, Redirect = a.Redirect, SortCode = a.SortCode, Meta = new RouteMeta() { Title = a.Title, Icon = a.Icon, } }) .ToListAsync(); list.AddRange(perlist); //去重 list.Distinct(); //排序 list = list.OrderBy(x => x.SortCode).ToList(); foreach (var item in list) { var childs = await db.Queryable().Where(x => (x.MenuType == 1 || x.MenuType == 2) && x.ParentId == item.ParentId && x.IsHidden == false && permissions.Contains(x.PermissionId) && (x.PermissionType == 1 || x.PermissionType == 0) && x.PermissionId != 1744968217220222976) //排除企业用户维护 .OrderBy(x => x.SortCode) .Select(a => new RouteItem { Id = a.Id, ParentId = a.PermissionId, Path = a.Url, Name = a.PermissionName, EnName = a.PermissionEnName, Component = a.Component, IsCache = a.IsCache, Meta = new RouteMeta() { Title = a.Title, Icon = a.Icon, } }).ToListAsync(); //去重 childs.Distinct(); //排序 childs = childs.OrderBy(x => x.SortCode).ToList(); item.Children = childs; } // list = list.OrderBy(x => x.Id).ToList(); return await Task.FromResult(DataResult>.Success("获取数据成功!", list)); } /// /// 根据权限模块获取数据范围列表 /// /// /// public async Task>> GetDataRuleListByPermission(string permissionId) { var data = await db.Queryable() .Where(x => x.PermissionId == long.Parse(permissionId) && x.Status == StatusEnum.Enable) .Select() .ToListAsync(); return await Task.FromResult(DataResult>.Success(data, MultiLanguageConst.DataQuerySuccess)); } /// /// 按Excel导入用户信息 /// /// /// public async Task> ImportUserByExcel(IFormFile file) { //未上传文件 if (file == null || file.Length == 0) { return await Task.FromResult(DataResult.Failed("请上传Excel!")); } var formFile = file; //DataResult api_Result = new Api_Result(); //获取文件名 var fileName = formFile.FileName; // 获取文件后缀 var fileExtension = Path.GetExtension(fileName); // 判断后缀是否是xlsx或者xls if (fileExtension != ".xlsx" && fileExtension != ".xls") { return DataResult.Failed("文件格式错误"); } var length = formFile.Length; if (length > 1024 * 1024 * 10) { return DataResult.Failed("文件大小不能超过10M"); } // MemoryStream 内存流 在内存当中创建一个流(开辟空间) using (var stream = new MemoryStream()) { //将文件写入内存流 formFile.CopyTo(stream); //将流的位置归零 stream.Position = 0; //将内存流转成List集合 var list = await stream.QueryAsync(); var users = new List(); foreach (var item in list) { var sysUser = new SysUser() { UserCode = item.UserCode, UserName = item.UserName, PinYinCode = item.UserName + "("+ PinYinUtil.GetFristLetter(item.UserName)+")", UserNumber = item.UserNumber, Password = "123456ABC", MD5Password = MD5Helper.MD5Encrypt("123456ABC"), UserEnName = item.UserEnName, Sex = item.Sex == "女"? 2:1, Duty = item.Duty, OfficePhone = item.OfficePhone, Email = item.Email, Phone = item.Phone, IsOperator = item.IsOperator == 1? true : false, IsVouchingClerk = item.IsVouchingClerk == 1 ? true : false, IsSale = item.IsSale == 1 ? true : false, IsCustom = item.IsCustom == 1 ? true : false, IsFinancialStaff = item.IsFinancialStaff == 1 ? true : false, IsCustomerService = item.IsCustomerService == 1 ? true : false, IsDriver = item.IsDriver == 1 ? true : false, IsDispatcher = item.IsDispatcher == 1 ? true : false, UserType = 2 }; users.Add(sysUser); } await db.Insertable(users).ExecuteCommandAsync(); return await Task.FromResult(DataResult.Failed("导入成功!", MultiLanguageConst.DataImportSuccess)); } } }