Class ThreeDBatchUpdateWork
java.lang.Object
org.nuxeo.ecm.core.work.AbstractWork
org.nuxeo.ecm.platform.threed.service.ThreeDBatchUpdateWork
- All Implemented Interfaces:
Serializable,Work
Work running batch conversions to update 3D document type preview assets
- Since:
- 8.4
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.nuxeo.ecm.core.work.api.Work
Work.Progress, Work.State -
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final Stringprotected static final Stringstatic final StringFields inherited from class org.nuxeo.ecm.core.work.AbstractWork
callerThread, completionTime, docId, docIds, FAILURE_EXCEPTION, FAILURE_MSG, GLOBAL_DLQ_COUNT_REGISTRY_NAME, id, isTree, loginContext, originatingUsername, progress, RANDOM, repositoryName, schedulePath, schedulingTime, session, startTime, state, status, suspended, suspending, traceContext, WORK_FAILED_EVENT, WORK_INSTANCE -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionprotected static StringcomputeIdPrefix(String repositoryName, String docId) protected voidFire aTHREED_CONVERSIONS_DONE_EVENTGets the category for this work.Returns a key that can be used by the WorkManager implementation to guarantee that works with the same partition key will be executed in the order they are submitted.protected ThreeDgetTitle()Gets a human-readable name for this work instance.booleanWhen true the Work is part of a group, Works of the group have the sameWork.getPartitionKey().booleanReturns true if a work with a givenWork.getId()should always produce the same result.voidCalled whenWork.isGroupJoin()returns true and after the last Work of the group.protected voidsaveMainInfo(DocumentModel doc, ThreeDInfo info) protected voidsaveNewProperties(DocumentModel doc, Serializable properties, String schema) protected voidsaveNewRenderViews(DocumentModel doc, List<ThreeDRenderView> threeDRenderViews) protected voidsaveNewTransmissionThreeDs(DocumentModel doc, List<TransmissionThreeD> transmissionThreeDs) voidwork()This method should implement the actual work done by theWorkinstance.Methods inherited from class org.nuxeo.ecm.core.work.AbstractWork
appendWorkToDeadLetterQueue, buildWorkFailureEventProps, cleanUp, closeSession, commitOrRollbackTransaction, equals, getCompletionTime, getDocument, getDocuments, getId, getOriginatingUsername, getProgress, getRetryCount, getSchedulePath, getSchedulingTime, getSpanFromContext, getStartTime, getStatus, getWorkInstanceState, hashCode, isDocumentTree, isSuspending, isWorkInstanceSuspended, newDocumentLocation, openSystemSession, openUserSession, run, runWorkWithTransaction, setCompletionTime, setDocument, setDocument, setDocuments, setOriginatingUsername, setProgress, setSchedulePath, setStartTime, setStatus, setWorkInstanceState, setWorkInstanceSuspending, startTransaction, suspended, toString, workFailedMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface org.nuxeo.ecm.core.work.api.Work
isCoalescing
-
Field Details
-
CATEGORY_THREED_CONVERSION
- See Also:
-
THREED_CONVERSIONS_DONE_EVENT
- See Also:
-
STATUS_DONE
- See Also:
-
-
Constructor Details
-
ThreeDBatchUpdateWork
-
-
Method Details
-
computeIdPrefix
-
getCategory
Description copied from interface:WorkGets the category for this work.Used to choose an execution queue.
- Specified by:
getCategoryin interfaceWork- Overrides:
getCategoryin classAbstractWork- Returns:
- the category, or
nullfor the default
-
getTitle
Description copied from interface:WorkGets a human-readable name for this work instance.- Returns:
- a human-readable name
-
isIdempotent
public boolean isIdempotent()Description copied from interface:WorkReturns true if a work with a givenWork.getId()should always produce the same result. The WorkManager implementation can safely skip duplicate executions of idempotent work. -
isGroupJoin
public boolean isGroupJoin()Description copied from interface:WorkWhen true the Work is part of a group, Works of the group have the sameWork.getPartitionKey(). When all Works of the group are done theWork.onGroupJoinCompletion()hook is called. -
getPartitionKey
Description copied from interface:WorkReturns a key that can be used by the WorkManager implementation to guarantee that works with the same partition key will be executed in the order they are submitted.- Specified by:
getPartitionKeyin interfaceWork- Overrides:
getPartitionKeyin classAbstractWork
-
onGroupJoinCompletion
public void onGroupJoinCompletion()Description copied from interface:WorkCalled whenWork.isGroupJoin()returns true and after the last Work of the group. -
work
public void work()Description copied from interface:WorkThis method should implement the actual work done by theWorkinstance.It should periodically update its progress through
Work.setProgress(org.nuxeo.ecm.core.work.api.Work.Progress).To allow for suspension by the
WorkManager, it should periodically callWork.isSuspending(), and iftruecallWork.suspended()return early with saved state data.Clean up can by implemented by
Work.cleanUp(boolean, Exception).- Specified by:
workin interfaceWork- Specified by:
workin classAbstractWork- See Also:
-
getThreeDToConvert
-
saveNewProperties
-
saveMainInfo
-
saveNewTransmissionThreeDs
protected void saveNewTransmissionThreeDs(DocumentModel doc, List<TransmissionThreeD> transmissionThreeDs) -
saveNewRenderViews
-
fireThreeDConversionsDoneEvent
Fire aTHREED_CONVERSIONS_DONE_EVENT
-