2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright (C) 2017-2018 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============================================
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.hibernate.criterion.Criterion;
49 import org.hibernate.criterion.Restrictions;
50 import org.json.JSONArray;
51 import org.json.JSONObject;
52 import org.onap.portalapp.portal.domain.EPUser;
53 import org.onap.portalapp.portal.utils.EPCommonSystemProperties;
54 import org.onap.portalsdk.core.domain.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 private 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("unchecked")
82 public List<EPUser> 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 = EPCommonSystemProperties.getProperty(EPCommonSystemProperties.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
110 for (int i = 0; i < jsonUsers.length(); i++) {
111 JSONObject eachObject = jsonUsers.getJSONObject(i);
112 EPUser eachUser = new EPUser();
113 eachUser.setOrgUserId(eachObject.get("id").toString());
114 eachUser.setFirstName(eachObject.get("givenName").toString());
115 eachUser.setLastName(eachObject.get("familyName").toString());
116 eachUser.setEmail(eachObject.get("email").toString());
120 for (int i = 0; i < users.size(); i++) {
121 if (Utilities.nvl(userId).length() > 0) {
122 if (!userId.equalsIgnoreCase(users.get(i).getOrgUserId())) {
126 filterdUsers.add(users.get(i));
129 } catch (Exception e) {
130 logger.error(EELFLoggerDelegate.errorLogger, "getUserByUserId failed", e);
137 } catch (IOException e) {
138 logger.error(EELFLoggerDelegate.errorLogger, "getUserByUserId failed to close", e);
146 List<Criterion> restrictionsList = new ArrayList<Criterion>();
147 Criterion orgUserIdCriterion = Restrictions.eq("orgUserId",userId);
148 restrictionsList.add(orgUserIdCriterion);
150 List<EPUser> list = (List<EPUser>) dataAccessService.getList(EPUser.class, null, restrictionsList, null);
152 return (list == null || list.size() == 0) ? null : list;
158 @SuppressWarnings("unchecked")
160 public List<EPUser> getUserByFirstLastName(String firstName, String lastName) {
162 if (!SystemProperties.getProperty(SystemProperties.AUTHENTICATION_MECHANISM).trim().equalsIgnoreCase("OIDC")) {
163 List<Criterion> restrictionsList = new ArrayList<Criterion>();
164 Criterion firstNameCriterion = Restrictions.eq("firstName", firstName);
165 Criterion lastNameCriterion = Restrictions.eq("lastName", lastName);
166 restrictionsList.add(Restrictions.or(firstNameCriterion, lastNameCriterion));
168 List<EPUser> list = (List<EPUser>) dataAccessService.getList(EPUser.class, null, restrictionsList, null);
169 return (list == null || list.size() == 0) ? null : list;
173 List<EPUser> users = new ArrayList<EPUser>();
174 List<EPUser> filterdUsers = new ArrayList<EPUser>();
175 BufferedReader in = null;
176 HttpURLConnection con = null;
178 String url = EPCommonSystemProperties.getProperty(EPCommonSystemProperties.AUTH_USER_SERVER);
179 URL obj = new URL(url);
181 con = (HttpURLConnection) obj.openConnection();
183 // optional default is GET
184 con.setRequestMethod("GET");
185 con.setConnectTimeout(3000);
186 con.setReadTimeout(8000);
188 StringBuffer response = new StringBuffer();
190 in = new BufferedReader(new InputStreamReader(con.getInputStream(), "UTF-8"));
192 while ((inputLine = in.readLine()) != null) {
193 response.append(inputLine);
195 JSONObject jObject = new JSONObject(response.toString()); // json
196 JSONArray jsonUsers = jObject.getJSONArray("response"); // get
199 for (int i = 0; i < jsonUsers.length(); i++) {
200 JSONObject eachObject = jsonUsers.getJSONObject(i);
201 EPUser eachUser = new EPUser();
202 eachUser.setOrgUserId(eachObject.get("id").toString());// getString("id"));
203 eachUser.setFirstName(eachObject.get("givenName").toString());
204 eachUser.setLastName(eachObject.get("familyName").toString());
205 eachUser.setEmail(eachObject.get("email").toString());
209 for (int i = 0; i < users.size(); i++) {
211 if (Utilities.nvl(firstName).length() > 0) {
212 if (!firstName.equalsIgnoreCase(users.get(i).getFirstName())) {
216 if (Utilities.nvl(lastName).length() > 0) {
217 if (!lastName.equalsIgnoreCase(users.get(i).getLastName())) {
222 filterdUsers.add(users.get(i));
226 } catch (Exception e) {
227 logger.error(EELFLoggerDelegate.errorLogger, "getUserByFirstLastName failed", e);
234 } catch (IOException e) {
235 logger.error(EELFLoggerDelegate.errorLogger, "getUserByFirstLastName failed to close", e);
244 @SuppressWarnings("unchecked")
245 public String saveNewUser(EPUser newUser, String checkDuplicate) throws Exception {
249 List<Criterion> restrictionsList = new ArrayList<Criterion>();
250 Criterion orgUserIdCriterion = Restrictions.eq("orgUserId",newUser.getLoginId());
251 restrictionsList.add(orgUserIdCriterion);
252 List<EPUser> list = (List<EPUser>) dataAccessService.getList(EPUser.class, null, restrictionsList, null);
254 if (list == null || list.size() == 0) {
255 newUser.setActive(true);
256 newUser.setOrgUserId(newUser.getLoginId());
257 newUser.setLoginPwd(CipherUtil.encryptPKC(newUser.getLoginPwd()));
258 getDataAccessService().saveDomainObject(newUser, null);
260 if (checkDuplicate.equals("Yes")) {
261 // userId already exist in database
262 return "Record already exist";
265 EPUser oldUser = (EPUser) list.get(0);
266 oldUser.setFirstName(newUser.getFirstName());
267 oldUser.setLastName(newUser.getLastName());
268 oldUser.setMiddleInitial(newUser.getMiddleInitial());
269 if (!oldUser.getLoginPwd().equals(newUser.getLoginPwd()))
270 oldUser.setLoginPwd(CipherUtil.encryptPKC(newUser.getLoginPwd()));
272 oldUser.setLoginPwd(newUser.getLoginPwd());
273 getDataAccessService().saveDomainObject(oldUser, null);
279 } catch (Exception e) {
280 logger.error(EELFLoggerDelegate.errorLogger, "saveNewUser failed", e);
281 throw new Exception(e);
287 public void saveUser(EPUser user) throws Exception {
288 getDataAccessService().saveDomainObject(user, null);