Search in sources :

Example 6 with ClientRegistrationProviderEntity

use of io.gravitee.rest.api.model.configuration.application.registration.ClientRegistrationProviderEntity in project gravitee-management-rest-api by gravitee-io.

the class ClientRegistrationServiceImpl method renewClientSecret.

@Override
public ClientRegistrationResponse renewClientSecret(String previousRegistrationResponse) {
    try {
        ClientRegistrationResponse registrationResponse = mapper.readValue(previousRegistrationResponse, ClientRegistrationResponse.class);
        if (registrationResponse.getRegistrationAccessToken() == null || registrationResponse.getRegistrationAccessToken().isEmpty() || registrationResponse.getRegistrationClientUri() == null || registrationResponse.getRegistrationClientUri().isEmpty()) {
            throw new RegisteredClientNotUpdatableException();
        }
        Set<ClientRegistrationProviderEntity> providers = findAll();
        if (providers == null || providers.isEmpty()) {
            throw new MissingDynamicClientRegistrationProviderException();
        }
        // For now, take the first provider
        ClientRegistrationProviderEntity provider = providers.iterator().next();
        // Get provider client
        DynamicClientRegistrationProviderClient registrationProviderClient = getDCRClient(false, provider);
        String renewClientSecretEndpoint = provider.getRenewClientSecretEndpoint();
        TemplateEngine templateEngine = TemplateEngine.templateEngine();
        templateEngine.getTemplateContext().setVariable("client_id", registrationResponse.getClientId());
        if (registrationProviderClient instanceof DiscoveryBasedDynamicClientRegistrationProviderClient) {
            ((DiscoveryBasedDynamicClientRegistrationProviderClient) registrationProviderClient).getMetadata().forEach((s, o) -> templateEngine.getTemplateContext().setVariable(s, o));
        }
        return registrationProviderClient.renewClientSecret(provider.getRenewClientSecretMethod(), templateEngine.getValue(renewClientSecretEndpoint, String.class), registrationResponse.getRegistrationAccessToken());
    } catch (IOException ioe) {
        LOGGER.error("Unexpected error while updating a client", ioe);
        return null;
    }
}
Also used : TemplateEngine(io.gravitee.el.TemplateEngine) DiscoveryBasedDynamicClientRegistrationProviderClient(io.gravitee.rest.api.service.impl.configuration.application.registration.client.DiscoveryBasedDynamicClientRegistrationProviderClient) ClientRegistrationResponse(io.gravitee.rest.api.service.impl.configuration.application.registration.client.register.ClientRegistrationResponse) NewClientRegistrationProviderEntity(io.gravitee.rest.api.model.configuration.application.registration.NewClientRegistrationProviderEntity) UpdateClientRegistrationProviderEntity(io.gravitee.rest.api.model.configuration.application.registration.UpdateClientRegistrationProviderEntity) ClientRegistrationProviderEntity(io.gravitee.rest.api.model.configuration.application.registration.ClientRegistrationProviderEntity) UuidString(io.gravitee.rest.api.service.common.UuidString) IOException(java.io.IOException) DynamicClientRegistrationProviderClient(io.gravitee.rest.api.service.impl.configuration.application.registration.client.DynamicClientRegistrationProviderClient) DiscoveryBasedDynamicClientRegistrationProviderClient(io.gravitee.rest.api.service.impl.configuration.application.registration.client.DiscoveryBasedDynamicClientRegistrationProviderClient)

Example 7 with ClientRegistrationProviderEntity

use of io.gravitee.rest.api.model.configuration.application.registration.ClientRegistrationProviderEntity in project gravitee-management-rest-api by gravitee-io.

the class ClientRegistrationServiceImpl method create.

