blob: 10cb399645d7a06f89a525fd60603290b7604311 [file] [log] [blame]
Bharat saraswald25a30a2015-10-26 18:35:47 +05301/*
Brian O'Connor5ab426f2016-04-09 01:19:45 -07002 * Copyright 2015-present Open Networking Laboratory
Bharat saraswald25a30a2015-10-26 18:35:47 +05303 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package org.onosproject.vtnweb.resources;
17
Bharat saraswalf38e2262015-11-18 22:57:05 +053018import static javax.ws.rs.core.Response.Status.OK;
19import static org.onlab.util.Tools.nullIsNotFound;
Bharat saraswald25a30a2015-10-26 18:35:47 +053020
21import java.io.IOException;
22import java.io.InputStream;
Bharat saraswald25a30a2015-10-26 18:35:47 +053023
24import javax.ws.rs.Consumes;
25import javax.ws.rs.DELETE;
26import javax.ws.rs.GET;
27import javax.ws.rs.POST;
28import javax.ws.rs.PUT;
29import javax.ws.rs.Path;
30import javax.ws.rs.PathParam;
31import javax.ws.rs.Produces;
32import javax.ws.rs.core.MediaType;
33import javax.ws.rs.core.Response;
34
Bharat saraswalf38e2262015-11-18 22:57:05 +053035import org.onosproject.rest.AbstractWebResource;
Bharat saraswald25a30a2015-10-26 18:35:47 +053036import org.onosproject.vtnrsc.FlowClassifier;
37import org.onosproject.vtnrsc.FlowClassifierId;
Jonathan Hart317f4762015-11-09 16:05:36 -080038import org.onosproject.vtnrsc.flowclassifier.FlowClassifierService;
Bharat saraswalf38e2262015-11-18 22:57:05 +053039import org.slf4j.Logger;
40import org.slf4j.LoggerFactory;
Bharat saraswald25a30a2015-10-26 18:35:47 +053041
Bharat saraswalf38e2262015-11-18 22:57:05 +053042import com.fasterxml.jackson.databind.JsonNode;
Bharat saraswalf38e2262015-11-18 22:57:05 +053043import com.fasterxml.jackson.databind.node.ArrayNode;
Bharat saraswald25a30a2015-10-26 18:35:47 +053044import com.fasterxml.jackson.databind.node.ObjectNode;
45
46/**
47 * Query and program flow classifier.
48 */
49@Path("flow_classifiers")
50public class FlowClassifierWebResource extends AbstractWebResource {
51
Bharat saraswalf38e2262015-11-18 22:57:05 +053052 private final Logger log = LoggerFactory.getLogger(FlowClassifierWebResource.class);
53
Bharat saraswald25a30a2015-10-26 18:35:47 +053054 public static final String FLOW_CLASSIFIER_NOT_FOUND = "Flow classifier not found";
55
56 /**
Bharat saraswalf38e2262015-11-18 22:57:05 +053057 * Get all flow classifiers created.
Bharat saraswald25a30a2015-10-26 18:35:47 +053058 *
Bharat saraswala9929a92015-11-19 00:33:55 +053059 * @return 200 OK
Bharat saraswald25a30a2015-10-26 18:35:47 +053060 */
61 @GET
62 @Produces(MediaType.APPLICATION_JSON)
63 public Response getFlowClassifiers() {
Mahesh Poojary Sfac02262015-11-20 19:13:22 +053064 Iterable<FlowClassifier> flowClassifiers = get(FlowClassifierService.class).getFlowClassifiers();
Phaneendra Mandad66dca42015-12-01 20:24:10 +053065 ObjectNode result = mapper().createObjectNode();
Bharat saraswalf38e2262015-11-18 22:57:05 +053066 ArrayNode flowClassifierEntry = result.putArray("flow_classifiers");
67 if (flowClassifiers != null) {
68 for (final FlowClassifier flowClassifier : flowClassifiers) {
Phaneendra Mandad66dca42015-12-01 20:24:10 +053069 flowClassifierEntry.add(codec(FlowClassifier.class).encode(flowClassifier, this));
Bharat saraswalf38e2262015-11-18 22:57:05 +053070 }
71 }
Bharat saraswald25a30a2015-10-26 18:35:47 +053072 return ok(result.toString()).build();
73 }
74
75 /**
Bharat saraswalf38e2262015-11-18 22:57:05 +053076 * Get details of a flow classifier.
Bharat saraswald25a30a2015-10-26 18:35:47 +053077 *
Mahesh Poojary Sfac02262015-11-20 19:13:22 +053078 * @param id
79 * flow classifier id
Bharat saraswalf38e2262015-11-18 22:57:05 +053080 * @return 200 OK , 404 if given identifier does not exist
Bharat saraswald25a30a2015-10-26 18:35:47 +053081 */
82 @GET
83 @Path("{flow_id}")
84 @Produces(MediaType.APPLICATION_JSON)
85 public Response getFlowClassifier(@PathParam("flow_id") String id) {
Phaneendra Mandad66dca42015-12-01 20:24:10 +053086 FlowClassifier flowClassifier = nullIsNotFound(get(FlowClassifierService.class)
87 .getFlowClassifier(FlowClassifierId.of(id)), FLOW_CLASSIFIER_NOT_FOUND);
Bharat saraswald25a30a2015-10-26 18:35:47 +053088
Phaneendra Mandad66dca42015-12-01 20:24:10 +053089 ObjectNode result = mapper().createObjectNode();
90 result.set("flow_classifier", codec(FlowClassifier.class).encode(flowClassifier, this));
Bharat saraswalf38e2262015-11-18 22:57:05 +053091
Bharat saraswald25a30a2015-10-26 18:35:47 +053092 return ok(result.toString()).build();
93 }
94
95 /**
96 * Creates and stores a new flow classifier.
97 *
Mahesh Poojary Sfac02262015-11-20 19:13:22 +053098 * @param stream
99 * flow classifier from JSON
Bharat saraswald25a30a2015-10-26 18:35:47 +0530100 * @return status of the request - CREATED if the JSON is correct,
Mahesh Poojary Sfac02262015-11-20 19:13:22 +0530101 * BAD_REQUEST if the JSON is invalid
Bharat saraswald25a30a2015-10-26 18:35:47 +0530102 */
103 @POST
104 @Consumes(MediaType.APPLICATION_JSON)
105 @Produces(MediaType.APPLICATION_JSON)
106 public Response createFlowClassifier(InputStream stream) {
Bharat saraswald25a30a2015-10-26 18:35:47 +0530107 try {
Phaneendra Mandad66dca42015-12-01 20:24:10 +0530108 ObjectNode jsonTree = (ObjectNode) mapper().readTree(stream);
Bharat saraswalf38e2262015-11-18 22:57:05 +0530109 JsonNode flow = jsonTree.get("flow_classifier");
Bharat saraswald25a30a2015-10-26 18:35:47 +0530110
Phaneendra Mandad66dca42015-12-01 20:24:10 +0530111 FlowClassifier flowClassifier = codec(FlowClassifier.class).decode((ObjectNode) flow, this);
Mahesh Poojary Sfac02262015-11-20 19:13:22 +0530112 Boolean issuccess = nullIsNotFound(get(FlowClassifierService.class).createFlowClassifier(flowClassifier),
Phaneendra Mandad66dca42015-12-01 20:24:10 +0530113 FLOW_CLASSIFIER_NOT_FOUND);
Bharat saraswalf38e2262015-11-18 22:57:05 +0530114 return Response.status(OK).entity(issuccess.toString()).build();
115 } catch (IOException ex) {
116 log.error("Exception while creating flow classifier {}.", ex.toString());
Bharat saraswald25a30a2015-10-26 18:35:47 +0530117 throw new IllegalArgumentException(ex);
118 }
Bharat saraswald25a30a2015-10-26 18:35:47 +0530119 }
120
121 /**
Bharat saraswalf38e2262015-11-18 22:57:05 +0530122 * Update details of a flow classifier.
Bharat saraswald25a30a2015-10-26 18:35:47 +0530123 *
Mahesh Poojary Sfac02262015-11-20 19:13:22 +0530124 * @param id
125 * flow classifier id
126 * @param stream
127 * InputStream
Bharat saraswalf38e2262015-11-18 22:57:05 +0530128 * @return 200 OK, 404 if given identifier does not exist
Bharat saraswald25a30a2015-10-26 18:35:47 +0530129 */
130 @PUT
131 @Path("{flow_id}")
132 @Produces(MediaType.APPLICATION_JSON)
133 @Consumes(MediaType.APPLICATION_JSON)
134 public Response updateFlowClassifier(@PathParam("flow_id") String id, final InputStream stream) {
135 try {
Bharat saraswalf38e2262015-11-18 22:57:05 +0530136
137 JsonNode jsonTree = mapper().readTree(stream);
138 JsonNode flow = jsonTree.get("flow_classifier");
Phaneendra Mandad66dca42015-12-01 20:24:10 +0530139 FlowClassifier flowClassifier = codec(FlowClassifier.class).decode((ObjectNode) flow, this);
Mahesh Poojary Sfac02262015-11-20 19:13:22 +0530140 Boolean result = nullIsNotFound(get(FlowClassifierService.class).updateFlowClassifier(flowClassifier),
Phaneendra Mandad66dca42015-12-01 20:24:10 +0530141 FLOW_CLASSIFIER_NOT_FOUND);
Bharat saraswalf38e2262015-11-18 22:57:05 +0530142 return Response.status(OK).entity(result.toString()).build();
143 } catch (IOException e) {
144 log.error("Update flow classifier failed because of exception {}.", e.toString());
145 throw new IllegalArgumentException(e);
Bharat saraswald25a30a2015-10-26 18:35:47 +0530146 }
147 }
148
149 /**
Bharat saraswalf38e2262015-11-18 22:57:05 +0530150 * Delete details of a flow classifier.
Bharat saraswald25a30a2015-10-26 18:35:47 +0530151 *
Jian Lic2a542b2016-05-10 11:48:19 -0700152 * @param id flow classifier id
153 * @return 204 NO CONTENT
Bharat saraswald25a30a2015-10-26 18:35:47 +0530154 */
155 @Path("{flow_id}")
156 @DELETE
Jian Lic2a542b2016-05-10 11:48:19 -0700157 public Response deleteFlowClassifier(@PathParam("flow_id") String id) {
Bharat saraswalf38e2262015-11-18 22:57:05 +0530158 log.debug("Deletes flow classifier by identifier {}.", id);
159 FlowClassifierId flowClassifierId = FlowClassifierId.of(id);
Mahesh Poojary Sfac02262015-11-20 19:13:22 +0530160 Boolean issuccess = nullIsNotFound(get(FlowClassifierService.class).removeFlowClassifier(flowClassifierId),
Phaneendra Mandad66dca42015-12-01 20:24:10 +0530161 FLOW_CLASSIFIER_NOT_FOUND);
Jian Lic2a542b2016-05-10 11:48:19 -0700162 return Response.noContent().build();
Bharat saraswald25a30a2015-10-26 18:35:47 +0530163 }
164}