2 * Copyright 2016-2017 Huawei Technologies Co., Ltd.
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
17 package org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.rest;
19 import javax.servlet.http.HttpServletRequest;
20 import javax.servlet.http.HttpServletResponse;
21 import javax.ws.rs.Consumes;
22 import javax.ws.rs.DELETE;
23 import javax.ws.rs.GET;
24 import javax.ws.rs.PUT;
25 import javax.ws.rs.Path;
26 import javax.ws.rs.PathParam;
27 import javax.ws.rs.Produces;
28 import javax.ws.rs.QueryParam;
29 import javax.ws.rs.core.Context;
30 import javax.ws.rs.core.MediaType;
31 import javax.ws.rs.core.Response;
33 import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.common.VnfmJsonUtil;
34 import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.Constant;
35 import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.constant.ParamConstants;
36 import org.onap.vfc.nfvo.vnfm.svnfm.vnfmadapter.service.process.AuthMgr;
37 import org.slf4j.Logger;
38 import org.slf4j.LoggerFactory;
40 import net.sf.json.JSONObject;
43 * Provide interfaces for authInfo <br/>
45 * auth tokens interface is provided by platform not in nfvo for vnfm
46 * differences from other interface
50 * @version VFC 1.0 Aug 24, 2016
53 @Consumes(MediaType.APPLICATION_JSON)
54 @Produces(MediaType.APPLICATION_JSON)
55 public class AuthRoa {
57 private static final Logger LOG = LoggerFactory.getLogger(AuthRoa.class);
59 private AuthMgr authMgr;
61 public void setAuthMgr(AuthMgr authMgr) {
62 this.authMgr = authMgr;
66 * Provide interface for add authInfo <br/>
73 @Path("/plat/smapp/v1/oauth/token")
74 public String authToken(@Context HttpServletRequest context, @Context HttpServletResponse resp) {
75 LOG.warn("function=login, msg=enter to get token.");
76 JSONObject subJsonObject = VnfmJsonUtil.getJsonFromContexts(context);
77 LOG.warn("subJsonObject: {}", subJsonObject);
79 if (null == subJsonObject) {
80 LOG.error("function=login, msg=params are insufficient");
81 String resultStr = "Login params insufficient";
82 resp.setStatus(Constant.HTTP_BAD_REQUEST);
87 JSONObject authResult = authMgr.authToken(subJsonObject);
88 LOG.warn("authResult: {}", authResult);
89 if (authResult.getInt(Constant.RETCODE) == Constant.REST_SUCCESS) {
90 JSONObject data = authResult.getJSONObject("data");
91 resp.setStatus(Constant.HTTP_OK);
92 return data.toString();
93 } else if (authResult.getInt(Constant.RETCODE) == Constant.HTTP_INNERERROR) {
94 Response.status(Response.Status.INTERNAL_SERVER_ERROR).entity(authResult.getString("data")).build();
95 return String.format(ParamConstants.GET_TOKEN_FAIL_RESP, authResult.getString("data"));
97 Response.status(Response.Status.UNAUTHORIZED).entity(authResult.getString("data")).build();
98 return String.format(ParamConstants.GET_TOKEN_FAIL_RESP, authResult.getString("data"));
103 * Provide interface for delete authInfo <br/>
111 @Path("/plat/smapp/v1/auth/tokens/{userName}/{roarand}")
112 public String delAuthToken(@PathParam(Constant.USERNAME) String userName, @PathParam("roarand") String roarand,
113 @Context HttpServletResponse resp) {
114 LOG.warn("function=logout, msg=enter to logout");
115 JSONObject resultJson = new JSONObject();
117 resultJson.put("Information", "Operation success");
118 resp.setStatus(Constant.HTTP_NOCONTENT);
119 LOG.warn("function=logout, msg=end to logout");
120 return resultJson.toString();
124 * Provide interface for handshake authInfo <br/>
131 @Path("/vnfmmed/v2/nfvo/shakehand")
132 public String shakehand(@QueryParam("roattr") String roattr, @Context HttpServletResponse resp) {
133 JSONObject resultJson = new JSONObject();
134 resultJson.put("status", "running");
135 resultJson.put("description", "Operation success");
136 resp.setStatus(Constant.HTTP_OK);
138 return resultJson.toString();
142 * Provide interface for handshake authInfo <br/>
149 @Path("/plat/smapp/v1/nfvo/shakehand")
150 public String shakehandOld(@QueryParam("roattr") String roattr, @Context HttpServletResponse resp) {
151 JSONObject resultJson = new JSONObject();
152 resultJson.put("status", "running");
153 resultJson.put("description", "Operation success");
154 resp.setStatus(Constant.HTTP_OK);
156 return resultJson.toString();