fix: check remember-me and handle split email/password epic login
This commit is contained in:
parent
f5e404329f
commit
943fdbbf0c
1 changed files with 12 additions and 2 deletions
|
|
@ -127,11 +127,21 @@ const ensureLoggedIn = async (page, context) => {
|
||||||
await page.goto('https://www.epicgames.com/id/login?lang=en-US&noHostRedirect=true&redirectUrl=' + URL_CLAIM, { waitUntil: 'domcontentloaded' });
|
await page.goto('https://www.epicgames.com/id/login?lang=en-US&noHostRedirect=true&redirectUrl=' + URL_CLAIM, { waitUntil: 'domcontentloaded' });
|
||||||
const emailField = page.locator('input[name="email"], input#email');
|
const emailField = page.locator('input[name="email"], input#email');
|
||||||
const passwordField = page.locator('input[name="password"], input#password');
|
const passwordField = page.locator('input[name="password"], input#password');
|
||||||
// Some flows pre-fill email and show only password field
|
const continueBtn = page.locator('button:has-text("Continue"), button[type="submit"]');
|
||||||
if (await emailField.count()) await emailField.fill(cfg.eg_email);
|
|
||||||
|
// step 1: email + continue
|
||||||
|
if (await emailField.count()) {
|
||||||
|
await emailField.fill(cfg.eg_email);
|
||||||
|
await continueBtn.first().click();
|
||||||
|
}
|
||||||
|
|
||||||
|
// step 2: password + submit
|
||||||
await passwordField.waitFor({ timeout: cfg.login_visible_timeout });
|
await passwordField.waitFor({ timeout: cfg.login_visible_timeout });
|
||||||
await passwordField.fill(cfg.eg_password);
|
await passwordField.fill(cfg.eg_password);
|
||||||
|
const rememberMe = page.locator('input[name="rememberMe"], #rememberMe');
|
||||||
|
if (await rememberMe.count()) await rememberMe.check().catch(() => {});
|
||||||
await page.click('button[type="submit"]');
|
await page.click('button[type="submit"]');
|
||||||
|
|
||||||
// MFA step
|
// MFA step
|
||||||
try {
|
try {
|
||||||
await page.waitForURL('**/id/login/mfa**', { timeout: cfg.login_timeout });
|
await page.waitForURL('**/id/login/mfa**', { timeout: cfg.login_timeout });
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue