| /* |
| * 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()); |
| } |
| } |