public final class io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess extends java.lang.Object implements com.adobe.granite.workflow.exec.WorkflowProcess
{
private static final org.slf4j.Logger log;
private com.adobe.granite.workflow.collection.ResourceCollectionManager resourceCollectionManager;
private io.wcm.handler.mediasource.dam.impl.metadata.AssetSynchonizationService assetSynchronizationService;
private com.day.cq.dam.api.handler.store.AssetStore assetStore;
public void <init>()
{
io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess v;
v := @this: io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess;
specialinvoke v.<java.lang.Object: void <init>()>();
return;
}
public void execute(com.adobe.granite.workflow.exec.WorkItem, com.adobe.granite.workflow.WorkflowSession, com.adobe.granite.workflow.metadata.MetaDataMap)
{
io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess v;
com.adobe.granite.workflow.exec.WorkItem v;
java.lang.Integer v, v;
com.adobe.granite.workflow.collection.ResourceCollectionManager v;
int v, v;
java.lang.String v, v;
boolean v, v;
org.slf4j.Logger v, v, v, v, v;
com.adobe.granite.workflow.metadata.MetaDataMap v;
java.util.Iterator v;
com.adobe.granite.workflow.exec.WorkflowData v;
java.util.List v;
com.adobe.granite.workflow.WorkflowSession v;
java.lang.Object v, v;
v := @this: io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess;
v := @parameter: com.adobe.granite.workflow.exec.WorkItem;
v := @parameter: com.adobe.granite.workflow.WorkflowSession;
v := @parameter: com.adobe.granite.workflow.metadata.MetaDataMap;
v = staticinvoke <io.wcm.handler.mediasource.dam.impl.metadata.WorkflowProcessUtil: java.lang.String getPayloadResourcePath(com.adobe.granite.workflow.exec.WorkItem)>(v);
if v != null goto label;
v = <io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: org.slf4j.Logger log>;
v = interfaceinvoke v.<com.adobe.granite.workflow.exec.WorkItem: com.adobe.granite.workflow.exec.WorkflowData getWorkflowData()>();
v = interfaceinvoke v.<com.adobe.granite.workflow.exec.WorkflowData: java.lang.String getPayloadType()>();
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Object)>("Invalid payload: {}", v);
return;
label:
v = staticinvoke <io.wcm.sling.commons.adapter.AdaptTo: java.lang.Object notNull(org.apache.sling.api.adapter.Adaptable,java.lang.Class)>(v, class "Lorg/apache/sling/api/resource/ResourceResolver;");
v = v.<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: com.adobe.granite.workflow.collection.ResourceCollectionManager resourceCollectionManager>;
v = staticinvoke <io.wcm.handler.mediasource.dam.impl.metadata.WorkflowProcessUtil: java.util.List getPayloadResourcePaths(java.lang.String,java.lang.String,org.apache.sling.api.resource.ResourceResolver,com.adobe.granite.workflow.collection.ResourceCollectionManager)>(v, "dam:Asset", v, v);
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v == 0 goto label;
v = <io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("Did not found any asset reference in workflow payload: {}", v);
goto label;
label:
v = <io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: org.slf4j.Logger log>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Start processing {} asset references from workflow payload {} ...", v, v);
v = <io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: org.slf4j.Logger log>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("All asset references: {}", v);
label:
v = interfaceinvoke v.<java.util.List: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
specialinvoke v.<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: void process(java.lang.String,org.apache.sling.api.resource.ResourceResolver)>(v, v);
goto label;
label:
v = <io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: org.slf4j.Logger log>;
v = interfaceinvoke v.<java.util.List: int size()>();
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object,java.lang.Object)>("Finished processing {} asset references from workflow payload {}.", v, v);
return;
}
private void process(java.lang.String, org.apache.sling.api.resource.ResourceResolver)
{
java.lang.Throwable v;
com.day.cq.dam.api.Asset v;
io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataGenerator v;
org.apache.sling.api.resource.ResourceResolver v;
org.slf4j.Logger v;
io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess v;
java.util.concurrent.locks.Lock v;
com.day.cq.dam.api.handler.store.AssetStore v;
java.lang.String v, v, v;
io.wcm.handler.mediasource.dam.impl.metadata.AssetSynchonizationService v;
v := @this: io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess;
v := @parameter: java.lang.String;
v := @parameter: org.apache.sling.api.resource.ResourceResolver;
v = specialinvoke v.<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: com.day.cq.dam.api.Asset getAsset(java.lang.String,org.apache.sling.api.resource.ResourceResolver)>(v, v);
if v != null goto label;
v = <io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: org.slf4j.Logger log>;
v = interfaceinvoke v.<org.apache.sling.api.resource.ResourceResolver: java.lang.String getUserID()>();
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object,java.lang.Object)>("Unable to read asset at {} with user {}", v, v);
return;
label:
v = v.<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: io.wcm.handler.mediasource.dam.impl.metadata.AssetSynchonizationService assetSynchronizationService>;
v = interfaceinvoke v.<com.day.cq.dam.api.Asset: java.lang.String getPath()>();
v = virtualinvoke v.<io.wcm.handler.mediasource.dam.impl.metadata.AssetSynchonizationService: java.util.concurrent.locks.Lock getLock(java.lang.String)>(v);
interfaceinvoke v.<java.util.concurrent.locks.Lock: void lock()>();
label:
interfaceinvoke v.<org.apache.sling.api.resource.ResourceResolver: void refresh()>();
v = new io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataGenerator;
v = v.<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: com.day.cq.dam.api.handler.store.AssetStore assetStore>;
specialinvoke v.<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataGenerator: void <init>(org.apache.sling.api.resource.ResourceResolver,com.day.cq.dam.api.handler.store.AssetStore)>(v, v);
virtualinvoke v.<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataGenerator: void processAllRenditions(com.day.cq.dam.api.Asset)>(v);
label:
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
goto label;
label:
v := @caughtexception;
interfaceinvoke v.<java.util.concurrent.locks.Lock: void unlock()>();
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
}
private com.day.cq.dam.api.Asset getAsset(java.lang.String, org.apache.sling.api.resource.ResourceResolver)
{
com.day.cq.dam.api.Asset v;
org.apache.sling.api.resource.ResourceResolver v;
io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess v;
org.apache.sling.api.resource.Resource v;
java.lang.String v;
v := @this: io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess;
v := @parameter: java.lang.String;
v := @parameter: org.apache.sling.api.resource.ResourceResolver;
v = interfaceinvoke v.<org.apache.sling.api.resource.ResourceResolver: org.apache.sling.api.resource.Resource getResource(java.lang.String)>(v);
if v == null goto label;
v = staticinvoke <com.day.cq.dam.commons.util.DamUtil: com.day.cq.dam.api.Asset resolveToAsset(org.apache.sling.api.resource.Resource)>(v);
return v;
label:
return null;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lio/wcm/handler/mediasource/dam/impl/metadata/RenditionMetadataWorkflowProcess;");
<io.wcm.handler.mediasource.dam.impl.metadata.RenditionMetadataWorkflowProcess: org.slf4j.Logger log> = v;
return;
}
}