/// <summary> /// 清除角色用户关联 /// </summary> /// <param name="userInfo">用户</param> /// <param name="roleId">角色主键</param> /// <returns>影响行数</returns> public int ClearRoleUser(BaseUserInfo userInfo, string roleId) { var result = 0; var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod()); ServiceUtil.ProcessUserCenterWriteDb(userInfo, parameter, (dbHelper) => { var manager = new BaseUserManager(dbHelper, userInfo); result = manager.ClearUser(userInfo.SystemCode, roleId); }); return(result); }
/// <summary> /// 清除角色用户关联 /// </summary> /// <param name="userInfo">用户</param> /// <param name="roleId">角色主键</param> /// <returns>影响行数</returns> public int ClearRoleUser(BaseUserInfo userInfo, string roleId) { // 写入调试信息 #if (DEBUG) int milliStart = BaseBusinessLogic.StartDebug(userInfo, MethodBase.GetCurrentMethod()); #endif // 加强安全验证防止未授权匿名调用 #if (!DEBUG) LogOnService.UserIsLogOn(userInfo); #endif int returnValue = 0; using (IDbHelper dbHelper = DbHelperFactory.GetHelper(BaseSystemInfo.UserCenterDbType)) { try { dbHelper.Open(UserCenterDbConnection); string tableName = BaseUserRoleEntity.TableName; if (!string.IsNullOrEmpty(BaseSystemInfo.SystemCode)) { tableName = BaseSystemInfo.SystemCode + "UserRole"; } BaseUserManager userManager = new BaseUserManager(dbHelper, userInfo, tableName); returnValue = userManager.ClearUser(roleId); BaseLogManager.Instance.Add(dbHelper, userInfo, serviceName, AppMessage.RoleService_ClearRoleUser, MethodBase.GetCurrentMethod()); } catch (Exception ex) { BaseExceptionManager.LogException(dbHelper, userInfo, ex); throw ex; } finally { dbHelper.Close(); } } // 写入调试信息 #if (DEBUG) BaseBusinessLogic.EndDebug(MethodBase.GetCurrentMethod(), milliStart); #endif return(returnValue); }
/// <summary> /// 设置角色中的用户 /// </summary> /// <param name="userInfo">用户</param> /// <param name="roleId">角色</param> /// <param name="userIds">用户主键数组</param> /// <returns>影响行数</returns> public int SetUsersToRole(BaseUserInfo userInfo, string roleId, string[] userIds) { var result = 0; var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod()); ServiceUtil.ProcessUserCenterWriteDb(userInfo, parameter, (dbHelper) => { var manager = new BaseUserManager(dbHelper, userInfo); result = manager.ClearUser(userInfo.SystemCode, roleId); // 小心异常,检查一下参数的有效性 if (userIds != null) { result += manager.AddToRole(userInfo.SystemCode, userIds, new string[] { roleId }); } }); return(result); }
/// <summary> /// 清除角色权限 /// /// 1.清除角色的用户归属。 /// 2.清除角色的模块权限。 /// 3.清除角色的操作权限。 /// </summary> /// <param name="userInfo">用户</param> /// <param name="id">主键</param> /// <returns>数据表</returns> public int ClearRolePermission(BaseUserInfo userInfo, string id) { var result = 0; var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod()); ServiceUtil.ProcessUserCenterWriteDb(userInfo, parameter, (dbHelper) => { var userManager = new BaseUserManager(dbHelper, userInfo); result += userManager.ClearUser(userInfo.SystemCode, id); var rolePermissionManager = new BasePermissionManager(dbHelper, userInfo); result += rolePermissionManager.RevokeRoleAll(userInfo.SystemCode, id); var roleScopeManager = new BaseRoleScopeManager(dbHelper, userInfo); result += roleScopeManager.RevokeAll(userInfo.SystemCode, id); }); return(result); }