/*- * ========================LICENSE_START================================= * O-RAN-SC * %% * Copyright (C) 2019 AT&T Intellectual Property * %% * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ========================LICENSE_END=================================== */ package org.oransc.ric.portal.dashboard.model; import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; import java.util.List; import org.onap.portalsdk.core.restful.domain.EcompRole; import org.onap.portalsdk.core.restful.domain.EcompUser; import org.springframework.security.core.GrantedAuthority; import org.springframework.security.core.authority.SimpleGrantedAuthority; import org.springframework.security.core.userdetails.UserDetails; public class EcompUserDetails implements UserDetails { private static final long serialVersionUID = 1L; // use transient per Sonar warning private final transient EcompUser ecompUser; // This is the default Spring role-name prefix. private static final String ROLEP = "ROLE_"; public EcompUserDetails(EcompUser ecompUser) { this.ecompUser = ecompUser; } /* * Gets a list of authorities (roles) for this user. To keep Spring happy, every * item has prefix ROLE_. */ public Collection getAuthorities() { List roleList = new ArrayList<>(); Iterator roleIter = ecompUser.getRoles().iterator(); while (roleIter.hasNext()) { EcompRole role = roleIter.next(); // Add the prefix if the ONAP portal doesn't supply it. final String roleName = role.getName().startsWith(ROLEP) ? role.getName() : ROLEP + role.getName(); roleList.add(new SimpleGrantedAuthority(roleName)); } return roleList; } public String getPassword() { return null; } public String getUsername() { return ecompUser.getLoginId(); } public boolean isAccountNonExpired() { return true; } public boolean isAccountNonLocked() { return true; } public boolean isCredentialsNonExpired() { return true; } public boolean isEnabled() { return ecompUser.isActive(); } @Override public String toString() { return this.getClass().getSimpleName() + "[ecompUser=" + ecompUser + ", isAccountNonExpired=" + isAccountNonExpired() + ", isAccountNonLocked=" + isAccountNonLocked() + ", isCredentialsNonExpired=" + isCredentialsNonExpired() + "]"; } }