Set Up Authentication and Single Sign-On
Depending on whether SSO is implemented on your site, you can use one of the following to authenticate your users:
- GoodData login page and registration page
- GoodData SSO process
Prerequisites
Before you start, verify that your site meets the following requirements:
- Cross-Origin Resource Sharing (CORS) is set up. The URL where your analytical application runs is whitelisted in the CORS settings. - If CORS is not set up, contact GoodData Support and request them to set up CORS and whitelist the URL where your analytical application runs in the CORS settings. Optionally, ask them to enable cross-origin redirects to sites allowed by your CORS settings. 
- All your users have a GoodData account and have access to your GoodData workspace. - If some users do not have a GoodData account or do not have access to the workspace, see Grant users access to your workspace. 
Implementing authentication
Choose the use case depending on whether SSO is implemented on your site.
SSO is implemented on your site
Update your application code so that the application calls the GoodData SSO resource for authentication. For more information about GoodData SSO setup, see SAML SSO with GoodData and GoodData PGP Single Sign-On.
This is how authentication process works:
- The user goes to the URL where your analytical application runs. For example: - https://my.app.com/
- The SSO authentication process authenticates the user. 
- If authentication is successful, the SSO provider redirects the user to the GoodData platform. 
- The GoodData platform verifies whether the application is allowed and redirects the user to the analytical application. 
SSO is not implemented on your site
You do not have to perform any steps for authentication to start working. It is automatically enabled as long as the prerequisites are met.
This is how authentication process works:
- The user goes to the URL where your analytical application runs. For example: - https://my.app.com/
- Your application verifies whether the user is logged in. For example: - ```javascript import { factory } from '@gooddata/gooddata-js'; const domain = 'https://my.app.com/'; const sdk = factory({ domain }); sdk.user.isLoggedIn().then((isLogged) => { if (isLogged) { // write your own application logic for logged-in users here } else { // redirect to the login page providing the URL to redirect to upon a successful login window.location.replace(`${domain}/account.html?lastUrl=${encodeURIComponent(window.location)}`); } }; ```- NOTE: If you want to pass multiple arguments in - lastUrl, protect them by using- encodeURIComponent.
- If the user is not logged in, the application redirects the user to the GoodData login page (white-labeled with your domain name) with the appended - lastUrlparameter that points to the URL where your analytical application runs:- https://my.company.com/account.html?lastUrl=https://my.app.com/
- The user logs in to the GoodData Portal. 
- If authentication is successful, the GoodData Portal redirects the user back to the URL where your analytical application runs: - https://my.app.com/
Grant users access to your workspace
For authentication to work correctly, all users of your application must have a GoodData account and be able to access your GoodData workspace.
If some users do not have a GoodData account or do not have access to your workspace, you have to invite them to your workspace and make sure that the users with no GoodData account create one.
To do so, follow these steps:
- Customize the link in the invitation email: set the - invitationWelcomePageplatform setting to the URL where your application runs. For example:- "invitationWelcomePage": "https://my.app.com"- For more information, see Configure Various Features via Platform Settings and the API for updating the platform settings. 
- Invite the users to your GoodData workspace via the GoodData Portal. - The link in the invitation email will redirect an invited user to the URL where your application runs. The users with no GoodData account will additionally be asked to create a GoodData account.