Browse Source

🎉 2.0.4.RELEASE

test
smallchill 6 years ago
parent
commit
df745448f2
  1. 2
      blade-auth/pom.xml
  2. 2
      blade-common/pom.xml
  3. 2
      blade-gateway/pom.xml
  4. 2
      blade-ops-api/blade-flow-api/pom.xml
  5. 4
      blade-ops-api/pom.xml
  6. 2
      blade-ops/blade-admin/pom.xml
  7. 2
      blade-ops/blade-develop/pom.xml
  8. 2
      blade-ops/blade-flow-design/pom.xml
  9. 2
      blade-ops/blade-flow/pom.xml
  10. 2
      blade-ops/blade-log/pom.xml
  11. 2
      blade-ops/blade-resource/pom.xml
  12. 4
      blade-ops/pom.xml
  13. 2
      blade-service-api/blade-desk-api/pom.xml
  14. 2
      blade-service-api/blade-dict-api/pom.xml
  15. 2
      blade-service-api/blade-system-api/pom.xml
  16. 82
      blade-service-api/blade-system-api/src/main/java/org/springblade/system/entity/DataScope.java
  17. 20
      blade-service-api/blade-system-api/src/main/java/org/springblade/system/entity/Dept.java
  18. 65
      blade-service-api/blade-system-api/src/main/java/org/springblade/system/entity/RoleScope.java
  19. 35
      blade-service-api/blade-system-api/src/main/java/org/springblade/system/vo/CheckedTreeVO.java
  20. 7
      blade-service-api/blade-system-api/src/main/java/org/springblade/system/vo/DeptVO.java
  21. 35
      blade-service-api/blade-system-api/src/main/java/org/springblade/system/vo/GrantTreeVO.java
  22. 2
      blade-service-api/blade-user-api/pom.xml
  23. 4
      blade-service-api/pom.xml
  24. 2
      blade-service/blade-desk/pom.xml
  25. 2
      blade-service/blade-system/pom.xml
  26. 113
      blade-service/blade-system/src/main/java/org/springblade/system/controller/DataScopeController.java
  27. 2
      blade-service/blade-system/src/main/java/org/springblade/system/controller/DeptController.java
  28. 16
      blade-service/blade-system/src/main/java/org/springblade/system/controller/MenuController.java
  29. 11
      blade-service/blade-system/src/main/java/org/springblade/system/controller/RoleController.java
  30. 30
      blade-service/blade-system/src/main/java/org/springblade/system/mapper/DataScopeMapper.java
  31. 5
      blade-service/blade-system/src/main/java/org/springblade/system/mapper/DataScopeMapper.xml
  32. 2
      blade-service/blade-system/src/main/java/org/springblade/system/mapper/DeptMapper.xml
  33. 17
      blade-service/blade-system/src/main/java/org/springblade/system/mapper/MenuMapper.java
  34. 206
      blade-service/blade-system/src/main/java/org/springblade/system/mapper/MenuMapper.xml
  35. 29
      blade-service/blade-system/src/main/java/org/springblade/system/mapper/RoleScopeMapper.java
  36. 12
      blade-service/blade-system/src/main/java/org/springblade/system/mapper/RoleScopeMapper.xml
  37. 30
      blade-service/blade-system/src/main/java/org/springblade/system/service/IDataScopeService.java
  38. 8
      blade-service/blade-system/src/main/java/org/springblade/system/service/IDeptService.java
  39. 16
      blade-service/blade-system/src/main/java/org/springblade/system/service/IMenuService.java
  40. 29
      blade-service/blade-system/src/main/java/org/springblade/system/service/IRoleScopeService.java
  41. 2
      blade-service/blade-system/src/main/java/org/springblade/system/service/IRoleService.java
  42. 34
      blade-service/blade-system/src/main/java/org/springblade/system/service/impl/DataScopeServiceImpl.java
  43. 11
      blade-service/blade-system/src/main/java/org/springblade/system/service/impl/DeptServiceImpl.java
  44. 20
      blade-service/blade-system/src/main/java/org/springblade/system/service/impl/MenuServiceImpl.java
  45. 33
      blade-service/blade-system/src/main/java/org/springblade/system/service/impl/RoleScopeServiceImpl.java
  46. 24
      blade-service/blade-system/src/main/java/org/springblade/system/service/impl/RoleServiceImpl.java
  47. 11
      blade-service/blade-system/src/main/java/org/springblade/system/wrapper/DeptWrapper.java
  48. 2
      blade-service/blade-user/pom.xml
  49. 4
      blade-service/pom.xml
  50. 20
      doc/sql/bladex-datascope-update.sql
  51. 8
      pom.xml
  52. 2
      script/docker/.env

2
blade-auth/pom.xml

@ -8,7 +8,7 @@
<parent> <parent>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<artifactId>blade-auth</artifactId> <artifactId>blade-auth</artifactId>

2
blade-common/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-gateway/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-ops-api/blade-flow-api/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-ops-api</artifactId> <artifactId>blade-ops-api</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

4
blade-ops-api/pom.xml

@ -5,13 +5,13 @@
<parent> <parent>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>blade-ops-api</artifactId> <artifactId>blade-ops-api</artifactId>
<name>${project.artifactId}</name> <name>${project.artifactId}</name>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
<packaging>pom</packaging> <packaging>pom</packaging>
<description>BladeX 微服务API集合</description> <description>BladeX 微服务API集合</description>

2
blade-ops/blade-admin/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-ops</artifactId> <artifactId>blade-ops</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-ops/blade-develop/pom.xml

@ -6,7 +6,7 @@
<parent> <parent>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<artifactId>blade-ops</artifactId> <artifactId>blade-ops</artifactId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-ops/blade-flow-design/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-ops</artifactId> <artifactId>blade-ops</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-ops/blade-flow/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-ops</artifactId> <artifactId>blade-ops</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-ops/blade-log/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-ops</artifactId> <artifactId>blade-ops</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-ops/blade-resource/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-ops</artifactId> <artifactId>blade-ops</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

4
blade-ops/pom.xml

@ -5,13 +5,13 @@
<parent> <parent>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>blade-ops</artifactId> <artifactId>blade-ops</artifactId>
<name>${project.artifactId}</name> <name>${project.artifactId}</name>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
<packaging>pom</packaging> <packaging>pom</packaging>
<modules> <modules>

