EntityUnPublishOperation.java
5.33 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/*
* 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);
}
}
}