2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ===================================================================
8 * Unless otherwise specified, all software contained herein is licensed
9 * under the Apache License, Version 2.0 (the "License");
10 * you may not use this software except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
21 * Unless otherwise specified, all documentation contained herein is licensed
22 * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
23 * you may not use this documentation except in compliance with the License.
24 * You may obtain a copy of the License at
26 * https://creativecommons.org/licenses/by/4.0/
28 * Unless required by applicable law or agreed to in writing, documentation
29 * distributed under the License is distributed on an "AS IS" BASIS,
30 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31 * See the License for the specific language governing permissions and
32 * limitations under the License.
34 * ============LICENSE_END============================================
36 * ECOMP is a trademark and service mark of AT&T Intellectual Property.
38 package org.onap.portalapp.portal.service;
40 import java.io.BufferedReader;
41 import java.io.IOException;
42 import java.io.InputStreamReader;
43 import java.net.HttpURLConnection;
45 import java.util.ArrayList;
46 import java.util.List;
48 import org.json.JSONArray;
49 import org.json.JSONObject;
50 import org.onap.portalapp.portal.domain.EPUser;
51 import org.onap.portalapp.portal.service.UserService;
52 import org.onap.portalapp.portal.service.UserServiceImpl;
53 import org.onap.portalapp.portal.utils.EPSystemProperties;
54 import org.onap.portalsdk.core.FusionObject.Utilities;
55 import org.onap.portalsdk.core.logging.logic.EELFLoggerDelegate;
56 import org.onap.portalsdk.core.onboarding.util.CipherUtil;
57 import org.onap.portalsdk.core.service.DataAccessService;
58 import org.onap.portalsdk.core.util.SystemProperties;
59 import org.springframework.beans.factory.annotation.Autowired;
60 import org.springframework.stereotype.Service;
61 import org.springframework.transaction.annotation.Transactional;
63 @Service("userService")
65 public class UserServiceImpl implements UserService {
67 EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(UserServiceImpl.class);
70 private DataAccessService dataAccessService;
72 public DataAccessService getDataAccessService() {
73 return dataAccessService;
76 public void setDataAccessService(DataAccessService dataAccessService) {
77 this.dataAccessService = dataAccessService;
80 @SuppressWarnings("rawtypes")
82 public List getUserByUserId(String userId) {
84 if (SystemProperties.getProperty(SystemProperties.AUTHENTICATION_MECHANISM).trim().equalsIgnoreCase("OIDC")) {
85 List<EPUser> users = new ArrayList<EPUser>();
86 List<EPUser> filterdUsers = new ArrayList<EPUser>();
87 BufferedReader in = null;
88 HttpURLConnection con = null;
90 String url = EPSystemProperties.getProperty(EPSystemProperties.AUTH_USER_SERVER);
91 URL obj = new URL(url);
93 con = (HttpURLConnection) obj.openConnection();
95 // optional default is GET
96 con.setRequestMethod("GET");
97 con.setConnectTimeout(3000);
98 con.setReadTimeout(8000);
100 StringBuffer response = new StringBuffer();
102 in = new BufferedReader(new InputStreamReader(con.getInputStream(), "UTF-8"));
104 while ((inputLine = in.readLine()) != null)
105 response.append(inputLine);
106 JSONObject jObject = new JSONObject(response.toString()); // json
107 JSONArray jsonUsers = jObject.getJSONArray("response"); // get data object
108 for (int i = 0; i < jsonUsers.length(); i++) {
109 JSONObject eachObject = jsonUsers.getJSONObject(i);
110 EPUser eachUser = new EPUser();
111 eachUser.setOrgUserId(eachObject.get("id").toString());// getString("id"));
112 eachUser.setFirstName(eachObject.get("givenName").toString());
113 eachUser.setLastName(eachObject.get("familyName").toString());
114 eachUser.setEmail(eachObject.get("email").toString());
118 for (int i = 0; i < users.size(); i++) {
120 if (Utilities.nvl(userId).length() > 0) {
121 if (!userId.equalsIgnoreCase(users.get(i).getOrgUserId())) {
125 filterdUsers.add(users.get(i));
129 } catch (Exception e) {
130 logger.error(EELFLoggerDelegate.errorLogger, "getUserByUserId failed", e);
135 } catch (IOException e) {
136 logger.error(EELFLoggerDelegate.errorLogger, "getUserByUserId 2 failed", e);
145 StringBuffer criteria = new StringBuffer();
146 criteria.append(" where org_user_id = '").append(userId).append("'");
147 list = getDataAccessService().getList(EPUser.class, criteria.toString(), null, null);
148 return (list == null || list.size() == 0) ? null : list;
154 @SuppressWarnings("rawtypes")
156 public List getUserByFirstLastName(String firstName, String lastName) {
158 if (!SystemProperties.getProperty(SystemProperties.AUTHENTICATION_MECHANISM).trim().equalsIgnoreCase("OIDC")) {
161 StringBuffer criteria = new StringBuffer();
162 if (firstName != null)
163 criteria.append(" where first_name = '").append(firstName).append("'");
164 if (lastName != null)
165 criteria.append(" where last_name = '").append(lastName).append("'");
166 list = getDataAccessService().getList(EPUser.class, criteria.toString(), null, null);
167 return (list == null || list.size() == 0) ? null : list;
171 List<EPUser> users = new ArrayList<EPUser>();
172 List<EPUser> filterdUsers = new ArrayList<EPUser>();
173 BufferedReader in = null;
174 HttpURLConnection con = null;
176 String url = EPSystemProperties.getProperty(EPSystemProperties.AUTH_USER_SERVER);
177 URL obj = new URL(url);
179 con = (HttpURLConnection) obj.openConnection();
181 // optional default is GET
182 con.setRequestMethod("GET");
183 con.setConnectTimeout(3000);
184 con.setReadTimeout(8000);
186 StringBuffer response = new StringBuffer();
188 in = new BufferedReader(new InputStreamReader(con.getInputStream(), "UTF-8"));
190 while ((inputLine = in.readLine()) != null)
191 response.append(inputLine);
192 JSONObject jObject = new JSONObject(response.toString()); // json
193 JSONArray jsonUsers = jObject.getJSONArray("response"); // get data object
194 for (int i = 0; i < jsonUsers.length(); i++) {
195 JSONObject eachObject = jsonUsers.getJSONObject(i);
196 EPUser eachUser = new EPUser();
197 eachUser.setOrgUserId(eachObject.get("id").toString());// getString("id"));
198 eachUser.setFirstName(eachObject.get("givenName").toString());
199 eachUser.setLastName(eachObject.get("familyName").toString());
200 eachUser.setEmail(eachObject.get("email").toString());
204 for (int i = 0; i < users.size(); i++) {
206 if (Utilities.nvl(firstName).length() > 0) {
207 if (!firstName.equalsIgnoreCase(users.get(i).getFirstName())) {
211 if (Utilities.nvl(lastName).length() > 0) {
212 if (!lastName.equalsIgnoreCase(users.get(i).getLastName())) {
217 filterdUsers.add(users.get(i));
221 } catch (Exception e) {
222 logger.error(EELFLoggerDelegate.errorLogger, "getUserByFirstLastName failed", e);
227 } catch (IOException e) {
228 logger.error(EELFLoggerDelegate.errorLogger, "getUserByFirstLastName 2 failed", e);
237 public String saveNewUser(EPUser newUser, String checkDuplicate) throws Exception {
240 StringBuffer criteria = new StringBuffer();
241 criteria.append(" where org_user_id = '").append(newUser.getLoginId()).append("'");
242 list = getDataAccessService().getList(EPUser.class, criteria.toString(), null, null);
243 if (list == null || list.size() == 0) {
244 newUser.setActive(true);
245 newUser.setOrgUserId(newUser.getLoginId());
246 newUser.setLoginPwd(CipherUtil.encryptPKC(newUser.getLoginPwd()));
247 getDataAccessService().saveDomainObject(newUser, null);
249 if (checkDuplicate.equals("Yes")) {
250 // userId already exist in database
251 return "Record already exist";
254 EPUser oldUser = (EPUser) list.get(0);
255 oldUser.setFirstName(newUser.getFirstName());
256 oldUser.setLastName(newUser.getLastName());
257 oldUser.setMiddleInitial(newUser.getMiddleInitial());
258 if (!oldUser.getLoginPwd().equals(newUser.getLoginPwd()))
259 oldUser.setLoginPwd(CipherUtil.encryptPKC(newUser.getLoginPwd()));
261 oldUser.setLoginPwd(newUser.getLoginPwd());
262 getDataAccessService().saveDomainObject(oldUser, null);
268 } catch (Exception e) {
269 logger.error(EELFLoggerDelegate.errorLogger, "saveNewUser failed", e);
270 throw new Exception(e);