blob: 6ab1b14eb78bf8798abb7426c4b8a94502aaa057 [file] [log] [blame]
xuzhang41ad7282015-08-07 15:07:34 +08001/*
2 * Copyright 2015 Open Networking Laboratory
3 *
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
18import static com.google.common.base.Preconditions.checkNotNull;
19import static javax.ws.rs.core.Response.Status.INTERNAL_SERVER_ERROR;
20import static javax.ws.rs.core.Response.Status.OK;
21
22import java.io.InputStream;
23import java.util.Collections;
24import java.util.HashSet;
25import java.util.Iterator;
26import java.util.Set;
27import java.util.concurrent.ConcurrentMap;
28
29import javax.ws.rs.Consumes;
30import javax.ws.rs.DELETE;
31import javax.ws.rs.GET;
32import javax.ws.rs.POST;
33import javax.ws.rs.PUT;
34import javax.ws.rs.Path;
35import javax.ws.rs.PathParam;
36import javax.ws.rs.Produces;
37import javax.ws.rs.QueryParam;
38import javax.ws.rs.core.MediaType;
39import javax.ws.rs.core.Response;
40
41import org.onlab.util.ItemNotFoundException;
42import org.onosproject.app.vtnrsc.DefaultTenantNetwork;
43import org.onosproject.app.vtnrsc.PhysicalNetwork;
44import org.onosproject.app.vtnrsc.SegmentationId;
45import org.onosproject.app.vtnrsc.TenantId;
46import org.onosproject.app.vtnrsc.TenantNetwork;
47import org.onosproject.app.vtnrsc.TenantNetwork.State;
48import org.onosproject.app.vtnrsc.TenantNetwork.Type;
49import org.onosproject.app.vtnrsc.TenantNetworkId;
50import org.onosproject.app.vtnrsc.tenantnetwork.TenantNetworkService;
51import org.onosproject.app.vtnrsc.web.TenantNetworkCodec;
52import org.onosproject.rest.AbstractWebResource;
53import org.slf4j.Logger;
54import org.slf4j.LoggerFactory;
55
56import com.fasterxml.jackson.databind.JsonNode;
57import com.fasterxml.jackson.databind.ObjectMapper;
58import com.fasterxml.jackson.databind.node.ObjectNode;
59import com.google.common.collect.Maps;
60
61/**
62 * REST resource for interacting with the inventory of networks.
63 */
64@Path("networks")
65public class TenantNetworkWebResource extends AbstractWebResource {
66 public static final String NETWORK_NOT_FOUND = "Network is not found";
67 public static final String NETWORK_ID_EXIST = "Network id is existed";
68 public static final String NETWORK_ID_NOT_EXIST = "Network id is not existed";
69 public static final String CREATE_NETWORK = "create network";
70 public static final String UPDATE_NETWORK = "update network";
71 public static final String DELETE_NETWORK = "delete network";
72 public static final String JSON_NOT_NULL = "JsonNode can not be null";
73
74 protected static final Logger log = LoggerFactory
75 .getLogger(TenantNetworkWebResource.class);
76 private final ConcurrentMap<TenantNetworkId, TenantNetwork> networksMap = Maps
77 .newConcurrentMap();
78
79 @GET
80 @Produces({ MediaType.APPLICATION_JSON })
81 public Response getNetworks(@QueryParam("id") String queryId,
82 @QueryParam("name") String queryName,
83 @QueryParam("admin_state_up") String queryadminStateUp,
84 @QueryParam("status") String querystate,
85 @QueryParam("shared") String queryshared,
86 @QueryParam("tenant_id") String querytenantId,
87 @QueryParam("router:external") String routerExternal,
88 @QueryParam("provider:network_type") String type,
89 @QueryParam("provider:physical_network") String physicalNetwork,
90 @QueryParam("provider:segmentation_id") String segmentationId) {
91 Iterable<TenantNetwork> networks = get(TenantNetworkService.class)
92 .getNetworks();
93 Iterator<TenantNetwork> networkors = networks.iterator();
94 while (networkors.hasNext()) {
95 TenantNetwork network = networkors.next();
96 if ((queryId == null || queryId.equals(network.id().toString()))
97 && (queryName == null || queryName.equals(network.name()
98 .toString()))
99 && (queryadminStateUp == null || queryadminStateUp
100 .equals(network.adminStateUp()))
101 && (querystate == null || querystate.equals(network.state()
102 .toString()))
103 && (queryshared == null || queryshared.equals(network
104 .shared()))
105 && (querytenantId == null || querytenantId.equals(network
106 .tenantId().toString()))
107 && (routerExternal == null || routerExternal.equals(network
108 .routerExternal()))
109 && (type == null || type.equals(network.type()))
110 && (physicalNetwork == null || physicalNetwork
111 .equals(network.physicalNetwork()))
112 && (segmentationId == null || segmentationId.equals(network
113 .segmentationId()))) {
114 networksMap.putIfAbsent(network.id(), network);
115 }
116 }
117 networks = Collections.unmodifiableCollection(networksMap.values());
118 ObjectNode result = new ObjectMapper().createObjectNode();
119 result.set("networks", new TenantNetworkCodec().encode(networks, this));
120
121 return ok(result.toString()).build();
122 }
123
124 private State isState(String state) {
125 if (state.equals("ACTIVE")) {
126 return TenantNetwork.State.ACTIVE;
127 } else if (state.equals("BUILD")) {
128 return TenantNetwork.State.BUILD;
129 } else if (state.equals("DOWN")) {
130 return TenantNetwork.State.DOWN;
131 } else if (state.equals("ERROR")) {
132 return TenantNetwork.State.ERROR;
133 } else {
134 return null;
135 }
136 }
137
138 private Type isType(String type) {
139 if (type.equals("LOCAL")) {
140 return TenantNetwork.Type.LOCAL;
141 } else {
142 return null;
143 }
144 }
145
146 @GET
147 @Path("{id}")
148 @Produces({ MediaType.APPLICATION_JSON })
149 public Response getNetwork(@PathParam("id") String id) {
150
151 if (!get(TenantNetworkService.class).exists(TenantNetworkId
152 .networkId(id))) {
153 return ok("The tenantNetwork does not exists").build();
154 }
155 TenantNetwork network = nullIsNotFound(get(TenantNetworkService.class)
156 .getNetwork(TenantNetworkId.networkId(id)), NETWORK_NOT_FOUND);
157 ObjectNode result = new ObjectMapper().createObjectNode();
158 result.set("network", new TenantNetworkCodec().encode(network, this));
159
160 return ok(result.toString()).build();
161
162 }
163
164 @POST
165 @Produces(MediaType.APPLICATION_JSON)
166 @Consumes(MediaType.APPLICATION_JSON)
167 public Response createNetworks(InputStream input) {
168 try {
169 ObjectMapper mapper = new ObjectMapper();
170 JsonNode cfg = mapper.readTree(input);
171 JsonNode nodes = null;
172 Iterable<TenantNetwork> networks = null;
173 if (cfg.get("network") != null) {
174 nodes = cfg.get("network");
175 if (nodes.isArray()) {
176 networks = changeJson2objs(nodes);
177 } else {
178 networks = changeJson2obj(CREATE_NETWORK, null, nodes);
179 }
180 } else if (cfg.get("networks") != null) {
181 nodes = cfg.get("networks");
182 networks = changeJson2objs(nodes);
183 }
184 Boolean issuccess = nullIsNotFound((get(TenantNetworkService.class)
185 .createNetworks(networks)),
186 NETWORK_NOT_FOUND);
187
188 if (!issuccess) {
189 return Response.status(INTERNAL_SERVER_ERROR)
190 .entity(NETWORK_ID_EXIST).build();
191 }
192 return Response.status(OK).entity(issuccess.toString()).build();
193 } catch (Exception e) {
194 log.error("Creates tenantNetwork exception {}.", e.toString());
195 return Response.status(INTERNAL_SERVER_ERROR).entity(e.toString())
196 .build();
197 }
198 }
199
200 @PUT
201 @Path("{id}")
202 @Produces(MediaType.APPLICATION_JSON)
203 @Consumes(MediaType.APPLICATION_JSON)
204 public Response updateNetworks(@PathParam("id") String id, InputStream input) {
205 try {
206 ObjectMapper mapper = new ObjectMapper();
207 JsonNode cfg = mapper.readTree(input);
208 JsonNode nodes = null;
209 Iterable<TenantNetwork> networks = null;
210 if (cfg.get("network") != null) {
211 nodes = cfg.get("network");
212 if (nodes.isArray()) {
213 networks = changeJson2objs(nodes);
214 } else {
215 networks = changeJson2obj(UPDATE_NETWORK,
216 TenantNetworkId.networkId(id),
217 nodes);
218 }
219 } else if (cfg.get("networks") != null) {
220 nodes = cfg.get("networks");
221 networks = changeJson2objs(nodes);
222 }
223 Boolean issuccess = nullIsNotFound((get(TenantNetworkService.class)
224 .updateNetworks(networks)),
225 NETWORK_NOT_FOUND);
226 if (!issuccess) {
227 return Response.status(INTERNAL_SERVER_ERROR)
228 .entity(NETWORK_ID_NOT_EXIST).build();
229 }
230 return Response.status(OK).entity(issuccess.toString()).build();
231 } catch (Exception e) {
232 log.error("Updates tenantNetwork failed because of exception {}.",
233 e.toString());
234 return Response.status(INTERNAL_SERVER_ERROR).entity(e.toString())
235 .build();
236 }
237 }
238
239 @DELETE
240 @Path("{id}")
241 public Response deleteNetworks(@PathParam("id") String id) {
242 log.debug("Deletes network by identifier {}.", id);
243 Set<TenantNetworkId> networkSet = new HashSet<TenantNetworkId>();
244 networkSet.add(TenantNetworkId.networkId(id));
245 Boolean issuccess = nullIsNotFound(get(TenantNetworkService.class)
246 .removeNetworks(networkSet), NETWORK_NOT_FOUND);
247 if (!issuccess) {
248 log.debug("Network identifier {} is not existed", id);
249 return Response.status(INTERNAL_SERVER_ERROR)
250 .entity(NETWORK_ID_NOT_EXIST).build();
251 }
252 return Response.status(OK).entity(issuccess.toString()).build();
253 }
254
255 /**
256 * Returns a collection of tenantNetworks.
257 *
258 * @param flag the flag
259 * @param networkId network identifier
260 * @param node the network json node
261 * @return a collection of tenantNetworks
262 */
263 public Iterable<TenantNetwork> changeJson2obj(String flag,
264 TenantNetworkId networkId,
265 JsonNode node) {
266 checkNotNull(node, JSON_NOT_NULL);
267 TenantNetwork network = null;
268 ConcurrentMap<TenantNetworkId, TenantNetwork> networksMap = Maps
269 .newConcurrentMap();
270 if (node != null) {
271 String name = node.get("name").asText();
272 boolean adminStateUp = node.get("admin_state_up").asBoolean();
273 String state = node.get("status").asText();
274 boolean shared = node.get("shared").asBoolean();
275 String tenantId = node.get("tenant_id").asText();
276 boolean routerExternal = node.get("router:external").asBoolean();
277 String type = node.get("provider:network_type").asText();
278 String physicalNetwork = node.get("provider:physical_network")
279 .asText();
280 String segmentationId = node.get("provider:segmentation_id")
281 .asText();
282 TenantNetworkId id = null;
283 if (flag == CREATE_NETWORK) {
284 id = TenantNetworkId.networkId(node.get("id").asText());
285 } else if (flag == UPDATE_NETWORK) {
286 id = networkId;
287 }
288 network = new DefaultTenantNetwork(
289 id,
290 name,
291 adminStateUp,
292 isState(state),
293 shared,
294 TenantId.tenantId(tenantId),
295 routerExternal,
296 isType(type),
297 PhysicalNetwork
298 .physicalNetwork(physicalNetwork),
299 SegmentationId
300 .segmentationId(segmentationId));
301 networksMap.putIfAbsent(id, network);
302 }
303 return Collections.unmodifiableCollection(networksMap.values());
304 }
305
306 /**
307 * Returns a collection of tenantNetworks.
308 *
309 * @param nodes the network jsonnodes
310 * @return a collection of tenantNetworks
311 */
312 public Iterable<TenantNetwork> changeJson2objs(JsonNode nodes) {
313 checkNotNull(nodes, JSON_NOT_NULL);
314 TenantNetwork network = null;
315 ConcurrentMap<TenantNetworkId, TenantNetwork> networksMap = Maps
316 .newConcurrentMap();
317 if (nodes != null) {
318 for (JsonNode node : nodes) {
319 String id = node.get("id").asText();
320 String name = node.get("name").asText();
321 boolean adminStateUp = node.get("admin_state_up").asBoolean();
322 String state = node.get("status").asText();
323 boolean shared = node.get("shared").asBoolean();
324 String tenantId = node.get("tenant_id").asText();
325 boolean routerExternal = node.get("router:external")
326 .asBoolean();
327 String type = node.get("provider:network_type").asText();
328 String physicalNetwork = node.get("provider:physical_network")
329 .asText();
330 String segmentationId = node.get("provider:segmentation_id")
331 .asText();
332 network = new DefaultTenantNetwork(
333 TenantNetworkId
334 .networkId(id),
335 name,
336 adminStateUp,
337 isState(state),
338 shared,
339 TenantId.tenantId(tenantId),
340 routerExternal,
341 isType(type),
342 PhysicalNetwork
343 .physicalNetwork(physicalNetwork),
344 SegmentationId
345 .segmentationId(segmentationId));
346 networksMap.putIfAbsent(TenantNetworkId.networkId(id), network);
347 }
348 }
349 return Collections.unmodifiableCollection(networksMap.values());
350 }
351
352 /**
353 * Returns the specified item if that items is null; otherwise throws not
354 * found exception.
355 *
356 * @param item item to check
357 * @param <T> item type
358 * @param message not found message
359 * @return item if not null
360 * @throws org.onlab.util.ItemNotFoundException if item is null
361 */
362 protected <T> T nullIsNotFound(T item, String message) {
363 if (item == null) {
364 throw new ItemNotFoundException(message);
365 }
366 return item;
367 }
368}