KerberosLdapContextSourceConfig.java 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*
  2. * Copyright 2015 the original author or authors.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package org.springframework.security.kerberos.client.docs;
  17. import org.springframework.beans.factory.annotation.Value;
  18. import org.springframework.context.annotation.Bean;
  19. import org.springframework.core.io.FileSystemResource;
  20. import org.springframework.security.kerberos.client.config.SunJaasKrb5LoginConfig;
  21. import org.springframework.security.kerberos.client.ldap.KerberosLdapContextSource;
  22. import org.springframework.security.ldap.search.FilterBasedLdapUserSearch;
  23. import org.springframework.security.ldap.userdetails.LdapUserDetailsMapper;
  24. import org.springframework.security.ldap.userdetails.LdapUserDetailsService;
  25. public class KerberosLdapContextSourceConfig {
  26. //tag::snippetA[]
  27. @Value("${app.ad-server}")
  28. private String adServer;
  29. @Value("${app.service-principal}")
  30. private String servicePrincipal;
  31. @Value("${app.keytab-location}")
  32. private String keytabLocation;
  33. @Value("${app.ldap-search-base}")
  34. private String ldapSearchBase;
  35. @Value("${app.ldap-search-filter}")
  36. private String ldapSearchFilter;
  37. @Bean
  38. public KerberosLdapContextSource kerberosLdapContextSource() {
  39. KerberosLdapContextSource contextSource = new KerberosLdapContextSource(adServer);
  40. SunJaasKrb5LoginConfig loginConfig = new SunJaasKrb5LoginConfig();
  41. loginConfig.setKeyTabLocation(new FileSystemResource(keytabLocation));
  42. loginConfig.setServicePrincipal(servicePrincipal);
  43. loginConfig.setDebug(true);
  44. loginConfig.setIsInitiator(true);
  45. contextSource.setLoginConfig(loginConfig);
  46. return contextSource;
  47. }
  48. @Bean
  49. public LdapUserDetailsService ldapUserDetailsService() {
  50. FilterBasedLdapUserSearch userSearch =
  51. new FilterBasedLdapUserSearch(ldapSearchBase, ldapSearchFilter, kerberosLdapContextSource());
  52. LdapUserDetailsService service = new LdapUserDetailsService(userSearch);
  53. service.setUserDetailsMapper(new LdapUserDetailsMapper());
  54. return service;
  55. }
  56. //end::snippetA[]
  57. }