/*
* 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.tuscany.sca.implementation.java.injection;
import org.apache.tuscany.sca.core.factory.ObjectCreationException;
import org.apache.tuscany.sca.core.factory.ObjectFactory;
/**
* Resolves a runtime resource to be injected on a field or method of a Java component type marked with {@link
* javax.annotation.Resource}. If the mapped name of the resource is an absolute URI such as
* sca://localhost
or jndi://localhost
the host container namespace is searched; otherwise the
* URI is assumed to be relative and the parent composite is searched. If a mapped name is not provided, i.e. resolution
* is by type, the parent composite is first searched followed by the host namespace.
*
* @version $Rev$ $Date$
*/
public class ResourceObjectFactory implements ObjectFactory {
private Class type;
private String mappedName;
private ResourceHost host;
private boolean optional;
/**
* Instantiates a factory that resolves resources by type
*
* @param type the type of the resource to inject
* @param optional true if an error should be thrown if the resource is not found
* @param host the runtime resource provider
*/
public ResourceObjectFactory(Class type, boolean optional, ResourceHost host) {
this(type, null, optional, host);
}
/**
* Instantiates a factory that resolves resources by mapped name
*
* @param type the type of the resource to inject
* @param mappedName the resource name
* @param optional true if an error should be thrown if the resource is not found
* @param host the runtime resource provider
*/
public ResourceObjectFactory(Class type, String mappedName, boolean optional, ResourceHost host) {
this.type = type;
this.host = host;
this.mappedName = mappedName;
this.optional = optional;
}
public T getInstance() throws ObjectCreationException {
try {
T resource;
if (mappedName == null) {
resource = host.resolveResource(type);
if (!optional && resource == null) {
throw new ResourceNotFoundException("Resource not found: " + type.getName());
}
} else {
resource = host.resolveResource(type, mappedName);
if (!optional && resource == null) {
throw new ResourceNotFoundException("Resource not found: " + mappedName);
}
}
return resource;
} catch (ResourceResolutionException e) {
throw new ObjectCreationException(e);
}
}
}