/**
  * Returns all switches
  *
  * @param none
  * @return List of all switches
  *     <pre>
  *
  * Example:
  *
  * Request URL:
  * http://localhost:8080/controller/nb/v2/opendove/odmc/switches
  *
  * Response body in JSON:
  * {
  *   "switches":  [ {
  *     "id": "uuid",
  *     "name": "switch name",
  *     "tunnelip": "10.10.10.1",
  *     "mgmtip": "20.20.20.2",
  *     "timestamp": "now"
  *   } ]
  * }
  * </pre>
  */
 @GET
 @Produces({MediaType.APPLICATION_JSON})
 @TypeHint(OpenDoveSwitchRequest.class)
 @StatusCodes({
   @ResponseCode(code = 200, condition = "Operation successful"),
   @ResponseCode(code = 204, condition = "No content"),
   @ResponseCode(code = 401, condition = "Unauthorized"),
   @ResponseCode(code = 500, condition = "Internal Error")
 })
 public Response showServiceAppliances() {
   IfOpenDoveSwitchCRUD sbInterface = OpenDoveCRUDInterfaces.getIfOpenDoveSwitchCRU(this);
   if (sbInterface == null) {
     throw new ServiceUnavailableException(
         "OpenDove SB Interface " + RestMessages.SERVICEUNAVAILABLE.toString());
   }
   return Response.status(200)
       .entity(new OpenDoveSwitchRequest(sbInterface.getSwitches()))
       .build();
 }