Checkstyle Import issues fix (SPI tests,Northbound API)
[neutron.git] / northbound-api / src / main / java / org / opendaylight / neutron / northbound / api / NeutronLoadBalancerPoolNorthbound.java
index a9b1a165d8f5a901097845a4b07dc01ef7f5fad9..0ae021214576d1a95b6951b6639478f8354ce795 100644 (file)
@@ -9,11 +9,9 @@
 package org.opendaylight.neutron.northbound.api;
 
 import java.net.HttpURLConnection;
-
 import java.util.ArrayList;
 import java.util.Iterator;
 import java.util.List;
-
 import javax.ws.rs.Consumes;
 import javax.ws.rs.DELETE;
 import javax.ws.rs.GET;
@@ -25,10 +23,8 @@ import javax.ws.rs.Produces;
 import javax.ws.rs.QueryParam;
 import javax.ws.rs.core.MediaType;
 import javax.ws.rs.core.Response;
-
 import org.codehaus.enunciate.jaxrs.ResponseCode;
 import org.codehaus.enunciate.jaxrs.StatusCodes;
-import org.opendaylight.neutron.spi.INeutronLoadBalancerPoolAware;
 import org.opendaylight.neutron.spi.INeutronLoadBalancerPoolCRUD;
 import org.opendaylight.neutron.spi.NeutronCRUDInterfaces;
 import org.opendaylight.neutron.spi.NeutronLoadBalancerPool;
@@ -58,26 +54,34 @@ import org.opendaylight.neutron.spi.NeutronLoadBalancerPoolMember;
  */
 
 @Path("/lbaas/pools")
