All Downloads are FREE. Search and download functionalities are using the official Maven repository.

java-pkmst.security.resourceServerConfiguration.mustache Maven / Gradle / Ivy

There is a newer version: 7.8.0
Show newest version
package {{basePackage}}.security;

import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.oauth2.config.annotation.web.configuration.EnableResourceServer;
import org.springframework.security.oauth2.config.annotation.web.configuration.ResourceServerConfigurerAdapter;
import org.springframework.security.oauth2.config.annotation.web.configurers.ResourceServerSecurityConfigurer;
import org.springframework.security.oauth2.provider.error.OAuth2AccessDeniedHandler;
import org.springframework.http.HttpMethod;
/**
 * Configurer class for @EnableResourceServer classes. This class adjust the access
 * rules and paths that are protected by OAuth2 security. If more than one configures the same property, then the last
 * one wins. The configurers are sorted by {@link Order} before being applied.
 * 
 * @author pkmst
 * 
 */
@Configuration
@EnableResourceServer
public class ResourceServerConfiguration extends ResourceServerConfigurerAdapter {

    private static final String RESOURCE_ID = "my_rest_api";

    @Override
    public void configure(ResourceServerSecurityConfigurer resources) {
        resources.resourceId(RESOURCE_ID).stateless(false);
    }

    @Override
    public void configure(HttpSecurity http) throws Exception {
    //configure security for the http methods
    {{#resourcePaths}}
        http.
        anonymous().disable()
        .requestMatchers().antMatchers(HttpMethod.GET, "/{{path}}/**")
        .and().authorizeRequests()
        .antMatchers(HttpMethod.GET, "/{{path}}/**").access("hasRole('ADMIN')")
        .and().exceptionHandling().accessDeniedHandler(new OAuth2AccessDeniedHandler());
        {{/resourcePaths}}
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy