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;
}
}
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);
}
}
Aggregations