2
blade-service-api/blade-desk-api/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-service-api</artifactId> <artifactId>blade-service-api</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-service-api/blade-dict-api/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-service-api</artifactId> <artifactId>blade-service-api</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-service-api/blade-system-api/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-service-api</artifactId> <artifactId>blade-service-api</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

82
blade-service-api/blade-system-api/src/main/java/org/springblade/system/entity/DataScope.java

@ -0,0 +1,82 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.entity;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import org.springblade.core.mp.base.BaseEntity;
/**
* 实体类
*
* @author BladeX
* @since 2019-06-23
*/
@Data
@TableName("blade_data_scope")
@EqualsAndHashCode(callSuper = true)
@ApiModel(value = "DataScope对象", description = "DataScope对象")
public class DataScope extends BaseEntity {
private static final long serialVersionUID = 1L;
/**
* 菜单主键
*/
@ApiModelProperty(value = "菜单主键")
private Long menuId;
/**
* 资源编号
*/
@ApiModelProperty(value = "资源编号")
private String resourceCode;
/**
* 数据权限名称
*/
@ApiModelProperty(value = "数据权限名称")
private String scopeName;
/**
* 数据权限类名
*/
@ApiModelProperty(value = "数据权限类名")
private String scopeClass;
/**
* 数据权限字段
*/
@ApiModelProperty(value = "数据权限字段")
private String scopeColumn;
/**
* 数据权限类型
*/
@ApiModelProperty(value = "数据权限类型")
private Integer scopeType;
/**
* 数据权限值域
*/
@ApiModelProperty(value = "数据权限值域")
private String scopeValue;
/**
* 数据权限备注
*/
@ApiModelProperty(value = "数据权限备注")
private String remark;
}

20
blade-service-api/blade-system-api/src/main/java/org/springblade/system/entity/Dept.java

@ -62,17 +62,29 @@ public class Dept implements Serializable {
private Long parentId; private Long parentId;
/** /**
* 部门 * 机构
*/ */
@ApiModelProperty(value = "部门名") @ApiModelProperty(value = "机构名")
private String deptName; private String deptName;
/** /**
* 部门全称 * 机构全称
*/ */
@ApiModelProperty(value = "部门全称") @ApiModelProperty(value = "机构全称")
private String fullName; private String fullName;
/**
* 租级机构主键
*/
@ApiModelProperty(value = "祖级机构主键")
private String ancestors;
/**
* 机构类型
*/
@ApiModelProperty(value = "机构类型")
private Integer deptCategory;
/** /**
* 排序 * 排序
*/ */

65
blade-service-api/blade-system-api/src/main/java/org/springblade/system/entity/RoleScope.java

@ -0,0 +1,65 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.entity;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import java.io.Serializable;
/**
* 实体类
*
* @author Chill
*/
@Data
@TableName("blade_role_scope")
@ApiModel(value = "RoleScope对象", description = "RoleScope对象")
public class RoleScope implements Serializable {
private static final long serialVersionUID = 1L;
/**
* 主键
*/
@JsonSerialize(using = ToStringSerializer.class)
@ApiModelProperty(value = "主键")
@TableId(value = "id", type = IdType.ID_WORKER)
private Long id;
/**
* 数据权限id
*/
@JsonSerialize(using = ToStringSerializer.class)
@ApiModelProperty(value = "数据权限id")
private Long scopeId;
/**
* 角色id
*/
@JsonSerialize(using = ToStringSerializer.class)
@ApiModelProperty(value = "角色id")
private Long roleId;
}

35
blade-service-api/blade-system-api/src/main/java/org/springblade/system/vo/CheckedTreeVO.java

@ -0,0 +1,35 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.vo;
import lombok.Data;
import java.util.List;
/**
* CheckedTreeVO
*
* @author Chill
*/
@Data
public class CheckedTreeVO {
private List<String> menu;
private List<String> scope;
}

7
blade-service-api/blade-system-api/src/main/java/org/springblade/system/vo/DeptVO.java

@ -66,8 +66,13 @@ public class DeptVO extends Dept implements INode {
} }
/** /**
* 上级部门 * 上级机构
*/ */
private String parentName; private String parentName;
/**
* 机构类型名称
*/
private String deptCategoryName;
} }

35
blade-service-api/blade-system-api/src/main/java/org/springblade/system/vo/GrantTreeVO.java

@ -0,0 +1,35 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.vo;
import lombok.Data;
import java.util.List;
/**
* GrantTreeVO
*
* @author Chill
*/
@Data
public class GrantTreeVO {
private List<MenuVO> menu;
private List<MenuVO> scope;
}

2
blade-service-api/blade-user-api/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-service-api</artifactId> <artifactId>blade-service-api</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

4
blade-service-api/pom.xml

@ -5,13 +5,13 @@
<parent> <parent>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>blade-service-api</artifactId> <artifactId>blade-service-api</artifactId>
<name>${project.artifactId}</name> <name>${project.artifactId}</name>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
<packaging>pom</packaging> <packaging>pom</packaging>
<description>BladeX 微服务API集合</description> <description>BladeX 微服务API集合</description>

2
blade-service/blade-desk/pom.xml

@ -6,7 +6,7 @@
<parent> <parent>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<artifactId>blade-service</artifactId> <artifactId>blade-service</artifactId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

2
blade-service/blade-system/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-service</artifactId> <artifactId>blade-service</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

113
blade-service/blade-system/src/main/java/org/springblade/system/controller/DataScopeController.java

