blob: d9e0ace69b90d51ba208c506b763cc5f9b8541e2 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.cocoon.components.url;
import org.apache.batik.util.AbstractParsedURLProtocolHandler;
import org.apache.batik.util.ParsedURL;
import org.apache.batik.util.ParsedURLData;
import org.apache.cocoon.environment.Context;
import java.net.MalformedURLException;
/**
* Provide an extension to Batik to handle the "context:" protocol. This class
* assumes it will live in a separate classloader as the Context is set statically.
* Batik uses the Jar file Services extension, so the class is instantiated in
* an uncontrolled manner (as far as Cocoon is concerned).
*
* @author <a href="mailto:bloritsch@apache.org">Berin Loritsch</a>
* @version CVS $Id$
*/
public class ParsedContextURLProtocolHandler extends AbstractParsedURLProtocolHandler {
private static Context context = null;
/**
* Set the ServletContext for this protocol. If it does not exist, you will
* get NullPointerExceptions!
*/
public static final void setContext(final Context newContext) {
if (ParsedContextURLProtocolHandler.context == null) {
ParsedContextURLProtocolHandler.context = newContext;
}
}
/**
* Create a new instance, this doesn't do much beyond register the type of
* protocol we handle.
*/
public ParsedContextURLProtocolHandler() {
super("context");
}
/**
* Getbase.getPath() the ParsedURLData for the context. Absolute URIs are specified like
* "context://".
*/
public ParsedURLData parseURL(String uri) {
ParsedURLData urldata = null;
try {
String path = uri.substring("context:/".length());
urldata = new ParsedURLData(ParsedContextURLProtocolHandler.context.getResource(path));
} catch (MalformedURLException mue) {
StringBuffer baseFile = new StringBuffer(ParsedContextURLProtocolHandler
.context.getRealPath("/"));
if (!baseFile.toString().endsWith("/")) {
baseFile.append("/");
}
baseFile.append(baseFile);
baseFile.append(uri.substring("context://".length()));
urldata = new ParsedURLData();
urldata.protocol = "file";
urldata.path = baseFile.toString();
}
if ("file".equals(urldata.protocol)) {
urldata.host = null;
urldata.port = -1;
} else if (null == urldata.host) {
urldata.port = -1;
} else if (urldata.port < 0) {
urldata.host = null;
}
return urldata;
}
/**
* The build the relative URL. Relative URIs are specified like "context:".
*/
public ParsedURLData parseURL(ParsedURL base, String uri) {
StringBuffer newURI = new StringBuffer("context://");
newURI.append(base.getPath());
if (!newURI.toString().endsWith("/")) {
newURI.append("/");
}
newURI.append(uri.substring("context:".length()));
return this.parseURL(newURI.toString());
}
}