/*
* Copyright (C) 2012 Red Hat, Inc. and/or its affiliates.
*
* 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.errai.bus.server.service.bootstrap;
import java.util.Map;
import java.util.Set;
import org.jboss.errai.bus.client.api.messaging.MessageBus;
import org.jboss.errai.bus.server.service.ErraiServiceConfigurator;
import org.jboss.errai.bus.server.service.ErraiServiceConfiguratorImpl;
import org.jboss.errai.common.client.api.ResourceProvider;
import org.jboss.errai.common.metadata.MetaDataScanner;
import org.jboss.errai.common.server.api.ErraiBootstrapFailure;
import org.jboss.errai.common.server.api.ErraiConfig;
import org.jboss.errai.common.server.api.ErraiConfigExtension;
import org.jboss.errai.common.server.api.annotations.ExtensionComponent;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.google.inject.AbstractModule;
import com.google.inject.CreationException;
import com.google.inject.Guice;
/**
* @author: Heiko Braun <hbraun@redhat.com>
* @date: May 7, 2010
*/
public class LoadExtensions implements BootstrapExecution {
private final Logger log = LoggerFactory.getLogger(LoadExtensions.class);
@Override
public void execute(final BootstrapContext context) {
final ErraiServiceConfiguratorImpl config = (ErraiServiceConfiguratorImpl) context.getConfig();
boolean autoScanModules = true;
if (config.hasProperty("errai.auto_load_extensions")) {
autoScanModules = Boolean.parseBoolean(config.getProperty("errai.auto_load_extensions"));
}
if (autoScanModules) {
log.info("searching for errai extensions ...");
final ErraiConfig erraiConfig = new ErraiConfig() {
@Override
public void addBinding(Class<?> type, ResourceProvider provider) {
config.getExtensionBindings().put(type, provider);
}
@Override
public void addResourceProvider(String name, ResourceProvider provider) {
config.getResourceProviders().put(name, provider);
}
};
// Search for Errai extensions.
final MetaDataScanner scanner = context.getScanner();
final Set<Class<?>> extensionComponents = scanner.getTypesAnnotatedWith(ExtensionComponent.class);
for (final Class<?> loadClass : extensionComponents) {
if (ErraiConfigExtension.class.isAssignableFrom(loadClass)) {
// We have an annotated ErraiConfigExtension. So let's configure it.
final Class<? extends ErraiConfigExtension> clazz =
loadClass.asSubclass(ErraiConfigExtension.class);
log.info("found extension " + clazz.getName());
try {
final Runnable create = new Runnable() {
@Override
public void run() {
final AbstractModule module = new AbstractModule() {
@Override
protected void configure() {
bind(ErraiConfigExtension.class).to(clazz);
bind(ErraiServiceConfigurator.class).toInstance(config);
bind(MessageBus.class).toInstance(context.getBus());
// Add any extension bindings.
for (final Map.Entry<Class<?>, ResourceProvider> entry : config.getExtensionBindings().entrySet()) {
bind(entry.getKey()).toProvider(new GuiceProviderProxy(entry.getValue()));
}
}
};
Guice.createInjector(module)
.getInstance(ErraiConfigExtension.class)
.configure(erraiConfig);
}
};
try {
create.run();
}
catch (final CreationException e) {
log.debug("extension " + clazz.getName() + " cannot be bound yet, deferring ...");
context.defer(create);
}
}
catch (final Throwable e) {
throw new ErraiBootstrapFailure("could not initialize extension: " + loadClass.getName(), e);
}
}
}
}
else {
log.info("auto-loading of extensions disabled.");
}
}
}