Esempio n. 1
0
        /// <summary>
        /// 修改用户
        /// </summary>
        /// <param name="user"></param>
        /// <param name="password"></param>
        /// <returns></returns>
        public bool UpdateUser(int operater, TUser user, string password, int[] roleIds)
        {
            if (!string.IsNullOrWhiteSpace(password))
            {
                user.PasswordHash = _userManager.PasswordHasher.HashPassword(password);
            }

            var result = _userManager.Update <TUser, int>(user);

            if (result.Succeeded)
            {
                List <SysUserRole> userRoleList = _db.SysUserRole.Where(m => m.UserId == user.Id).ToList();

                foreach (var userRole in userRoleList)
                {
                    _db.SysUserRole.Remove(userRole);
                }

                if (roleIds != null)
                {
                    if (roleIds.Length > 0)
                    {
                        foreach (int roleId in roleIds)
                        {
                            if (roleId != 0)
                            {
                                _db.SysUserRole.Add(new SysUserRole {
                                    UserId = user.Id, RoleId = roleId
                                });
                            }
                        }
                    }
                }
                _db.SaveChanges();

                AddOperateHistory(operater, Enumeration.OperateType.Update, user.Id, string.Format("修改用户{0}(ID:{1})", user.UserName, user.Id));
            }

            return(result.Succeeded);
        }
Esempio n. 2
0
        /// <summary>
        /// 修改用户
        /// </summary>
        /// <param name="user"></param>
        /// <param name="password"></param>
        /// <returns></returns>
        public bool UpdateUser(TUser user, string password, params int[] roleIds)
        {
            if (!string.IsNullOrWhiteSpace(password))
            {
                user.PasswordHash = _userManager.PasswordHasher.HashPassword(password);
            }

            var result = _userManager.Update <TUser, int>(user);

            if (result.Succeeded)
            {
                List <SysUserRole> userRoleList = _db.SysUserRole.Where(m => m.UserId == user.Id).ToList();

                foreach (var userRole in userRoleList)
                {
                    _db.SysUserRole.Remove(userRole);
                }

                if (roleIds != null)
                {
                    if (roleIds.Length > 0)
                    {
                        foreach (int roleId in roleIds)
                        {
                            if (roleId != 0)
                            {
                                _db.SysUserRole.Add(new SysUserRole {
                                    UserId = user.Id, RoleId = roleId
                                });
                            }
                        }
                    }
                }
                _db.SaveChanges();
            }


            return(result.Succeeded);
        }