/**
* 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.camel.component.kura;
import java.io.ByteArrayInputStream;
import java.io.InputStream;
import java.util.Map;
import org.apache.camel.CamelContext;
import org.apache.camel.ConsumerTemplate;
import org.apache.camel.ProducerTemplate;
import org.apache.camel.builder.RouteBuilder;
import org.apache.camel.core.osgi.OsgiDefaultCamelContext;
import org.apache.camel.model.RoutesDefinition;
import org.osgi.framework.BundleActivator;
import org.osgi.framework.BundleContext;
import org.osgi.framework.ServiceReference;
import org.osgi.service.cm.Configuration;
import org.osgi.service.cm.ConfigurationAdmin;
import org.osgi.service.component.ComponentContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public abstract class KuraRouter extends RouteBuilder implements BundleActivator {
// Member collaborators
protected final Logger log = LoggerFactory.getLogger(getClass());
protected BundleContext bundleContext;
protected CamelContext camelContext;
protected ProducerTemplate producerTemplate;
protected ConsumerTemplate consumerTemplate;
// Lifecycle
@Override
public void start(BundleContext bundleContext) throws Exception {
try {
this.bundleContext = bundleContext;
log.debug("Initializing bundle {}.", bundleContext.getBundle().getBundleId());
camelContext = createCamelContext();
camelContext.addRoutes(this);
ConfigurationAdmin configurationAdmin = requiredService(ConfigurationAdmin.class);
Configuration camelKuraConfig = configurationAdmin.getConfiguration(camelXmlRoutesPid());
if (camelKuraConfig != null && camelKuraConfig.getProperties() != null) {
Object routePropertyValue = camelKuraConfig.getProperties().get(camelXmlRoutesProperty());
if (routePropertyValue != null) {
InputStream routesXml = new ByteArrayInputStream(routePropertyValue.toString().getBytes());
RoutesDefinition loadedRoutes = camelContext.loadRoutesDefinition(routesXml);
camelContext.addRouteDefinitions(loadedRoutes.getRoutes());
}
}
beforeStart(camelContext);
log.debug("About to start Camel Kura router: {}", getClass().getName());
camelContext.start();
producerTemplate = camelContext.createProducerTemplate();
consumerTemplate = camelContext.createConsumerTemplate();
log.debug("Bundle {} started.", bundleContext.getBundle().getBundleId());
} catch (Throwable e) {
String errorMessage = "Problem when starting Kura module " + getClass().getName() + ":";
log.warn(errorMessage, e);
// Print error to the Kura console.
System.err.println(errorMessage);
e.printStackTrace();
throw e;
}
}
@Override
public void stop(BundleContext bundleContext) throws Exception {
log.debug("Stopping bundle {}.", bundleContext.getBundle().getBundleId());
camelContext.stop();
log.debug("Bundle {} stopped.", bundleContext.getBundle().getBundleId());
}
protected void activate(ComponentContext componentContext, Map<String, Object> properties) throws Exception {
start(componentContext.getBundleContext());
}
protected void deactivate(ComponentContext componentContext) throws Exception {
stop(componentContext.getBundleContext());
}
// Callbacks
@Override
public void configure() throws Exception {
log.debug("No programmatic routes configuration found.");
}
protected CamelContext createCamelContext() {
return new OsgiDefaultCamelContext(bundleContext);
}
protected void beforeStart(CamelContext camelContext) {
log.debug("Empty KuraRouter CamelContext before start configuration - skipping.");
}
// API Helpers
protected <T> T service(Class<T> serviceType) {
ServiceReference reference = bundleContext.getServiceReference(serviceType);
return reference == null ? null : (T) bundleContext.getService(reference);
}
protected <T> T requiredService(Class<T> serviceType) {
ServiceReference reference = bundleContext.getServiceReference(serviceType);
if (reference == null) {
throw new IllegalStateException("Cannot find service: " + serviceType.getName());
}
return (T) bundleContext.getService(reference);
}
// Private helpers
protected String camelXmlRoutesPid() {
return "kura.camel";
}
protected String camelXmlRoutesProperty() {
return "kura.camel." + bundleContext.getBundle().getSymbolicName() + ".route";
}
}