Class PolicyOverride
- java.lang.Object
- 
- com.broadleafcommerce.data.tracking.core.policy.PolicyOverride
 
- 
- All Implemented Interfaces:
- org.springframework.core.Ordered
 
 public class PolicyOverride extends Object implements org.springframework.core.Ordered An alternative toPolicyused to introduce, alter or remove policy configuration on one or more component methods. Usually declared as a bean in a Spring application context Configuration class and generally associated with a singleAspectdeclaring component, although the latter is not a requirement. The aspect is responsible for declaring pointcuts that are responsible for catching calls to methods that should be protected with policy enforcement. The aspect delegates toPolicyAspectProcessor, which is responsible for utilizing PolicyOverride instances to define policy enforcement configuration. In the absence of PolicyOverride, any applicablePolicyannotations are leveraged.When enhancing (altering or removing) existing Policyannotated methods in the Broadleaf stack, it is not necessary to declare any aspect, asDefaultPolicyAspectis already responsible for recognizing these fields. In this case, you may simply declare an instance ofPolicyOverridewith the desired change. Here's an example that alters policy configuration for a Policy annotated method inTrackableRepository.@BeanPolicyOverride saveOverride() { return new PolicyOverride("save.*") .withPermissionRoots(new String[] {"OTHER"}) .withOperationTypes(new OperationType[] {OperationType.UPDATE}) .withAspect(DefaultPolicyAspect.class); }When adding policy protection to a method in your own codebase (i.e. extending from Broadleaf), it is generally easiest to add the Policyannotation to your methods, which will automatically be picked up byDefaultPolicyAspect.When adding policy protection to a method in the Broadleaf codebase (or Spring codebase) for which there is not already existing protection, it is necessary to declare an aspect and appropriate supporting PolicyOverrideinstances. SeeCrudPolicyAspectas an example that catches calls to methods in Spring'sCrudRepository. Also, reviewCrudPolicyConfigurationfor examples of the supportingPolicyOverrideinstances declared against that aspect.PolicyOverrideinstances are alsoOrdered. The first matching override in the ordered list is the one to be used. This means it is easy to replace the behavior introduced by a PolicyOverride instance in the Broadleaf codebase with a different/custom PolicyOverride instance matching on the same method with a higher precedence ordering.- Author:
- Jeff Fischer
 
- 
- 
Constructor SummaryConstructors Constructor Description PolicyOverride(Method position)PolicyOverride(String positionRegex)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected booleancanEqual(Object other)booleanequals(Object o)Class<?>getAspect()Optional parameter used to differentiate which aspect this override should apply against in thePolicyAspectProcessor.IdentityType[]getIdentityTypes()OperationType[]getOperationTypes()intgetOrder()StringgetOwnerIdentifier()intgetOwnerIdentifierParam()intgetParam()SeePolicy.param().PermissionMatchingStrategygetPermissionMatchingStrategy()String[]getPermissionRoots()MethodgetPosition()Matches against a specific method name and params encountered via an aspect pointcut.PatterngetPositionPattern()Matches against a specific method name encountered via an aspect pointcut.StringgetPositionRegex()Regex string for matching target method.inthashCode()booleanisRemoveTarget()Whether or not existing policy enforcement configuration at the target method should be removed.PolicyOverridewithAspect(Class<?> aspect)PolicyOverridewithIdentityTypes(IdentityType[] identityTypes)PolicyOverridewithOperationTypes(OperationType[] operationTypes)PolicyOverridewithParam(int param)PolicyOverridewithPermissionMatchingStrategy(PermissionMatchingStrategy permissionMatchingStrategy)PolicyOverridewithPermissionRoots(String[] permissionRoots)PolicyOverridewithRemoveTarget(boolean removeTarget)
 
- 
- 
- 
Method Detail- 
getOrderpublic int getOrder() - Specified by:
- getOrderin interface- org.springframework.core.Ordered
 
 - 
