Class JpaCustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>

java.lang.Object
com.broadleafcommerce.order.provider.jpa.repository.JpaCustomizedOrderFulfillmentRepository<D>
All Implemented Interfaces:
CustomizedOrderFulfillmentRepository<D>

public class JpaCustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment> extends Object implements CustomizedOrderFulfillmentRepository<D>
Author:
Dima Myroniuk (dmyroniuk)
  • Field Details

  • Constructor Details

    • JpaCustomizedOrderFulfillmentRepository

      public JpaCustomizedOrderFulfillmentRepository(List<com.broadleafcommerce.data.tracking.core.service.RsqlQueryTransformer> rsqlQueryTransformers, com.broadleafcommerce.data.tracking.jpa.filtering.fetch.rsql.JpaCriteriaBuilderRsqlVisitor rsqlVisitor, com.broadleafcommerce.common.jpa.RepositoryEntityTypeManager repositoryEntityTypeManager, JpaOrderTenantQueryHelper tenantQueryHelper)
  • Method Details

    • validate

      @PostConstruct public void validate()
    • findAllDistinctContextIds

      public List<String> findAllDistinctContextIds(int page, cz.jirutka.rsql.parser.ast.Node filters)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Retrieves a list of unique order fulfillment context IDs no larger than page. It is expected that any appropriate offset is achieved through criteria designated in filters.
      Specified by:
      findAllDistinctContextIds in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      page - the requested amount of results from the database. -1 indicates no limit.
      filters - additional filters to apply in the query. Should be EmptyNode if no additional filters should be applied.
      Returns:
      unique order fulfillment IDs
    • applyRsqlCriteria

      protected void applyRsqlCriteria(cz.jirutka.rsql.parser.ast.Node filters, jakarta.persistence.criteria.CriteriaBuilder criteriaBuilder, jakarta.persistence.criteria.CriteriaQuery<?> nativeQuery, Map<String,Object> nativeQueryParams, List<jakarta.persistence.criteria.Predicate> nativePredicates)
    • findByContextIdAndMatchingTenant

      public Optional<D> findByContextIdAndMatchingTenant(String id, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Retrieves the order fulfillment matching the provided ID and the tenant from ContextInfo if present.

      Differs from the standard narrowing behavior of TrackableRepository.findByContextId(String, ContextInfo), which only returns tenant-level (non-application-associated) records when fetching from a tenant context. This implementation finds all records within the tenant regardless of whether they're associated to an application.

      Specified by:
      findByContextIdAndMatchingTenant in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      id - the id of the order fulfillment to find
      contextInfo - context information surrounding multitenant state.
      Returns:
      an Optional containing the requested order fulfillment if found within the tenant, or Optional.empty() otherwise
    • findAllByOrderIdAndMatchingTenant

      public List<D> findAllByOrderIdAndMatchingTenant(String orderId, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Retrieves the order fulfillment matching the provided ID and the tenant from ContextInfo if present.

      Differs from the standard narrowing behavior of OrderFulfillmentRepository.findAllByOrderId(String, ContextInfo), which only returns tenant-level (non-application-associated) records when fetching from a tenant context. This implementation finds all records within the tenant regardless of whether they're associated to an application.

      Specified by:
      findAllByOrderIdAndMatchingTenant in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      orderId - The ID of the order to find fulfillments for
      contextInfo - context information surrounding multitenant state
      Returns:
      the fulfillments that are associated with the given orderId
    • buildOrderIdIsEqualToFilter

      public jakarta.persistence.criteria.Predicate buildOrderIdIsEqualToFilter(String orderId, Map<String,Object> queryParams, jakarta.persistence.criteria.CriteriaBuilder criteriaBuilder, jakarta.persistence.criteria.Root<? extends com.broadleafcommerce.data.tracking.core.Trackable> entity)
    • buildStatusIsEqualToFilter

      public jakarta.persistence.criteria.Predicate buildStatusIsEqualToFilter(String status, Map<String,Object> queryParams, jakarta.persistence.criteria.CriteriaBuilder criteriaBuilder, jakarta.persistence.criteria.Root<? extends com.broadleafcommerce.data.tracking.core.Trackable> entity)
    • findPageByOrderIdAndMatchingTenant

      public org.springframework.data.domain.Page<D> findPageByOrderIdAndMatchingTenant(String orderId, cz.jirutka.rsql.parser.ast.Node filters, org.springframework.data.domain.Pageable pageable, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Retrieves the order fulfillment matching the provided ID and the tenant from ContextInfo if present.

      Differs from the standard narrowing behavior of OrderFulfillmentRepository.findAllByOrderId(String, ContextInfo), which only returns tenant-level (non-application-associated) records when fetching from a tenant context. This implementation finds all records within the tenant regardless of whether they're associated to an application.

      Specified by:
      findPageByOrderIdAndMatchingTenant in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      orderId - The ID of the order to find fulfillments for
      contextInfo - context information surrounding multitenant state
      Returns:
      the fulfillments that are associated with the given orderId
    • findAllMatchingTenant

      public org.springframework.data.domain.Page<D> findAllMatchingTenant(cz.jirutka.rsql.parser.ast.Node filters, org.springframework.data.domain.Pageable pageable, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Retrieves the order fulfillment matching the query and the tenant from ContextInfo if present.

      Differs from the standard narrowing behavior of TrackableRsqlFilterExecutor.findAll(Node, Pageable, ContextInfo), which only returns tenant-level (non-application-associated) records when fetching from a tenant context. This implementation finds all records within the tenant regardless of whether they're associated to an application.

      Specified by:
      findAllMatchingTenant in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      filters - the RSQL Node used to restrict result, must not be null
      pageable - may be Pageable.unpaged(), must not be null.
      contextInfo - context information surrounding multitenant state.
      Returns:
      The subset (page) of narrowed entities
    • findAllByOrderIdInAndExcludeFulfillmentItems

      public List<D> findAllByOrderIdInAndExcludeFulfillmentItems(List<String> orderIds, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Retrieves the order fulfillments for the provided orderIds. This method avoids eagerly fetching the associated OrderFulfillmentItems.
      Specified by:
      findAllByOrderIdInAndExcludeFulfillmentItems in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      orderIds - the order ids
      contextInfo - context information surrounding multitenant state
      Returns:
      the fulfillments that are associated with the given orderIds
    • findAllByOrderIdAndStatusAndMatchingTenant

      public List<D> findAllByOrderIdAndStatusAndMatchingTenant(String orderId, String status, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Reads all of the order OrderFulfillments which are associated with the given orderId, and the tenant from ContextInfo if present.

      Differs from the standard narrowing behavior of OrderFulfillmentRepository.findAllByOrderIdAndStatus(String, String, ContextInfo), which only returns tenant-level (non-application-associated) records when fetching from a tenant context. This implementation finds all records within the tenant regardless of whether they're associated to an application.

      Specified by:
      findAllByOrderIdAndStatusAndMatchingTenant in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      orderId - The ID of the parent Order
      status - The OrderFulfillment.getStatus()
      contextInfo - context information surrounding sandboxing and multitenant state
      Returns:
      the OrderFulfillments which are associated with the given orderId
    • findByContextIdAndStatusAndMatchingTenant

      public Optional<D> findByContextIdAndStatusAndMatchingTenant(String contextId, String status, @Nullable com.broadleafcommerce.data.tracking.core.context.ContextInfo contextInfo)
      Description copied from interface: CustomizedOrderFulfillmentRepository
      Reads the OrderFulfillment for the given id and status, and the tenant from ContextInfo if present.

      Differs from the standard narrowing behavior of OrderFulfillmentRepository.findByContextIdAndStatus(String, String, ContextInfo), which only returns tenant-level (non-application-associated) records when fetching from a tenant context. This implementation finds all records within the tenant regardless of whether they're associated to an application.

      Specified by:
      findByContextIdAndStatusAndMatchingTenant in interface CustomizedOrderFulfillmentRepository<D extends JpaOrderFulfillment>
      Parameters:
      contextId - The ID of the OrderFulfillment
      status - The OrderFulfillment.getStatus()
      contextInfo - context information surrounding sandboxing and multitenant state
      Returns:
      Reads the OrderFulfillment for the given id and status.
    • getManagedType

      protected Class<D> getManagedType()
    • getEntityManager

      protected jakarta.persistence.EntityManager getEntityManager()
    • getRsqlQueryTransformers

      protected List<com.broadleafcommerce.data.tracking.core.service.RsqlQueryTransformer> getRsqlQueryTransformers()
    • getRsqlVisitor

      protected com.broadleafcommerce.data.tracking.jpa.filtering.fetch.rsql.JpaCriteriaBuilderRsqlVisitor getRsqlVisitor()
    • getRepositoryEntityTypeManager

      protected com.broadleafcommerce.common.jpa.RepositoryEntityTypeManager getRepositoryEntityTypeManager()
    • getTenantQueryHelper

      protected JpaOrderTenantQueryHelper getTenantQueryHelper()
    • getRepository

      protected OrderFulfillmentRepository<D> getRepository()
    • setRepository

      @Autowired @Lazy public void setRepository(OrderFulfillmentRepository<D> repository)