using Infrastructure; using Infrastructure.Attribute; using Microsoft.AspNetCore.Http; using System; using System.Collections; using System.Collections.Generic; using System.Linq; using System.Text; using ARW.Common; using ARW.Model; using ARW.Model.System; using ARW.Model.System.Dto; using ARW.Repository.System; using ARW.Service.System.IService; namespace ARW.Service { /// /// 系统用户 /// [AppService(ServiceType = typeof(ISysUserService), ServiceLifetime = LifeTime.Transient)] public class SysUserService : BaseService, ISysUserService { private readonly SysUserRepository UserRepository; private readonly ISysRoleService RoleService; private readonly ISysUserRoleService UserRoleService; private readonly ISysUserPostService UserPostService; public SysUserService( SysUserRepository userRepository, ISysRoleService sysRoleService, ISysUserRoleService userRoleService, ISysUserPostService userPostService) { UserRepository = userRepository; RoleService = sysRoleService; UserRoleService = userRoleService; UserPostService = userPostService; } /// /// 根据条件分页查询用户列表 /// /// public PagedInfo SelectUserList(SysUser user, PagerInfo pager) { var list = UserRepository.SelectUserList(user, pager); return list; } /// /// 通过用户ID查询用户 /// /// /// public SysUser SelectUserById(long userId) { var user = UserRepository.SelectUserById(userId); if (user != null && user.UserId > 0) { user.Roles = RoleService.SelectUserRoleListByUserId(userId); user.RoleIds = user.Roles.Select(x => x.RoleId).ToArray(); } return user; } /// /// 通过用户邮箱查询用户 /// /// /// public SysUser SelectUserByEmail(string email) { var user = UserRepository.Queryable().Where(s => s.Email == email).First(); return user; } /// /// 校验用户名称是否唯一 /// /// /// public string CheckUserNameUnique(string userName) { int count = UserRepository.CheckUserNameUnique(userName); if (count > 0) { return UserConstants.NOT_UNIQUE; } return UserConstants.UNIQUE; } /// /// 新增保存用户信息 /// /// /// public long InsertUser(SysUser sysUser) { long userId = UserRepository.AddUser(sysUser); sysUser.UserId = userId; //新增用户角色信息 UserRoleService.InsertUserRole(sysUser); //新增用户岗位信息 UserPostService.InsertUserPost(sysUser); return userId; } /// /// 修改用户信息 /// /// /// public int UpdateUser(SysUser user) { var roleIds = RoleService.SelectUserRoles(user.UserId); var diffArr = roleIds.Where(c => !((IList)user.RoleIds).Contains(c)).ToArray(); var diffArr2 = user.RoleIds.Where(c => !((IList)roleIds).Contains(c)).ToArray(); if (diffArr.Length > 0 || diffArr2.Length > 0) { //删除用户与角色关联 UserRoleService.DeleteUserRoleByUserId((int)user.UserId); //新增用户与角色关联 UserRoleService.InsertUserRole(user); } // 删除用户与岗位关联 UserPostService.Delete(user.UserId); // 新增用户与岗位管理 UserPostService.InsertUserPost(user); return UserRepository.UpdateUser(user); } public int ChangeUser(SysUser user) { return UserRepository.UpdateUser(user); } /// /// 重置密码 /// /// /// /// public int ResetPwd(long userid, string password) { return UserRepository.ResetPwd(userid, password); } public int ChangeUserStatus(SysUser user) { return UserRepository.ChangeUserStatus(user); } /// /// 删除用户 /// /// /// public int DeleteUser(long userid) { CheckUserAllowed(new SysUser() { UserId = userid}); //删除用户与角色关联 UserRoleService.DeleteUserRoleByUserId((int)userid); // 删除用户与岗位关联 UserPostService.Delete(userid); return UserRepository.DeleteUser(userid); } /// /// 修改用户头像 /// /// /// public int UpdatePhoto(SysUser user) { return UserRepository.UpdatePhoto(user); } /// /// 注册用户 /// /// /// public SysUser Register(RegisterDto dto) { //密码md5 string password = NETCore.Encrypt.EncryptProvider.Md5(dto.Password); if (!Tools.PasswordStrength(dto.Password)) { throw new CustomException("密码强度不符合要求"); } SysUser user = new() { Create_time = DateTime.Now, UserName = dto.Username, NickName = dto.Username, Password = password, Status = "0", DeptId = 0, Remark = "用户注册" }; user.UserId = UserRepository.AddUser(user); return user; } /// /// 校验角色是否允许操作 /// /// public void CheckUserAllowed(SysUser user) { if (user.IsAdmin()) { throw new CustomException("不允许操作超级管理员角色"); } } /// /// 校验用户是否有数据权限 /// /// /// public void CheckUserDataScope(long userid, long loginUserId) { if (!SysUser.IsAdmin(loginUserId)) { SysUser user = new SysUser() { UserId = userid}; //TODO 判断用户是否有数据权限 } } } }