2 * ========================LICENSE_START=================================
5 * Copyright (C) 2019 AT&T Intellectual Property
6 * Modifications Copyright (C) 2020 Nordix Foundation
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ========================LICENSE_END===================================
21 package org.oransc.ric.portal.dashboard.model;
23 import java.util.ArrayList;
24 import java.util.Collection;
25 import java.util.Iterator;
26 import java.util.List;
28 import org.onap.portalsdk.core.restful.domain.EcompRole;
29 import org.onap.portalsdk.core.restful.domain.EcompUser;
30 import org.springframework.security.core.GrantedAuthority;
31 import org.springframework.security.core.authority.SimpleGrantedAuthority;
32 import org.springframework.security.core.userdetails.UserDetails;
34 public class EcompUserDetails implements UserDetails {
36 private static final long serialVersionUID = 1L;
37 private final transient EcompUser ecompUser;
39 // This is the default Spring role-name prefix.
40 private static final String ROLEP = "ROLE_";
42 public EcompUserDetails(EcompUser ecompUser) {
43 this.ecompUser = ecompUser;
47 * Gets a list of authorities (roles) for this user. To keep Spring happy, every
48 * item has prefix ROLE_.
51 public Collection<? extends GrantedAuthority> getAuthorities() {
52 List<GrantedAuthority> roleList = new ArrayList<>();
53 Iterator<EcompRole> roleIter = ecompUser.getRoles().iterator();
54 while (roleIter.hasNext()) {
55 EcompRole role = roleIter.next();
56 // Add the prefix if the ONAP portal doesn't supply it.
57 final String roleName = role.getName().startsWith(ROLEP) ? role.getName() : ROLEP + role.getName();
58 roleList.add(new SimpleGrantedAuthority(roleName));
64 public String getPassword() {
69 public String getUsername() {
70 return ecompUser.getLoginId();
74 public boolean isAccountNonExpired() {
79 public boolean isAccountNonLocked() {
84 public boolean isCredentialsNonExpired() {
89 public boolean isEnabled() {
90 return ecompUser.isActive();