WcmWorkflowServlet.java 2.57 KB
/*
 * Decompiled with CFR 0_118.
 * 
 * Could not load the following classes:
 *  com.day.cq.commons.TidyJSONWriter
 *  com.day.cq.workflow.status.WorkflowStatus
 *  javax.servlet.ServletException
 *  org.apache.felix.scr.annotations.sling.SlingServlet
 *  org.apache.sling.api.SlingHttpServletRequest
 *  org.apache.sling.api.SlingHttpServletResponse
 *  org.apache.sling.api.resource.Resource
 *  org.apache.sling.api.resource.ResourceResolver
 *  org.apache.sling.api.servlets.SlingAllMethodsServlet
 *  org.apache.sling.commons.json.JSONException
 *  org.slf4j.Logger
 *  org.slf4j.LoggerFactory
 */
package com.day.cq.wcm.workflow.impl;

import com.day.cq.commons.TidyJSONWriter;
import com.day.cq.workflow.status.WorkflowStatus;
import java.io.IOException;
import java.io.PrintWriter;
import java.io.Writer;
import javax.servlet.ServletException;
import org.apache.felix.scr.annotations.sling.SlingServlet;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.api.servlets.SlingAllMethodsServlet;
import org.apache.sling.commons.json.JSONException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@SlingServlet(paths={"/bin/workflow"})
public class WcmWorkflowServlet
extends SlingAllMethodsServlet {
    Logger log = LoggerFactory.getLogger(WcmWorkflowServlet.class);

    protected void doGet(SlingHttpServletRequest request, SlingHttpServletResponse response) throws ServletException, IOException {
        String resourcePath = request.getParameter("isInWorkflow");
        this.log.info("********************** resourcePath: {}", (Object)resourcePath);
        if (resourcePath != null && !resourcePath.equals("")) {
            Resource resource = request.getResourceResolver().getResource(resourcePath);
            this.log.info("********************** resource    : {}", (Object)resource);
            WorkflowStatus wfState = (WorkflowStatus)resource.adaptTo(WorkflowStatus.class);
            this.log.info("********************** wfState     : {}", (Object)wfState);
            TidyJSONWriter writer = new TidyJSONWriter((Writer)response.getWriter());
            writer.setTidy(true);
            try {
                writer.object();
                writer.key("status").value(wfState.isInRunningWorkflow());
                writer.endObject();
            }
            catch (JSONException e) {
                throw new ServletException("Unable to build response", (Throwable)e);
            }
        }
    }
}