/*
* Copyright (c) 2016 Cisco Systems, Inc. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.groupbasedpolicy.sxp_ise_adapter.impl;
import org.opendaylight.controller.md.sal.binding.api.ClusteredDataTreeChangeListener;
import org.opendaylight.controller.md.sal.binding.api.DataBroker;
import org.opendaylight.controller.md.sal.binding.api.DataTreeIdentifier;
import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
import org.opendaylight.controller.sal.binding.api.BindingAwareBroker;
import org.opendaylight.controller.sal.binding.api.BindingAwareProvider;
import org.opendaylight.groupbasedpolicy.sxp.ep.provider.api.EPPolicyTemplateProvider;
import org.opendaylight.groupbasedpolicy.sxp.ep.provider.spi.SxpEpProviderProvider;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.groupbasedpolicy.sxp.integration.sxp.ise.adapter.model.rev160630.GbpSxpIseAdapter;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.config.groupbasedpolicy.sxp.integration.sxp.ise.adapter.model.rev160630.gbp.sxp.ise.adapter.IseSourceConfig;
import org.opendaylight.yangtools.concepts.ListenerRegistration;
import org.opendaylight.yangtools.concepts.ObjectRegistration;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.google.common.base.Preconditions;
/**
* Purpose: main provider of gbp-ise adapter (for reading sgts and generating EndpointPolicyTemplates)
*/
public class GbpIseAdapterProvider implements AutoCloseable, BindingAwareProvider {
private static final Logger LOG = LoggerFactory.getLogger(GbpIseAdapterProvider.class);
private final DataBroker dataBroker;
private final SxpEpProviderProvider sxpEpProvider;
private ListenerRegistration<ClusteredDataTreeChangeListener<IseSourceConfig>> registration;
private ObjectRegistration<EPPolicyTemplateProvider> epPolicyTemplateProviderRegistration;
public GbpIseAdapterProvider(final DataBroker dataBroker, final BindingAwareBroker broker,
final SxpEpProviderProvider sxpEpProvider) {
this.dataBroker = Preconditions.checkNotNull(dataBroker, "provided dataBroker must not be null");
this.sxpEpProvider = Preconditions.checkNotNull(sxpEpProvider, "provided sxp-ep-provider must not be null");
broker.registerProvider(this);
}
@Override
public void close() throws Exception {
if (registration != null) {
LOG.info("closing GbpIseAdapterProvider");
registration.close();
registration = null;
}
if (epPolicyTemplateProviderRegistration != null) {
LOG.info("closing EPPolicyTemplateProvider");
epPolicyTemplateProviderRegistration.close();
epPolicyTemplateProviderRegistration = null;
}
}
@Override
public void onSessionInitiated(final BindingAwareBroker.ProviderContext providerContext) {
LOG.info("Starting GbpIseAdapterProvider ..");
// setup template provider pipeline
final EPPolicyTemplateProviderFacade templateProviderFacade = new EPPolicyTemplateProviderIseImpl();
epPolicyTemplateProviderRegistration = sxpEpProvider.getEPPolicyTemplateProviderRegistry()
.registerTemplateProvider(templateProviderFacade);
// setup harvesting and processing pipeline
final SgtInfoProcessor epgGenerator = new SgtToEpgGeneratorImpl(dataBroker);
final SgtInfoProcessor templateGenerator = new SgtToEPTemplateGeneratorImpl(dataBroker);
final GbpIseSgtHarvester gbpIseSgtHarvester = new GbpIseSgtHarvesterImpl(epgGenerator, templateGenerator);
final GbpIseConfigListenerImpl gbpIseConfigListener = new GbpIseConfigListenerImpl(
dataBroker, gbpIseSgtHarvester, templateProviderFacade);
templateProviderFacade.setIseSgtHarvester(gbpIseSgtHarvester);
// build data-tree path
final DataTreeIdentifier<IseSourceConfig> dataTreePath = new DataTreeIdentifier<>(
LogicalDatastoreType.CONFIGURATION,
InstanceIdentifier.create(GbpSxpIseAdapter.class).child(IseSourceConfig.class));
// register config listener
registration = dataBroker.registerDataTreeChangeListener(dataTreePath,
gbpIseConfigListener);
LOG.info("Started");
}
}