/*
|
* 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.core.datascope.constant;
|
|
import org.springblade.core.tool.utils.StringUtil;
|
|
/**
|
* 数据权限常量
|
*
|
* @author Chill
|
*/
|
public interface DataScopeConstant {
|
|
String DEFAULT_COLUMN = "create_dept";
|
|
/**
|
* 获取部门数据
|
*/
|
String DATA_BY_DEPT = "select id from blade_dept where ancestors like concat(concat('%', ?),'%') and is_deleted = 0";
|
|
/**
|
* 根据resourceCode获取数据权限配置
|
*/
|
String DATA_BY_CODE = "select resource_code, scope_column, scope_field, scope_type, scope_value from blade_scope_data where resource_code = ?";
|
|
/**
|
* 根据mapperId获取数据权限配置
|
*
|
* @param size 数量
|
* @return String
|
*/
|
static String dataByMapper(int size) {
|
return "select resource_code, scope_column, scope_field, scope_type, scope_value from blade_scope_data where scope_class = ? and id in (select scope_id from blade_role_scope where scope_category = 1 and role_id in (" + buildHolder(size) + "))";
|
}
|
|
/**
|
* 获取Sql占位符
|
*
|
* @param size 数量
|
* @return String
|
*/
|
static String buildHolder(int size) {
|
StringBuilder builder = StringUtil.builder();
|
for (int i = 0; i < size; i++) {
|
builder.append("?,");
|
}
|
return StringUtil.removeSuffix(builder.toString(), ",");
|
}
|
|
|
}
|