@ -0,0 +1,113 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.controller;
import com.baomidou.mybatisplus.core.metadata.IPage;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import lombok.AllArgsConstructor;
import org.springblade.core.boot.ctrl.BladeController;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.utils.Func;
import org.springblade.system.entity.DataScope;
import org.springblade.system.service.IDataScopeService;
import org.springframework.cache.annotation.CacheEvict;
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
import static org.springblade.core.cache.constant.CacheConstant.SYS_CACHE;
/**
* 数据权限控制器
*
* @author BladeX
* @since 2019-06-23
*/
@RestController
@AllArgsConstructor
@RequestMapping("data-scope")
@Api(value = "数据权限", tags = "接口")
public class DataScopeController extends BladeController {
private IDataScopeService dataScopeService;
/**
* 详情
*/
@GetMapping("/detail")
@ApiOperation(value = "详情", notes = "传入dataScope", position = 1)
public R<DataScope> detail(DataScope dataScope) {
DataScope detail = dataScopeService.getOne(Condition.getQueryWrapper(dataScope));
return R.data(detail);
}
/**
* 分页
*/
@GetMapping("/list")
@ApiOperation(value = "分页", notes = "传入dataScope", position = 2)
public R<IPage<DataScope>> list(DataScope dataScope, Query query) {
IPage<DataScope> pages = dataScopeService.page(Condition.getPage(query), Condition.getQueryWrapper(dataScope));
return R.data(pages);
}
/**
* 新增
*/
@PostMapping("/save")
@CacheEvict(cacheNames = {SYS_CACHE})
@ApiOperation(value = "新增", notes = "传入dataScope", position = 4)
public R save(@Valid @RequestBody DataScope dataScope) {
return R.status(dataScopeService.save(dataScope));
}
/**
* 修改
*/
@PostMapping("/update")
@CacheEvict(cacheNames = {SYS_CACHE})
@ApiOperation(value = "修改", notes = "传入dataScope", position = 5)
public R update(@Valid @RequestBody DataScope dataScope) {
return R.status(dataScopeService.updateById(dataScope));
}
/**
* 新增或修改
*/
@PostMapping("/submit")
@CacheEvict(cacheNames = {SYS_CACHE})
@ApiOperation(value = "新增或修改", notes = "传入dataScope", position = 6)
public R submit(@Valid @RequestBody DataScope dataScope) {
return R.status(dataScopeService.saveOrUpdate(dataScope));
}
/**
* 删除
*/
@PostMapping("/remove")
@CacheEvict(cacheNames = {SYS_CACHE})
@ApiOperation(value = "逻辑删除", notes = "传入ids", position = 7)
public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
return R.status(dataScopeService.deleteLogic(Func.toLongList(ids)));
}
}

2
blade-service/blade-system/src/main/java/org/springblade/system/controller/DeptController.java

@ -103,7 +103,7 @@ public class DeptController extends BladeController {
if (Func.isEmpty(dept.getId())) { if (Func.isEmpty(dept.getId())) {
dept.setTenantId(user.getTenantId()); dept.setTenantId(user.getTenantId());
} }
return R.status(deptService.saveOrUpdate(dept)); return R.status(deptService.submit(dept));
} }
/** /**

16
blade-service/blade-system/src/main/java/org/springblade/system/controller/MenuController.java

@ -28,6 +28,8 @@ import org.springblade.core.tool.support.Kv;
import org.springblade.core.tool.utils.Func; import org.springblade.core.tool.utils.Func;
import org.springblade.system.entity.Menu; import org.springblade.system.entity.Menu;
import org.springblade.system.service.IMenuService; import org.springblade.system.service.IMenuService;
import org.springblade.system.vo.CheckedTreeVO;
import org.springblade.system.vo.GrantTreeVO;
import org.springblade.system.vo.MenuVO; import org.springblade.system.vo.MenuVO;
import org.springblade.system.wrapper.MenuWrapper; import org.springblade.system.wrapper.MenuWrapper;
import org.springframework.cache.annotation.CacheEvict; import org.springframework.cache.annotation.CacheEvict;
@ -139,8 +141,11 @@ public class MenuController extends BladeController {
*/ */
@GetMapping("/grant-tree") @GetMapping("/grant-tree")
@ApiOperation(value = "权限分配树形结构", notes = "权限分配树形结构", position = 6) @ApiOperation(value = "权限分配树形结构", notes = "权限分配树形结构", position = 6)
public R<List<MenuVO>> grantTree(BladeUser user) { public R<GrantTreeVO> grantTree(BladeUser user) {
return R.data(menuService.grantTree(user)); GrantTreeVO vo = new GrantTreeVO();
vo.setMenu(menuService.grantTree(user));
vo.setScope(menuService.grantScopeTree(user));
return R.data(vo);
} }
/** /**
@ -148,8 +153,11 @@ public class MenuController extends BladeController {
*/ */
@GetMapping("/role-tree-keys") @GetMapping("/role-tree-keys")
@ApiOperation(value = "角色所分配的树", notes = "角色所分配的树", position = 7) @ApiOperation(value = "角色所分配的树", notes = "角色所分配的树", position = 7)
public R<List<String>> roleTreeKeys(String roleIds) { public R<CheckedTreeVO> roleTreeKeys(String roleIds) {
return R.data(menuService.roleTreeKeys(roleIds)); CheckedTreeVO vo = new CheckedTreeVO();
vo.setMenu(menuService.roleTreeKeys(roleIds));
vo.setScope(menuService.scopeTreeKeys(roleIds));
return R.data(vo);
} }
/** /**

11
blade-service/blade-system/src/main/java/org/springblade/system/controller/RoleController.java

@ -116,17 +116,14 @@ public class RoleController extends BladeController {
} }
/** /**
* 设置菜单权限 * 设置角色权限
*
* @param roleIds
* @param menuIds
* @return
*/ */
@PostMapping("/grant") @PostMapping("/grant")
@ApiOperation(value = "权限设置", notes = "传入roleId集合以及menuId集合", position = 6) @ApiOperation(value = "权限设置", notes = "传入roleId集合以及menuId集合", position = 6)
public R grant(@ApiParam(value = "roleId集合", required = true) @RequestParam String roleIds, public R grant(@ApiParam(value = "roleId集合", required = true) @RequestParam String roleIds,
@ApiParam(value = "menuId集合", required = true) @RequestParam String menuIds) { @ApiParam(value = "menuId集合", required = true) @RequestParam String menuIds,
boolean temp = roleService.grant(Func.toLongList(roleIds), Func.toLongList(menuIds)); @ApiParam(value = "scopeId集合") String scopeIds) {
boolean temp = roleService.grant(Func.toLongList(roleIds), Func.toLongList(menuIds), Func.toLongList(scopeIds));
return R.status(temp); return R.status(temp);
} }

