UNPKG

auth0

Version:
205 lines (204 loc) 14.6 kB
import * as runtime from '../../../lib/runtime.js'; import type { InitOverride, ApiResponse } from '../../../lib/runtime.js'; import type { Client, ClientCreate, ClientUpdate, GetClientConnections200Response, GetCredentials200ResponseInner, PatchCredentialsByCredentialIdRequest, PostCredentialsRequest, GetClients200ResponseOneOf, DeleteClientsByIdRequest, DeleteCredentialsByCredentialIdRequest, GetClientConnectionsRequest, GetClientsRequest, GetClientsByIdRequest, GetCredentialsRequest, GetCredentialsByCredentialIdRequest, PatchClientsByIdRequest, PatchCredentialsByCredentialIdOperationRequest, PostCredentialsOperationRequest, PostRotateSecretRequest } from '../models/index.js'; declare const BaseAPI: typeof runtime.BaseAPI; /** * */ export declare class ClientsManager extends BaseAPI { /** * Delete a client and related configuration (rules, connections, etc). * Delete a client * * @throws {RequiredError} */ delete(requestParameters: DeleteClientsByIdRequest, initOverrides?: InitOverride): Promise<ApiResponse<void>>; /** * Delete a client credential you previously created. May be enabled or disabled. For more information, read <a href="https://www.auth0.com/docs/get-started/authentication-and-authorization-flow/client-credentials-flow">Client Credential Flow</a>. * Delete a client credential * * @throws {RequiredError} */ deleteCredential(requestParameters: DeleteCredentialsByCredentialIdRequest, initOverrides?: InitOverride): Promise<ApiResponse<void>>; /** * Retrieve all connections that are enabled for the specified <a href="https://www.auth0.com/docs/get-started/applications"> Application</a>, using checkpoint pagination. A list of fields to include or exclude for each connection may also be specified. * <ul> * <li> * This endpoint requires the <code>read:connections</code> scope and any one of <code>read:clients</code> or <code>read:client_summary</code>. * </li> * <li> * <b>Note</b>: The first time you call this endpoint, omit the <code>from</code> parameter. If there are more results, a <code>next</code> value is included in the response. You can use this for subsequent API calls. When <code>next</code> is no longer included in the response, no further results are remaining. * </li> * </ul> * * Get enabled connections for a client * * @throws {RequiredError} */ getEnabledConnections(requestParameters: GetClientConnectionsRequest, initOverrides?: InitOverride): Promise<ApiResponse<GetClientConnections200Response>>; /** * Retrieve clients (applications and SSO integrations) matching provided filters. A list of fields to include or exclude may also be specified. * For more information, read <a href="https://www.auth0.com/docs/get-started/applications"> Applications in Auth0</a> and <a href="https://www.auth0.com/docs/authenticate/single-sign-on"> Single Sign-On</a>. * * <ul> * <li> * The following can be retrieved with any scope: * <code>client_id</code>, <code>app_type</code>, <code>name</code>, and <code>description</code>. * </li> * <li> * The following properties can only be retrieved with the <code>read:clients</code> or * <code>read:client_keys</code> scope: * <code>callbacks</code>, <code>oidc_logout</code>, <code>allowed_origins</code>, * <code>web_origins</code>, <code>tenant</code>, <code>global</code>, <code>config_route</code>, * <code>callback_url_template</code>, <code>jwt_configuration</code>, * <code>jwt_configuration.lifetime_in_seconds</code>, <code>jwt_configuration.secret_encoded</code>, * <code>jwt_configuration.scopes</code>, <code>jwt_configuration.alg</code>, <code>api_type</code>, * <code>logo_uri</code>, <code>allowed_clients</code>, <code>owners</code>, <code>custom_login_page</code>, * <code>custom_login_page_off</code>, <code>sso</code>, <code>addons</code>, <code>form_template</code>, * <code>custom_login_page_codeview</code>, <code>resource_servers</code>, <code>client_metadata</code>, * <code>mobile</code>, <code>mobile.android</code>, <code>mobile.ios</code>, <code>allowed_logout_urls</code>, * <code>token_endpoint_auth_method</code>, <code>is_first_party</code>, <code>oidc_conformant</code>, * <code>is_token_endpoint_ip_header_trusted</code>, <code>initiate_login_uri</code>, <code>grant_types</code>, * <code>refresh_token</code>, <code>refresh_token.rotation_type</code>, <code>refresh_token.expiration_type</code>, * <code>refresh_token.leeway</code>, <code>refresh_token.token_lifetime</code>, <code>refresh_token.policies</code>, <code>organization_usage</code>, * <code>organization_require_behavior</code>. * </li> * <li> * The following properties can only be retrieved with the * <code>read:client_keys</code> or <code>read:client_credentials</code> scope: * <code>encryption_key</code>, <code>encryption_key.pub</code>, <code>encryption_key.cert</code>, * <code>client_secret</code>, <code>client_authentication_methods</code> and <code>signing_key</code>. * </li> * </ul> * * Get clients * * @throws {RequiredError} */ getAll(requestParameters: GetClientsRequest & { include_totals: true; }, initOverrides?: InitOverride): Promise<ApiResponse<GetClients200ResponseOneOf>>; getAll(requestParameters?: GetClientsRequest, initOverrides?: InitOverride): Promise<ApiResponse<Array<Client>>>; /** * Retrieve client details by ID. Clients are SSO connections or Applications linked with your Auth0 tenant. A list of fields to include or exclude may also be specified. * For more information, read <a href="https://www.auth0.com/docs/get-started/applications"> Applications in Auth0</a> and <a href="https://www.auth0.com/docs/authenticate/single-sign-on"> Single Sign-On</a>. * <ul> * <li> * The following properties can be retrieved with any of the scopes: * <code>client_id</code>, <code>app_type</code>, <code>name</code>, and <code>description</code>. * </li> * <li> * The following properties can only be retrieved with the <code>read:clients</code> or * <code>read:client_keys</code> scopes: * <code>callbacks</code>, <code>oidc_logout</code>, <code>allowed_origins</code>, * <code>web_origins</code>, <code>tenant</code>, <code>global</code>, <code>config_route</code>, * <code>callback_url_template</code>, <code>jwt_configuration</code>, * <code>jwt_configuration.lifetime_in_seconds</code>, <code>jwt_configuration.secret_encoded</code>, * <code>jwt_configuration.scopes</code>, <code>jwt_configuration.alg</code>, <code>api_type</code>, * <code>logo_uri</code>, <code>allowed_clients</code>, <code>owners</code>, <code>custom_login_page</code>, * <code>custom_login_page_off</code>, <code>sso</code>, <code>addons</code>, <code>form_template</code>, * <code>custom_login_page_codeview</code>, <code>resource_servers</code>, <code>client_metadata</code>, * <code>mobile</code>, <code>mobile.android</code>, <code>mobile.ios</code>, <code>allowed_logout_urls</code>, * <code>token_endpoint_auth_method</code>, <code>is_first_party</code>, <code>oidc_conformant</code>, * <code>is_token_endpoint_ip_header_trusted</code>, <code>initiate_login_uri</code>, <code>grant_types</code>, * <code>refresh_token</code>, <code>refresh_token.rotation_type</code>, <code>refresh_token.expiration_type</code>, * <code>refresh_token.leeway</code>, <code>refresh_token.token_lifetime</code>, <code>refresh_token.policies</code>, <code>organization_usage</code>, * <code>organization_require_behavior</code>. * </li> * <li> * The following properties can only be retrieved with the <code>read:client_keys</code> or <code>read:client_credentials</code> scopes: * <code>encryption_key</code>, <code>encryption_key.pub</code>, <code>encryption_key.cert</code>, * <code>client_secret</code>, <code>client_authentication_methods</code> and <code>signing_key</code>. * </li> * </ul> * * Get client by ID * * @throws {RequiredError} */ get(requestParameters: GetClientsByIdRequest, initOverrides?: InitOverride): Promise<ApiResponse<Client>>; /** * Get the details of a client credential. * * <b>Important</b>: To enable credentials to be used for Private Key JWT authentication method, set the <code>client_authentication_methods</code> property on the client. * Get client credentials * * @throws {RequiredError} */ getCredentials(requestParameters: GetCredentialsRequest, initOverrides?: InitOverride): Promise<ApiResponse<Array<GetCredentials200ResponseInner>>>; /** * Get the details of a client credential. * * <b>Important</b>: To enable credentials to be used for Private Key JWT authentication method, set the <code>client_authentication_methods</code> property on the client. * Get client credential details * * @throws {RequiredError} */ getCredential(requestParameters: GetCredentialsByCredentialIdRequest, initOverrides?: InitOverride): Promise<ApiResponse<GetCredentials200ResponseInner>>; /** * Updates a client's settings. For more information, read <a href="https://www.auth0.com/docs/get-started/applications"> Applications in Auth0</a> and <a href="https://www.auth0.com/docs/authenticate/single-sign-on"> Single Sign-On</a>. * * Notes: * - The `client_secret` and `signing_key` attributes can only be updated with the `update:client_keys` scope. * - The <code>client_authentication_methods</code> and <code>token_endpoint_auth_method</code> properties are mutually exclusive. Use * <code>client_authentication_methods</code> to configure the client with Private Key JWT authentication method. Otherwise, use <code>token_endpoint_auth_method</code> * to configure the client with client secret (basic or post) or with no authentication method (none). * - When using <code>client_authentication_methods</code> to configure the client with Private Key JWT authentication method, only specify the credential IDs * that were generated when creating the credentials on the client. * - To configure <code>client_authentication_methods</code>, the <code>update:client_credentials</code> scope is required. * - To configure <code>client_authentication_methods</code>, the property <code>jwt_configuration.alg</code> must be set to RS256. * Update a client * * @throws {RequiredError} */ update(requestParameters: PatchClientsByIdRequest, bodyParameters: ClientUpdate, initOverrides?: InitOverride): Promise<ApiResponse<Client>>; /** * Change a client credential you previously created. May be enabled or disabled. For more information, read <a href="https://www.auth0.com/docs/get-started/authentication-and-authorization-flow/client-credentials-flow">Client Credential Flow</a>. * Update a client credential * * @throws {RequiredError} */ updateCredential(requestParameters: PatchCredentialsByCredentialIdOperationRequest, bodyParameters: PatchCredentialsByCredentialIdRequest, initOverrides?: InitOverride): Promise<ApiResponse<GetCredentials200ResponseInner>>; /** * Create a new client (application or SSO integration). For more information, read <a href="https://www.auth0.com/docs/get-started/auth0-overview/create-applications">Create Applications</a> * <a href="https://www.auth0.com/docs/authenticate/single-sign-on/api-endpoints-for-single-sign-on>">API Endpoints for Single Sign-On</a>. * * Notes: * - We recommend leaving the `client_secret` parameter unspecified to allow the generation of a safe secret. * - The <code>client_authentication_methods</code> and <code>token_endpoint_auth_method</code> properties are mutually exclusive. Use * <code>client_authentication_methods</code> to configure the client with Private Key JWT authentication method. Otherwise, use <code>token_endpoint_auth_method</code> * to configure the client with client secret (basic or post) or with no authentication method (none). * - When using <code>client_authentication_methods</code> to configure the client with Private Key JWT authentication method, specify fully defined credentials. * These credentials will be automatically enabled for Private Key JWT authentication on the client. * - To configure <code>client_authentication_methods</code>, the <code>create:client_credentials</code> scope is required. * - To configure <code>client_authentication_methods</code>, the property <code>jwt_configuration.alg</code> must be set to RS256. * * <div class="alert alert-warning">SSO Integrations created via this endpoint will accept login requests and share user profile information.</div> * * Create a client * * @throws {RequiredError} */ create(bodyParameters: ClientCreate, initOverrides?: InitOverride): Promise<ApiResponse<Client>>; /** * Create a client credential associated to your application. The credential will be created but not yet enabled for use with Private Key JWT authentication method. To enable the credential, set the <code>client_authentication_methods</code> property on the client. * For more information, read <a href="https://www.auth0.com//docs/get-started/applications/configure-private-key-jwt">Configure Private Key JWT Authentication</a>. * Create a client credential * * @throws {RequiredError} */ createCredential(requestParameters: PostCredentialsOperationRequest, bodyParameters: PostCredentialsRequest, initOverrides?: InitOverride): Promise<ApiResponse<GetCredentials200ResponseInner>>; /** * Rotate a client secret. * * This endpoint cannot be used with clients configured with Private Key JWT authentication method (client_authentication_methods configured with private_key_jwt). * * Note: The generated secret is NOT base64 encoded. * * Rotate a client secret * * @throws {RequiredError} */ rotateClientSecret(requestParameters: PostRotateSecretRequest, initOverrides?: InitOverride): Promise<ApiResponse<Client>>; } export {};