@Override
public ClientRegistrationProviderEntity create(NewClientRegistrationProviderEntity newClientRegistrationProvider) {
    try {
        LOGGER.debug("Create client registration provider {}", newClientRegistrationProvider);
        Set<ClientRegistrationProviderEntity> clientRegistrationProviders = this.findAll();
        // For now, we are supporting only a single client registration provider.
        if (clientRegistrationProviders.size() == 1) {
            throw new IllegalStateException("Until now, supports only a single client registration provider. " + "Please update the existing one: " + clientRegistrationProviders.iterator().next().getName());
        }
        Optional<ClientRegistrationProvider> optClientRegistrationProvider = clientRegistrationProviderRepository.findById(IdGenerator.generate(newClientRegistrationProvider.getName()));
        if (optClientRegistrationProvider.isPresent()) {
            throw new ClientRegistrationProviderAlreadyExistsException(newClientRegistrationProvider.getName());
        }
        if (newClientRegistrationProvider.getInitialAccessTokenType() == InitialAccessTokenType.INITIAL_ACCESS_TOKEN && (newClientRegistrationProvider.getInitialAccessToken() == null || newClientRegistrationProvider.getInitialAccessToken().isEmpty())) {
            throw new EmptyInitialAccessTokenException();
        }
        ClientRegistrationProvider clientRegistrationProvider = convert(newClientRegistrationProvider);
        // Check renew_client_secret configuration
        renewClientSecretSupport(clientRegistrationProvider);
        clientRegistrationProvider.setId(UuidString.generateRandom());
        DynamicClientRegistrationProviderClient registrationProviderClient = getDCRClient(true, convert(clientRegistrationProvider));
        // Ensure that the client credentials are valid
        registrationProviderClient.getInitialAccessToken();
        LOGGER.debug("Found a DCR Client for provider: {}", clientRegistrationProvider.getName(), registrationProviderClient);
        // Set date fields
        clientRegistrationProvider.setCreatedAt(new Date());
        clientRegistrationProvider.setUpdatedAt(clientRegistrationProvider.getCreatedAt());
        ClientRegistrationProvider createdClientRegistrationProvider = clientRegistrationProviderRepository.create(clientRegistrationProvider);
        auditService.createEnvironmentAuditLog(singletonMap(CLIENT_REGISTRATION_PROVIDER, createdClientRegistrationProvider.getId()), ClientRegistrationProvider.AuditEvent.CLIENT_REGISTRATION_PROVIDER_CREATED, createdClientRegistrationProvider.getUpdatedAt(), null, createdClientRegistrationProvider);
        return convert(createdClientRegistrationProvider);
    } catch (TechnicalException ex) {
        LOGGER.error("An error occurs while trying to create client registration provider {}", newClientRegistrationProvider, ex);
        throw new TechnicalManagementException("An error occurs while trying to create " + newClientRegistrationProvider, ex);
    }
}
Also used : TechnicalException(io.gravitee.repository.exceptions.TechnicalException) NewClientRegistrationProviderEntity(io.gravitee.rest.api.model.configuration.application.registration.NewClientRegistrationProviderEntity) UpdateClientRegistrationProviderEntity(io.gravitee.rest.api.model.configuration.application.registration.UpdateClientRegistrationProviderEntity) ClientRegistrationProviderEntity(io.gravitee.rest.api.model.configuration.application.registration.ClientRegistrationProviderEntity) ClientRegistrationProvider(io.gravitee.repository.management.model.ClientRegistrationProvider) DynamicClientRegistrationProviderClient(io.gravitee.rest.api.service.impl.configuration.application.registration.client.DynamicClientRegistrationProviderClient) DiscoveryBasedDynamicClientRegistrationProviderClient(io.gravitee.rest.api.service.impl.configuration.application.registration.client.DiscoveryBasedDynamicClientRegistrationProviderClient) Date(java.util.Date) TechnicalManagementException(io.gravitee.rest.api.service.exceptions.TechnicalManagementException)

Aggregations

ClientRegistrationProviderEntity (io.gravitee.rest.api.model.configuration.application.registration.ClientRegistrationProviderEntity)7 NewClientRegistrationProviderEntity (io.gravitee.rest.api.model.configuration.application.registration.NewClientRegistrationProviderEntity)6 UpdateClientRegistrationProviderEntity (io.gravitee.rest.api.model.configuration.application.registration.UpdateClientRegistrationProviderEntity)5 DiscoveryBasedDynamicClientRegistrationProviderClient (io.gravitee.rest.api.service.impl.configuration.application.registration.client.DiscoveryBasedDynamicClientRegistrationProviderClient)4 DynamicClientRegistrationProviderClient (io.gravitee.rest.api.service.impl.configuration.application.registration.client.DynamicClientRegistrationProviderClient)4 ClientRegistrationResponse (io.gravitee.rest.api.service.impl.configuration.application.registration.client.register.ClientRegistrationResponse)3 IOException (java.io.IOException)3 TechnicalException (io.gravitee.repository.exceptions.TechnicalException)2 UuidString (io.gravitee.rest.api.service.common.UuidString)2 TechnicalManagementException (io.gravitee.rest.api.service.exceptions.TechnicalManagementException)2 ClientRegistrationRequest (io.gravitee.rest.api.service.impl.configuration.application.registration.client.register.ClientRegistrationRequest)2 TemplateEngine (io.gravitee.el.TemplateEngine)1 ClientRegistrationProvider (io.gravitee.repository.management.model.ClientRegistrationProvider)1 ApplicationSettings (io.gravitee.rest.api.model.application.ApplicationSettings)1 OAuthClientSettings (io.gravitee.rest.api.model.application.OAuthClientSettings)1 SimpleApplicationSettings (io.gravitee.rest.api.model.application.SimpleApplicationSettings)1 Date (java.util.Date)1 Response (javax.ws.rs.core.Response)1 Test (org.junit.Test)1