Class: StytchB2B::MagicLinks::Discovery
- Inherits:
-
Object
- Object
- StytchB2B::MagicLinks::Discovery
- Includes:
- Stytch::RequestHelper
- Defined in:
- lib/stytch/b2b_magic_links.rb
Instance Method Summary collapse
-
#authenticate(discovery_magic_links_token:, pkce_code_verifier: nil) ⇒ Object
Authenticates the Discovery Magic Link token and exchanges it for an Intermediate Session Token.
-
#initialize(connection) ⇒ Discovery
constructor
A new instance of Discovery.
Methods included from Stytch::RequestHelper
#delete_request, #get_request, #post_request, #put_request, #request_with_query_params
Constructor Details
#initialize(connection) ⇒ Discovery
Returns a new instance of Discovery.
433 434 435 |
# File 'lib/stytch/b2b_magic_links.rb', line 433 def initialize(connection) @connection = connection end |
Instance Method Details
#authenticate(discovery_magic_links_token:, pkce_code_verifier: nil) ⇒ Object
Authenticates the Discovery Magic Link token and exchanges it for an Intermediate Session Token. Intermediate Session Tokens can be used for various Discovery login flows and are valid for 10 minutes.
Parameters:
- discovery_magic_links_token
-
The Discovery Email Magic Link token to authenticate. The type of this field is
String
. - pkce_code_verifier
-
A base64url encoded one time secret used to validate that the request starts and ends on the same device. The type of this field is nilable
String
.
Returns:
An object with the following fields:
- request_id
-
Globally unique UUID that is returned with every API call. This value is important to log for debugging purposes; we may ask for this value to help identify a specific API call when helping you debug an issue. The type of this field is
String
. - intermediate_session_token
-
The Intermediate Session Token. This token does not necessarily belong to a specific instance of a Member, but represents a bag of factors that may be converted to a member session. The token can be used with the [OTP SMS Authenticate endpoint](stytch.com/docs/b2b/api/authenticate-otp-sms), [TOTP Authenticate endpoint](stytch.com/docs/b2b/api/authenticate-totp), or [Recovery Codes Recover endpoint](stytch.com/docs/b2b/api/recovery-codes-recover) to complete an MFA flow and log in to the Organization. It can also be used with the [Exchange Intermediate Session endpoint](stytch.com/docs/b2b/api/exchange-intermediate-session) to join a specific Organization that allows the factors represented by the intermediate session token; or the [Create Organization via Discovery endpoint](stytch.com/docs/b2b/api/create-organization-via-discovery) to create a new Organization and Member. The type of this field is
String
. - email_address
-
The email address. The type of this field is
String
. - discovered_organizations
-
An array of ‘discovered_organization` objects tied to the `intermediate_session_token`, `session_token`, or `session_jwt`. See the [Discovered Organization Object](stytch.com/docs/b2b/api/discovered-organization-object) for complete details.
Note that Organizations will only appear here under any of the following conditions:
-
The end user is already a Member of the Organization.
-
The end user is invited to the Organization.
-
The end user can join the Organization because:
a) The Organization allows JIT provisioning. b) The Organizations' allowed domains list contains the Member's email domain. c) The Organization has at least one other Member with a verified email address with the same domain as the end user (to prevent phishing attacks).
The type of this field is list of
DiscoveredOrganization
(object
). -
- status_code
-
The HTTP status code of the response. Stytch follows standard HTTP response status code patterns, e.g. 2XX values equate to success, 3XX values are redirects, 4XX are client errors, and 5XX are server errors. The type of this field is
Integer
.
475 476 477 478 479 480 481 482 483 484 485 486 |
# File 'lib/stytch/b2b_magic_links.rb', line 475 def authenticate( discovery_magic_links_token:, pkce_code_verifier: nil ) headers = {} request = { discovery_magic_links_token: discovery_magic_links_token } request[:pkce_code_verifier] = pkce_code_verifier unless pkce_code_verifier.nil? post_request('/v1/b2b/magic_links/discovery/authenticate', request, headers) end |