30
blade-service/blade-system/src/main/java/org/springblade/system/mapper/DataScopeMapper.java

@ -0,0 +1,30 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.springblade.system.entity.DataScope;
/**
* Mapper 接口
*
* @author BladeX
* @since 2019-06-23
*/
public interface DataScopeMapper extends BaseMapper<DataScope> {
}

5
blade-service/blade-system/src/main/java/org/springblade/system/mapper/DataScopeMapper.xml

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.springblade.system.mapper.DataScopeMapper">
</mapper>

2
blade-service/blade-system/src/main/java/org/springblade/system/mapper/DeptMapper.xml

@ -8,6 +8,8 @@
<result column="parent_id" property="parentId"/> <result column="parent_id" property="parentId"/>
<result column="dept_name" property="deptName"/> <result column="dept_name" property="deptName"/>
<result column="full_name" property="fullName"/> <result column="full_name" property="fullName"/>
<result column="ancestors" property="ancestors"/>
<result column="dept_category" property="deptCategory"/>
<result column="sort" property="sort"/> <result column="sort" property="sort"/>
<result column="remark" property="remark"/> <result column="remark" property="remark"/>
<result column="is_deleted" property="isDeleted"/> <result column="is_deleted" property="isDeleted"/>

17
blade-service/blade-system/src/main/java/org/springblade/system/mapper/MenuMapper.java

@ -24,6 +24,7 @@ import org.springblade.system.vo.MenuVO;
import java.util.List; import java.util.List;
/** /**
* Mapper 接口 * Mapper 接口
* *
@ -62,6 +63,21 @@ public interface MenuMapper extends BaseMapper<Menu> {
*/ */
List<MenuVO> grantTreeByRole(List<Long> roleId); List<MenuVO> grantTreeByRole(List<Long> roleId);
/**
* 数据权限授权树形结构
*
* @return
*/
List<MenuVO> grantScopeTree();
/**
* 数据权限授权树形结构
*
* @param roleId
* @return
*/
List<MenuVO> grantScopeTreeByRole(List<Long> roleId);
/** /**
* 所有菜单 * 所有菜单
* *
@ -95,7 +111,6 @@ public interface MenuMapper extends BaseMapper<Menu> {
/** /**
* 获取配置的角色权限 * 获取配置的角色权限
*
* @param roleIds * @param roleIds
* @return * @return
*/ */

206
blade-service/blade-system/src/main/java/org/springblade/system/mapper/MenuMapper.xml

@ -30,7 +30,7 @@
<!-- 通用查询结果列 --> <!-- 通用查询结果列 -->
<sql id="baseColumnList"> <sql id="baseColumnList">
select select
id, code, parent_id, name, alias, path, source, sort, category, action, is_open, remark, is_deleted id, code, parent_id, name, alias, path, source, sort, category, action, is_open, remark, is_deleted
</sql> </sql>
<select id="selectMenuPage" resultMap="menuResultMap"> <select id="selectMenuPage" resultMap="menuResultMap">
@ -54,58 +54,58 @@
<select id="routes" resultMap="menuResultMap"> <select id="routes" resultMap="menuResultMap">
SELECT SELECT
* *
FROM FROM
blade_menu blade_menu
WHERE WHERE
is_deleted = 0 and category = 1 is_deleted = 0 and category = 1
and id IN ( SELECT menu_id FROM blade_role_menu WHERE role_id IN and id IN ( SELECT menu_id FROM blade_role_menu WHERE role_id IN
<foreach collection="list" index="index" item="item" open="(" separator="," close=")"> <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item} #{item}
</foreach> ) </foreach> )
</select> </select>
<select id="buttons" resultMap="menuResultMap"> <select id="buttons" resultMap="menuResultMap">
SELECT SELECT
id, id,
parent_id, parent_id,
`code`, `code`,
`name`, `name`,
alias, alias,
path, path,
source, source,
action, action,
sort sort
FROM FROM
blade_menu blade_menu
WHERE WHERE
is_deleted = 0 and id IN ( is_deleted = 0 and id IN (
SELECT parent_id FROM blade_menu SELECT parent_id FROM blade_menu
WHERE ( category = 2 AND id IN ( SELECT menu_id FROM blade_role_menu WHERE role_id IN WHERE ( category = 2 AND id IN ( SELECT menu_id FROM blade_role_menu WHERE role_id IN
<foreach collection="list" index="index" item="item" open="(" separator="," close=")"> <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item} #{item}
</foreach> </foreach>
) ) ) ) ) )
UNION ALL UNION ALL
SELECT SELECT
id, id,
parent_id, parent_id,
`code`, `code`,
`name`, `name`,
alias, alias,
path, path,
source, source,
action, action,
sort sort
FROM FROM
blade_menu blade_menu
WHERE WHERE
is_deleted = 0 and category = 2 AND id IN ( SELECT menu_id FROM blade_role_menu WHERE role_id IN is_deleted = 0 and category = 2 AND id IN ( SELECT menu_id FROM blade_role_menu WHERE role_id IN
<foreach collection="list" index="index" item="item" open="(" separator="," close=")"> <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item} #{item}
</foreach>) </foreach>)
</select> </select>
<select id="grantTree" resultMap="treeNodeResultMap"> <select id="grantTree" resultMap="treeNodeResultMap">
@ -119,29 +119,123 @@
#{item} #{item}
</foreach> ) </foreach> )
or id in ( or id in (
select parent_id from blade_menu where is_deleted = 0 select parent_id from blade_menu where is_deleted = 0
and id in ( select menu_id from blade_role_menu where role_id in and id in ( select menu_id from blade_role_menu where role_id in
<foreach collection="list" index="index" item="item" open="(" separator="," close=")"> <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item} #{item}
</foreach> ) </foreach> )
) )
order by sort order by sort
</select> </select>
<select id="authRoutes" resultType="org.springblade.system.dto.MenuDTO"> <select id="grantScopeTree" resultMap="treeNodeResultMap">
SELECT
*
FROM
(
SELECT
id,
parent_id,
NAME AS title,
id AS 'value',
id AS 'key'
FROM
blade_menu
WHERE
category = 1
AND is_deleted = 0
AND id IN ( SELECT menu_id FROM blade_data_scope WHERE is_deleted = 0 AND menu_id IS NOT NULL )
ORDER BY
sort
) menu
UNION ALL
SELECT SELECT
GROUP_CONCAT(r.role_alias) as alias, id,
m.path menu_id AS parent_id,
scope_name AS title,
id AS 'value',
id AS 'key'
FROM FROM
blade_role_menu rm blade_data_scope
LEFT JOIN blade_menu m ON rm.menu_id = m.id
LEFT JOIN blade_role r ON rm.role_id = r.id
WHERE WHERE
rm.role_id IN is_deleted = 0
<foreach collection="list" index="index" item="item" open="(" separator="," close=")"> AND menu_id IS NOT NULL
#{item} </select>
</foreach>
AND m.path IS NOT NULL and m.is_deleted = 0 <select id="grantScopeTreeByRole" resultMap="treeNodeResultMap">
SELECT
*
FROM
(
SELECT
id,
parent_id,
NAME AS title,
id AS 'value',
id AS 'key'
FROM
blade_menu
WHERE
category = 1
AND is_deleted = 0
AND id IN ( SELECT menu_id FROM blade_data_scope WHERE is_deleted = 0 AND menu_id IS NOT NULL )
AND id IN ( select menu_id from blade_role_menu where role_id in
<foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach> )
OR id IN (
select parent_id from blade_menu where is_deleted = 0
and id in ( select menu_id from blade_role_menu where role_id in
<foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach> )
)
ORDER BY
sort
) menu
UNION ALL
SELECT
id,
menu_id AS parent_id,
scope_name AS title,
id AS 'value',
id AS 'key'
FROM
blade_data_scope
WHERE
is_deleted = 0
AND menu_id IN ( select menu_id from blade_role_menu where role_id in
<foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach> )
OR menu_id IN (
select parent_id from blade_menu where is_deleted = 0
and id in ( select menu_id from blade_role_menu where role_id in
<foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach> )
)
AND menu_id IS NOT NULL
</select>
<select id="authRoutes" resultType="org.springblade.modules.system.dto.MenuDTO">
SELECT
GROUP_CONCAT(r.role_alias) as alias,
m.path
FROM
blade_role_menu rm
LEFT JOIN blade_menu m ON rm.menu_id = m.id
LEFT JOIN blade_role r ON rm.role_id = r.id
WHERE
rm.role_id IN
<foreach collection="list" index="index" item="item" open="(" separator="," close=")">
#{item}
</foreach>
AND m.path IS NOT NULL and m.is_deleted = 0
GROUP BY m.path GROUP BY m.path
</select> </select>

