/// <summary> /// 授予角色的权限 /// </summary> /// <param name="userInfo">用户</param> /// <param name="roleId">角色主键</param> /// <param name="grantPermissionId">授予权限数组</param> /// <returns>数据主键</returns> public string GrantRolePermissionById(BaseUserInfo userInfo, string roleId, string grantPermissionId) { var result = string.Empty; var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod()); ServiceUtil.ProcessUserCenterReadDb(userInfo, parameter, (dbHelper) => { var manager = new BasePermissionManager(dbHelper, userInfo); // 小心异常,检查一下参数的有效性 if (grantPermissionId != null) { result = manager.GrantRole(userInfo.SystemCode, roleId, grantPermissionId); } }); return(result); }
/// <summary> /// 授予角色的权限 /// </summary> /// <param name="userInfo">用户</param> /// <param name="roleIds">角色主键数组</param> /// <param name="grantPermissionIds">授予权限数组</param> /// <returns>影响的行数</returns> public int GrantRolePermissions(BaseUserInfo userInfo, string[] roleIds, string[] grantPermissionIds) { var result = 0; var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod()); ServiceUtil.ProcessUserCenterWriteDb(userInfo, parameter, (dbHelper) => { var tableName = userInfo.SystemCode + "Permission"; var manager = new BasePermissionManager(dbHelper, userInfo, tableName); // 小心异常,检查一下参数的有效性 if (roleIds != null && grantPermissionIds != null) { result += manager.GrantRole(userInfo.SystemCode, roleIds, grantPermissionIds); } }); return(result); }
/// <summary> /// 给角色权限 /// </summary> /// <param name="userInfo">用户</param> /// <param name="roleName">角色名</param> /// <param name="permissionCode">权限编号</param> /// <returns>主键</returns> public string GrantRolePermission(BaseUserInfo userInfo, string roleName, string permissionCode) { var result = string.Empty; var parameter = ServiceInfo.Create(userInfo, MethodBase.GetCurrentMethod()); ServiceUtil.ProcessUserCenterWriteDb(userInfo, parameter, (dbHelper) => { var roleId = BaseRoleManager.GetIdByCodeByCache(userInfo.SystemCode, roleName); var permissionId = new BaseModuleManager().GetIdByCodeByCache(userInfo.SystemCode, permissionCode); if (!string.IsNullOrEmpty(roleId) && !string.IsNullOrEmpty(permissionId)) { var rolePermissionManager = new BasePermissionManager(dbHelper, userInfo); result = rolePermissionManager.GrantRole(userInfo.SystemCode, roleId, permissionId); } }); return(result); }