Guide to migrating from 3.x
to 4.x
Node 18 LTS and newer LTS releases are supported.
All methods no longer accept a callback and only return a Promise. The last argument is now an object to override the fetch
request.
management.users.getAll({}, function (err, users) {
console.log(users.length);
});
const users = await management.users.getAll();
console.log(users.length);
The SDK now returns an object which includes the data and other information about the response.
const user = await management.users.get({ id: 'user-id' });
const { data: user } = await management.users.get({ id: 'user-id' });
The following configuration options have changed:
scope
- You should use thescope
option for the specific grant.proxy
- You should now provide an HttpsAgent as theagent
config.supportedAlgorithms
- This has been replaced withidTokenSigningAlg
which defaults toRS256
(If your ID Tokens are signed withHS256
you should provide this as the configuration option)
The following endpoints are deprecated and have been removed:
oauth.socialSignIn
- We recommend that you open the browser to do social authentication instead, more infooauth.signIn
- You should useoauth.passwordGrant
instead.tokens.getInfo
- You should useUserInfoClient.getUserInfo
instead.tokens.getDelegationToken
andgetDelegationToken
- See https://auth0.com/docs/authenticate/login/oidc-conformant-authentication/oidc-adoption-delegationusers.impersonate
- See https://community.auth0.com/t/auth0-user-impersonation/81821/2
Previously, in many cases, there were 2 ways to call a method:
await auth.clientCredentialsGrant({ audience: 'my-api' });
Now the top level methods on the Authentication Client have been removed, so you must call the method on the applicable namespace.
await auth.oauth.clientCredentialsGrant({ audience: 'my-api' });
Full list
Before | After |
---|---|
requestMagicLink |
passwordless.sendEmail |
requestEmailCode |
passwordless.sendEmail |
verifyEmailCode |
passwordless.loginWithEmail |
requestSMSCode |
passwordless.sendSMS |
verifySMSCode |
passwordless.loginWithSMS |
changePassword |
database.changePassword |
requestChangePasswordEmail |
database.changePassword |
getProfile |
UserInfoClient.getUserInfo |
clientCredentialsGrant |
oauth.clientCredentialsGrant |
passwordGrant |
oauth.passwordGrant |
refreshToken |
oauth.refreshTokenGrant |
Some method names have been changed to better align with the documentation.
Before | After |
---|---|
oauth.refreshToken |
oauth.refreshTokenGrant |
database.requestChangePasswordEmail |
database.changePassword |
passwordless.signIn |
passwordless.loginWithEmail passwordless.loginWithSMS |
users.getInfo |
UserInfoClient.getUserInfo |
The following configuration options have changed:
scope
- The Management Client uses the Client Credentials grant which gets all the scopes granted to the application. So this is redundant and has been removed.tokenProvider.enableCache
- Each instance of the Management Client has its own cache, if you want a new cache you want to instantiate a new Management Client.tokenProvider.cacheTTLInSeconds
- Each instance of the Management Client only stores a single access token, so this functionality has been removed.proxy
- You should now provide an HttpsAgent as theagent
config.includeResponseHeaders
- This has been removed, all return types include the response headers by default.
Previously, in many cases, there were 2 ways to call a method:
const users = await management.getUsers();
Now the top level methods on the Management Client have been removed, so you must call the method on the applicable namespace.
const usersAlso = await management.users.getAll();
Full list
Before | After |
---|---|
getConnections |
connections.getAll |
createConnection |
connections.create |
getConnection |
connections.get |
deleteConnection |
connections.delete |
updateConnection |
connections.update |
getClients |
clients.getAll |
getClient |
clients.get |
createClient |
clients.create |
updateClient |
clients.update |
deleteClient |
clients.delete |
getClientGrants |
clientGrants.getAll |
createClientGrant |
clientGrants.create |
updateClientGrant |
clientGrants.update |
deleteClientGrant |
clientGrants.delete |
getGrants |
grants.getAll |
deleteGrant |
grants.delete |
createDevicePublicKey |
deviceCredentials.createPublicKey |
getDeviceCredentials |
deviceCredentials.getAll |
deleteDeviceCredential |
deviceCredentials.delete |
getRules |
rules.getAll |
createRule |
rules.create |
getRule |
rules.get |
deleteRule |
rules.delete |
updateRule |
rules.update |
getUsers |
users.getAll |
getUsersByEmail |
usersByEmail.getByEmail |
getUser |
users.get |
deleteAllUsers |
users.deleteAll |
deleteUser |
users.delete |
createUser |
users.create |
updateUser |
users.update |
updateUserMetadata |
REMOVED |
updateAppMetadata |
REMOVED |
deleteUserMultifactor |
users.deleteMultifactorProvider |
deleteUserMultifcator |
users.deleteMultifactorProvider |
unlinkUsers |
users.unlink |
linkUsers |
users.link |
getUserLogs |
users.logs |
getUserRoles |
users.getRoles |
assignRolestoUser |
users.assignRoles |
assignUsersToRole |
roles.assignUsers |
removeRolesFromUser |
users.removeRoles |
getUserPermissions |
users.getPermissions |
assignPermissionsToUser |
users.assignPermissions |
removePermissionsFromUser |
users.removePermissions |
getGuardianEnrollments |
users.getGuardianEnrollments |
regenerateRecoveryCode |
users.regenerateRecoveryCode |
invalidateRememberBrowser |
users.invalidateRememberBrowser |
getUserBlocks |
userBlocks.get |
unblockUser |
userBlocks.delete |
getUserBlocksByIdentifier |
userBlocks.getByIdentifier |
unblockUserByIdentifier |
userBlocks.deleteByIdentifier |
getGuardianEnrollment |
guardian.getGuardianEnrollment |
deleteGuardianEnrollment |
guardian.deleteGuardianEnrollment |
getBlacklistedTokens |
blacklistedTokens.getAll |
blacklistToken |
blacklistedTokens.add |
createEmailTemplate |
emailTemplates.create |
getEmailTemplate |
emailTemplates.get |
updateEmailTemplate |
emailTemplates.update |
getEmailProvider |
emailProvider.get |
configureEmailProvider |
emailProvider.configure |
deleteEmailProvider |
emailProvider.delete |
updateEmailProvider |
emailProvider.update |
getActiveUsersCount |
stats.getActiveUsersCount |
getDailyStats |
stats.getDaily |
getTenantSettings |
tenant.getSettings |
updateTenantSettings |
tenant.updateSettings |
getJob |
jobs.get |
importUsers |
jobs.importUsers |
importUsersJob |
jobs.importUsers |
exportUsers |
jobs.exportUsers |
getJobErrors |
jobs.errors |
sendEmailVerification |
jobs.verifyEmail |
createPasswordChangeTicket |
tickets.changePassword |
createEmailVerificationTicket |
tickets.verifyEmail |
getLog |
logs.get |
getLogs |
logs.getAll |
getLogStreams |
logStreams.getAll |
createLogStream |
logStreams.create |
getLogStream |
logStreams.get |
deleteLogStream |
logStreams.delete |
updateLogStream |
logStreams.update |
createResourceServer |
resourceServers.create |
getResourceServers |
resourceServers.getAll |
getResourceServer |
resourceServers.get |
deleteResourceServer |
resourceServers.delete |
updateResourceServer |
resourceServers.update |
setRulesConfig |
rulesConfigs.set |
getRulesConfigs |
rulesConfigs.getAll |
deleteRulesConfig |
rulesConfigs.delete |
createCustomDomain |
customDomains.create |
getCustomDomains |
customDomains.getAll |
getCustomDomain |
customDomains.get |
verifyCustomDomain |
customDomains.verify |
deleteCustomDomain |
customDomains.delete |
createGuardianEnrollmentTicket |
guardian.createEnrollmentTicket |
getGuardianFactors |
guardian.getFactors |
getGuardianFactorSettings |
guardian.getFactorSettings |
getGuardianFactorProvider |
guardian.getFactorProvider |
updateGuardianFactorProvider |
guardian.updateFactorProvider |
updateGuardianFactorSettings |
guardian.updateFactorSettings |
getGuardianFactorTemplates |
guardian.getFactorTemplates |
updateGuardianFactorTemplates |
guardian.updateFactorTemplates |
updateGuardianFactor |
guardian.updateFactor |
getGuardianPolicies |
guardian.getPolicies |
updateGuardianPolicies |
guardian.updatePolicies |
getGuardianPhoneFactorSelectedProvider |
guardian.getPhoneFactorSelectedProvider |
updateGuardianPhoneFactorSelectedProvider |
guardian.updatePhoneFactorSelectedProvider |
getGuardianPhoneFactorMessageTypes |
guardian.getPhoneFactorMessageTypes |
updateGuardianPhoneFactorMessageTypes |
guardian.updatePhoneFactorMessageTypes |
getRoles |
roles.getAll |
createRole |
roles.create |
getRole |
roles.get |
deleteRole |
roles.delete |
updateRole |
roles.update |
getPermissionsInRole |
roles.getPermissions |
addPermissionsInRole |
roles.addPermissions |
removePermissionsFromRole |
roles.removePermissions |
getUsersInRole |
roles.getUsers |
getHooks |
hooks.getAll |
getHook |
hooks.get |
createHook |
hooks.create |
updateHook |
hooks.update |
deleteHook |
hooks.delete |
getHookSecrets |
hooks.getSecrets |
addHookSecrets |
hooks.addSecrets |
updateHookSecrets |
hooks.updateSecrets |
removeHookSecrets |
hooks.removeSecrets |
getAccessToken |
oauth.clientCredentialsGrant (on AuthenticationClient ) |
updateBrandingSettings |
branding.updateSettings |
getBrandingSettings |
branding.getSettings |
getBrandingUniversalLoginTemplate |
branding.getUniversalLoginTemplate |
setBrandingUniversalLoginTemplate |
branding.setUniversalLoginTemplate |
deleteBrandingUniversalLoginTemplate |
branding.deleteUniversalLoginTemplate |
updateMigrations |
migrations.updateMigrations |
getMigrations |
migrations.getMigrations |
getPromptsSettings |
prompts.getSettings |
updatePromptsSettings |
prompts.updateSettings |
getCustomTextByLanguage |
prompts.getCustomTextByLanguage |
updateCustomTextByLanguage |
prompts.updateCustomTextByLanguage |
Some method names have been changed to better align with the documentation.
await users.removeRoles({ id: 'user' }, { roles: ['read:users'] });
await users.deleteRoles({ id: 'user' }, { roles: ['read:users'] });
full list
Before | After |
---|---|
blacklistedTokens.add |
blacklists.add |
blacklistedTokens.getAll |
blacklists.getAll |
clientCredentials.create |
clients.createCredential |
clientCredentials.getAll |
clients.getredentials |
clientCredentials.get |
clients.getCredential |
clientCredentials.delete |
clients.deleteCredential |
emailProvider.get |
emails.get |
emailProvider.update |
emails.update |
emailProvider.configure |
emails.configure |
tenant.getSettings |
tenants.getSettings |
tenant.updateSettings |
tenants.updateSettings |
users.getByEmail |
usersByEmail.getByEmail |
users.updateUserMetadata |
users.update |
users.updateAppMetadata |
users.update |
users.deleteAll |
REMOVED |
users.logs |
users.getLogs |
users.getGuardianEnrollments |
getEnrollments |
users.removeRoles |
users.deleteRoles |
users.removePermissions |
users.deletePermissions |
users.getAuthenticationMethodById |
users.getAuthenticationMethod |
users.updateAuthenticationMethodById |
users.updateAuthenticationMethod |
users.deleteAuthenticationMethodById |
users.deleteAuthenticationMethod |
userBlocks.getByIdentifier |
userBlocks.get |
userBlocks.deleteByIdentifier |
userBlocks.delete |
guardian.getFactorProvider |
guardian.get{name}FactorProvider{provider} |
guardian.updateFactorProvider |
guardian.update{name}FactorProvider{provider} |
guardian.getFactorTemplates |
guardian.get{name}FactorTemplates |
guardian.updateFactorTemplates |
guardian.update{name}FactorTemplates |
jobs.importUsersJob |
jobs.importUsers |
jobs.errors |
jobs.getErrors |
roles.removePermissions |
deletePermissions |
hooks.removeSecrets |
hooks.deleteSecrets |
prompts.updateSettings |
prompts.update |
prompts.getSettings |
prompts.get |
organizations.getByID |
organizations.get |
organizations.removeEnabledConnection |
organizations.deleteEnabledConnection |
organizations.removeMembers |
organizations.deleteMembers |
organizations.removeMemberRoles |
organizations.deleteMemberRoles |
await management.jobs.importUsers({
users: fs.createReadStream('./myusers.json'),
connection_id: 'con_123',
});
await management.jobs.importUsers({
users: new Blob([fs.readFileSync('./myusers.json')], { type: 'application/json' }),
connection_id: 'con_123',
});
If you don't want to read the whole file into memory, you can use a library like fetch-blob.
import { fileFrom } from 'fetch-blob/from.js';
await management.jobs.importUsers({
users: await fileFrom('./myusers.json', 'application/json'),
connection_id: 'con_123',
});
The fields
parameter, used to include or exclude fields from a response, now takes only a string.
await management.connections.getAll({
fields: ['name', 'strategy'],
});
await management.connections.getAll({
fields: 'name,strategy',
});