29
blade-service/blade-system/src/main/java/org/springblade/system/mapper/RoleScopeMapper.java

@ -0,0 +1,29 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.springblade.system.entity.RoleScope;
/**
* Mapper 接口
*
* @author Chill
*/
public interface RoleScopeMapper extends BaseMapper<RoleScope> {
}

12
blade-service/blade-system/src/main/java/org/springblade/system/mapper/RoleScopeMapper.xml

@ -0,0 +1,12 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.springblade.modules.system.mapper.RoleScopeMapper">
<!-- 通用查询映射结果 -->
<resultMap id="roleMenuResultMap" type="org.springblade.system.entity.RoleScope">
<id column="id" property="id"/>
<result column="scope_id" property="scopeId"/>
<result column="role_id" property="roleId"/>
</resultMap>
</mapper>

30
blade-service/blade-system/src/main/java/org/springblade/system/service/IDataScopeService.java

@ -0,0 +1,30 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.service;
import org.springblade.core.mp.base.BaseService;
import org.springblade.system.entity.DataScope;
/**
* 服务类
*
* @author BladeX
* @since 2019-06-23
*/
public interface IDataScopeService extends BaseService<DataScope> {
}

8
blade-service/blade-system/src/main/java/org/springblade/system/service/IDeptService.java

@ -63,4 +63,12 @@ public interface IDeptService extends IService<Dept> {
*/ */
boolean removeDept(String ids); boolean removeDept(String ids);
/**
* 提交
*
* @param dept
* @return
*/
boolean submit(Dept dept);
} }

16
blade-service/blade-system/src/main/java/org/springblade/system/service/IMenuService.java

@ -72,6 +72,14 @@ public interface IMenuService extends IService<Menu> {
*/ */
List<MenuVO> grantTree(BladeUser user); List<MenuVO> grantTree(BladeUser user);
/**
* 数据权限授权树形结构
*
* @param user
* @return
*/
List<MenuVO> grantScopeTree(BladeUser user);
/** /**
* 默认选中节点 * 默认选中节点
* *
@ -80,6 +88,14 @@ public interface IMenuService extends IService<Menu> {
*/ */
List<String> roleTreeKeys(String roleIds); List<String> roleTreeKeys(String roleIds);
/**
* 默认选中节点
*
* @param roleIds
* @return
*/
List<String> scopeTreeKeys(String roleIds);
/** /**
* 获取配置的角色权限 * 获取配置的角色权限
* *

29
blade-service/blade-system/src/main/java/org/springblade/system/service/IRoleScopeService.java

@ -0,0 +1,29 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.service;
import com.baomidou.mybatisplus.extension.service.IService;
import org.springblade.system.entity.RoleScope;
/**
* 服务类
*
* @author Chill
*/
public interface IRoleScopeService extends IService<RoleScope> {
}

2
blade-service/blade-system/src/main/java/org/springblade/system/service/IRoleService.java

@ -55,7 +55,7 @@ public interface IRoleService extends IService<Role> {
* @param menuIds 菜单id集合 * @param menuIds 菜单id集合
* @return 是否成功 * @return 是否成功
*/ */
boolean grant(@NotEmpty List<Long> roleIds, @NotEmpty List<Long> menuIds); boolean grant(@NotEmpty List<Long> roleIds, @NotEmpty List<Long> menuIds, List<Long> scopeIds);
/** /**
* 获取角色名 * 获取角色名

34
blade-service/blade-system/src/main/java/org/springblade/system/service/impl/DataScopeServiceImpl.java

@ -0,0 +1,34 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.service.impl;
import org.springblade.core.mp.base.BaseServiceImpl;
import org.springblade.system.entity.DataScope;
import org.springblade.system.mapper.DataScopeMapper;
import org.springblade.system.service.IDataScopeService;
import org.springframework.stereotype.Service;
/**
* 服务实现类
*
* @author BladeX
* @since 2019-06-23
*/
@Service
public class DataScopeServiceImpl extends BaseServiceImpl<DataScopeMapper, DataScope> implements IDataScopeService {
}

11
blade-service/blade-system/src/main/java/org/springblade/system/service/impl/DeptServiceImpl.java

@ -22,6 +22,7 @@ import com.baomidou.mybatisplus.extension.exceptions.ApiException;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springblade.core.tool.node.ForestNodeMerger; import org.springblade.core.tool.node.ForestNodeMerger;
import org.springblade.core.tool.utils.Func; import org.springblade.core.tool.utils.Func;
import org.springblade.core.tool.utils.StringPool;
import org.springblade.system.entity.Dept; import org.springblade.system.entity.Dept;
import org.springblade.system.mapper.DeptMapper; import org.springblade.system.mapper.DeptMapper;
import org.springblade.system.service.IDeptService; import org.springblade.system.service.IDeptService;
@ -62,4 +63,14 @@ public class DeptServiceImpl extends ServiceImpl<DeptMapper, Dept> implements ID
return removeByIds(Func.toLongList(ids)); return removeByIds(Func.toLongList(ids));
} }
@Override
public boolean submit(Dept dept) {
if (dept.getParentId() > 0) {
Dept parent = getById(dept.getParentId());
String ancestors = parent.getAncestors() + StringPool.COMMA + dept.getParentId();
dept.setAncestors(ancestors);
}
return saveOrUpdate(dept);
}
} }

