Last active
November 20, 2020 19:49
-
-
Save sir-dunxalot/db9b647009dd466f3b9bee814cf87ea6 to your computer and use it in GitHub Desktop.
cypress-nextjs-auth0__helper--login-with-session
This file contains hidden or 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
import auth0 from 'auth0-js'; | |
import Iron from '@hapi/iron'; | |
const auth = new auth0.WebAuth({ | |
domain: Cypress.env('auth0Domain'), | |
clientID: Cypress.env('auth0ClientId'), | |
}); | |
const sessionCookieName = Cypress.env('sessionCookieName'); | |
const stateCookieName = Cypress.env('stateCookieName'); | |
/* 1. We've move our login() code to _login() */ | |
Cypress.Commands.add('_login', (credentials) => { | |
const { username, password } = credentials; | |
return new Cypress.Promise((resolve, reject) => { | |
auth.client.loginWithDefaultDirectory({ | |
username, | |
password, | |
audience: Cypress.env('auth0Audience'), | |
scope: Cypress.env('auth0Scope'), | |
client_secret: Cypress.env('auth0ClientSecret'), | |
}, (err, response) => { | |
if (err) { | |
reject(err); | |
} else { | |
resolve(response); | |
} | |
}); | |
}); | |
}); | |
/* 2. We've added a login() helper */ | |
Cypress.Commands.add('login', () => { | |
/* 2. We retrieve our username and password from cypress.env.json */ | |
const credentials = { | |
username: Cypress.env('auth0Username'), | |
password: Cypress.env('auth0Password'), | |
}; | |
/* 3. We set the state cookie to a random value */ | |
cy.setCookie(stateCookieName, 'some-random-state'); | |
cy._login(credentials).then((response) => { | |
const { accessToken, expiresIn, idToken, scope } = response; | |
/* 4. We use the access token from _login() to get the user's info */ | |
cy.getUserInfo(accessToken).then((user) => { | |
/* https://github.com/auth0/nextjs-auth0/blob/master/src/handlers/callback.ts#L44 */ | |
/* https://github.com/auth0/nextjs-auth0/blob/master/src/handlers/callback.ts#L47 */ | |
/* https://github.com/auth0/nextjs-auth0/blob/master/src/session/cookie-store/index.ts#L57 */ | |
const persistedSession = { | |
user, | |
idToken, | |
accessToken, | |
accessTokenScope: scope, | |
accessTokenExpiresAt: Date.now() + expiresIn, | |
createdAt: Date.now(), | |
}; | |
/* 5. We encrypt the user info */ | |
/* https://github.com/auth0/nextjs-auth0/blob/master/src/session/cookie-store/index.ts#L73 */ | |
cy.seal(persistedSession).then((encryptedSession) => { | |
/* 6. We store the encrypted session in the session cookie */ | |
cy.setCookie(sessionCookieName, encryptedSession); | |
}); | |
}); | |
}); | |
}); | |
/* 8. We create a getUserInfo() helper to query Auth0 for user info, given an Auth0 access token */ | |
Cypress.Commands.add('getUserInfo', (accessToken) => { | |
return new Cypress.Promise((resolve, reject) => { | |
auth.client.userInfo(accessToken, (err, user) => { | |
if (err) { | |
reject(err); | |
} | |
resolve(user); | |
}); | |
}); | |
}); | |
Cypress.Commands.add('seal', (thingToEncrypt) => { | |
return new Cypress.Promise((resolve, reject) => { | |
try { | |
/* 8. We use the Auth0 cookie secret to encrypt the session */ | |
Iron.seal(thingToEncrypt, Cypress.env('auth0CookieSecret'), Iron.defaults).then((encryptedThing) => { | |
resolve(encryptedThing); | |
}); | |
} catch (error) { | |
reject(error); | |
} | |
}); | |
}); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment