EntityUnPublishOperation.java 5.33 KB
/*
 * Decompiled with CFR 0_118.
 * 
 * Could not load the following classes:
 *  com.adobe.dps.client.producer.EntityType
 *  com.adobe.granite.ui.components.HtmlResponse
 *  com.day.cq.i18n.I18n
 *  javax.servlet.http.HttpServletRequest
 *  org.apache.commons.lang.StringUtils
 *  org.apache.felix.scr.annotations.Component
 *  org.apache.felix.scr.annotations.Properties
 *  org.apache.felix.scr.annotations.Property
 *  org.apache.felix.scr.annotations.Service
 *  org.apache.sling.api.SlingHttpServletRequest
 *  org.apache.sling.api.resource.Resource
 *  org.apache.sling.api.resource.ResourceResolver
 *  org.apache.sling.servlets.post.Modification
 *  org.slf4j.Logger
 */
package com.adobe.cq.mobile.dps.impl.operations;

import com.adobe.cq.mobile.dps.DPSEntity;
import com.adobe.cq.mobile.dps.DPSException;
import com.adobe.cq.mobile.dps.DPSObject;
import com.adobe.cq.mobile.dps.DPSProject;
import com.adobe.cq.mobile.dps.impl.DPSClient;
import com.adobe.cq.mobile.dps.impl.operations.MobilePublishAbstractOperation;
import com.adobe.cq.mobile.dps.impl.utils.DPSUtil;
import com.adobe.cq.mobile.dps.impl.utils.RequestUtils;
import com.adobe.dps.client.producer.EntityType;
import com.adobe.granite.ui.components.HtmlResponse;
import com.day.cq.i18n.I18n;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import org.apache.commons.lang.StringUtils;
import org.apache.felix.scr.annotations.Component;
import org.apache.felix.scr.annotations.Properties;
import org.apache.felix.scr.annotations.Property;
import org.apache.felix.scr.annotations.Service;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.servlets.post.Modification;
import org.slf4j.Logger;

@Component(metatype=0, label="Experience Manager Mobile Article UnPublisher")
@Service
@Properties(value={@Property(name="sling.post.operation", value={"dpsapps:dpsUnpublish"}), @Property(name="sling.servlet.methods", value={"POST"})})
public class EntityUnPublishOperation
extends MobilePublishAbstractOperation {
    public static final String PARAM_ENTITIES = "entityPaths";

    @Override
    protected void perform(SlingHttpServletRequest request, HtmlResponse response, List<Modification> modifications) {
        I18n i18n = new I18n((HttpServletRequest)request);
        Resource resource = request.getResource();
        String responseTitle = i18n.get("The unpublish request was initiated for {0}", resource.getPath());
        String responseMessage = "";
        try {
            DPSObject dpsObject = this.getDPSObject(request);
            if (dpsObject == null) {
                String message = i18n.get("Invalid dps resource {0}", "resource path", new Object[]{resource.getPath()});
                throw new DPSException(message);
            }
            if (dpsObject instanceof DPSProject) {
                DPSProject dpsProject = (DPSProject)dpsObject;
                String entityPathsCSV = RequestUtils.getParameter(request, "entityPaths", null);
                if (entityPathsCSV == null) {
                    throw new DPSException(i18n.get("Required parameter missing: {0}", "parameter name", new Object[]{"entityPaths"}));
                }
                List<DPSEntity> entitiesList = this.getEntityList(resource.getResourceResolver(), entityPathsCSV);
                DPSClient dpsClient = this.getDPSClient(request);
                dpsClient.unpublish(dpsProject, entitiesList);
                responseTitle = i18n.get("The unpublish request was initiated for {0}", "entity type name and resource path", new Object[]{entityPathsCSV});
                responseMessage = i18n.get("Initiated unpublish of {0} {1}", "entity type name and resource path", new Object[]{entityPathsCSV, resource.getPath()});
            } else {
                DPSEntity dpsEntity = this.getDPSEntity(request);
                if (dpsEntity == null) {
                    String message = i18n.get("Invalid dps resource {0}", "resource path", new Object[]{resource.getPath()});
                    throw new DPSException(message);
                }
                DPSClient dpsClient = this.getDPSClient(request);
                String publishJobId = dpsClient.unpublishEntity(dpsEntity);
                EntityType entityType = DPSUtil.getEntityType(dpsEntity);
                String entityName = entityType.name().toLowerCase();
                responseTitle = i18n.get("The {0} unpublish request was initiated", "entity type name", new Object[]{entityName});
                responseMessage = i18n.get("Initiated unpublish of {0} {1}", "entity type name and resource path", new Object[]{entityName, resource.getPath()});
            }
            response.setPath(resource.getPath());
            this.generateResponse(response, 200, responseMessage, responseTitle);
        }
        catch (Exception ex) {
            String title = i18n.get("Error");
            String cause = this.getCauseMessage(ex);
            if (StringUtils.isEmpty((String)cause)) {
                cause = ex.getLocalizedMessage();
            }
            String message = i18n.get("Error initiating unpublish of {0}. {1}", "entity name and root cause", new Object[]{resource.getName(), cause});
            this.getLogger().error(message, (Throwable)ex);
            this.generateError(response, message, title, ex);
        }
    }
}