
org.jboss.shrinkwrap.resolver.api.ResolverSystemFactory Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of shrinkwrap-resolver-api Show documentation
Show all versions of shrinkwrap-resolver-api Show documentation
API to Resolve Dependencies from a Generic Backend
The newest version!
/*
* JBoss, Home of Professional Open Source
* Copyright 2010, Red Hat Middleware LLC, and individual contributors
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* Licensed 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.jboss.shrinkwrap.resolver.api;
/**
* Utility capable of creating {@link ResolverSystem} instances given a requested end-user view.
*
* @author ALR
*/
final class ResolverSystemFactory {
private static final String CLASS_NAME_SERVICELOADER = "org.jboss.shrinkwrap.resolver.spi.loader.ServiceLoader";
private static final String CLASS_NAME_SPISERVICELOADER = "org.jboss.shrinkwrap.resolver.spi.loader.SpiServiceLoader";
private static final String CLASS_NAME_SERVICEREGISTRY = "org.jboss.shrinkwrap.resolver.spi.loader.ServiceRegistry";
private static final String METHOD_NAME_ONLY_ONE = "onlyOne";
private static final String METHOD_NAME_REGISTER = "register";
/**
* Internal constructor; not to be called
*/
private ResolverSystemFactory() {
throw new UnsupportedOperationException("No instances permitted");
}
/**
* Creates a new {@link ResolverSystem} instance of the specified user view type using the {@link Thread} Context
* {@link ClassLoader}. Will consult a configuration file visible to the {@link Thread} Context {@link ClassLoader} named
* "META-INF/services/$fullyQualifiedClassName" which should contain a key=value format with a key representing the fully
* qualified class name of the implementation class. The implementation class name must have a no-arg constructor.
*
* @param userViewClass The user view type
* @return The new {@link ResolverSystem} instance of the specified user view type created by using the {@link Thread}
* Context {@link ClassLoader}.
* @throws IllegalArgumentException
* If the user view class was not specified
*/
static RESOLVERSYSTEMTYPE createFromUserView(
final Class userViewClass) throws IllegalArgumentException {
return createFromUserView(userViewClass, SecurityActions.getThreadContextClassLoader());
}
/**
* Creates a new {@link ResolverSystem} instance of the specified user view type using the {@link Thread} Context
* {@link ClassLoader}. Will consult a configuration file visible to the {@link Thread} Context {@link ClassLoader} named
* "META-INF/services/$fullyQualifiedClassName" which should contain a key=value format with a key representing the fully
* qualified class name of the implementation class. The implementation class name must have a no-arg constructor.
*
* @param userViewClass The user view type
* @param cl The {@link ClassLoader}
* @return The new {@link ResolverSystem} instance of the specified user view type created by using the specified
* {@link ClassLoader}.
*/
static RESOLVERSYSTEMTYPE createFromUserView(
final Class userViewClass, final ClassLoader cl) {
assert userViewClass != null : "user view class must be specified";
assert cl != null : "ClassLoader must be specified";
// get SPI service loader
final Object spiServiceLoader = new Invokable(cl, CLASS_NAME_SPISERVICELOADER)
.invokeConstructor(new Class[] { ClassLoader.class }, new Object[] { cl });
// return service loader implementation
final Object serviceLoader = new Invokable(cl, CLASS_NAME_SPISERVICELOADER).invokeMethod(METHOD_NAME_ONLY_ONE,
new Class[] { Class.class, Class.class }, spiServiceLoader,
new Object[] { Invokable.loadClass(cl, CLASS_NAME_SPISERVICELOADER), spiServiceLoader.getClass() });
// get registry
final Object serviceRegistry = new Invokable(cl, CLASS_NAME_SERVICEREGISTRY).invokeConstructor(
new Class>[] { Invokable.loadClass(cl, CLASS_NAME_SERVICELOADER) },
new Object[] { serviceLoader });
// register itself
new Invokable(cl, serviceRegistry.getClass()).invokeMethod(METHOD_NAME_REGISTER,
new Class>[] { serviceRegistry.getClass() }, null, new Object[] { serviceRegistry });
Object userViewObject = new Invokable(cl, serviceRegistry.getClass()).invokeMethod(METHOD_NAME_ONLY_ONE,
new Class>[] { Class.class }, serviceRegistry, new Object[] { userViewClass });
return userViewClass.cast(userViewObject);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy