/* * 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(), ","); } }