-
Notifications
You must be signed in to change notification settings - Fork 167
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
…#4475) * add synthetics multi factor authentication docs (#4444) * add synthetics multi factor authentication docs * apply suggestions from code review Co-authored-by: Emilio Alvarez Piñeiro <[email protected]> * Apply suggestions from code review Co-authored-by: Brandon Morelli <[email protected]> Co-authored-by: Colleen McGinnis <[email protected]> * Update docs/en/observability/synthetics-mfa.asciidoc Co-authored-by: Colleen McGinnis <[email protected]> --------- Co-authored-by: Emilio Alvarez Piñeiro <[email protected]> Co-authored-by: Brandon Morelli <[email protected]> Co-authored-by: Colleen McGinnis <[email protected]> (cherry picked from commit 704f88d) # Conflicts: # docs/en/serverless/serverless-observability.docnav.json # docs/en/serverless/synthetics/synthetics-command-reference.mdx * Delete docs/en/serverless directory --------- Co-authored-by: Vignesh Shanmugam <[email protected]> Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com>
- Loading branch information
1 parent
7ffbd5b
commit 154db12
Showing
3 changed files
with
87 additions
and
0 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
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,62 @@ | ||
[[synthetics-mfa]] | ||
= Multi-factor Authentication (MFA) for browser monitors | ||
|
||
++++ | ||
<titleabbrev>Multi-factor Authentication</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] | ||
== 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 <<elastic-synthetics-totp-command>>. | ||
|
||
```sh | ||
npx @elastic/synthetics totp <secret> | ||
|
||
// prints | ||
OTP Token: 123456 | ||
``` | ||
|
||
[discrete] | ||
== 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`. | ||
|
||
```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.token(params.MFA_GH_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: | ||
|
||
```ts | ||
step('Login using 2FA', async () => { | ||
const token = mfa.token(params.MFA_GH_SECRET); | ||
await page.getByPlaceholder("token-input").fill(token) | ||
}); | ||
``` | ||
|
||
[NOTE] | ||
==== | ||
`params.MFA_GH_SECRET` would be the encoded secret that was used for registering the Synthetics Authentication in your web application. | ||
==== |