Skip to content

Latest commit

 

History

History
191 lines (145 loc) · 10.3 KB

TAX_CATEGORY_SYNC.md

File metadata and controls

191 lines (145 loc) · 10.3 KB

Tax Category Sync

Allows importing/syncing TaxCategory into a commercetools project. It also provides utilities for generating update actions based on the comparison of a TaxCategory against a TaxCategoryDraft.

Usage

Prerequisites

SphereClient

Use the ClientConfigurationUtils which apply the best practices for SphereClient creation. If you have custom requirements for the sphere client creation, have a look into the Important Usage Tips.

final SphereClientConfig clientConfig = SphereClientConfig.of("project-key", "client-id", "client-secret");

final SphereClient sphereClient = ClientConfigurationUtils.createClient(clientConfig);

Required Fields

The following fields are required to be set in, otherwise, they won't be matched by sync:

Draft Required Fields Note
TaxCategoryDraft key Also, the tax categories in the target project are expected to have the key fields set.

SyncOptions

After the sphereClient is set up, a TaxCategorySyncOptions should be built as follows:

// instantiating a TaxCategorySyncOptions
final TaxCategorySyncOptions taxCategorySyncOptions = TaxCategorySyncOptionsBuilder.of(sphereClient).build();

SyncOptions is an object which provides a place for users to add certain configurations to customize the sync process. Available configurations:

errorCallback

A callback that is called whenever an error event occurs during the sync process. Each resource executes its own error-callback. When the sync process of a particular resource runs successfully, it is not triggered. It contains the following context about the error-event:

  • sync exception
  • tax category draft from the source
  • tax category of the target project (only provided if an existing tax category could be found)
  • the update-actions, which failed (only provided if an existing tax category could be found)
 final Logger logger = LoggerFactory.getLogger(TaxCategorySync.class);
 final TaxCategorySyncOptions taxCategorySyncOptions = TaxCategorySyncOptionsBuilder
         .of(sphereClient)
         .errorCallback((syncException, draft, taxCategory, updateActions) -> 
            logger.error(new SyncException("My customized message"), syncException)).build();
warningCallback

A callback is called whenever a warning event occurs during the sync process. Each resource executes its own warning-callback. When the sync process of a particular resource runs successfully, it is not triggered. It contains the following context about the warning message:

  • sync exception
  • tax category draft from the source
  • tax category of the target project (only provided if an existing tax category could be found)
 final Logger logger = LoggerFactory.getLogger(TaxCategorySync.class);
 final TaxCategorySyncOptions taxCategorySyncOptions = TaxCategorySyncOptionsBuilder
         .of(sphereClient)
         .warningCallback((syncException, draft, taxCategory, updateActions) -> 
            logger.warn(new SyncException("My customized message"), syncException)).build();
beforeUpdateCallback

During the sync process, if a target tax category and a tax category draft are matched, this callback can be used to intercept the update request just before it is sent to the commercetools platform. This allows the user to modify update actions array with custom actions or discard unwanted actions. The callback provides the following information :

  • tax category draft from the source
  • tax category from the target project
  • update actions that were calculated after comparing both
final TriFunction<
        List<UpdateAction<TaxCategory>>, TaxCategoryDraft, TaxCategory, List<UpdateAction<TaxCategory>>> 
            beforeUpdateTaxCategoryCallback =
            (updateActions, newTaxCategoryDraft, oldTaxCategory) ->  updateActions.stream()
                    .filter(updateAction -> !(updateAction instanceof RemoveTaxRate))
                    .collect(Collectors.toList());
                        
final TaxCategorySyncOptions taxCategorySyncOptions = 
        TaxCategorySyncOptionsBuilder.of(sphereClient).beforeUpdateCallback(beforeUpdateTaxCategoryCallback).build();
beforeCreateCallback

During the sync process, if a tax category draft should be created, this callback can be used to intercept the create request just before it is sent to the commercetools platform. It contains the following information :

  • tax category draft that should be created

Please refer to example in product sync document.

batchSize

A number that could be used to set the batch size with which tax categories are fetched and processed, as tax categories are obtained from the target project on the commercetools platform in batches for better performance. The algorithm accumulates up to batchSize resources from the input list, then fetches the corresponding tax categories from the target project on commecetools platform in a single request. Playing with this option can slightly improve or reduce processing speed. If it is not set, the default batch size is 50 for tax category sync.

final TaxCategorySyncOptions taxCategorySyncOptions = 
         TaxCategorySyncOptionsBuilder.of(sphereClient).batchSize(30).build();
cacheSize

In the service classes of the commercetools-sync-java library, we have implemented an in-memory LRU cache to store a map used for the reference resolution of the library. The cache reduces the reference resolution based calls to the commercetools API as the required fields of a resource will be fetched only one time. These cached fields then might be used by another resource referencing the already resolved resource instead of fetching from commercetools API. It turns out, having the in-memory LRU cache will improve the overall performance of the sync library and commercetools API. which will improve the overall performance of the sync and commercetools API.

Playing with this option can change the memory usage of the library. If it is not set, the default cache size is 10.000 for tax category sync.

final TaxCategorySyncOptions taxCategorySyncOptions = 
         TaxCategorySyncOptionsBuilder.of(sphereClient).cacheSize(5000).build();

Running the sync

After all the aforementioned points in the previous section have been fulfilled, to run the sync:

// instantiating a TaxCategorySync
final TaxCategorySync taxCategorySync = new TaxCategorySync(taxCategorySyncOptions);

// execute the sync on your list of tax categories
CompletionStage<TaxCategorySyncStatistics> syncStatisticsStage = taxCategorySync.sync(taxCategoryDrafts);

The result of completing the syncStatisticsStage in the previous code snippet contains a TaxCategorySyncStatistics which contains all the stats of the sync process; which includes a report message, the total number of updated, created, failed, processed tax categories and the processing time of the last sync batch in different time units and in a human-readable format.

final TaxCategorySyncStatistics stats = syncStatisticsStage.toCompletebleFuture().join();
stats.getReportMessage();
/*"Summary: 2000 tax categories were processed in total (1000 created, 995 updated, 5 failed to sync)."*/

Note The statistics object contains the processing time of the last batch only. This is due to two reasons:

  1. The sync processing time should not take into account the time between supplying batches to the sync.
  2. It is not known by the sync which batch is going to be the last one supplied.

More examples of how to use the sync

Make sure to read the Important Usage Tips for optimal performance.

Build all update actions

A utility method provided by the library to compare a TaxCategory with a new TaxCategoryDraft and results in a list of tax category update actions.

List<UpdateAction<TaxCategory>> updateActions = TaxCategorySyncUtils.buildActions(taxCategory, taxCategoryDraft, taxCategorySyncOptions);

Build particular update action(s)

Utility methods provided by the library to compare the specific fields of a TaxCategory and a new TaxCategoryDraft, and in turn builds the update action. One example is the buildChangeNameUpdateAction which compares names:

Optional<UpdateAction<TaxCategory>> updateAction = TaxCategoryUpdateActionUtils.buildChangeNameAction(oldTaxCategory, taxCategoryDraft);

More examples of those utils for different tax categories can be found here.