package org.opendaylight.neutron.transcriber;
-import java.util.ArrayList;
-import java.util.HashSet;
import java.util.List;
-import java.util.Map.Entry;
-import java.util.Set;
-import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
+import org.opendaylight.controller.md.sal.binding.api.DataBroker;
import org.opendaylight.neutron.spi.INeutronSecurityGroupCRUD;
-import org.opendaylight.neutron.spi.INeutronSecurityRuleCRUD;
-import org.opendaylight.neutron.spi.NeutronCRUDInterfaces;
import org.opendaylight.neutron.spi.NeutronSecurityGroup;
-import org.opendaylight.neutron.spi.NeutronSecurityRule;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Uuid;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.rev150325.Neutron;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.secgroups.rev141002.security.groups.attributes.SecurityGroups;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.secgroups.rev141002.security.groups.attributes.security.groups.SecurityGroup;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.secgroups.rev141002.security.groups.attributes.security.groups.SecurityGroupBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.rev150712.Neutron;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.secgroups.rev150712.security.groups.attributes.SecurityGroups;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.secgroups.rev150712.security.groups.attributes.security.groups.SecurityGroup;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.neutron.secgroups.rev150712.security.groups.attributes.security.groups.SecurityGroupBuilder;
import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceRegistration;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
-public class NeutronSecurityGroupInterface extends AbstractNeutronInterface<SecurityGroup,NeutronSecurityGroup> implements INeutronSecurityGroupCRUD {
+public class NeutronSecurityGroupInterface extends AbstractNeutronInterface<SecurityGroup, SecurityGroups, NeutronSecurityGroup> implements INeutronSecurityGroupCRUD {
private static final Logger LOGGER = LoggerFactory.getLogger(NeutronSecurityGroupInterface.class);
- NeutronSecurityGroupInterface(ProviderContext providerContext) {
- super(providerContext);
+ NeutronSecurityGroupInterface(DataBroker db) {
+ super(db);
}
@Override
- public boolean neutronSecurityGroupExists(String uuid) {
- SecurityGroup group = readMd(createInstanceIdentifier(toMd(uuid)));
- if (group == null) {
- return false;
- }
- return true;
- }
-
- @Override
- public NeutronSecurityGroup getNeutronSecurityGroup(String uuid) {
- SecurityGroup group = readMd(createInstanceIdentifier(toMd(uuid)));
- if (group == null) {
- return null;
- }
- return fromMd(group);
- }
-
- @Override
- public List<NeutronSecurityGroup> getAllNeutronSecurityGroups() {
- Set<NeutronSecurityGroup> allSecurityGroups = new HashSet<NeutronSecurityGroup>();
- SecurityGroups groups = readMd(createInstanceIdentifier());
- if (groups != null) {
- for (SecurityGroup group: groups.getSecurityGroup()) {
- allSecurityGroups.add(fromMd(group));
- }
- }
- LOGGER.debug("Exiting getSecurityGroups, Found {} OpenStackSecurityGroup", allSecurityGroups.size());
- List<NeutronSecurityGroup> ans = new ArrayList<NeutronSecurityGroup>();
- ans.addAll(allSecurityGroups);
- return ans;
- }
-
- @Override
- public boolean addNeutronSecurityGroup(NeutronSecurityGroup input) {
- if (neutronSecurityGroupExists(input.getID())) {
- return false;
- }
- addMd(input);
- return true;
- }
-
- @Override
- public boolean removeNeutronSecurityGroup(String uuid) {
- if (!neutronSecurityGroupExists(uuid)) {
- return false;
- }
- removeMd(toMd(uuid));
- return true;
- }
-
- @Override
- public boolean updateNeutronSecurityGroup(String uuid, NeutronSecurityGroup delta) {
- if (!neutronSecurityGroupExists(uuid)) {
- return false;
- }
- updateMd(delta);
- return true;
- }
-
- @Override
- public boolean neutronSecurityGroupInUse(String securityGroupUUID) {
- return !neutronSecurityGroupExists(securityGroupUUID);
+ protected List<SecurityGroup> getDataObjectList(SecurityGroups groups) {
+ return groups.getSecurityGroup();
}
protected NeutronSecurityGroup fromMd(SecurityGroup group) {
- NeutronSecurityGroup answer = new NeutronSecurityGroup();
+ final NeutronSecurityGroup answer = new NeutronSecurityGroup();
if (group.getName() != null) {
answer.setSecurityGroupName(group.getName());
}
- if (group.getDescription() != null) {
- answer.setSecurityGroupDescription(group.getDescription());
- }
if (group.getTenantId() != null) {
- answer.setSecurityGroupTenantID(group.getTenantId().getValue().replace("-",""));
- }
- if (group.getSecurityRules() != null) {
- NeutronCRUDInterfaces interfaces = new NeutronCRUDInterfaces()
- .fetchINeutronSecurityRuleCRUD(this);
- INeutronSecurityRuleCRUD srCrud = interfaces.getSecurityRuleInterface();
-
- List<NeutronSecurityRule> rules = new ArrayList<NeutronSecurityRule>();
- for (Uuid uuid: group.getSecurityRules()) {
- rules.add(srCrud.getNeutronSecurityRule(uuid.getValue()));
- }
- answer.setSecurityRules(rules);
+ answer.setTenantID(group.getTenantId());
}
if (group.getUuid() != null) {
answer.setID(group.getUuid().getValue());
- }
+ }
return answer;
}
@Override
protected SecurityGroup toMd(NeutronSecurityGroup securityGroup) {
- SecurityGroupBuilder securityGroupBuilder = new SecurityGroupBuilder();
+ final SecurityGroupBuilder securityGroupBuilder = new SecurityGroupBuilder();
if (securityGroup.getSecurityGroupName() != null) {
securityGroupBuilder.setName(securityGroup.getSecurityGroupName());
}
- if (securityGroup.getSecurityGroupDescription() != null) {
- securityGroupBuilder.setDescription(securityGroup.getSecurityGroupDescription());
- }
- if (securityGroup.getSecurityGroupTenantID() != null) {
- securityGroupBuilder.setTenantId(toUuid(securityGroup.getSecurityGroupTenantID()));
- }
- if (securityGroup.getSecurityRules() != null) {
- List<Uuid> neutronSecurityRule = new ArrayList<Uuid>();
- for (NeutronSecurityRule securityRule : securityGroup.getSecurityRules()) {
- if (securityRule.getID() != null) {
- neutronSecurityRule.add(toUuid(securityRule.getID()));
- }
- }
- securityGroupBuilder.setSecurityRules(neutronSecurityRule);
+ if (securityGroup.getTenantID() != null) {
+ securityGroupBuilder.setTenantId(toUuid(securityGroup.getTenantID()));
}
if (securityGroup.getID() != null) {
securityGroupBuilder.setUuid(toUuid(securityGroup.getID()));
securityGroup.getKey());
}
+ @Override
protected InstanceIdentifier<SecurityGroups> createInstanceIdentifier() {
return InstanceIdentifier.create(Neutron.class)
.child(SecurityGroups.class);
@Override
protected SecurityGroup toMd(String uuid) {
- SecurityGroupBuilder securityGroupBuilder = new SecurityGroupBuilder();
+ final SecurityGroupBuilder securityGroupBuilder = new SecurityGroupBuilder();
securityGroupBuilder.setUuid(toUuid(uuid));
return securityGroupBuilder.build();
}
-
- public static void registerNewInterface(BundleContext context,
- ProviderContext providerContext,
- List<ServiceRegistration<?>> registrations) {
- NeutronSecurityGroupInterface neutronSecurityGroupInterface = new NeutronSecurityGroupInterface(providerContext);
- ServiceRegistration<INeutronSecurityGroupCRUD> neutronSecurityGroupInterfaceRegistration = context.registerService(INeutronSecurityGroupCRUD.class, neutronSecurityGroupInterface, null);
- if(neutronSecurityGroupInterfaceRegistration != null) {
- registrations.add(neutronSecurityGroupInterfaceRegistration);
- }
- }
}