📄 checkpermission.java
字号:
/* * $Id: CheckPermission.java 6201 2005-11-28 12:24:44Z jonesde $ * * Copyright (c) 2001, 2002 The Open For Business Project - www.ofbiz.org * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT * OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR * THE USE OR OTHER DEALINGS IN THE SOFTWARE. */package org.ofbiz.minilang.method.ifops;import java.util.Iterator;import java.util.LinkedList;import java.util.List;import java.util.Map;import org.ofbiz.base.util.UtilProperties;import org.ofbiz.base.util.UtilValidate;import org.ofbiz.base.util.UtilXml;import org.ofbiz.entity.GenericValue;import org.ofbiz.minilang.SimpleMethod;import org.ofbiz.minilang.method.ContextAccessor;import org.ofbiz.minilang.method.MethodContext;import org.ofbiz.minilang.method.MethodOperation;import org.ofbiz.security.Security;import org.w3c.dom.Element;/** * Iff the user does not have the specified permission the fail-message * or fail-property sub-elements are used to add a message to the error-list. * * @author <a href="mailto:jonesde@ofbiz.org">David E. Jones</a> * @version $Rev: 6201 $ * @since 2.0 */public class CheckPermission extends MethodOperation { String message = null; String propertyResource = null; boolean isProperty = false; /** If null no partyId env-name will be checked against the userLogin.partyId and accepted as permission */ ContextAccessor acceptUlPartyIdEnvNameAcsr = null; PermissionInfo permissionInfo; ContextAccessor errorListAcsr; List altPermissions = null; public CheckPermission(Element element, SimpleMethod simpleMethod) { super(element, simpleMethod); permissionInfo = new PermissionInfo(element); this.errorListAcsr = new ContextAccessor(element.getAttribute("error-list-name"), "error_list"); Element acceptUserloginPartyElement = UtilXml.firstChildElement(element, "accept-userlogin-party"); if (acceptUserloginPartyElement != null) { acceptUlPartyIdEnvNameAcsr = new ContextAccessor(acceptUserloginPartyElement.getAttribute("party-id-env-name"), "partyId"); } List altPermElements = UtilXml.childElementList(element, "alt-permission"); Iterator apeIter = altPermElements.iterator(); if (apeIter.hasNext()) { altPermissions = new LinkedList(); } while (apeIter.hasNext()) { Element altPermElement = (Element) apeIter.next(); altPermissions.add(new PermissionInfo(altPermElement)); } Element failMessage = UtilXml.firstChildElement(element, "fail-message"); Element failProperty = UtilXml.firstChildElement(element, "fail-property"); if (failMessage != null) { this.message = failMessage.getAttribute("message"); this.isProperty = false; } else if (failProperty != null) { this.propertyResource = failProperty.getAttribute("resource"); this.message = failProperty.getAttribute("property"); this.isProperty = true; } } public boolean exec(MethodContext methodContext) { boolean hasPermission = false; List messages = (List) errorListAcsr.get(methodContext); if (messages == null) { messages = new LinkedList(); errorListAcsr.put(methodContext, messages); } // if no user is logged in, treat as if the user does not have permission: do not run subops GenericValue userLogin = methodContext.getUserLogin(); if (userLogin != null) { Security security = methodContext.getSecurity(); if (this.permissionInfo.hasPermission(methodContext, userLogin, security)) { hasPermission = true; } // if failed, check alternate permissions if (!hasPermission && altPermissions != null) { Iterator altPermIter = altPermissions.iterator(); while (altPermIter.hasNext()) { PermissionInfo altPermInfo = (PermissionInfo) altPermIter.next(); if (altPermInfo.hasPermission(methodContext, userLogin, security)) { hasPermission = true; break; } } } } if (!hasPermission && acceptUlPartyIdEnvNameAcsr != null) { String acceptPartyId = (String) acceptUlPartyIdEnvNameAcsr.get(methodContext); if (UtilValidate.isEmpty(acceptPartyId)) { // try the parameters Map Map parameters = (Map) methodContext.getEnv("parameters"); if (parameters != null) { acceptPartyId = (String) acceptUlPartyIdEnvNameAcsr.get(parameters, methodContext); } } if (UtilValidate.isNotEmpty(acceptPartyId) && UtilValidate.isNotEmpty(userLogin.getString("partyId")) && acceptPartyId.equals(userLogin.getString("partyId"))) { hasPermission = true; } } if (!hasPermission) { this.addMessage(messages, methodContext); } return true; } public void addMessage(List messages, MethodContext methodContext) { ClassLoader loader = methodContext.getLoader(); String message = methodContext.expandString(this.message); String propertyResource = methodContext.expandString(this.propertyResource); if (!isProperty && message != null) { messages.add(message); // if (Debug.infoOn()) Debug.logInfo("[SimpleMapOperation.addMessage] Adding message: " + message, module); } else if (isProperty && propertyResource != null && message != null) { //String propMsg = UtilProperties.getPropertyValue(UtilURL.fromResource(propertyResource, loader), message); String propMsg = UtilProperties.getMessage(propertyResource, message, methodContext.getEnvMap(), methodContext.getLocale()); if (propMsg == null || propMsg.length() == 0) { messages.add("Simple Method Permission error occurred, but no message was found, sorry."); } else { messages.add(methodContext.expandString(propMsg)); } // if (Debug.infoOn()) Debug.logInfo("[SimpleMapOperation.addMessage] Adding property message: " + propMsg, module); } else { messages.add("Simple Method Permission error occurred, but no message was found, sorry."); // if (Debug.infoOn()) Debug.logInfo("[SimpleMapOperation.addMessage] ERROR: No message found", module); } } public static class PermissionInfo { String permission; String action; public PermissionInfo(Element altPermissionElement) { this.permission = altPermissionElement.getAttribute("permission"); this.action = altPermissionElement.getAttribute("action"); } public boolean hasPermission(MethodContext methodContext, GenericValue userLogin, Security security) { String permission = methodContext.expandString(this.permission); String action = methodContext.expandString(this.action); if (action != null && action.length() > 0) { // run hasEntityPermission return security.hasEntityPermission(permission, action, userLogin); } else { // run hasPermission return security.hasPermission(permission, userLogin); } } } public String rawString() { // TODO: add all attributes and other info return "<check-permission/>"; } public String expandedString(MethodContext methodContext) { // TODO: something more than a stub/dummy return this.rawString(); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -