Domain model change
[portal.git] / portal-BE / src / main / java / org / onap / portal / service / fn / FnRoleService.java
1 /*
2  * ============LICENSE_START==========================================
3  * ONAP Portal
4  * ===================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  * Modifications Copyright (c) 2019 Samsung
8  * ===================================================================
9  *
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
14  *
15  *             http://www.apache.org/licenses/LICENSE-2.0
16  *
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.
22  *
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
27  *
28  *             https://creativecommons.org/licenses/by/4.0/
29  *
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.
35  *
36  * ============LICENSE_END============================================
37  *
38  *
39  */
40
41 package org.onap.portal.service.fn;
42
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;
53
54 @Service
55 @Transactional
56 public class FnRoleService {
57
58   private final EELFLoggerDelegate logger = EELFLoggerDelegate.getLogger(FnRoleService.class);
59
60
61   private final FnRoleDao fnRoleDao;
62
63   @Autowired
64   public FnRoleService(FnRoleDao fnRoleDao) {
65     this.fnRoleDao = fnRoleDao;
66   }
67
68   public FnRole getById(final Long id) {
69     return fnRoleDao.findById(id).orElseThrow(EntityExistsException::new);
70   }
71
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,
77           String.format(
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.");
82       return roles.get(0);
83     }
84     return null;
85   }
86
87   public List<FnRole> getAppRoles(Long appId) {
88     List<FnRole> applicationRoles;
89     try {
90       if (appId == 1) {
91         applicationRoles = retrieveAppRolesWhereAppIdIsNull();
92       } else {
93         applicationRoles = retrieveAppRolesByAppId(appId);
94       }
95     } catch (Exception e) {
96       logger.error(EELFLoggerDelegate.errorLogger, "getAppRoles: failed", e);
97       throw e;
98     }
99     return applicationRoles;
100   }
101
102   public List<FnRole> retrieveAppRoleByAppRoleIdAndByAppId(final Long appId, final Long appRoleId) {
103     return Optional.of(fnRoleDao.retrieveAppRoleByAppRoleIdAndByAppId(appId, appRoleId)).orElse(new ArrayList<>());
104   }
105
106   public List<FnRole> getUserRoleOnUserIdAndAppId(final Long userId, final Long appId) {
107     return Optional.of(fnRoleDao.getUserRoleOnUserIdAndAppId(userId, appId)).orElse(new ArrayList<>());
108   }
109
110   public List<FnRole> retrieveAppRoleByRoleIdWhereAppIdIsNull(final Long roleId) {
111     return Optional.of(fnRoleDao.retrieveAppRoleByRoleIdWhereAppIdIsNull(roleId)).orElse(new ArrayList<>());
112   }
113
114   public List<FnRole> retrieveAppRolesWhereAppIdIsNull() {
115     return Optional.of(fnRoleDao.retrieveAppRolesWhereAppIdIsNull()).orElse(new ArrayList<>());
116   }
117
118   public List<FnRole> retrieveAppRolesByAppId(final Long id) {
119     return Optional.of(fnRoleDao.retrieveAppRolesByAppId(id)).orElse(new ArrayList<>());
120   }
121
122   public List<FnRole> retrieveAppRolesByRoleNameAndByAppId(final String roleName, final Long appId) {
123     return Optional.of(fnRoleDao.retrieveAppRolesByRoleNameAndByAppId(roleName, appId)).orElse(new ArrayList<>());
124   }
125
126   public List<FnRole> retrieveActiveRolesOfApplication(final Long appId) {
127     return Optional.of(fnRoleDao.retrieveActiveRolesOfApplication(appId)).orElse(new ArrayList<>());
128   }
129
130   public List<FnRole> getGlobalRolesOfPortal() {
131     List<FnRole> globalRoles = new ArrayList<>();
132     try {
133       globalRoles = Optional.of(fnRoleDao.getGlobalRolesOfPortal()).orElse(new ArrayList<>());
134     } catch (Exception e) {
135       logger.error(EELFLoggerDelegate.errorLogger, "getGlobalRolesOfPortal failed", e);
136     }
137     return globalRoles;
138   }
139
140   public Long getSysAdminRoleId(){
141     FnRole role = fnRoleDao.getSysAdminRoleId();
142     return role.getId();
143   }
144
145   public void delete(FnRole role) {
146     fnRoleDao.delete(role);
147   }
148
149   public FnRole saveOne(final FnRole role){
150     return fnRoleDao.save(role);
151   }
152 }