20
blade-service/blade-system/src/main/java/org/springblade/system/service/impl/MenuServiceImpl.java

@ -30,9 +30,11 @@ import org.springblade.core.tool.utils.StringUtil;
import org.springblade.system.dto.MenuDTO; import org.springblade.system.dto.MenuDTO;
import org.springblade.system.entity.Menu; import org.springblade.system.entity.Menu;
import org.springblade.system.entity.RoleMenu; import org.springblade.system.entity.RoleMenu;
import org.springblade.system.entity.RoleScope;
import org.springblade.system.mapper.MenuMapper; import org.springblade.system.mapper.MenuMapper;
import org.springblade.system.service.IMenuService; import org.springblade.system.service.IMenuService;
import org.springblade.system.service.IRoleMenuService; import org.springblade.system.service.IRoleMenuService;
import org.springblade.system.service.IRoleScopeService;
import org.springblade.system.vo.MenuVO; import org.springblade.system.vo.MenuVO;
import org.springblade.system.wrapper.MenuWrapper; import org.springblade.system.wrapper.MenuWrapper;
import org.springframework.cache.annotation.Cacheable; import org.springframework.cache.annotation.Cacheable;
@ -53,6 +55,7 @@ import static org.springblade.core.cache.constant.CacheConstant.MENU_CACHE;
public class MenuServiceImpl extends ServiceImpl<MenuMapper, Menu> implements IMenuService { public class MenuServiceImpl extends ServiceImpl<MenuMapper, Menu> implements IMenuService {
private IRoleMenuService roleMenuService; private IRoleMenuService roleMenuService;
private IRoleScopeService roleScopeService;
@Override @Override
public IPage<MenuVO> selectMenuPage(IPage<MenuVO> page, MenuVO menu) { public IPage<MenuVO> selectMenuPage(IPage<MenuVO> page, MenuVO menu) {
@ -66,6 +69,10 @@ public class MenuServiceImpl extends ServiceImpl<MenuMapper, Menu> implements IM
} }
List<Menu> allMenus = baseMapper.allMenu(); List<Menu> allMenus = baseMapper.allMenu();
List<Menu> roleMenus = baseMapper.roleMenu(Func.toLongList(roleId)); List<Menu> roleMenus = baseMapper.roleMenu(Func.toLongList(roleId));
return buildRoutes(allMenus, roleMenus);
}
private List<MenuVO> buildRoutes(List<Menu> allMenus, List<Menu> roleMenus) {
List<Menu> routes = new LinkedList<>(roleMenus); List<Menu> routes = new LinkedList<>(roleMenus);
roleMenus.forEach(roleMenu -> recursion(allMenus, routes, roleMenu)); roleMenus.forEach(roleMenu -> recursion(allMenus, routes, roleMenu));
routes.sort(Comparator.comparing(Menu::getSort)); routes.sort(Comparator.comparing(Menu::getSort));
@ -74,7 +81,7 @@ public class MenuServiceImpl extends ServiceImpl<MenuMapper, Menu> implements IM
return menuWrapper.listNodeVO(collect); return menuWrapper.listNodeVO(collect);
} }
public void recursion(List<Menu> allMenus, List<Menu> routes, Menu roleMenu) { private void recursion(List<Menu> allMenus, List<Menu> routes, Menu roleMenu) {
Optional<Menu> menu = allMenus.stream().filter(x -> Func.equals(x.getId(), roleMenu.getParentId())).findFirst(); Optional<Menu> menu = allMenus.stream().filter(x -> Func.equals(x.getId(), roleMenu.getParentId())).findFirst();
if (menu.isPresent() && !routes.contains(menu.get())) { if (menu.isPresent() && !routes.contains(menu.get())) {
routes.add(menu.get()); routes.add(menu.get());
@ -99,12 +106,23 @@ public class MenuServiceImpl extends ServiceImpl<MenuMapper, Menu> implements IM
return ForestNodeMerger.merge(user.getTenantId().equals(BladeConstant.ADMIN_TENANT_ID) ? baseMapper.grantTree() : baseMapper.grantTreeByRole(Func.toLongList(user.getRoleId()))); return ForestNodeMerger.merge(user.getTenantId().equals(BladeConstant.ADMIN_TENANT_ID) ? baseMapper.grantTree() : baseMapper.grantTreeByRole(Func.toLongList(user.getRoleId())));
} }
@Override
public List<MenuVO> grantScopeTree(BladeUser user) {
return ForestNodeMerger.merge(user.getTenantId().equals(BladeConstant.ADMIN_TENANT_ID) ? baseMapper.grantScopeTree() : baseMapper.grantScopeTreeByRole(Func.toLongList(user.getRoleId())));
}
@Override @Override
public List<String> roleTreeKeys(String roleIds) { public List<String> roleTreeKeys(String roleIds) {
List<RoleMenu> roleMenus = roleMenuService.list(Wrappers.<RoleMenu>query().lambda().in(RoleMenu::getRoleId, Func.toLongList(roleIds))); List<RoleMenu> roleMenus = roleMenuService.list(Wrappers.<RoleMenu>query().lambda().in(RoleMenu::getRoleId, Func.toLongList(roleIds)));
return roleMenus.stream().map(roleMenu -> Func.toStr(roleMenu.getMenuId())).collect(Collectors.toList()); return roleMenus.stream().map(roleMenu -> Func.toStr(roleMenu.getMenuId())).collect(Collectors.toList());
} }
@Override
public List<String> scopeTreeKeys(String roleIds) {
List<RoleScope> roleScopes = roleScopeService.list(Wrappers.<RoleScope>query().lambda().in(RoleScope::getRoleId, Func.toLongList(roleIds)));
return roleScopes.stream().map(roleScope -> Func.toStr(roleScope.getScopeId())).collect(Collectors.toList());
}
@Override @Override
@Cacheable(cacheNames = MENU_CACHE, key = "'auth:routes:' + #user.roleId") @Cacheable(cacheNames = MENU_CACHE, key = "'auth:routes:' + #user.roleId")
public List<Kv> authRoutes(BladeUser user) { public List<Kv> authRoutes(BladeUser user) {

33
blade-service/blade-system/src/main/java/org/springblade/system/service/impl/RoleScopeServiceImpl.java

@ -0,0 +1,33 @@
/*
* Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* Neither the name of the dreamlu.net developer nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
* Author: Chill 庄骞 (smallchill@163.com)
*/
package org.springblade.system.service.impl;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springblade.system.entity.RoleScope;
import org.springblade.system.mapper.RoleScopeMapper;
import org.springblade.system.service.IRoleScopeService;
import org.springframework.stereotype.Service;
/**
* 服务实现类
*
* @author Chill
*/
@Service
public class RoleScopeServiceImpl extends ServiceImpl<RoleScopeMapper, RoleScope> implements IRoleScopeService {
}

24
blade-service/blade-system/src/main/java/org/springblade/system/service/impl/RoleServiceImpl.java

@ -27,6 +27,7 @@ import org.springblade.core.tool.utils.CollectionUtil;
import org.springblade.core.tool.utils.Func; import org.springblade.core.tool.utils.Func;
import org.springblade.system.entity.Role; import org.springblade.system.entity.Role;
import org.springblade.system.entity.RoleMenu; import org.springblade.system.entity.RoleMenu;
import org.springblade.system.entity.RoleScope;
import org.springblade.system.mapper.RoleMapper; import org.springblade.system.mapper.RoleMapper;
import org.springblade.system.service.IRoleMenuService; import org.springblade.system.service.IRoleMenuService;
import org.springblade.system.service.IRoleService; import org.springblade.system.service.IRoleService;
@ -68,7 +69,8 @@ public class RoleServiceImpl extends ServiceImpl<RoleMapper, Role> implements IR
@Override @Override
@Transactional(rollbackFor = Exception.class) @Transactional(rollbackFor = Exception.class)
public boolean grant(@NotEmpty List<Long> roleIds, @NotEmpty List<Long> menuIds) { public boolean grant(@NotEmpty List<Long> roleIds, @NotEmpty List<Long> menuIds, List<Long> scopeIds) {
// 菜单权限模块
// 删除角色配置的菜单集合 // 删除角色配置的菜单集合
roleMenuService.remove(Wrappers.<RoleMenu>update().lambda().in(RoleMenu::getRoleId, roleIds)); roleMenuService.remove(Wrappers.<RoleMenu>update().lambda().in(RoleMenu::getRoleId, roleIds));
// 组装配置 // 组装配置
@ -80,7 +82,25 @@ public class RoleServiceImpl extends ServiceImpl<RoleMapper, Role> implements IR
roleMenus.add(roleMenu); roleMenus.add(roleMenu);
})); }));
// 新增配置 // 新增配置
return roleMenuService.saveBatch(roleMenus); roleMenuService.saveBatch(roleMenus);
// 数据权限模块
if (CollectionUtil.isNotEmpty(scopeIds)) {
// 删除角色配置的数据权限集合
roleScopeService.remove(Wrappers.<RoleScope>update().lambda().in(RoleScope::getRoleId, roleIds));
// 组装配置
List<RoleScope> roleScopes = new ArrayList<>();
roleIds.forEach(roleId -> scopeIds.forEach(scopeId -> {
RoleScope roleScope = new RoleScope();
roleScope.setRoleId(roleId);
roleScope.setScopeId(scopeId);
roleScopes.add(roleScope);
}));
// 新增配置
roleScopeService.saveBatch(roleScopes);
}
return true;
} }
@Override @Override

