2 * ============LICENSE_START==========================================
4 * ===================================================================
5 * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6 * ===================================================================
7 * Modifications Copyright (c) 2019 Samsung
8 * ===================================================================
10 * Unless otherwise specified, all software contained herein is licensed
11 * under the Apache License, Version 2.0 (the "License");
12 * you may not use this software except in compliance with the License.
13 * You may obtain a copy of the License at
15 * http://www.apache.org/licenses/LICENSE-2.0
17 * Unless required by applicable law or agreed to in writing, software
18 * distributed under the License is distributed on an "AS IS" BASIS,
19 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20 * See the License for the specific language governing permissions and
21 * limitations under the License.
23 * Unless otherwise specified, all documentation contained herein is licensed
24 * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
25 * you may not use this documentation except in compliance with the License.
26 * You may obtain a copy of the License at
28 * https://creativecommons.org/licenses/by/4.0/
30 * Unless required by applicable law or agreed to in writing, documentation
31 * distributed under the License is distributed on an "AS IS" BASIS,
32 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
33 * See the License for the specific language governing permissions and
34 * limitations under the License.
36 * ============LICENSE_END============================================
41 package org.onap.portal.service.fn;
43 import java.util.ArrayList;
44 import java.util.List;
45 import java.util.Optional;
46 import javax.persistence.EntityExistsException;
47 import org.onap.portal.dao.fn.FnRoleDao;
48 import org.onap.portal.domain.db.fn.FnRole;
49 import org.onap.portalsdk.core.logging.logic.EELFLoggerDelegate;
50 import org.springframework.beans.factory.annotation.Autowired;
51 import org.springframework.stereotype.Service;
52 import org.springframework.transaction.annotation.Transactional;
56 public class FnRoleService {
58 private final EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(FnRoleService.class);
61 private final FnRoleDao fnRoleDao;
64 public FnRoleService(FnRoleDao fnRoleDao) {
65 this.fnRoleDao = fnRoleDao;
68 public FnRole getById(final Long id) {
69 return fnRoleDao.findById(id).orElseThrow(EntityExistsException::new);
72 public FnRole getRole(final Long appId, final Long appRoleId) {
73 List<FnRole> roles = Optional.of(fnRoleDao.retrieveAppRoleByAppRoleIdAndByAppId(appId, appRoleId))
74 .orElse(new ArrayList<>());
75 if (!roles.isEmpty()) {
76 logger.error(EELFLoggerDelegate.errorLogger,
78 "search by appId=%s, appRoleid=%s should have returned 0 or 1 results. Got %d. This is an internal server error.",
79 appId, appRoleId, roles.size()));
80 logger.error(EELFLoggerDelegate.errorLogger,
81 "Trying to recover from duplicates by returning the first search result. This issue should be treated, it is probably not critical because duplicate roles should be similar.");
87 public List<FnRole> getAppRoles(Long appId) {
88 List<FnRole> applicationRoles;
91 applicationRoles = retrieveAppRolesWhereAppIdIsNull();
93 applicationRoles = retrieveAppRolesByAppId(appId);
95 } catch (Exception e) {
96 logger.error(EELFLoggerDelegate.errorLogger, "getAppRoles: failed", e);
99 return applicationRoles;
102 public List<FnRole> retrieveAppRoleByAppRoleIdAndByAppId(final Long appId, final Long appRoleId) {
103 return Optional.of(fnRoleDao.retrieveAppRoleByAppRoleIdAndByAppId(appId, appRoleId)).orElse(new ArrayList<>());
106 public List<FnRole> getUserRoleOnUserIdAndAppId(final Long userId, final Long appId) {
107 return Optional.of(fnRoleDao.getUserRoleOnUserIdAndAppId(userId, appId)).orElse(new ArrayList<>());
110 public List<FnRole> retrieveAppRoleByRoleIdWhereAppIdIsNull(final Long roleId) {
111 return Optional.of(fnRoleDao.retrieveAppRoleByRoleIdWhereAppIdIsNull(roleId)).orElse(new ArrayList<>());
114 public List<FnRole> retrieveAppRolesWhereAppIdIsNull() {
115 return Optional.of(fnRoleDao.retrieveAppRolesWhereAppIdIsNull()).orElse(new ArrayList<>());
118 public List<FnRole> retrieveAppRolesByAppId(final Long id) {
119 return Optional.of(fnRoleDao.retrieveAppRolesByAppId(id)).orElse(new ArrayList<>());
122 public List<FnRole> retrieveAppRolesByRoleNameAndByAppId(final String roleName, final Long appId) {
123 return Optional.of(fnRoleDao.retrieveAppRolesByRoleNameAndByAppId(roleName, appId)).orElse(new ArrayList<>());
126 public List<FnRole> retrieveActiveRolesOfApplication(final Long appId) {
127 return Optional.of(fnRoleDao.retrieveActiveRolesOfApplication(appId)).orElse(new ArrayList<>());
130 public List<FnRole> getGlobalRolesOfPortal() {
131 List<FnRole> globalRoles = new ArrayList<>();
133 globalRoles = Optional.of(fnRoleDao.getGlobalRolesOfPortal()).orElse(new ArrayList<>());
134 } catch (Exception e) {
135 logger.error(EELFLoggerDelegate.errorLogger, "getGlobalRolesOfPortal failed", e);
140 public Long getSysAdminRoleId(){
141 FnRole role = fnRoleDao.getSysAdminRoleId();
145 public void delete(FnRole role) {
146 fnRoleDao.delete(role);
149 public FnRole saveOne(final FnRole role){
150 return fnRoleDao.save(role);