com.databricks.sdk.service.oauth2.ServicePrincipalSecretsAPI Maven / Gradle / Ivy
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT.
package com.databricks.sdk.service.oauth2;
import com.databricks.sdk.core.ApiClient;
import com.databricks.sdk.support.Generated;
import com.databricks.sdk.support.Paginator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* These APIs enable administrators to manage service principal secrets.
*
* You can use the generated secrets to obtain OAuth access tokens for a service principal, which
* can then be used to access Databricks Accounts and Workspace APIs. For more information, see
* [Authentication using OAuth tokens for service principals],
*
*
In addition, the generated secrets can be used to configure the Databricks Terraform Provider
* to authenticate with the service principal. For more information, see [Databricks Terraform
* Provider].
*
*
[Authentication using OAuth tokens for service principals]:
* https://docs.databricks.com/dev-tools/authentication-oauth.html [Databricks Terraform Provider]:
* https://github.com/databricks/terraform-provider-databricks/blob/master/docs/index.md#authenticating-with-service-principal
*/
@Generated
public class ServicePrincipalSecretsAPI {
private static final Logger LOG = LoggerFactory.getLogger(ServicePrincipalSecretsAPI.class);
private final ServicePrincipalSecretsService impl;
/** Regular-use constructor */
public ServicePrincipalSecretsAPI(ApiClient apiClient) {
impl = new ServicePrincipalSecretsImpl(apiClient);
}
/** Constructor for mocks */
public ServicePrincipalSecretsAPI(ServicePrincipalSecretsService mock) {
impl = mock;
}
public CreateServicePrincipalSecretResponse create(long servicePrincipalId) {
return create(
new CreateServicePrincipalSecretRequest().setServicePrincipalId(servicePrincipalId));
}
/**
* Create service principal secret.
*
*
Create a secret for the given service principal.
*/
public CreateServicePrincipalSecretResponse create(CreateServicePrincipalSecretRequest request) {
return impl.create(request);
}
public void delete(long servicePrincipalId, String secretId) {
delete(
new DeleteServicePrincipalSecretRequest()
.setServicePrincipalId(servicePrincipalId)
.setSecretId(secretId));
}
/**
* Delete service principal secret.
*
*
Delete a secret from the given service principal.
*/
public void delete(DeleteServicePrincipalSecretRequest request) {
impl.delete(request);
}
public Iterable list(long servicePrincipalId) {
return list(new ListServicePrincipalSecretsRequest().setServicePrincipalId(servicePrincipalId));
}
/**
* List service principal secrets.
*
* List all secrets associated with the given service principal. This operation only returns
* information about the secrets themselves and does not include the secret values.
*/
public Iterable list(ListServicePrincipalSecretsRequest request) {
return new Paginator<>(
request,
impl::list,
ListServicePrincipalSecretsResponse::getSecrets,
response -> {
String token = response.getNextPageToken();
if (token == null || token.isEmpty()) {
return null;
}
return request.setPageToken(token);
});
}
public ServicePrincipalSecretsService impl() {
return impl;
}
}