-
Notifications
You must be signed in to change notification settings - Fork 166
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Synthetics]: fix MFA totp method for browser monitors (#4581)
(cherry picked from commit 083cf27) # Conflicts: # docs/en/serverless/synthetics/synthetics-mfa.asciidoc
- Loading branch information
1 parent
2711473
commit 9262e05
Showing
2 changed files
with
69 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
[[observability-synthetics-mfa]] | ||
= Multi-factor Authentication (MFA) for browser monitors | ||
|
||
++++ | ||
<titleabbrev>Multifactor Authentication for browser monitors</titleabbrev> | ||
++++ | ||
|
||
Multi-factor Authentication (MFA) adds an essential layer of security to | ||
applications login processes, protecting against unauthorized access. A very | ||
common use case in Synthetics is testing user journeys involving websites | ||
protected by MFA. | ||
|
||
Synthetics supports testing websites secured by Time-based One-Time Password | ||
(TOTP), a common MFA method that provides short-lived one-time tokens to | ||
enhance security. | ||
|
||
[discrete] | ||
[[observability-synthetics-mfa-configuring-totp-for-mfa]] | ||
== Configuring TOTP for MFA | ||
|
||
To test a browser journey that uses TOTP for MFA, first configure the | ||
Synthetics authenticator token in the target application. To do this, generate a One-Time | ||
Password (OTP) using the Synthetics CLI; refer to <<observability-synthetics-command-reference,`@elastic/synthetics totp <secret>`>>. | ||
|
||
[source,sh] | ||
---- | ||
npx @elastic/synthetics totp <secret> | ||
// prints | ||
OTP Token: 123456 | ||
---- | ||
|
||
[discrete] | ||
[[observability-synthetics-mfa-applying-the-totp-token-in-browser-journeys]] | ||
== Applying the TOTP Token in Browser Journeys | ||
|
||
Once the Synthetics TOTP Authentication is configured in your application, you can now use the OTP token in the synthetics browser | ||
journeys using the `mfa` object imported from `@elastic/synthetics`. | ||
|
||
[source,ts] | ||
---- | ||
import { journey, step, mfa } from "@elastic/synthetics"; | ||
journey("MFA Test", ({ page, params }) => { | ||
step("Login using TOTP token", async () => { | ||
// login using username and pass and go to 2FA in next page | ||
const token = mfa.totp(params.MFA_SECRET); | ||
await page.getByPlaceholder("token-input").fill(token); | ||
}); | ||
}); | ||
---- | ||
|
||
For monitors created in the Synthetics UI using the Script editor, the `mfa` object can be accessed as shown below: | ||
|
||
[source,ts] | ||
---- | ||
step("Login using 2FA", async () => { | ||
const token = mfa.totp(params.MFA_SECRET); | ||
await page.getByPlaceholder("token-input").fill(token); | ||
}); | ||
---- | ||
|
||
[NOTE] | ||
==== | ||
`params.MFA_SECRET` would be the encoded secret that was used for registering the Synthetics Authentication in your web application. | ||
==== |