using WIDESEAWCS_Core.Authorization; using WIDESEAWCS_Core; using WIDESEAWCS_Core.BaseServices; using WIDESEAWCS_Core.Const; using WIDESEAWCS_Core.Helper; using WIDESEAWCS_Core.HttpContextUser; using WIDESEAWCS_ISystemServices; using WIDESEAWCS_Model; using WIDESEAWCS_Model.Models; using WIDESEAWCS_ISystemRepository; using WIDESEAWCS_Core.BaseRepository; using System.Net; using WIDESEAWCS_Core.Caches; using System.Drawing.Drawing2D; using WIDESEAWCS_SystemServices.System; using OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup; using Newtonsoft.Json; namespace WIDESEAWCS_SystemServices { public class Sys_UserService : ServiceBase, ISys_UserService { private readonly IUnitOfWorkManage _unitOfWorkManage; private readonly ICacheService _cacheService; private readonly ISys_MenuService _menuService; private readonly ISys_RoleService _sys_RoleService; public Sys_UserService(ISys_UserRepository repository, IUnitOfWorkManage unitOfWorkManage, ICacheService cacheService, ISys_RoleService sys_RoleService, ISys_MenuService menuService) : base(repository) { _unitOfWorkManage = unitOfWorkManage; _cacheService = cacheService; _sys_RoleService = sys_RoleService; _menuService = menuService; } //public override PageGridData GetPageData(PageDataOptions options) //{ // var roleIds = _sys_RoleService.GetAllChildren(App.User.RoleId).Select(x => x.Id); // PageGridData pageGridData = new PageGridData(); // //树形菜单传查询角色下所有用户 // if (App.User.IsSuperAdmin) // { // var GridData = base.GetPageData(options); // pageGridData = new PageGridData() // { // Rows = options.Order?.ToLower() == "asc" ? GridData.Rows.OrderBy(x => x.Role_Id).ToList() : GridData.Rows, // Total = GridData.Total // }; // return pageGridData; // } // string where = ValidatePageOptions(options); // var a = BaseDal.Db.Queryable().Where(x => roleIds.Contains(x.Role_Id)).Where(where); // int total = 0; // pageGridData = new PageGridData() // { // Rows = BaseDal.Db.Queryable().Where(x => roleIds.Contains(x.Role_Id)).Where(where).ToPageList(options.Page, options.Rows), // Total = total // }; // return pageGridData; //} public WebResponseContent Login(LoginInfo loginInfo) { WebResponseContent content = new WebResponseContent(); try { //BaseDal.QueryFirst(x => x.UserName == loginInfo.UserName); string msg = string.Empty; #region 临时使用 try { loginInfo.Password = loginInfo.Password.EncryptDES(AppSecret.User); } catch { } #endregion UserInfo user = BaseDal.GetUserInfo(loginInfo.UserName, loginInfo.Password); if (user != null) { object obj = _menuService.GetMenuActionList(user.RoleId); #region 判断当前用户是否启用 if (BaseDal.QueryFirst(x => x.User_Id == user.UserId, s => s.Enable) != 1) throw new Exception($"账号{user.UserName}禁止使用,请联系管理员"); #endregion string token = JwtHelper.IssueJwt(new TokenModelJwt() { UserId = user.UserId, RoleId = user.RoleId, UserName = user.UserName, TenantId = user.TenantId, }); _cacheService.AddOrUpdate(user.UserId.ToString(), token); content = WebResponseContent.Instance.OK(data: new { token, userName = user.UserTrueName, img = user.HeadImageUrl }); } else { content = WebResponseContent.Instance.Error("账号或密码错误"); } } catch (Exception ex) { content = WebResponseContent.Instance.Error(ex.Message); } return content; } public override WebResponseContent UpdateData(SaveModel saveModel) { //var User1 = JsonConvert.DeserializeObject(JsonConvert.SerializeObject(GetCurrentUserInfo().Data)); var User = JsonConvert.DeserializeObject(GetCurrentUserInfo().Data.ToJson()); #region 只能修改比当前用户角色等级低的用户 int userId = saveModel.MainData[nameof(Sys_User.User_Id).FirstLetterToLower()].ObjToInt(); int RoleId = saveModel.MainData[nameof(Sys_User.Role_Id).FirstLetterToLower()].ObjToInt(); var user = BaseDal.QueryFirst(x => x.User_Id == userId); if (User.User_Id == user.User_Id && User.Role_Id != RoleId) return WebResponseContent.Instance.Error("不可修改自己的角色"); if (User.User_Id != user.User_Id && User.Role_Id >= RoleId) return WebResponseContent.Instance.Error("权限等级不足"); if (User.Role_Id > user.Role_Id || User.Role_Id == user.Role_Id && User.User_Id != userId) return WebResponseContent.Instance.Error("暂无修改权限"); //if (User.User_Id != userId) return WebResponseContent.Instance.Error("暂无修改权限");只限当前用户修改 #endregion saveModel.MainData[nameof(Sys_User.UserPwd).FirstLetterToLower()] = User.UserPwd; //saveModel.MainData[nameof(Sys_User.UserPwd).FirstLetterToLower()] = App.User.TenantId; UpdateIgnoreColOnExecute = x => { return new List { nameof(Sys_User.UserPwd), nameof(Sys_User.TenantId) }; }; return base.UpdateData(saveModel); } public override WebResponseContent AddData(SaveModel saveModel) { string pwd = "123456"; string uesrName = saveModel.MainData[nameof(Sys_User.UserName).FirstLetterToLower()].ToString(); saveModel.MainData[nameof(Sys_User.UserPwd).FirstLetterToLower()] = pwd.EncryptDES(AppSecret.User); WebResponseContent content = base.AddData(saveModel); if (content.Status) { return WebResponseContent.Instance.OK($"用户新建成功.帐号{uesrName}密码{pwd}"); } else { return content; } } /// /// 个人中心获取当前用户信息 /// /// public WebResponseContent GetCurrentUserInfo() { var data = BaseDal.QueryFirst(x => x.User_Id == App.User.UserId, s => new { s.UserName, s.Role_Id, s.User_Id, s.UserPwd, s.UserTrueName, s.Address, s.PhoneNo, s.Email, s.Remark, s.Gender, s.RoleName, s.HeadImageUrl, s.CreateDate }); return WebResponseContent.Instance.OK(null, data); } /// /// 修改密码 /// /// /// public WebResponseContent ModifyPwd(string oldPwd, string newPwd, string userName) { WebResponseContent content = WebResponseContent.Instance; oldPwd = oldPwd?.Trim(); newPwd = newPwd?.Trim(); string message = ""; try { if (string.IsNullOrEmpty(oldPwd)) return WebResponseContent.Instance.Error("旧密码不能为空"); if (string.IsNullOrEmpty(newPwd)) return WebResponseContent.Instance.Error("新密码不能为空"); if (newPwd.Length < 6) return WebResponseContent.Instance.Error("密码不能少于6位"); //int userId = App.User.UserId; //string userCurrentPwd = BaseDal.QueryFirst(x => x.User_Id == userId, s => s.UserPwd); var User = JsonConvert.DeserializeObject(GetCurrentUserInfo().Data.ToJson()); if (User.UserName != userName) return WebResponseContent.Instance.Error($"非本人不可修改密码"); string _oldPwd = oldPwd.EncryptDES(AppSecret.User); if (_oldPwd != User.UserPwd) return WebResponseContent.Instance.Error("旧密码不正确"); string _newPwd = newPwd.EncryptDES(AppSecret.User); if (User.UserPwd == _newPwd) return WebResponseContent.Instance.Error("新密码不能与旧密码相同"); BaseDal.UpdateData(new Sys_User { User_Id = User.User_Id, UserPwd = _newPwd, LastModifyPwdDate = DateTime.Now }, new List { nameof(Sys_User.LastModifyPwdDate), nameof(Sys_User.UserPwd) }); content = WebResponseContent.Instance.OK("密码修改成功"); } catch (Exception ex) { message = ex.Message; content = WebResponseContent.Instance.Error("服务器了点问题,请稍后再试"); } return content; } } }