11
blade-service/blade-system/src/main/java/org/springblade/system/wrapper/DeptWrapper.java

@ -22,11 +22,13 @@ import org.springblade.core.tool.node.ForestNodeMerger;
import org.springblade.core.tool.node.INode; import org.springblade.core.tool.node.INode;
import org.springblade.core.tool.utils.BeanUtil; import org.springblade.core.tool.utils.BeanUtil;
import org.springblade.core.tool.utils.Func; import org.springblade.core.tool.utils.Func;
import org.springblade.system.cache.DictCache;
import org.springblade.system.cache.SysCache; import org.springblade.system.cache.SysCache;
import org.springblade.system.entity.Dept; import org.springblade.system.entity.Dept;
import org.springblade.system.vo.DeptVO; import org.springblade.system.vo.DeptVO;
import java.util.List; import java.util.List;
import java.util.Objects;
import java.util.stream.Collectors; import java.util.stream.Collectors;
/** /**
@ -50,12 +52,19 @@ public class DeptWrapper extends BaseEntityWrapper<Dept, DeptVO> {
Dept parent = SysCache.getDept(dept.getParentId()); Dept parent = SysCache.getDept(dept.getParentId());
deptVO.setParentName(parent.getDeptName()); deptVO.setParentName(parent.getDeptName());
} }
String category = DictCache.getValue("org_category", dept.getDeptCategory());
deptVO.setDeptCategoryName(category);
return deptVO; return deptVO;
} }
public List<INode> listNodeVO(List<Dept> list) { public List<INode> listNodeVO(List<Dept> list) {
List<INode> collect = list.stream().map(dept -> BeanUtil.copy(dept, DeptVO.class)).collect(Collectors.toList()); List<INode> collect = list.stream().map(dept -> {
DeptVO deptVO = BeanUtil.copy(dept, DeptVO.class);
String category = DictCache.getValue("org_category", dept.getDeptCategory());
Objects.requireNonNull(deptVO).setDeptCategoryName(category);
return deptVO;
}).collect(Collectors.toList());
return ForestNodeMerger.merge(collect); return ForestNodeMerger.merge(collect);
} }

2
blade-service/blade-user/pom.xml

@ -5,7 +5,7 @@
<parent> <parent>
<artifactId>blade-service</artifactId> <artifactId>blade-service</artifactId>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>

4
blade-service/pom.xml

@ -6,14 +6,14 @@
<parent> <parent>
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
</parent> </parent>
<modelVersion>4.0.0</modelVersion> <modelVersion>4.0.0</modelVersion>
<artifactId>blade-service</artifactId> <artifactId>blade-service</artifactId>
<name>${project.artifactId}</name> <name>${project.artifactId}</name>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
<packaging>pom</packaging> <packaging>pom</packaging>
<description>BladeX 微服务集合</description> <description>BladeX 微服务集合</description>

20
doc/sql/bladex-datascope-update.sql

@ -70,9 +70,17 @@ UPDATE `blade_dept` SET `tenant_id` = '000000', `parent_id` = 112359881373867520
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675227, 0, 'org_category', -1, '机构类型', 7, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675227, 0, 'org_category', -1, '机构类型', 7, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675228, 1123598814738675227, 'org_category', 1, '公司', 1, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675228, 1123598814738675227, 'org_category', 1, '公司', 1, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675229, 1123598814738675227, 'org_category', 2, '部门', 2, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675229, 1123598814738675227, 'org_category', 2, '部门', 2, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675230, 0, 'data_scope', -1, '数据权限', 8, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675230, 1123598814738675227, 'org_category', 3, '小组', 3, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675231, 1123598814738675230, 'data_scope', 1, '全部可见', 1, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675231, 0, 'scope_type', -1, '数据权限', 8, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675232, 1123598814738675230, 'data_scope', 2, '本人可见', 2, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675232, 1123598814738675230, 'scope_type', 1, '全部可见', 1, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675233, 1123598814738675230, 'data_scope', 3, '所在机构可见', 3, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675233, 1123598814738675230, 'scope_type', 2, '本人可见', 2, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675234, 1123598814738675230, 'data_scope', 4, '所在机构及子级可见', 4, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675234, 1123598814738675230, 'scope_type', 3, '所在机构可见', 3, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675235, 1123598814738675230, 'data_scope', 5, '自定义', 5, NULL, 0); INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675235, 1123598814738675230, 'scope_type', 4, '所在机构及子级可见', 4, NULL, 0);
INSERT INTO `blade_dict`(`id`, `parent_id`, `code`, `dict_key`, `dict_value`, `sort`, `remark`, `is_deleted`) VALUES (1123598814738675236, 1123598814738675230, 'scope_type', 5, '自定义', 5, NULL, 0);
-- ----------------------------
-- 增加数据权限菜单及权限
-- ----------------------------
UPDATE `blade_menu` SET `name` = '机构管理' WHERE `id` = 1123598815738675205;
INSERT INTO `blade_menu`(`id`, `parent_id`, `code`, `name`, `alias`, `path`, `source`, `sort`, `category`, `action`, `is_open`, `remark`, `is_deleted`) VALUES (1123598815738675306, 1123598815738675207, 'menu_data_scope', '数据权限', 'datascope', NULL, 'setting', 5, 2, 2, 1, NULL, 0);
INSERT INTO `blade_role_menu`(`id`, `menu_id`, `role_id`) VALUES (1132812106487730179, 1123598815738675306, 1123598816738675201);

8
pom.xml

@ -5,12 +5,12 @@
<groupId>org.springblade</groupId> <groupId>org.springblade</groupId>
<artifactId>BladeX</artifactId> <artifactId>BladeX</artifactId>
<version>2.0.3.RELEASE</version> <version>2.0.4.RELEASE</version>
<packaging>pom</packaging> <packaging>pom</packaging>
<properties> <properties>
<bladex.tool.version>2.0.3.RELEASE</bladex.tool.version> <bladex.tool.version>2.0.4.RELEASE</bladex.tool.version>
<bladex.project.version>2.0.3.RELEASE</bladex.project.version> <bladex.project.version>2.0.4.RELEASE</bladex.project.version>
<java.version>1.8</java.version> <java.version>1.8</java.version>
<maven.plugin.version>3.8.1</maven.plugin.version> <maven.plugin.version>3.8.1</maven.plugin.version>
@ -20,7 +20,7 @@
<swagger.version>2.9.2</swagger.version> <swagger.version>2.9.2</swagger.version>
<swagger.models.version>1.5.21</swagger.models.version> <swagger.models.version>1.5.21</swagger.models.version>
<swagger.bootstrapui.version>1.9.4</swagger.bootstrapui.version> <swagger.bootstrapui.version>1.9.4</swagger.bootstrapui.version>
<mybatis.plus.version>3.1.1</mybatis.plus.version> <mybatis.plus.version>3.1.0</mybatis.plus.version>
<curator.framework.version>4.0.1</curator.framework.version> <curator.framework.version>4.0.1</curator.framework.version>
<protostuff.version>1.6.0</protostuff.version> <protostuff.version>1.6.0</protostuff.version>
<flowable.version>6.4.1</flowable.version> <flowable.version>6.4.1</flowable.version>

2
script/docker/.env

@ -1,2 +1,2 @@
REGISTER=192.168.0.157/blade REGISTER=192.168.0.157/blade
TAG=2.0.3.RELEASE TAG=2.0.4.RELEASE

Loading…
Cancel
Save