1 /*****************************************************************************
2 * Copyright Igor Barma, Eric Brun, Alexandre Desoubeaux, Christian Martel,
5 * Ce logiciel est un programme informatique servant à l'évaluation des
8 * Ce logiciel est régi par la licence CeCILL soumise au droit français et
9 * respectant les principes de diffusion des logiciels libres. Vous pouvez
10 * utiliser, modifier et/ou redistribuer ce programme sous les conditions
11 * de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
12 * sur le site "http://www.cecill.info".
14 * En contrepartie de l'accessibilité au code source et des droits de copie,
15 * de modification et de redistribution accordés par cette licence, il n'est
16 * offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
17 * seule une responsabilité restreinte pèse sur l'auteur du programme, le
18 * titulaire des droits patrimoniaux et les concédants successifs.
20 * A cet égard l'attention de l'utilisateur est attirée sur les risques
21 * associés au chargement, à l'utilisation, à la modification et/ou au
22 * développement et à la reproduction du logiciel par l'utilisateur étant
23 * donné sa spécificité de logiciel libre, qui peut le rendre complexe à
24 * manipuler et qui le réserve donc à des développeurs et des professionnels
25 * avertis possédant des connaissances informatiques approfondies. Les
26 * utilisateurs sont donc invités à charger et tester l'adéquation du
27 * logiciel à leurs besoins dans des conditions permettant d'assurer la
28 * sécurité de leurs systèmes et ou de leurs données et, plus généralement,
29 * à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
31 * Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
32 * pris connaissance de la licence CeCILL, et que vous en avez accepté les
34 *******************************************************************************/
35 package com.pentila.jackrabbit.auth;
37 import java.util.Collection;
38 import java.util.HashSet;
41 import org.springframework.dao.DataAccessException;
42 import org.springframework.security.core.GrantedAuthority;
43 import org.springframework.security.core.authority.GrantedAuthorityImpl;
44 import org.springframework.security.core.context.SecurityContext;
45 import org.springframework.security.core.context.SecurityContextHolder;
46 import org.springframework.security.core.userdetails.UserDetails;
47 import org.springframework.security.core.userdetails.UserDetailsService;
48 import org.springframework.security.core.userdetails.UsernameNotFoundException;
56 public class CasAuth implements UserDetailsService{
59 public static String role = "ROLE_MEMBER";
61 private static LdapDAO ldapDAO;
63 public CasAuth(String role){
70 * Gets the current user.
72 * @return the current user
74 public static UserDetails getCurrentUser() {
75 SecurityContext securityContext = SecurityContextHolder.getContext();
76 if (securityContext != null && securityContext.getAuthentication() != null && securityContext.getAuthentication().getPrincipal() != null){
77 return (UserDetails) securityContext.getAuthentication().getPrincipal();
86 * @return the user name
88 public static String getUserName() {
91 return getCurrentUser().getUsername();
97 public UserDetails loadUserByUsername(String login)
98 throws UsernameNotFoundException, DataAccessException {
100 String internalUserId = login;
102 if (ldapDAO != null){
104 LdapUser u = ldapDAO.getUserFromLogin(login);
107 throw new UsernameNotFoundException(login);
110 internalUserId = u.getId();
114 final Set<GrantedAuthority> cga = new HashSet<GrantedAuthority>();
117 cga.add(new GrantedAuthorityImpl(role));
119 final String uid = internalUserId;
121 UserDetails ud = new UserDetails(){
123 public Collection<GrantedAuthority> getAuthorities() {
128 public String getPassword() {
133 public String getUsername() {
138 public boolean isAccountNonExpired() {
143 public boolean isAccountNonLocked() {
148 public boolean isCredentialsNonExpired() {
153 public boolean isEnabled() {
166 public static LdapDAO getLdapDAO() {
171 public void setLdapDAO(LdapDAO ldapDAO) {
172 CasAuth.ldapDAO = ldapDAO;
177 public static String getRole() {
183 public static void setRole(String role) {