Class UpdateValidationDomainMapperMember
java.lang.Object
com.broadleafcommerce.data.tracking.core.mapping.UpdateValidationDomainMapperMember
- All Implemented Interfaces:
- com.broadleafcommerce.common.extension.data.DataRoutePartitionAware,- DomainMapper,- DomainMapperMember,- IdAware,- org.springframework.core.Ordered
public class UpdateValidationDomainMapperMember
extends Object
implements DomainMapperMember, IdAware
 A special DomainMapperMember which is responsible for validating the id variable state
 for update requests. Update requests (including replace) include a path parameter in the API that
 identifies the entity receiving the update. However, the payload may also contain an id value
 that may end up being applied during the mapping phase to the repository state. This mapper
 member performs some lightweight checks and mitigations:
 
- If the id in the payload is null, change it's value to the requested id from the path parameter
- If the id in the payload is populated, and it matches the path parameter, pass through
- If the id in the payload is populated, and does not match the path parameter, throw a
 ValidationException.
CrudEntityService.replace(String, Object, ContextInfo) and
 CrudEntityService.update(String, Object, ContextInfo), and is used to find the entity
 which will be replaced or updated. If found, this is the entity that becomes the
 repositoryDomain argument to fromBusinessDomain(Object, Object, ContextInfo).
 Thus, its contextId can be reliably used as the "path parameter" source of truth on what
 the ID should be, and this implementation uses it as such.- Author:
- Jeff Fischer
- 
Nested Class SummaryNested classes/interfaces inherited from interface com.broadleafcommerce.data.tracking.core.mapping.IdAwareIdAware.Id
- 
Field SummaryFields inherited from interface com.broadleafcommerce.common.extension.data.DataRoutePartitionAwareALL_MATCHFields inherited from interface org.springframework.core.OrderedHIGHEST_PRECEDENCE, LOWEST_PRECEDENCE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescription<D> DfromBusinessDomain(Object businessDomain, D repositoryDomain, ContextInfo contextInfo) Validates the identifier value state for a mutation request.intgetOrder()<D,P> D modifyMap(D repositoryDomain, P businessDomain, ContextInfo contextInfo, boolean allowNull) Validates the identifier value state for a mutation request.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.broadleafcommerce.data.tracking.core.mapping.DomainMapperdeleteMap, getBusinessDomainTypeMethods inherited from interface com.broadleafcommerce.data.tracking.core.mapping.DomainMapperMemberfromRepositoryDomain
- 
Constructor Details- 
UpdateValidationDomainMapperMemberpublic UpdateValidationDomainMapperMember()
 
- 
- 
Method Details- 
getDataRoutePartition- Specified by:
- getDataRoutePartitionin interface- com.broadleafcommerce.common.extension.data.DataRoutePartitionAware
 
- 
fromBusinessDomainpublic <D> D fromBusinessDomain(@Nullable Object businessDomain, @Nullable D repositoryDomain, @Nullable ContextInfo contextInfo) Validates the identifier value state for a mutation request. Confirms the repository entity requested for update matches the id in the payload, if applicable.- Specified by:
- fromBusinessDomainin interface- DomainMapperMember
- Type Parameters:
- D- The repository entity type
- Parameters:
- businessDomain- The business instance containing the relevant property information
- repositoryDomain- The repository specific instance to affect and return
- contextInfo- The context information used to make tracking determinations relevant to sandboxing and multitenant concerns. See- TrackableRepositoryfor more info on persistence behavior based on context.
- Returns:
- The validated (possibly altered) repository entity instance
 
- 
modifyMappublic <D,P> D modifyMap(D repositoryDomain, P businessDomain, ContextInfo contextInfo, boolean allowNull) Validates the identifier value state for a mutation request. Confirms the repository entity requested for update matches the id in the payload, if applicable.- Specified by:
- modifyMapin interface- DomainMapper
- Type Parameters:
- D- The repository entity type
- P- The projection type
- Parameters:
- repositoryDomain- The persistence domain instance to modify
- businessDomain- The business instance containing changes to map to the repository domain
- contextInfo- The context information used to make tracking determinations relevant to sandboxing and multitenant concerns. See- TrackableRepositoryfor more info on persistence behavior based on context.
- allowNull- Whether or not null values in properties in the payload instance should be ignored during the mapping operation.
- Returns:
- The validated (possibly altered) repository entity instance
 
- 
getOrderpublic int getOrder()- Specified by:
- getOrderin interface- DomainMapperMember
- Specified by:
- getOrderin interface- org.springframework.core.Ordered
 
 
-