Documentation Index
Fetch the complete documentation index at: https://turnkey-0e7c1f5b-amir-mfa-docs.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
What is multi-factor authentication (MFA)?
Requests made to Turnkey’s public API are required to be authenticated using an API key or WebAuthn stamp. MFA adds an additional layer of security by requiring users to provide multiple forms of authentication before they can perform specific activities or establish a session with elevated permissions. Turnkey’s MFA policies can be configured to require any combination of supported authentication methods.MFA policies
MFA policies are a unique resource type in Turnkey that allows configuration of authentication requirements, scoped to a specific condition. MFA policies can be configured in both parent and sub-organizations, and are enforced at the user level rather than the organization level. Once an MFA policy is created, it is immediately enforced for the user.MFA policy structure
An MFA policy can be created using theCreateMfaPolicy activity and passing in the following parameters:
userId: The ID of the user the policy applies tomfaPolicyName: The name of the MFA policycondition: A string of policy language that evaluates to true or false based on the context of an activity. If the condition evaluates to true, the specified authentication methods are required.requiredAuthenticationMethods: An array of authentication methods that are required when the policy condition is met. Grouping methods within nested ANY blocks enables logical OR behavior.order: An integer that specifies the order of evaluation for multiple MFA policies. Policies with lower order values are evaluated first.notes: Optional field for any additional information about the policy
Condition
Thecondition field is a string written in Turnkey’s policy language. It determines when the MFA policy applies based on the context of the incoming activity.
When a user submits a request, each of their MFA policies are evaluated in order. If a policy’s condition evaluates to true, the authentication requirements defined in that policy must be satisfied before the activity can proceed.
Conditions have access to the same keywords available in regular policy conditions.
Examples:
Required authentication methods
TherequiredAuthenticationMethods field defines an ordered list of authentication steps that the user must complete when the policy’s condition is met. Each step is a RequiredAuthenticationMethodParams object containing an any array of AuthenticationMethodParams.
The structure works as follows:
- Each entry in
requiredAuthenticationMethodsrepresents a sequential step - all steps must be satisfied in order. - Within each step, the
anyarray contains one or more authentication methods. If multiple methods are listed, the user must satisfy any one of them (logical OR).
- Authenticate with an API key
- Authenticate with either a passkey or email OTP
AuthenticationMethodParams accepts:
type(required): The authentication type. Supported values:AUTHENTICATION_TYPE_PASSKEYAUTHENTICATION_TYPE_API_KEYAUTHENTICATION_TYPE_SESSIONAUTHENTICATION_TYPE_EMAIL_OTPAUTHENTICATION_TYPE_SMS_OTPAUTHENTICATION_TYPE_OAUTH
id(optional): A specific authentication method’s ID. When provided, only that specific authentication method satisfies the requirement. When omitted, any authentication method of the specified type can be used.
Evaluation order
Theorder field is an integer that determines the evaluation priority when a user has multiple MFA policies. Policies with lower order values are evaluated first.
When a request is made, Turnkey evaluates a user’s MFA policies in order (from lowest order to highest). The first policy whose condition evaluates to true is the one that applies: its requiredAuthenticationMethods define the authentication requirements for that request, and later policies are not considered.
This lets you place narrowly-scoped, high-sensitivity policies first, and keep broader “catch-all” policies with higher order values as a fallback.