Scene7Rendition.java
4.99 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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* com.adobe.granite.asset.api.Rendition
* javax.jcr.RepositoryException
* javax.jcr.Session
* org.apache.commons.lang.StringUtils
* org.apache.felix.scr.annotations.Reference
* org.apache.sling.api.resource.Resource
* org.apache.sling.api.resource.ResourceResolver
* org.apache.sling.api.resource.ResourceUtil
* org.apache.sling.api.resource.ResourceWrapper
* org.apache.sling.api.resource.ValueMap
* org.apache.sling.jcr.api.SlingRepository
* org.apache.sling.jcr.resource.JcrResourceResolverFactory
* org.slf4j.Logger
* org.slf4j.LoggerFactory
*/
package com.day.cq.dam.scene7.impl.rendition;
import com.adobe.granite.asset.api.Rendition;
import com.day.cq.dam.scene7.api.S7Config;
import com.day.cq.dam.scene7.api.S7ConfigResolver;
import com.day.cq.dam.scene7.api.Scene7APIClient;
import com.day.cq.dam.scene7.impl.rendition.Scene7RenditionProperty;
import java.io.InputStream;
import javax.jcr.RepositoryException;
import javax.jcr.Session;
import org.apache.commons.lang.StringUtils;
import org.apache.felix.scr.annotations.Reference;
import org.apache.sling.api.resource.Resource;
import org.apache.sling.api.resource.ResourceResolver;
import org.apache.sling.api.resource.ResourceUtil;
import org.apache.sling.api.resource.ResourceWrapper;
import org.apache.sling.api.resource.ValueMap;
import org.apache.sling.jcr.api.SlingRepository;
import org.apache.sling.jcr.resource.JcrResourceResolverFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class Scene7Rendition
extends ResourceWrapper
implements Rendition {
private static final Logger LOGGER = LoggerFactory.getLogger(Scene7Rendition.class);
private final ValueMap contentProperties;
private Scene7APIClient scene7Client;
private S7ConfigResolver s7ConfigResolver;
@Reference
private SlingRepository slingRepository;
@Reference
private JcrResourceResolverFactory resolverFactory;
public Scene7Rendition(Resource resource, Scene7APIClient scene7Client, S7ConfigResolver s7ConfigResolver) {
super(resource);
this.scene7Client = scene7Client;
this.s7ConfigResolver = s7ConfigResolver;
Resource contentResource = resource.getResourceResolver().getResource(resource, "jcr:content");
this.contentProperties = ResourceUtil.getValueMap((Resource)contentResource);
}
public String getMimeType() {
return (String)this.contentProperties.get(Scene7RenditionProperty.MIME_TYPE.getPropertyName(), (Object)"");
}
public long getSize() {
return ((Integer)this.contentProperties.get(Scene7RenditionProperty.SIZE.getPropertyName(), (Object)0)).intValue();
}
/*
* WARNING - Removed try catching itself - possible behaviour change.
*/
public InputStream getStream() {
InputStream renditionInputStream;
Resource resource = this.getResource();
Session configSession = null;
S7Config config = null;
renditionInputStream = null;
try {
configSession = this.slingRepository.loginService("scene7configservice", null);
config = this.resolveScene7Configuration(configSession);
String assetHandle = (String)this.contentProperties.get(Scene7RenditionProperty.ASSET_HANDLE.getPropertyName(), (Object)"");
if (StringUtils.isBlank((String)assetHandle)) {
LOGGER.error("Invalid asset handle found on rendition resource {}", (Object)(resource != null ? resource.getPath() : "null"));
}
if (config != null && StringUtils.isNotBlank((String)assetHandle)) {
renditionInputStream = this.scene7Client.getOriginalFile(assetHandle, config);
}
}
catch (RepositoryException ee) {
LOGGER.error("Could not access a S7Config for resource {}", (Object)(resource != null ? resource.getPath() : "null"));
}
finally {
if (configSession != null) {
configSession.logout();
configSession = null;
}
}
return renditionInputStream;
}
private S7Config resolveScene7Configuration(Session configSession) {
ResourceResolver resolver;
S7Config config;
Resource resource = this.getResource();
Resource configResource = null;
if (resource != null) {
ResourceResolver rr = resource.getResourceResolver();
if (rr != null) {
configResource = rr.getResource(resource, "../../metadata");
} else {
LOGGER.error("Invalid Resource resolver obtained from resource {}", (Object)resource.getPath());
}
}
if ((config = this.s7ConfigResolver.getS7Config(resolver = this.resolverFactory.getResourceResolver(configSession), configResource.getPath())) == null) {
LOGGER.error("Could not resolve a S7Config from resource {}", (Object)(resource != null ? resource.getPath() : "null"));
}
return config;
}
}