Search in sources :

Example 1 with BeanBuilder

use of hudson.util.spring.BeanBuilder in project hudson-2.x by hudson.

the class LegacySecurityRealm method createFilter.

/**
 * Filter to run for the LegacySecurityRealm is the
 * ChainServletFilter legacy from /WEB-INF/security/SecurityFilters.groovy.
 */
@Override
public Filter createFilter(FilterConfig filterConfig) {
    Binding binding = new Binding();
    SecurityComponents sc = this.createSecurityComponents();
    binding.setVariable("securityComponents", sc);
    binding.setVariable("securityRealm", this);
    BeanBuilder builder = new BeanBuilder();
    builder.parse(filterConfig.getServletContext().getResourceAsStream("/WEB-INF/security/SecurityFilters.groovy"), binding);
    WebApplicationContext context = builder.createApplicationContext();
    return (Filter) context.getBean("legacy");
}
Also used : Binding(groovy.lang.Binding) BeanBuilder(hudson.util.spring.BeanBuilder) Filter(javax.servlet.Filter) WebApplicationContext(org.springframework.web.context.WebApplicationContext)

Example 2 with BeanBuilder

use of hudson.util.spring.BeanBuilder in project hudson-2.x by hudson.

the class PAMSecurityRealm method createSecurityComponents.

public SecurityComponents createSecurityComponents() {
    Binding binding = new Binding();
    binding.setVariable("instance", this);
    BeanBuilder builder = new BeanBuilder();
    builder.parse(Hudson.getInstance().servletContext.getResourceAsStream("/WEB-INF/security/PAMSecurityRealm.groovy"), binding);
    WebApplicationContext context = builder.createApplicationContext();
    return new SecurityComponents(findBean(AuthenticationManager.class, context), new UserDetailsService() {

        public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException, DataAccessException {
            if (!UnixUser.exists(username))
                throw new UsernameNotFoundException("No such Unix user: " + username);
            // return some dummy instance
            return new User(username, "", true, true, true, true, new GrantedAuthority[] { AUTHENTICATED_AUTHORITY });
        }
    });
}
Also used : Binding(groovy.lang.Binding) BeanBuilder(hudson.util.spring.BeanBuilder) AuthenticationManager(org.acegisecurity.AuthenticationManager) UsernameNotFoundException(org.acegisecurity.userdetails.UsernameNotFoundException) UserDetails(org.acegisecurity.userdetails.UserDetails) UnixUser(org.jvnet.libpam.UnixUser) User(org.acegisecurity.userdetails.User) GrantedAuthority(org.acegisecurity.GrantedAuthority) UserDetailsService(org.acegisecurity.userdetails.UserDetailsService) DataAccessException(org.springframework.dao.DataAccessException) WebApplicationContext(org.springframework.web.context.WebApplicationContext)

Example 3 with BeanBuilder

use of hudson.util.spring.BeanBuilder in project hudson-2.x by hudson.

the class AbstractPasswordBasedSecurityRealm method createSecurityComponents.

@Override
public SecurityComponents createSecurityComponents() {
    Binding binding = new Binding();
    binding.setVariable("authenticator", new Authenticator());
    BeanBuilder builder = new BeanBuilder();
    builder.parse(Hudson.getInstance().servletContext.getResourceAsStream("/WEB-INF/security/AbstractPasswordBasedSecurityRealm.groovy"), binding);
    WebApplicationContext context = builder.createApplicationContext();
    return new SecurityComponents(findBean(AuthenticationManager.class, context), this);
}
Also used : Binding(groovy.lang.Binding) BeanBuilder(hudson.util.spring.BeanBuilder) AuthenticationManager(org.acegisecurity.AuthenticationManager) WebApplicationContext(org.springframework.web.context.WebApplicationContext)

Example 4 with BeanBuilder

use of hudson.util.spring.BeanBuilder in project hudson-2.x by hudson.

the class SecurityRealm method createFilter.

/**
 * Creates {@link Filter} that all the incoming HTTP requests will go through
 * for authentication.
 * <p/>
 * <p/>
 * The default implementation uses {@link #getSecurityComponents()} and builds
 * a standard filter chain from /WEB-INF/security/SecurityFilters.groovy.
 * But subclasses can override this to completely change the filter sequence.
 * <p/>
 * <p/>
 * For other plugins that want to contribute {@link Filter}, see
 * {@link PluginServletFilter}.
 *
 * @since 1.271
 */
public Filter createFilter(FilterConfig filterConfig) {
    LOGGER.entering(SecurityRealm.class.getName(), "createFilter");
    Binding binding = new Binding();
    SecurityComponents sc = getSecurityComponents();
    binding.setVariable("securityComponents", sc);
    binding.setVariable("securityRealm", this);
    BeanBuilder builder = new BeanBuilder();
    builder.parse(filterConfig.getServletContext().getResourceAsStream("/WEB-INF/security/SecurityFilters.groovy"), binding);
    WebApplicationContext context = builder.createApplicationContext();
    return (Filter) context.getBean("filter");
}
Also used : Binding(groovy.lang.Binding) BeanBuilder(hudson.util.spring.BeanBuilder) Filter(javax.servlet.Filter) PluginServletFilter(hudson.util.PluginServletFilter) WebApplicationContext(org.springframework.web.context.WebApplicationContext)

Example 5 with BeanBuilder

use of hudson.util.spring.BeanBuilder in project hudson-2.x by hudson.

the class LDAPSecurityRealm method createSecurityComponents.

public SecurityComponents createSecurityComponents() {
    Binding binding = new Binding();
    binding.setVariable("instance", this);
    BeanBuilder builder = new BeanBuilder();
    builder.parse(Hudson.getInstance().servletContext.getResourceAsStream("/WEB-INF/security/LDAPBindSecurityRealm.groovy"), binding);
    WebApplicationContext appContext = builder.createApplicationContext();
    ldapTemplate = new LdapTemplate(findBean(InitialDirContextFactory.class, appContext));
    return new SecurityComponents(findBean(AuthenticationManager.class, appContext), new LDAPUserDetailsService(appContext));
}
Also used : Binding(groovy.lang.Binding) BeanBuilder(hudson.util.spring.BeanBuilder) AuthenticationManager(org.acegisecurity.AuthenticationManager) LdapTemplate(org.acegisecurity.ldap.LdapTemplate) WebApplicationContext(org.springframework.web.context.WebApplicationContext)

Aggregations

Binding (groovy.lang.Binding)5 BeanBuilder (hudson.util.spring.BeanBuilder)5 WebApplicationContext (org.springframework.web.context.WebApplicationContext)5 AuthenticationManager (org.acegisecurity.AuthenticationManager)3 Filter (javax.servlet.Filter)2 PluginServletFilter (hudson.util.PluginServletFilter)1 GrantedAuthority (org.acegisecurity.GrantedAuthority)1 LdapTemplate (org.acegisecurity.ldap.LdapTemplate)1 User (org.acegisecurity.userdetails.User)1 UserDetails (org.acegisecurity.userdetails.UserDetails)1 UserDetailsService (org.acegisecurity.userdetails.UserDetailsService)1 UsernameNotFoundException (org.acegisecurity.userdetails.UsernameNotFoundException)1 UnixUser (org.jvnet.libpam.UnixUser)1 DataAccessException (org.springframework.dao.DataAccessException)1