/*
* Copyright (c) 2016 Cisco 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.
*/
/*
* Modifications copyright (c) 2018 AT&T Intellectual Property
*/
package org.onap.vnf.vlb;
import io.fd.honeycomb.translate.read.ReadFailedException;
import io.fd.honeycomb.translate.write.WriteFailedException;
import java.util.Collections;
import java.util.List;
import javax.annotation.Nonnull;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vlb.business.vnf.onap.plugin.rev160918.VlbBusinessVnfOnapPluginState;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vlb.business.vnf.onap.plugin.rev160918.vlb.business.vnf.onap.plugin.params.VdnsInstances;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vlb.business.vnf.onap.plugin.rev160918.vlb.business.vnf.onap.plugin.params.vdns.instances.VdnsInstance;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vlb.business.vnf.onap.plugin.rev160918.vlb.business.vnf.onap.plugin.params.vdns.instances.VdnsInstanceBuilder;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vlb.business.vnf.onap.plugin.rev160918.vlb.business.vnf.onap.plugin.params.vdns.instances.VdnsInstanceKey;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Simple example of class handling Crud operations for plugin.
*
* No real handling, serves just as an illustration.
*
* TODO update javadoc
*/
final class ElementCrudService implements CrudService {
private static final Logger LOG = LoggerFactory.getLogger(ElementCrudService.class);
@Override
public void writeData(@Nonnull final InstanceIdentifier identifier, @Nonnull final VdnsInstance data)
throws WriteFailedException {
if (data != null) {
// identifier.firstKeyOf(SomeClassUpperInHierarchy.class) can be used to identify
// relationships such as to which parent these data are related to
// Performs any logic needed for persisting such data
LOG.info("Writing path[{}] / data [{}]", identifier, data);
} else {
throw new WriteFailedException.CreateFailedException(identifier, data,
new NullPointerException("Provided data are null"));
}
}
@Override
public void deleteData(@Nonnull final InstanceIdentifier identifier, @Nonnull final VdnsInstance data)
throws WriteFailedException {
if (data != null) {
// identifier.firstKeyOf(SomeClassUpperInHierarchy.class) can be used to identify
// relationships such as to which parent these data are related to
// Performs any logic needed for persisting such data
LOG.info("Removing path[{}] / data [{}]", identifier, data);
} else {
throw new WriteFailedException.DeleteFailedException(identifier,
new NullPointerException("Provided data are null"));
}
}
@Override
public void updateData(@Nonnull final InstanceIdentifier identifier, @Nonnull final VdnsInstance dataOld,
@Nonnull final VdnsInstance dataNew) throws WriteFailedException {
if (dataOld != null && dataNew != null) {
// identifier.firstKeyOf(SomeClassUpperInHierarchy.class) can be used to identify
// relationships such as to which parent these data are related to
// Performs any logic needed for persisting such data
LOG.info("Update path[{}] from [{}] to [{}]", identifier, dataOld, dataNew);
} else {
throw new WriteFailedException.DeleteFailedException(identifier,
new NullPointerException("Provided data are null"));
}
}
@Override
public VdnsInstance readSpecific(@Nonnull final InstanceIdentifier identifier) throws ReadFailedException {
// read key specified in path identifier
final VdnsInstanceKey key = identifier.firstKeyOf(VdnsInstance.class);
// load data by this key
// *Key class will always contain key of entity, in this case long value
return new VdnsInstanceBuilder()
.setIpAddr(key.getIpAddr())
.setKey(key)
.setOamIpAddr("10.0.80.0")
.setEnabled(true)
.build();
}
@Override
public List readAll() throws ReadFailedException {
// read all data under parent node,in this case {@link ModuleState}
return Collections.singletonList(
readSpecific(InstanceIdentifier.create(VlbBusinessVnfOnapPluginState.class).child(VdnsInstances.class).child(VdnsInstance.class, new VdnsInstanceKey(""))));
}
}