Table of Contents

Interface IUsersClient

Namespace
Auth0.ManagementApi
Assembly
Auth0.ManagementApi.dll
public interface IUsersClient
Extension Methods

Properties

AuthenticationMethods

IAuthenticationMethodsClient AuthenticationMethods { get; }

Property Value

IAuthenticationMethodsClient

Authenticators

IAuthenticatorsClient Authenticators { get; }

Property Value

IAuthenticatorsClient

ConnectedAccounts

IConnectedAccountsClient ConnectedAccounts { get; }

Property Value

IConnectedAccountsClient

Enrollments

IEnrollmentsClient Enrollments { get; }

Property Value

IEnrollmentsClient

FederatedConnectionsTokensets

IFederatedConnectionsTokensetsClient FederatedConnectionsTokensets { get; }

Property Value

IFederatedConnectionsTokensetsClient

Groups

IGroupsClient Groups { get; }

Property Value

IGroupsClient

Identities

IIdentitiesClient Identities { get; }

Property Value

IIdentitiesClient

Logs

ILogsClient Logs { get; }

Property Value

ILogsClient

Multifactor

IMultifactorClient Multifactor { get; }

Property Value

IMultifactorClient

Organizations

IOrganizationsClient Organizations { get; }

Property Value

IOrganizationsClient

Permissions

IPermissionsClient Permissions { get; }

Property Value

IPermissionsClient

RefreshToken

IRefreshTokenClient RefreshToken { get; }

Property Value

IRefreshTokenClient

RiskAssessments

IRiskAssessmentsClient RiskAssessments { get; }

Property Value

IRiskAssessmentsClient

Roles

IRolesClient Roles { get; }

Property Value

IRolesClient

Sessions

ISessionsClient Sessions { get; }

Property Value

ISessionsClient

Methods

CreateAsync(CreateUserRequestContent, RequestOptions?, CancellationToken)

Create a new user for a given database or passwordless connection.

Note: connection is required but other parameters such as email and password are dependent upon the type of connection.

