Skip to content

Latest commit

 

History

History
117 lines (96 loc) · 2.99 KB

README.md

File metadata and controls

117 lines (96 loc) · 2.99 KB

aws-cognito-react - v2

signin

Testing for cross sites using aws cognito:

Scenario

We'll have 2 websites with local start

Testing flow:

  • Open web1 -> login to web1 -> open web 2 to check that we don't need to login to see the home page of web2
  • Logout web1 -> refresh web 2 to see whether we still can see the home page of web2

Reference Link

link

Code Notes

  • module in package.json with cross-domain-storage for token exchanging between 2 webs
"dependencies": {
    ....
    "amazon-cognito-identity-js": "^5.2.9",
    "cross-domain-storage": "^2.0.7",
    ...
  },
  • signout function to invalidate all tokens provided by cognito in case of user do sign-out in cognito.ts
export function signOut(callbacks: { onSuccess: (msg: string) => void; onFailure: (err: Error) => void }) {
  if (currentUser) {
    //currentUser.signOut()
    currentUser.globalSignOut(callbacks)
  }
}
  • handle session token from web1 to web2 in case login in web1 and token will be set to web2 with allowed origin on web2 in signIn.tst of web1
  const handleSendToken = () => {
    // send token
    if(!localStorage) return

    var tokenStorage = createGuest('http://localhost:3000/accessStorage');
    Object.keys(localStorage).forEach(key => {
      console.log('key', key);
      tokenStorage.set(key, localStorage[key])
    })
  }
  • allow origin on web2 to accept access from web1 on App.tsx
const App: React.FunctionComponent = () => {
  useEffect(() => {
    createHost([
      {
        origin: "http://localhost:4000",
        allowedMethods: ["set", "remove"],
      },
    ]);
  }, []);

AWS Cognito Infrastructure setup

To help deploy the AWS Cognito infrastructure I've create an Amazon Cloud Development (CDK) script

CDK set up instructions can be found here Setup AWS configure with access keys from your account

aws configure

CDK deploy instructions

cd cdk
npm run cdk bootstrap   # only needed first time
npm run cdk deploy

After deployment copy the userPoolId and userPoolClientId values from the command line window; you will need these values in the app config step

App Configuration

Setup the Cognito environment values buy creating app/.env.local for app1 and app2 file and adding the following

REACT_APP_USERPOOL_ID=YOUR_USER_POOL_ID
REACT_APP_CLIENT_ID=YOUR_CLIENT_ID

Create React App has been used to setup the development process so the next steps should be familiar

  • Install and start web1 on port 4000
cd app
npm install --force 
npm start
  • Note: for macbook then we adjust file package json in app folder as below
  "scripts": {
    "start": "PORT=4000 && react-scripts start",
    ....
  },
  • Install and start web2
cd app2
npm install --force
npm start

Result