GateKeeperProcess.java 4.19 KB
/*
 * Decompiled with CFR 0_118.
 * 
 * Could not load the following classes:
 *  com.day.cq.dam.api.Asset
 *  com.day.cq.dam.api.Rendition
 *  com.day.cq.dam.commons.process.AbstractAssetWorkflowProcess
 *  com.day.cq.workflow.WorkflowException
 *  com.day.cq.workflow.WorkflowSession
 *  com.day.cq.workflow.exec.Route
 *  com.day.cq.workflow.exec.WorkItem
 *  com.day.cq.workflow.exec.Workflow
 *  com.day.cq.workflow.exec.WorkflowData
 *  com.day.cq.workflow.metadata.MetaDataMap
 *  javax.jcr.Node
 *  javax.jcr.Property
 *  javax.jcr.RepositoryException
 *  javax.jcr.Session
 *  org.apache.felix.scr.annotations.Component
 *  org.apache.felix.scr.annotations.Property
 *  org.apache.felix.scr.annotations.Service
 *  org.slf4j.Logger
 *  org.slf4j.LoggerFactory
 */
package com.day.cq.dam.core.process;

import com.day.cq.dam.api.Asset;
import com.day.cq.dam.api.Rendition;
import com.day.cq.dam.commons.process.AbstractAssetWorkflowProcess;
import com.day.cq.dam.core.process.SyncVarProcess;
import com.day.cq.workflow.WorkflowException;
import com.day.cq.workflow.WorkflowSession;
import com.day.cq.workflow.exec.Route;
import com.day.cq.workflow.exec.WorkItem;
import com.day.cq.workflow.exec.Workflow;
import com.day.cq.workflow.exec.WorkflowData;
import com.day.cq.workflow.metadata.MetaDataMap;
import java.util.List;
import javax.jcr.Node;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Property;
import org.apache.felix.scr.annotations.Service;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Component(metatype=0)
@Service
@Property(name="process.label", value={"Gate Keeper"})
public class GateKeeperProcess
extends AbstractAssetWorkflowProcess {
    private static final Logger log = LoggerFactory.getLogger(SyncVarProcess.class);

    public void execute(WorkItem workItem, WorkflowSession workflowSession, MetaDataMap metaData) throws WorkflowException {
        block10 : {
            try {
                Asset asset = this.getAssetFromPayload(workItem, workflowSession.getSession());
                if (null != asset) {
                    Node assetNode = (Node)asset.adaptTo(Node.class);
                    if (asset.getOriginal().getSize() == 0 || assetNode.hasProperty("jcr:content/restored")) {
                        if (assetNode.hasProperty("jcr:content/restored")) {
                            assetNode.getNode("jcr:content").getProperty("restored").remove();
                            log.debug("It is a restored asset[{}], no processing needed. terminating workflow...", (Object)asset.getPath());
                        } else {
                            log.debug("File size is ZERO. terminating workflow...", (Object)asset.getPath());
                        }
                        workflowSession.terminateWorkflow(workItem.getWorkflow());
                        log.debug("execute: terminated workflow for asset [{}] .", (Object)asset.getPath());
                    } else if (!metaData.containsKey((Object)"PROCESS_AUTO_ADVANCE") || !((Boolean)metaData.get("PROCESS_AUTO_ADVANCE", Boolean.class)).booleanValue()) {
                        boolean advanced = false;
                        List routes = workflowSession.getRoutes(workItem);
                        for (Route route : routes) {
                            if (!route.hasDefault()) continue;
                            workflowSession.complete(workItem, route);
                            advanced = true;
                            break;
                        }
                        if (!advanced) {
                            workflowSession.complete(workItem, (Route)routes.get(0));
                        }
                    }
                    break block10;
                }
                String wfPayload = workItem.getWorkflowData().getPayload().toString();
                String message = "execute: gatekeeping failed, asset [{" + wfPayload + "}] in payload doesn't exist for workflow [{" + workItem.getId() + "}].";
                throw new WorkflowException(message);
            }
            catch (RepositoryException e) {
                throw new WorkflowException((Throwable)e);
            }
        }
    }
}