org.keycloak.adapters.springsecurity.userdetails.config.AppConfig.java Source code

Java tutorial

Introduction

Here is the source code for org.keycloak.adapters.springsecurity.userdetails.config.AppConfig.java

Source

/*
 * Copyright 2015 Smartling, Inc.
 *
 * 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.
 */

package org.keycloak.adapters.springsecurity.userdetails.config;

import org.keycloak.adapters.KeycloakDeployment;
import org.keycloak.adapters.KeycloakDeploymentBuilder;
import org.keycloak.adapters.springsecurity.KeycloakSecurityComponents;
import org.keycloak.adapters.springsecurity.authentication.DirectAccessGrantAuthenticationProvider;
import org.keycloak.adapters.springsecurity.userdetails.authentication.DirectAccessGrantUserDetailsAuthenticationProvider;
import org.keycloak.adapters.springsecurity.service.DirectAccessGrantService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.io.Resource;
import org.springframework.security.core.authority.SimpleGrantedAuthority;
import org.springframework.security.core.userdetails.User;
import org.springframework.security.core.userdetails.UserDetails;
import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.provisioning.InMemoryUserDetailsManager;

import java.io.IOException;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;

/**
 * Spring integration test application configuration.
 */
@Configuration
@ComponentScan(basePackageClasses = KeycloakSecurityComponents.class)
public class AppConfig {

    public static final String KNOWN_EMAIL = "srossillo@smartling.com";
    public static final String KNOWN_USERNAME = "srossillo";
    public static final String KNOWN_PASSWORD = "password";

    @Autowired
    protected DirectAccessGrantService directAccessGrantService;

    @Bean
    KeycloakDeployment keycloakDeployment(
            @Value("${keycloak.configurationFile:WEB-INF/keycloak.json}") Resource keycloakConfigFileResource)
            throws IOException {
        return KeycloakDeploymentBuilder.build(keycloakConfigFileResource.getInputStream());
    }

    @Bean
    DirectAccessGrantAuthenticationProvider directAccessGrantAuthenticationProvider() {
        DirectAccessGrantAuthenticationProvider provider = new DirectAccessGrantAuthenticationProvider();
        provider.setDirectAccessGrantService(directAccessGrantService);
        return provider;
    }

    @Bean
    DirectAccessGrantUserDetailsAuthenticationProvider directAccessGrantUserDetailsAuthenticationProvider() {
        DirectAccessGrantUserDetailsAuthenticationProvider provider = new DirectAccessGrantUserDetailsAuthenticationProvider();
        provider.setDirectAccessGrantService(directAccessGrantService);
        provider.setUserDetailsService(userDetailsService());
        return provider;
    }

    @Bean
    UserDetailsService userDetailsService() {
        Set<UserDetails> users = new HashSet<>();
        User user = new User(KNOWN_EMAIL, "does_not_matter", Arrays.asList(new SimpleGrantedAuthority("user")));
        users.add(user);
        return new InMemoryUserDetailsManager(Collections.unmodifiableCollection(users));
    }
}