org.apache.axis2.deployment.resolver.AARFileBasedURIResolver Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of axis2-kernel Show documentation
Show all versions of axis2-kernel Show documentation
Core Parts of Axis2. This includes Axis2 engine, Client API, Addressing support, etc.,
/*
* 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.axis2.deployment.resolver;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.apache.ws.commons.schema.resolver.DefaultURIResolver;
import org.xml.sax.InputSource;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.net.URI;
import java.util.zip.ZipEntry;
import java.util.zip.ZipInputStream;
/**
* A custom URI resolver that can
*/
public class AARFileBasedURIResolver extends DefaultURIResolver {
protected static final Log log = LogFactory
.getLog(AARFileBasedURIResolver.class);
private File aarFile;
private URI lastImportLocation;
public AARFileBasedURIResolver(File aarFile) {
this.aarFile = aarFile;
}
public InputSource resolveEntity(
String targetNamespace,
String schemaLocation,
String baseUri) {
//no issue with abloslute schemas
// this schema can be in a relative location for another base scheama. so first
// try to see the proper location
lastImportLocation = URI.create(baseUri).resolve(schemaLocation);
if (isAbsolute(lastImportLocation.toString())) {
return super.resolveEntity(
targetNamespace, schemaLocation, baseUri);
} else {
//validate
if ((baseUri == null || "".equals(baseUri)) && schemaLocation.startsWith("..")) {
throw new RuntimeException(
"Unsupported schema location " + schemaLocation);
}
ZipInputStream zin = null;
try {
zin = new ZipInputStream(new FileInputStream(aarFile));
ZipEntry entry;
byte[] buf = new byte[1024];
int read;
ByteArrayOutputStream out;
String searchingStr = lastImportLocation.toString();
while ((entry = zin.getNextEntry()) != null) {
String entryName = entry.getName().toLowerCase();
if (entryName.equalsIgnoreCase(searchingStr)) {
out = new ByteArrayOutputStream();
while ((read = zin.read(buf)) > 0) {
out.write(buf, 0, read);
}
ByteArrayInputStream in = new ByteArrayInputStream(out.toByteArray());
InputSource inputSoruce = new InputSource(in);
inputSoruce.setSystemId(lastImportLocation.getPath());
inputSoruce.setPublicId(targetNamespace);
return inputSoruce;
}
}
} catch (IOException e) {
throw new RuntimeException(e);
} finally {
try {
if (zin != null) {
zin.close();
}
} catch (IOException e) {
log.debug(e);
}
}
}
log.info("AARFileBasedURIResolver: Unable to resolve" + lastImportLocation);
return null;
}
}