On this page
Temporary access code authenticator integration guide
This guide shows you how to integrate a temporary access code (TAC) authenticator into your authentication use cases with Okta APIs.
Learning outcomes
- Understand how to configure the TAC authenticator
- Configure the TAC authenticator for different use cases
What you need
- Okta Integrator Free Plan org (opens new window)
- The Temporary Access Code feature enabled for your org
- A test user account (opens new window) that you can use to enroll an authenticator
- A test group (opens new window) in your org that the test user is added to
About the TAC authenticator
TAC is an authenticator that allows users to authenticate with a temporary access code that admins generate. It’s commonly used in onboarding and account recovery scenarios. In those scenarios, users might not have access to other authenticators and can require temporary access to enroll other authenticators or unlock their account.
After an admin configures the TAC authenticator settings, admins or help-desk agents can generate a TAC. After an admin generates a TAC, they contact the user who needs it and verifies their identity and their need for a TAC. The admin then sends the TAC to the user.
Note: There’s no default way to send a TAC to a user. Okta recommends that admins or help-desk agents send a TAC through a secure out-of-band channel.
Use the TAC authenticator in policies
This guide outlines two app sign-in policy scenarios that allow the use of the TAC authenticator. When you add the TAC authenticator to your own org policies remember that it's a knowledge factor.
Users can sign in with TAC, security questions, and their password as knowledge factors, depending on your app sign-in policy configuration and which authenticators they have access to. However, if your global session policy requires MFA, users must also have access to a possession or biometric factor.
Configure the TAC authenticator in authenticator enrollment policies
When you create the TAC authenticator, admins can generate TACs for any user in their org by default.
If you want to prevent users from signing in with a TAC authenticator, set it as Disabled in your relevant authenticator enrollment policy. When it’s Disabled, admins can still create a TAC for a user. But the option to use a TAC isn't available to users when they sign in.
Configure the TAC authenticator
Use the Create an authenticator (opens new window) endpoint to set up TAC as an authenticator.
To configure the TAC authenticator in the Admin Console, see Configure the temporary access code authenticator (opens new window).
- Use the values and format provided in the request body example.
- Ensure that the following request body parameters are set correctly:
- Set the authenticator
key
astac
. - Enter a value for
name
. - Set the provider
type
asTAC
. - Set the minimum time-to-live (
minTtl
) for the TAC as10
minutes. - Set the maximum TTL (
maxTtl
) for the TAC as720
minutes (12 hours). - Set the default TTL as
480
minutes (8 hours). - Set the number of characters in the TAC (
length
) as16
. - Set all the complexity parameters as
true
. This ensures that the TAC includes numbers, letters, and special characters.Note: You can’t set numbers as
false
. - Set
multiUseAllowed
astrue
. This means that the TAC can be used multiple times before it expires.
- Set the authenticator
- Send the
POST /api/v1/authenticators
request. - Copy and paste the
id
of the response into a text editor to use it later.
Create a TAC authenticator request example
{
"key": "tac",
"name": "Temporary Access Code",
"provider": {
"type": "tac",
"configuration": {
"minTtl": 10,
"maxTtl": 720,
"defaultTtl": 480,
"length": 16,
"complexity": {
"numbers": true,
"letters": true,
"specialCharacters": true
},
"multiUseAllowed": true
}
}
}
Create a TAC authenticator response example
{
"type": "tac",
"id": "aut8j8vbvcr5b4a8l0g7",
"key": "tac",
"status": "ACTIVE",
"name": "Temporary Access Code",
"created": "2025-05-29T15:28:36.000Z",
"lastUpdated": "2025-05-29T15:28:36.000Z",
"provider": {
"type": "TAC",
"configuration": {
"length": 16,
"minTtl": 10,
"maxTtl": 180,
"defaultTtl": 120,
"multiUseAllowed": true,
"complexity": {
"numbers": true,
"letters": true,
"specialCharacters": true
}
}
},
"_links": {
"self": {
"href": "https://{yourOktaDomain}/api/v1/authenticators/aut8j8vbvcr5b4a8l0g7",
"hints": {
"allow": [
"GET",
"PUT"
]
}
},
"deactivate": {
"href": "https://{yourOktaDomain}/api/v1/authenticators/aut8j8vbvcr5b4a8l0g7/lifecycle/deactivate",
"hints": {
"allow": [
"POST"
]
}
},
"methods": {
"href": "https://{yourOktaDomain}/api/v1/authenticators/aut8j8vbvcr5b4a8l0g7/methods",
"hints": {
"allow": [
"GET"
]
}
}
}
}
Configure app sign-in policies for TAC
There are various ways to configure TAC with app sign-in policies. Use either of the following app sign-in policy examples in your own org.
Ensure that you first create an app sign-in policy before creating policy rules for either of the scenarios.
Create an app sign-in policy
First, create an app sign-in policy. Use the Create a policy (opens new window) endpoint.
- Use the values and format provided in the request body example.
- Enter a value for
name
. For example,TAC app sign-in policy
. - Set the
type
asACCESS_POLICY
. - Send the
POST /api/v1/policies
request. - In the response, copy and paste the
id
of the app sign-in policy.
App sign-in policy request example
{
"description": null,
"name": "TAC app sign-in policy",
"priority": "1",
"status": "ACTIVE",
"system": false,
"type": "ACCESS_POLICY",
"conditions": null,
"_embedded": {
"resourceType": "string",
"property1": {},
"property2": {}
}
}
Use TAC in an authentication method chain
Use this app sign-in policy rule when you want users to specifically authenticate with TAC and a WebAuthn (opens new window) factor. You can customize which authenticators to require in the authentication method chain. This policy rule can be used in the following scenario.
One of your users doesn't have their phone with them and doesn't have access to their Phone or Okta Verify authenticators. You generate a TAC for them that they can use for eight hours. With this policy rule, they're required to use the TAC and their WebAuthn authenticator whenever they sign in.
Use the Create a policy rule (opens new window) endpoint to create the rule.
- Use the values and format provided in the request body example.
- In the path of the POST request, set the
policyId
as theid
of the TAC app sign-in policy. - Ensure that the following parameters are set correctly:
- Enter a value for
name
. For example,TAC and authentication method chain
. - Under
groups.include
use the groupid
of your test group. - Set the
verificationMethod.type
asAUTH_METHOD_CHAIN
.
- Enter a value for
- Send the
POST /api/v1/policies
request.
TAC and authentication method chain request example
{
"name": "TAC and authentication method chain",
"type": "ACCESS_POLICY",
"conditions": {
"people": {
"groups": {
"include": [
"{groupId}"
]
}
}
},
"actions": {
"appSignOn": {
"access": "ALLOW",
"verificationMethod": {
"type": "AUTH_METHOD_CHAIN",
"chains": [
{
"authenticationMethods": [
{
"key": "tac",
"method": "tac"
}
],
"next": [
{
"authenticationMethods": [
{
"key": "webauthn",
"userVerification": "REQUIRED",
"method": "webauthn"
}
]
}
]
}
]
}
}
}
}
Use TAC with any two factor types
Use this app sign-in policy rule to provide more flexibility for users when they sign in. With this rule, they can use TAC, and any other authenticator to sign in.
Use the Create a policy rule (opens new window) endpoint to create the rule.
- Use the values and format provided in the request body example.
- In the path of the POST request, set the
policyId
as theid
of the TAC app sign-in policy. - Ensure that the following parameters are set correctly:
- Enter a value for
name
. For example,Allow any two factors for TAC users
. - Under
groups.include
use the groupid
of your test group. - Set the
verificationMethod.type
asASSURANCE
.
- Enter a value for
- Send the
POST /api/v1/policies
request.
Any two factors and TAC request example
{
"name": "Allow any two factors for TAC users",
"type": "ACCESS_POLICY",
"conditions": {
"people": {
"groups": {
"include": [
"{groupId}"
]
}
}
},
"actions": {
"appSignOn": {
"access": "ALLOW",
"verificationMethod": {
"factorMode": "2FA",
"type": "ASSURANCE",
"reauthenticateIn": "PT0S",
"constraints": [
{
"possession": {
"required": true,
"userPresence": "OPTIONAL"
}
}
]
}
}
}
}
Generate a TAC for a user
After you've configured the TAC with your policies, you can then generate it for your users, as needed. Use the Create an auto-activated TAC authenticator enrollment (opens new window) endpoint to generate a TAC for a user.
Note: A user can only have one active TAC at any time. If you generate a TAC for a user and then generate a second one, the first TAC becomes invalid and can't be used.
Before you generate the TAC for a user, ensure that you have the following information:
- Use the List all users (opens new window) endpoint to retrieve the
id
of the user. - Use the List all authenticators (opens new window) endpoint to retrieve the TAC authenticator
id
.
- Use the values and format provided in the request body example.
- In the path of the POST request, set the
userId
as theid
of the user. - In the request body, set the following parameters:
- Set the
authenticatorId
as theid
of the TAC authenticator. - Set the
authenticatorType
astac
. - Set the
ttl
of the TAC as480
. - Set
multiUse
astrue
.
- Set the
- Send the
POST /api/v1/users/{userId}/authenticator-enrollments/tac
request.
After you generate the TAC, copy and paste the value of the tac
from the response into a text editor. Also note the time and date value of expiresAt
to see when the TAC expires.
The actual tac
value is only accessible from the POST response. It's not possible to retrieve the value of the TAC from any other GET requests.
Generate a TAC request example
{
"authenticatorId": "{authenticatorId}",
"authenticatorType": "tac",
"config": {
"ttl": 480,
"multiUse": true
}
}
Generate a TAC response example
{
"id": "tac8k59d3cvCEYniC0g7",
"type": "tac",
"key": "tac",
"name": "Temporary Access Code",
"status": "ACTIVE",
"profile": {
"tac": "4&^CnBV^3^u4b^Hg",
"multiUse": true,
"expiresAt": "2025-05-12T22:43:30"
},
"created": "2025-05-12T20:43:30.000Z",
"lastUpdated": "2025-05-12T20:43:30.000Z",
"nickname": "",
"_links": {
"self": {
"href": "https://{yourOktaDomain}/api/v1/users/00u8ja5c4uf26HSeN0g7/authenticator-enrollments/tac8k59d3cvCEYniC0g7",
"hints": {
"allow": [
"GET",
"DELETE"
]
}
},
"user": {
"href": "https://{yourOktaDomain}/api/v1/users/00u8ja5c4uf26HSeN0g7",
"hints": {
"allow": [
"GET"
]
}
}
}
}
Delete a TAC for a user
Use the Delete an authenticator enrollment (opens new window) to delete a TAC that you've generated for a user. When you delete a TAC enrollment, the user can't sign in with that code. You can generate a new TAC for them, if needed.
Before you delete a TAC for a user, ensure that you have the following information:
- Use the List all users (opens new window) endpoint to retrieve the
id
of the user. - Use the List all authenticator enrollments (opens new window) endpoint to retrieve the TAC
enrollmentid
.