SourceResolverImpl.java
1.89 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
/*
* Decompiled with CFR 0_118.
*
* Could not load the following classes:
* org.apache.sling.api.SlingHttpServletRequest
* org.apache.sling.api.SlingHttpServletResponse
* org.apache.sling.api.resource.ResourceResolver
* org.slf4j.Logger
* org.slf4j.LoggerFactory
*/
package com.day.cq.rewriter.xml;
import com.day.cq.rewriter.xml.SlingResourceSourceFactory;
import java.io.File;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.HashMap;
import java.util.Map;
import org.apache.excalibur.source.SourceFactory;
import org.apache.excalibur.source.factories.FileSourceFactory;
import org.apache.excalibur.source.factories.ResourceSourceFactory;
import org.apache.excalibur.source.factories.URLSourceFactory;
import org.apache.excalibur.source.impl.DefaultSourceResolver;
import org.apache.sling.api.SlingHttpServletRequest;
import org.apache.sling.api.SlingHttpServletResponse;
import org.apache.sling.api.resource.ResourceResolver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class SourceResolverImpl
extends DefaultSourceResolver {
private final Logger logger;
public SourceResolverImpl(ResourceResolver resolver, SlingHttpServletRequest request, SlingHttpServletResponse response) {
this.logger = LoggerFactory.getLogger((String)this.getClass().getName());
HashMap<String, SourceFactory> factories = new HashMap<String, SourceFactory>();
factories.put("file", new FileSourceFactory());
factories.put("resource", new ResourceSourceFactory());
factories.put("sling", new SlingResourceSourceFactory(resolver, request, response));
factories.put("*", new URLSourceFactory());
this.setSourceFactories(factories);
try {
this.setBaseURL(new File(".").toURL());
}
catch (MalformedURLException e) {
this.logger.error("Exception occured.", (Throwable)e);
}
}
}