-public class NeutronLoadBalancerPoolNorthbound {
+public class NeutronLoadBalancerPoolNorthbound
+    extends AbstractNeutronNorthbound<NeutronLoadBalancerPool, NeutronLoadBalancerPoolRequest, INeutronLoadBalancerPoolCRUD> {
+
+    private static final String RESOURCE_NAME = "LoadBalancerPool";
 
-    private static final int HTTP_OK_BOTTOM = 200;
-    private static final int HTTP_OK_TOP = 299;
-    private static final String INTERFACE_NAME = "LoadBalancerPool CRUD Interface";
-    private static final String UUID_NO_EXIST = "LoadBalancerPool UUID does not exist.";
-    private static final String NO_PROVIDERS = "No providers registered.  Please try again later";
-    private static final String NO_PROVIDER_LIST = "Couldn't get providers list.  Please try again later";
+    @Override
+    protected String getResourceName() {
+        return RESOURCE_NAME;
+    }
 
-    private NeutronLoadBalancerPool extractFields(NeutronLoadBalancerPool o, List<String> fields) {
+    @Override
+    protected NeutronLoadBalancerPool extractFields(NeutronLoadBalancerPool o, List<String> fields) {
         return o.extractFields(fields);
     }
 
-    private NeutronCRUDInterfaces getNeutronInterfaces() {
-        NeutronCRUDInterfaces answer = new NeutronCRUDInterfaces().fetchINeutronLoadBalancerPoolCRUD(this);
+    @Override
+    protected NeutronLoadBalancerPoolRequest newNeutronRequest(NeutronLoadBalancerPool o) {
+        return new NeutronLoadBalancerPoolRequest(o);
+    }
+
+    @Override
+    protected INeutronLoadBalancerPoolCRUD getNeutronCRUD() {
+        NeutronCRUDInterfaces answer = new NeutronCRUDInterfaces().
+            fetchINeutronLoadBalancerPoolCRUD(this);
         if (answer.getLoadBalancerPoolInterface() == null) {
-            throw new ServiceUnavailableException(INTERFACE_NAME
-                    + RestMessages.SERVICEUNAVAILABLE.toString());
+            throw new ServiceUnavailableException(serviceUnavailable());
         }
-        return answer;
+        return answer.getLoadBalancerPoolInterface();
     }
 
     /**
@@ -98,11 +102,10 @@ public class NeutronLoadBalancerPoolNorthbound {
             @QueryParam("id") String queryLoadBalancerPoolID,
             @QueryParam("tenant_id") String queryLoadBalancerPoolTenantID,
             @QueryParam("name") String queryLoadBalancerPoolName,
-            @QueryParam("description") String queryLoadBalancerDescription,
             @QueryParam("protocol") String queryLoadBalancerProtocol,
             @QueryParam("lb_algorithm") String queryLoadBalancerPoolLbAlgorithm,
             @QueryParam("healthmonitor_id") String queryLoadBalancerPoolHealthMonitorID,
-            @QueryParam("admin_state_up") String queryLoadBalancerIsAdminStateUp,
+            @QueryParam("admin_state_up") Boolean queryLoadBalancerIsAdminStateUp,
             @QueryParam("members") List<NeutronLoadBalancerPoolMember> queryLoadBalancerPoolMembers,
             // pagination
             @QueryParam("limit") String limit,
@@ -110,8 +113,8 @@ public class NeutronLoadBalancerPoolNorthbound {
             @QueryParam("page_reverse") String pageReverse
             // sorting not supported
     ) {
-        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronInterfaces().getLoadBalancerPoolInterface();
-        List<NeutronLoadBalancerPool> allLoadBalancerPools = loadBalancerPoolInterface.getAllNeutronLoadBalancerPools();
+        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronCRUD();
+        List<NeutronLoadBalancerPool> allLoadBalancerPools = loadBalancerPoolInterface.getAll();
         List<NeutronLoadBalancerPool> ans = new ArrayList<NeutronLoadBalancerPool>();
         Iterator<NeutronLoadBalancerPool> i = allLoadBalancerPools.iterator();
         while (i.hasNext()) {
@@ -119,11 +122,9 @@ public class NeutronLoadBalancerPoolNorthbound {
             if ((queryLoadBalancerPoolID == null ||
                     queryLoadBalancerPoolID.equals(nsg.getID())) &&
                     (queryLoadBalancerPoolTenantID == null ||
-                            queryLoadBalancerPoolTenantID.equals(nsg.getLoadBalancerPoolTenantID())) &&
+                            queryLoadBalancerPoolTenantID.equals(nsg.getTenantID())) &&
                     (queryLoadBalancerPoolName == null ||
                             queryLoadBalancerPoolName.equals(nsg.getLoadBalancerPoolName())) &&
-                    (queryLoadBalancerDescription == null ||
-                            queryLoadBalancerDescription.equals(nsg.getLoadBalancerPoolDescription())) &&
                     (queryLoadBalancerPoolLbAlgorithm == null ||
                             queryLoadBalancerPoolLbAlgorithm.equals(nsg.getLoadBalancerPoolLbAlgorithm())) &&
                     (queryLoadBalancerPoolHealthMonitorID == null ||
@@ -158,17 +159,7 @@ public class NeutronLoadBalancerPoolNorthbound {
     public Response showLoadBalancerPool(@PathParam("loadBalancerPoolID") String loadBalancerPoolID,
             // return fields
             @QueryParam("fields") List<String> fields) {
-        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronInterfaces().getLoadBalancerPoolInterface();
-        if (!loadBalancerPoolInterface.neutronLoadBalancerPoolExists(loadBalancerPoolID)) {
-            throw new ResourceNotFoundException(UUID_NO_EXIST);
-        }
-        if (fields.size() > 0) {
-            NeutronLoadBalancerPool ans = loadBalancerPoolInterface.getNeutronLoadBalancerPool(loadBalancerPoolID);
-            return Response.status(HttpURLConnection.HTTP_OK).entity(
-                    new NeutronLoadBalancerPoolRequest(extractFields(ans, fields))).build();
-        } else {
-            return Response.status(HttpURLConnection.HTTP_OK).entity(new NeutronLoadBalancerPoolRequest(loadBalancerPoolInterface.getNeutronLoadBalancerPool(loadBalancerPoolID))).build();
-        }
+        return show(loadBalancerPoolID, fields);
     }
 
     /**
@@ -181,67 +172,7 @@ public class NeutronLoadBalancerPoolNorthbound {
             @ResponseCode(code = HttpURLConnection.HTTP_CREATED, condition = "Created"),
             @ResponseCode(code = HttpURLConnection.HTTP_UNAVAILABLE, condition = "No providers available") })
     public Response createLoadBalancerPools(final NeutronLoadBalancerPoolRequest input) {
-        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronInterfaces().getLoadBalancerPoolInterface();
-        if (input.isSingleton()) {
-            NeutronLoadBalancerPool singleton = input.getSingleton();
-
-            Object[] instances = NeutronUtil.getInstances(INeutronLoadBalancerPoolAware.class, this);
-            if (instances != null) {
-                if (instances.length > 0) {
-                    for (Object instance : instances) {
-                        INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                        int status = service.canCreateNeutronLoadBalancerPool(singleton);
-                        if (status < HttpURLConnection.HTTP_OK || status > HTTP_OK_TOP) {
-                            return Response.status(status).build();
-                        }
-                    }
-                } else {
-                    throw new ServiceUnavailableException(NO_PROVIDERS);
-                }
-            } else {
-                throw new ServiceUnavailableException(NO_PROVIDER_LIST);
-            }
-            loadBalancerPoolInterface.addNeutronLoadBalancerPool(singleton);
-            if (instances != null) {
-                for (Object instance : instances) {
-                    INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                    service.neutronLoadBalancerPoolCreated(singleton);
-                }
-            }
-        } else {
-            Object[] instances = NeutronUtil.getInstances(INeutronLoadBalancerPoolAware.class, this);
-            for (NeutronLoadBalancerPool test : input.getBulk()) {
-
-                if (instances != null) {
-                    if (instances.length > 0) {
-                        for (Object instance : instances) {
-                            INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                            int status = service.canCreateNeutronLoadBalancerPool(test);
-                            if (status < HTTP_OK_BOTTOM || status > HTTP_OK_TOP) {
-                                return Response.status(status).build();
-                            }
-                        }
-                    } else {
-                        throw new ServiceUnavailableException(NO_PROVIDERS);
-                    }
-                } else {
-                    throw new ServiceUnavailableException(NO_PROVIDER_LIST);
-                }
-            }
-            /*
-             * now, each element of the bulk request can be added to the cache
-             */
-            for (NeutronLoadBalancerPool test : input.getBulk()) {
-                loadBalancerPoolInterface.addNeutronLoadBalancerPool(test);
-                if (instances != null) {
-                    for (Object instance : instances) {
-                        INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                        service.neutronLoadBalancerPoolCreated(test);
-                    }
-                }
-            }
-        }
-        return Response.status(HttpURLConnection.HTTP_CREATED).entity(input).build();
+        return create(input);
     }
 
     /**
@@ -253,43 +184,11 @@ public class NeutronLoadBalancerPoolNorthbound {
     @Consumes({ MediaType.APPLICATION_JSON })
     @StatusCodes({
             @ResponseCode(code = HttpURLConnection.HTTP_OK, condition = "Operation successful"),
+            @ResponseCode(code = HttpURLConnection.HTTP_NOT_FOUND, condition = "Not Found"),
             @ResponseCode(code = HttpURLConnection.HTTP_UNAVAILABLE, condition = "No providers available") })
     public Response updateLoadBalancerPool(
             @PathParam("loadBalancerPoolID") String loadBalancerPoolID, final NeutronLoadBalancerPoolRequest input) {
-        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronInterfaces().getLoadBalancerPoolInterface();
-
-        NeutronLoadBalancerPool delta = input.getSingleton();
-        NeutronLoadBalancerPool original = loadBalancerPoolInterface.getNeutronLoadBalancerPool(loadBalancerPoolID);
-
-        Object[] instances = NeutronUtil.getInstances(INeutronLoadBalancerPoolAware.class, this);
-        if (instances != null) {
-            if (instances.length > 0) {
-                for (Object instance : instances) {
-                    INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                    int status = service.canUpdateNeutronLoadBalancerPool(delta, original);
-                    if (status < HTTP_OK_BOTTOM || status > HTTP_OK_TOP) {
-                        return Response.status(status).build();
-                    }
-                }
-            } else {
-                throw new ServiceUnavailableException(NO_PROVIDERS);
-            }
-        } else {
-            throw new ServiceUnavailableException(NO_PROVIDER_LIST);
-        }
-
-        /*
-         * update the object and return it
-         */
-        loadBalancerPoolInterface.updateNeutronLoadBalancerPool(loadBalancerPoolID, delta);
-        NeutronLoadBalancerPool updatedLoadBalancerPool = loadBalancerPoolInterface.getNeutronLoadBalancerPool(loadBalancerPoolID);
-        if (instances != null) {
-            for (Object instance : instances) {
-                INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                service.neutronLoadBalancerPoolUpdated(updatedLoadBalancerPool);
-            }
-        }
-        return Response.status(HttpURLConnection.HTTP_OK).entity(new NeutronLoadBalancerPoolRequest(loadBalancerPoolInterface.getNeutronLoadBalancerPool(loadBalancerPoolID))).build();
+        return update(loadBalancerPoolID, input);
     }
 
     /**
@@ -300,39 +199,222 @@ public class NeutronLoadBalancerPoolNorthbound {
     @DELETE
     @StatusCodes({
             @ResponseCode(code = HttpURLConnection.HTTP_NO_CONTENT, condition = "No Content"),
+            @ResponseCode(code = HttpURLConnection.HTTP_NOT_FOUND, condition = "Not Found"),
             @ResponseCode(code = HttpURLConnection.HTTP_UNAVAILABLE, condition = "No providers available") })
     public Response deleteLoadBalancerPool(
             @PathParam("loadBalancerPoolUUID") String loadBalancerPoolUUID) {
-        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronInterfaces().getLoadBalancerPoolInterface();
-
-        NeutronLoadBalancerPool singleton = loadBalancerPoolInterface.getNeutronLoadBalancerPool(loadBalancerPoolUUID);
-        Object[] instances = NeutronUtil.getInstances(INeutronLoadBalancerPoolAware.class, this);
-        if (instances != null) {
-            if (instances.length > 0) {
-                for (Object instance : instances) {
-                    INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                    int status = service.canDeleteNeutronLoadBalancerPool(singleton);
-                    if (status < HTTP_OK_BOTTOM || status > HTTP_OK_TOP) {
-                        return Response.status(status).build();
-                    }
+        return delete(loadBalancerPoolUUID);
+    }
+
+    protected NeutronLoadBalancerPoolMember extractFields(NeutronLoadBalancerPoolMember o, List<String> fields) {
+        return o.extractFields(fields);
+    }
+
+    /**
+     * Returns a list of all LoadBalancerPoolMembers in specified pool
+     */
+    @Path("{loadBalancerPoolUUID}/members")
+    @GET
+    @Produces({MediaType.APPLICATION_JSON})
+    @StatusCodes({
+            @ResponseCode(code = HttpURLConnection.HTTP_OK, condition = "Operation successful"),
+            @ResponseCode(code = HttpURLConnection.HTTP_UNAUTHORIZED, condition = "Unauthorized"),
+            @ResponseCode(code = HttpURLConnection.HTTP_UNAVAILABLE, condition = "No providers available") })
+    public Response listMembers(
+            //Path param
+            @PathParam("loadBalancerPoolUUID") String loadBalancerPoolUUID,
+
+            // return fields
+            @QueryParam("fields") List<String> fields,
+
+            // OpenStack LoadBalancerPool attributes
+            @QueryParam("id") String queryLoadBalancerPoolMemberID,
+            @QueryParam("tenant_id") String queryLoadBalancerPoolMemberTenantID,
+            @QueryParam("address") String queryLoadBalancerPoolMemberAddress,
+            @QueryParam("protocol_port") String queryLoadBalancerPoolMemberProtoPort,
+            @QueryParam("admin_state_up") Boolean queryLoadBalancerPoolMemberAdminStateUp,
+            @QueryParam("weight") Integer queryLoadBalancerPoolMemberWeight,
+            @QueryParam("subnet_id") String queryLoadBalancerPoolMemberSubnetID,
+
+            // pagination
+            @QueryParam("limit") String limit,
+            @QueryParam("marker") String marker,
+            @QueryParam("page_reverse") String pageReverse
+            // sorting not supported
+    ) {
+        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronCRUD();
+        if (!loadBalancerPoolInterface.exists(loadBalancerPoolUUID)) {
+            throw new ResourceNotFoundException(uuidNoExist());
+        }
+        List<NeutronLoadBalancerPoolMember> members =
+                    loadBalancerPoolInterface.get(loadBalancerPoolUUID).getLoadBalancerPoolMembers();
+        List<NeutronLoadBalancerPoolMember> ans = new ArrayList<NeutronLoadBalancerPoolMember>();
+        Iterator<NeutronLoadBalancerPoolMember> i = members.iterator();
+        while (i.hasNext()) {
+            NeutronLoadBalancerPoolMember nsg = i.next();
+            if ((queryLoadBalancerPoolMemberID == null ||
+                queryLoadBalancerPoolMemberID.equals(nsg.getID())) &&
+                loadBalancerPoolUUID.equals(nsg.getPoolID()) &&
+                (queryLoadBalancerPoolMemberTenantID == null ||
+                        queryLoadBalancerPoolMemberTenantID.equals(nsg.getTenantID())) &&
+                (queryLoadBalancerPoolMemberAddress == null ||
+                        queryLoadBalancerPoolMemberAddress.equals(nsg.getPoolMemberAddress())) &&
+                (queryLoadBalancerPoolMemberAdminStateUp == null ||
+                        queryLoadBalancerPoolMemberAdminStateUp.equals(nsg.getPoolMemberAdminStateIsUp())) &&
+                (queryLoadBalancerPoolMemberWeight == null ||
+                        queryLoadBalancerPoolMemberWeight.equals(nsg.getPoolMemberWeight())) &&
+                (queryLoadBalancerPoolMemberSubnetID == null ||
+                        queryLoadBalancerPoolMemberSubnetID.equals(nsg.getPoolMemberSubnetID()))) {
+                if (fields.size() > 0) {
+                    ans.add(extractFields(nsg, fields));
+                } else {
+                    ans.add(nsg);
                 }
+            }
+        }
+        return Response.status(HttpURLConnection.HTTP_OK).entity(
+                new NeutronLoadBalancerPoolMemberRequest(ans)).build();
+    }
+
+    /**
+     * Returns a specific LoadBalancerPoolMember
+     */
+    @Path("{loadBalancerPoolUUID}/members/{loadBalancerPoolMemberUUID}")
+    @GET
+    @Produces({ MediaType.APPLICATION_JSON })
+    //@TypeHint(OpenStackLoadBalancerPoolMembers.class)
+    @StatusCodes({
+        @ResponseCode(code = HttpURLConnection.HTTP_OK, condition = "Operation successful"),
+        @ResponseCode(code = HttpURLConnection.HTTP_UNAUTHORIZED, condition = "Unauthorized"),
+        @ResponseCode(code = HttpURLConnection.HTTP_NOT_FOUND, condition = "Not Found"),
+        @ResponseCode(code = HttpURLConnection.HTTP_UNAVAILABLE, condition = "No providers available") })
+    public Response showLoadBalancerPoolMember(
+            @PathParam("loadBalancerPoolUUID") String loadBalancerPoolUUID,
+            @PathParam("loadBalancerPoolMemberUUID") String loadBalancerPoolMemberUUID,
+            // return fields
+            @QueryParam("fields") List<String> fields ) {
+
+        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronCRUD();
+        if (!loadBalancerPoolInterface.exists(loadBalancerPoolUUID)) {
+            throw new ResourceNotFoundException(uuidNoExist());
+        }
+        List<NeutronLoadBalancerPoolMember> members =
+                    loadBalancerPoolInterface.get(loadBalancerPoolUUID).getLoadBalancerPoolMembers();
+        for (NeutronLoadBalancerPoolMember ans: members) {
+            if (!ans.getID().equals(loadBalancerPoolMemberUUID)) {
+                continue;
+            }
+
+            if (fields.size() > 0) {
+                return Response.status(HttpURLConnection.HTTP_OK).entity(
+                    new NeutronLoadBalancerPoolMemberRequest(extractFields(ans, fields))).build();
             } else {
-                throw new ServiceUnavailableException(NO_PROVIDERS);
+                return Response.status(HttpURLConnection.HTTP_OK).entity(
+                    new NeutronLoadBalancerPoolMemberRequest(ans)).build();
             }
+        }
+        throw new ResourceNotFoundException(uuidNoExist());
+    }
+
+    /**
+     * Adds a Member to an LBaaS Pool member
+     */
+    @Path("{loadBalancerPoolUUID}/members")
+    @POST
+    @Produces({MediaType.APPLICATION_JSON})
+    @Consumes({MediaType.APPLICATION_JSON})
+    @StatusCodes({
+            @ResponseCode(code = HttpURLConnection.HTTP_OK, condition = "Operation successful"),
+            @ResponseCode(code = HttpURLConnection.HTTP_UNAVAILABLE, condition = "No providers available") })
+    public Response createLoadBalancerPoolMember(
+            @PathParam("loadBalancerPoolUUID") String loadBalancerPoolUUID,
+            final NeutronLoadBalancerPoolMemberRequest input) {
+
+        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronCRUD();
+        NeutronLoadBalancerPool singletonPool = loadBalancerPoolInterface.get(loadBalancerPoolUUID);
+
+        if (input.isSingleton()) {
+            NeutronLoadBalancerPoolMember singleton = input.getSingleton();
+            singleton.setPoolID(loadBalancerPoolUUID);
+            /**
+             * Add the member from the neutron load balancer pool as well
+             */
+
+            loadBalancerPoolInterface.addNeutronLoadBalancerPoolMember(loadBalancerPoolUUID, singleton);
         } else {
-            throw new ServiceUnavailableException(NO_PROVIDER_LIST);
+            /*
+             * now, each element of the bulk request can be added to the cache
+             */
+            for (NeutronLoadBalancerPoolMember test : input.getBulk()) {
+                loadBalancerPoolInterface.addNeutronLoadBalancerPoolMember(loadBalancerPoolUUID, test);
+            }
         }
+        return Response.status(HttpURLConnection.HTTP_CREATED).entity(input).build();
+    }
 
-        /*
-         * remove it and return 204 status
-         */
-        loadBalancerPoolInterface.removeNeutronLoadBalancerPool(loadBalancerPoolUUID);
-        if (instances != null) {
-            for (Object instance : instances) {
-                INeutronLoadBalancerPoolAware service = (INeutronLoadBalancerPoolAware) instance;
-                service.neutronLoadBalancerPoolDeleted(singleton);
+    /**
+     * Updates a LB member pool
+     */
+
+    @Path("{loadBalancerPoolUUID}/members/{loadBalancerPoolMemberUUID}")
+    @PUT
+    @Produces({ MediaType.APPLICATION_JSON })
+    @Consumes({ MediaType.APPLICATION_JSON })
+    @StatusCodes({
+            @ResponseCode(code = HttpURLConnection.HTTP_OK, condition = "Operation successful"),
+            @ResponseCode(code = HttpURLConnection.HTTP_NOT_FOUND, condition = "Not Found") })
+    public Response updateLoadBalancerPoolMember(
+            @PathParam("loadBalancerPoolUUID") String loadBalancerPoolUUID,
+            @PathParam("loadBalancerPoolMemberUUID") String loadBalancerPoolMemberUUID,
+            final NeutronLoadBalancerPoolMemberRequest input) {
+        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronCRUD();
+        NeutronLoadBalancerPool singletonPool = loadBalancerPoolInterface.get(loadBalancerPoolUUID);
+        NeutronLoadBalancerPoolMember singleton = input.getSingleton();
+        singleton.setPoolID(loadBalancerPoolUUID);
+
+        if (singletonPool == null) {
+            throw new ResourceNotFoundException("Pool doesn't Exist");
+        }
+        NeutronLoadBalancerPoolMember original = singletonPool.getNeutronLoadBalancerPoolMember(loadBalancerPoolMemberUUID);
+
+        loadBalancerPoolInterface.updateNeutronLoadBalancerPoolMember(loadBalancerPoolUUID, loadBalancerPoolMemberUUID, singleton);
+        return Response.status(HttpURLConnection.HTTP_OK).entity(input).build();
+    }
+
+    /**
+     * Deletes a LoadBalancerPoolMember
+     */
+
+    @Path("{loadBalancerPoolUUID}/members/{loadBalancerPoolMemberUUID}")
+    @DELETE
+    @StatusCodes({
+        @ResponseCode(code = HttpURLConnection.HTTP_NO_CONTENT, condition = "No Content"),
+        @ResponseCode(code = HttpURLConnection.HTTP_NOT_FOUND, condition = "Not Found"),
+        @ResponseCode(code = HttpURLConnection.HTTP_UNAVAILABLE, condition = "No providers available") })
+    public Response deleteLoadBalancerPoolMember(
+            @PathParam("loadBalancerPoolUUID") String loadBalancerPoolUUID,
+            @PathParam("loadBalancerPoolMemberUUID") String loadBalancerPoolMemberUUID) {
+        INeutronLoadBalancerPoolCRUD loadBalancerPoolInterface = getNeutronCRUD();
+
+        //Verify that the LB pool member exists
+        NeutronLoadBalancerPoolMember singleton = null;
+        List<NeutronLoadBalancerPoolMember> members =
+                loadBalancerPoolInterface.get(loadBalancerPoolUUID).getLoadBalancerPoolMembers();
+        for (NeutronLoadBalancerPoolMember member: members) {
+            if (member.getID().equals(loadBalancerPoolMemberUUID)) {
+                singleton = member;
+                break;
             }
         }
+        if (singleton == null) {
+            throw new BadRequestException("LoadBalancerPoolMember UUID does not exist.");
+        }
+
+        /**
+         * Remove the member from the neutron load balancer pool
+         */
+        loadBalancerPoolInterface.removeNeutronLoadBalancerPoolMember(loadBalancerPoolUUID, loadBalancerPoolMemberUUID);
+
         return Response.status(HttpURLConnection.HTTP_NO_CONTENT).build();
     }
 }