Package com.commercetools.sync.types
Class TypeSync
- java.lang.Object
-
- com.commercetools.sync.commons.BaseSync<io.sphere.sdk.types.TypeDraft,io.sphere.sdk.types.Type,TypeSyncStatistics,TypeSyncOptions>
-
- com.commercetools.sync.types.TypeSync
-
public class TypeSync extends BaseSync<io.sphere.sdk.types.TypeDraft,io.sphere.sdk.types.Type,TypeSyncStatistics,TypeSyncOptions>
This class syncs type drafts with the corresponding types in the CTP project.
-
-
Field Summary
-
Fields inherited from class com.commercetools.sync.commons.BaseSync
statistics, syncOptions
-
-
Constructor Summary
Constructors Constructor Description TypeSync(TypeSyncOptions typeSyncOptions)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected java.util.concurrent.CompletionStage<TypeSyncStatistics>
process(java.util.List<io.sphere.sdk.types.TypeDraft> typeDrafts)
Iterates through the wholetypeDrafts
list and accumulates its valid drafts to batches.protected java.util.concurrent.CompletionStage<TypeSyncStatistics>
processBatch(java.util.List<io.sphere.sdk.types.TypeDraft> batch)
This method first creates a newSet
of validTypeDraft
elements.-
Methods inherited from class com.commercetools.sync.commons.BaseSync
executeSupplierIfConcurrentModificationException, getStatistics, getSyncOptions, handleError, sync, syncBatches
-
-
-
-
Constructor Detail
-
TypeSync
public TypeSync(@Nonnull TypeSyncOptions typeSyncOptions)
-
-
Method Detail
-
process
protected java.util.concurrent.CompletionStage<TypeSyncStatistics> process(@Nonnull java.util.List<io.sphere.sdk.types.TypeDraft> typeDrafts)
Iterates through the wholetypeDrafts
list and accumulates its valid drafts to batches. Every batch is then processed byprocessBatch(List)
.Inherited doc: Given a list of resource (e.g. categories, products, etc..) drafts. This method compares each new resource in this list with it's corresponding old resource in a given CTP project, and in turn it either issues update actions on the existing resource if it exists or create it if it doesn't.
- Specified by:
process
in classBaseSync<io.sphere.sdk.types.TypeDraft,io.sphere.sdk.types.Type,TypeSyncStatistics,TypeSyncOptions>
- Parameters:
typeDrafts
-List
ofTypeDraft
's that would be synced into CTP project.- Returns:
CompletionStage
withTypeSyncStatistics
holding statistics of all sync processes performed by this sync instance.
-
processBatch
protected java.util.concurrent.CompletionStage<TypeSyncStatistics> processBatch(@Nonnull java.util.List<io.sphere.sdk.types.TypeDraft> batch)
This method first creates a newSet
of validTypeDraft
elements. For more on the rules of validation, check:TypeBatchValidator.validateAndCollectReferencedKeys(List)
. Using the resulting set ofvalidTypeDrafts
, the matching types in the target CTP project are fetched then the methodsyncBatch(Set, Set)
is called to perform the sync (update or create requests accordingly) on the target project.In case of error during of fetching of existing types, the error callback will be triggered. And the sync process would stop for the given batch.
- Specified by:
processBatch
in classBaseSync<io.sphere.sdk.types.TypeDraft,io.sphere.sdk.types.Type,TypeSyncStatistics,TypeSyncOptions>
- Parameters:
batch
- batch of drafts that need to be synced- Returns:
- a
CompletionStage
containing an instance ofTypeSyncStatistics
which contains information about the result of syncing the supplied batch to the target project.
-
-