in bundle/src/main/java/org/apache/karaf/cellar/bundle/BundleEventHandler.java [51:136]
public void handle(ClusterBundleEvent event) {
// check if the handler switch is ON
if (this.getSwitch().getStatus().equals(SwitchStatus.OFF)) {
LOGGER.debug("CELLAR BUNDLE: {} switch is OFF, cluster event is not handled", SWITCH_ID);
return;
}
if (groupManager == null) {
//in rare cases for example right after installation this happens!
LOGGER.error("CELLAR BUNDLE: retrieved event {} while groupManager is not available yet!", event);
return;
}
// check if the group is local
if (!groupManager.isLocalGroup(event.getSourceGroup().getName())) {
LOGGER.debug("CELLAR BUNDLE: node is not part of the event cluster group {}", event.getSourceGroup().getName());
return;
}
try {
// check if it's not a "local" event
if (event.getLocal() != null && event.getLocal().getId().equalsIgnoreCase(clusterManager.getNode().getId())) {
LOGGER.trace("CELLAR BUNDLE: cluster event is local (coming from local synchronizer or listener)");
return;
}
// check if the pid is marked as local.
if (isAllowed(event.getSourceGroup(), Constants.CATEGORY, event.getLocation(), EventType.INBOUND)) {
// check the features first
List<Feature> matchingFeatures = retrieveFeature(event.getLocation());
for (Feature feature : matchingFeatures) {
if (!isAllowed(event.getSourceGroup(), "feature", feature.getName(), EventType.INBOUND)) {
LOGGER.trace("CELLAR BUNDLE: bundle {} is contained in feature {} marked BLOCKED INBOUND for cluster group {}", event.getLocation(), feature.getName(), event.getSourceGroup().getName());
return;
}
}
if (event.getType() == Bundle.INSTALLED) {
installBundleFromLocation(event.getLocation(), event.getStartLevel());
LOGGER.debug("CELLAR BUNDLE: installing {}/{}", event.getSymbolicName(), event.getVersion());
} else if (event.getType() == Bundle.UNINSTALLED) {
uninstallBundle(event.getSymbolicName(), event.getVersion());
LOGGER.debug("CELLAR BUNDLE: uninstalling {}/{}", event.getSymbolicName(), event.getVersion());
} else if (event.getType() == Bundle.ACTIVE) {
if (!isInstalled(event.getLocation())) {
installBundleFromLocation(event.getLocation(), event.getStartLevel());
}
try {
startBundle(event.getSymbolicName(), event.getVersion());
LOGGER.debug("CELLAR BUNDLE: starting {}/{}", event.getSymbolicName(), event.getVersion());
} catch (Exception e) {
// start failed, update cluster state
Map<String, BundleState> clusterBundles = clusterManager.getMap(Constants.BUNDLE_MAP + Configurations.SEPARATOR + event.getSourceGroup().getName());
BundleState state = clusterBundles.get(event.getSymbolicName() + "/" + event.getVersion());
if (state != null) {
state.setStatus(Bundle.INSTALLED);
clusterBundles.put(event.getSymbolicName() + "/" + event.getVersion(), state);
}
}
} else if (event.getType() == Bundle.RESOLVED) {
if (!isInstalled(event.getLocation())) {
installBundleFromLocation(event.getLocation(), event.getStartLevel());
LOGGER.debug("CELLAR BUNDLE: installing {}/{}", event.getSymbolicName(), event.getVersion());
}
Bundle b = findBundle(event.getLocation());
if (b != null) {
if (b.getState() == Bundle.ACTIVE) {
LOGGER.debug("CELLAR BUNDLE: stopping bundle {}/{} on node", event.getSymbolicName(), event.getVersion());
stopBundle(event.getSymbolicName(), event.getVersion());
} else if (b.getState() == Bundle.INSTALLED) {
LOGGER.debug("CELLAR BUNDLE: resolving bundle {}/{} on node", event.getSymbolicName(), event.getVersion());
getBundleContext().getBundle(0).adapt(FrameworkWiring.class).resolveBundles(Collections.singleton(b));
}
} else {
LOGGER.warn("CELLAR BUNDLE: unable to find bundle located {} on node", event.getLocation());
}
} else if (event.getType() == BundleState.UPDATE) {
updateBundle(event.getSymbolicName(), event.getVersion(), event.getLocation());
}
} else
LOGGER.trace("CELLAR BUNDLE: bundle {} is marked BLOCKED INBOUND for cluster group {}", event.getSymbolicName(), event.getSourceGroup().getName());
} catch (BundleException e) {
LOGGER.error("CELLAR BUNDLE: failed to install bundle {}/{}.", new Object[]{event.getSymbolicName(), event.getVersion()}, e);
} catch (Exception e) {
LOGGER.error("CELLAR BUNDLE: failed to handle bundle event", e);
}
}