WithRawResponseTask<CreateUserResponseContent> CreateAsync(CreateUserRequestContent request, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

request CreateUserRequestContent
options RequestOptions
cancellationToken CancellationToken

Returns

WithRawResponseTask<CreateUserResponseContent>

DeleteAsync(string, RequestOptions?, CancellationToken)

Delete a user by user ID. This action cannot be undone. For Auth0 Dashboard instructions, see Delete Users.

Task DeleteAsync(string id, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

id string
options RequestOptions
cancellationToken CancellationToken

Returns

Task

GetAsync(string, GetUserRequestParameters, RequestOptions?, CancellationToken)

Retrieve user details. A list of fields to include or exclude may also be specified. For more information, see Retrieve Users with the Get Users Endpoint.

WithRawResponseTask<GetUserResponseContent> GetAsync(string id, GetUserRequestParameters request, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

id string
request GetUserRequestParameters
options RequestOptions
cancellationToken CancellationToken

Returns

WithRawResponseTask<GetUserResponseContent>

ListAsync(ListUsersRequestParameters, RequestOptions?, CancellationToken)

Retrieve details of users. It is possible to:

  • Specify a search criteria for users
  • Sort the users to be returned
  • Select the fields to be returned
  • Specify the number of users to retrieve per page and the page index

The q query parameter can be used to get users that match the specified criteria using query string syntax.

Learn more about searching for users.

Read about best practices when working with the API endpoints for retrieving users.

Auth0 limits the number of users you can return. If you exceed this threshold, please redefine your search, use the export job, or the User Import / Export extension.

Task<Pager<UserResponseSchema>> ListAsync(ListUsersRequestParameters request, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

request ListUsersRequestParameters
options RequestOptions
cancellationToken CancellationToken

Returns

Task<Pager<UserResponseSchema>>

ListUsersByEmailAsync(ListUsersByEmailRequestParameters, RequestOptions?, CancellationToken)

Find users by email. If Auth0 is the identity provider (idP), the email address associated with a user is saved in lower case, regardless of how you initially provided it.

For example, if you register a user as JohnSmith@example.com, Auth0 saves the user's email as johnsmith@example.com.

Therefore, when using this endpoint, make sure that you are searching for users via email addresses using the correct case.

WithRawResponseTask<IEnumerable<UserResponseSchema>> ListUsersByEmailAsync(ListUsersByEmailRequestParameters request, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

request ListUsersByEmailRequestParameters
options RequestOptions
cancellationToken CancellationToken

Returns

WithRawResponseTask<IEnumerable<UserResponseSchema>>

RegenerateRecoveryCodeAsync(string, RequestOptions?, CancellationToken)

Remove an existing multi-factor authentication (MFA) recovery code and generate a new one. If a user cannot access the original device or account used for MFA enrollment, they can use a recovery code to authenticate.

WithRawResponseTask<RegenerateUsersRecoveryCodeResponseContent> RegenerateRecoveryCodeAsync(string id, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

id string
options RequestOptions
cancellationToken CancellationToken

Returns

WithRawResponseTask<RegenerateUsersRecoveryCodeResponseContent>

RevokeAccessAsync(string, RevokeUserAccessRequestContent, RequestOptions?, CancellationToken)

Revokes selected resources related to a user (sessions, refresh tokens, ...).

Task RevokeAccessAsync(string id, RevokeUserAccessRequestContent request, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

id string
request RevokeUserAccessRequestContent
options RequestOptions
cancellationToken CancellationToken

Returns

Task

UpdateAsync(string, UpdateUserRequestContent, RequestOptions?, CancellationToken)

 Update a user.

 These are the attributes that can be updated at the root level:

 <ul><li>app_metadata</li><li>blocked</li><li>email</li><li>email_verified</li><li>family_name</li><li>given_name</li><li>name</li><li>nickname</li><li>password</li><li>phone_number</li><li>phone_verified</li><li>picture</li><li>username</li><li>user_metadata</li><li>verify_email</li></ul>

 Some considerations:

 <ul><li>The properties of the new object will replace the old ones.</li><li>The metadata fields are an exception to this rule (<code>user_metadata</code> and <code>app_metadata</code>). These properties are merged instead of being replaced but be careful, the merge only occurs on the first level.</li><li>If you are updating <code>email</code>, <code>email_verified</code>, <code>phone_number</code>, <code>phone_verified</code>, <code>username</code> or <code>password</code> of a secondary identity, you need to specify the <code>connection</code> property too.</li><li>If you are updating <code>email</code> or <code>phone_number</code> you can specify, optionally, the <code>client_id</code> property.</li><li>Updating <code>email_verified</code> is not supported for enterprise and passwordless sms connections.</li><li>Updating the <code>blocked</code> to <code>false</code> does not affect the user's blocked state from an excessive amount of incorrectly provided credentials. Use the "Unblock a user" endpoint from the "User Blocks" API to change the user's state.</li><li>Supported attributes can be unset by supplying <code>null</code> as the value.</li></ul>

 <p>Updating a field (non-metadata property)</p>

 To mark the email address of a user as verified, the body to send should be:

 <pre><code class="lang-csharp">{ "email_verified": true }</code></pre>

 <p>Updating a user metadata root property</p>

Let's assume that our test user has the following user_metadata:

 <pre><code class="lang-csharp">{ "user_metadata" : { "profileCode": 1479 } }</code></pre>

 To add the field <code>addresses</code> the body to send should be:

 <pre><code class="lang-csharp">{ "user_metadata" : { "addresses": {"work_address": "100 Industrial Way"} }}</code></pre>

 The modified object ends up with the following <code>user_metadata</code> property:
{
       "user_metadata": {
         "profileCode": 1479,
         "addresses": { "work_address": "100 Industrial Way" }
       }
     }
 <p>Updating an inner user metadata property</p>

If there's existing user metadata to which we want to add "home_address": "742 Evergreen Terrace" (using the addresses property) we should send the whole addresses object. Since this is a first-level object, the object will be merged in, but its own properties will not be. The body to send should be:

 <pre><code class="lang-csharp">{
   "user_metadata": {
     "addresses": {
       "work_address": "100 Industrial Way",
       "home_address": "742 Evergreen Terrace"
     }
   }
 }</code></pre>

 The modified object ends up with the following <code>user_metadata</code> property:

 <pre><code class="lang-csharp">{
   "user_metadata": {
     "profileCode": 1479,
     "addresses": {
       "work_address": "100 Industrial Way",
       "home_address": "742 Evergreen Terrace"
     }
   }
 }</code></pre>
WithRawResponseTask<UpdateUserResponseContent> UpdateAsync(string id, UpdateUserRequestContent request, RequestOptions? options = null, CancellationToken cancellationToken = default)

Parameters

id string
request UpdateUserRequestContent
options RequestOptions
cancellationToken CancellationToken

Returns

WithRawResponseTask<UpdateUserResponseContent>