withAspectpublic PolicyOverride withAspect(Class<?> aspect) 
 - 
withParampublic PolicyOverride withParam(int param) 
 - 
withPermissionRootspublic PolicyOverride withPermissionRoots(String[] permissionRoots) 
 - 
withOperationTypespublic PolicyOverride withOperationTypes(OperationType[] operationTypes) 
 - 
withIdentityTypespublic PolicyOverride withIdentityTypes(IdentityType[] identityTypes) 
 - 
withRemoveTargetpublic PolicyOverride withRemoveTarget(boolean removeTarget) 
 - 
withPermissionMatchingStrategypublic PolicyOverride withPermissionMatchingStrategy(PermissionMatchingStrategy permissionMatchingStrategy) 
 - 
canEqualprotected boolean canEqual(Object other) 
 - 
getPositionpublic Method getPosition() Matches against a specific method name and params encountered via an aspect pointcut. This field is primarily used to differentiate between multiple methods in a component sharing the same name.- Returns:
- Matches against a specific method name and params encountered via an aspect pointcut
 
 - 
getPositionPatternpublic Pattern getPositionPattern() Matches against a specific method name encountered via an aspect pointcut. This field is primarily used when method name alone can be used to differentiate between multiple methods in a component.- Returns:
- Matches against a specific method name encountered via an aspect pointcut
 
 - 
getAspectpublic Class<?> getAspect() Optional parameter used to differentiate which aspect this override should apply against in thePolicyAspectProcessor. If null, this override will apply against all method pointcuts passed into PolicyAspectProcessor, regardless of the originating aspect. However, this may result in wasted regex computation for inapplicable aspects, so this field is generally set as a performance optimization.- Returns:
- parameter used to differentiate which aspect this override should apply against
 
 - 
getParampublic int getParam() SeePolicy.param(). Default is -1.- Returns:
- See Policy.param(). Default is -1.
 
 - 
getOwnerIdentifierParampublic int getOwnerIdentifierParam() SeePolicy.ownerIdentifierParam(). Default is -1.- Returns:
- See Policy.ownerIdentifierParam(). Default is -1.
 
 - 
getPermissionRootspublic String[] getPermissionRoots() SeePolicy.permissionRoots(). Default is empty array.- Returns:
- See Policy.permissionRoots(). Default is empty array.
 
 - 
getPermissionMatchingStrategypublic PermissionMatchingStrategy getPermissionMatchingStrategy() SeePolicy.permissionMatchingStrategy(). Deafult isMatchingStrategy#ANY
 - 
getOperationTypespublic OperationType[] getOperationTypes() SeePolicy.operationTypes(). Default isOperationType.UNKNOWN.- Returns:
- See Policy.operationTypes(). Default isOperationType.UNKNOWN.
 
 - 
getIdentityTypespublic IdentityType[] getIdentityTypes() SeePolicy.identityTypes(). Default isIdentityType.UNKNOWN.- Returns:
- See Policy.identityTypes(). Default isIdentityType.UNKNOWN.
 
 - 
getOwnerIdentifierpublic String getOwnerIdentifier() SeePolicy.ownerIdentifier(). Default isPolicyUtils.DEFAULT_AUTH_DETAILS_OWNER_ID- Returns:
- See Policy.ownerIdentifier(). Default isPolicyUtils.DEFAULT_AUTH_DETAILS_OWNER_ID
- See Also:
- DefaultTrackablePolicyUtils.getAuthDetailsOwnerIdentifier()
 
 - 
isRemoveTargetpublic boolean isRemoveTarget() Whether or not existing policy enforcement configuration at the target method should be removed.- Returns:
- Whether or not existing policy enforcement configuration at the target method should be removed
 
 - 
getPositionRegexpublic String getPositionRegex() Regex string for matching target method. SeepositionPattern.- Returns:
- Regex string for matching target method. See positionPattern.
 
 
- 
 
-