Created
October 30, 2023 03:25
-
-
Save matsub/027984aeff719407204ca7b1dd186045 to your computer and use it in GitHub Desktop.
obtain an access token of AWS Cognito
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
#!/bin/bash | |
USER_POOL_ID=<user pool ID> | |
CLIENT_ID=<application client ID> | |
CLIENT_SECRET=<client secret> | |
COGNITO_USERNAME=<any user name> | |
COGNITO_TEMP_PASSWORD=<temporary password> | |
COGNITO_PASSWORD=<any user password> | |
SECRET_HASH=$(echo -n "${COGNITO_USERNAME}${CLIENT_ID}" | openssl dgst -sha256 -hmac "${CLIENT_SECRET}" -binary | base64) | |
aws cognito-idp admin-create-user \ | |
--user-pool-id ${USER_POOL_ID} \ | |
--username ${COGNITO_USERNAME} \ | |
--user-attributes Name=email,Value="[email protected]" Name=email_verified,Value=true \ | |
--message-action SUPPRESS | |
aws cognito-idp admin-set-user-password \ | |
--user-pool-id ${USER_POOL_ID} \ | |
--username ${COGNITO_USERNAME} \ | |
--password ${COGNITO_TEMP_PASSWORD} | |
SESSION_ID=$(aws cognito-idp admin-initiate-auth \ | |
--user-pool-id="${USER_POOL_ID}" \ | |
--client-id="${CLIENT_ID}" \ | |
--auth-flow="ADMIN_USER_PASSWORD_AUTH" \ | |
--auth-parameters="USERNAME=${COGNITO_USERNAME},PASSWORD=${COGNITO_TEMP_PASSWORD},SECRET_HASH=${SECRET_HASH}" \ | |
| jq -r .Session) | |
aws cognito-idp admin-respond-to-auth-challenge \ | |
--user-pool-id="${USER_POOL_ID}" \ | |
--client-id="${CLIENT_ID}" \ | |
--challenge-name="NEW_PASSWORD_REQUIRED" \ | |
--challenge-responses="USERNAME=${COGNITO_USERNAME},NEW_PASSWORD=${COGNITO_PASSWORD},SECRET_HASH=${SECRET_HASH}" \ | |
--session ${SESSION_ID} | jq -r .AuthenticationResult.IdToken |
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
#!/bin/bash | |
USER_POOL_ID=<user pool ID> | |
CLIENT_ID=<application client ID> | |
CLIENT_SECRET=<client secret> | |
COGNITO_USERNAME=<user name> | |
COGNITO_PASSWORD=<user password> | |
SECRET_HASH=$(echo -n "${COGNITO_USERNAME}${CLIENT_ID}" | openssl dgst -sha256 -hmac "${CLIENT_SECRET}" -binary | base64) | |
aws cognito-idp admin-initiate-auth \ | |
--user-pool-id ${USER_POOL_ID} \ | |
--client-id ${CLIENT_ID} \ | |
--auth-flow "ADMIN_USER_PASSWORD_AUTH" \ | |
--auth-parameters "USERNAME=${COGNITO_USERNAME},PASSWORD=${COGNITO_PASSWORD},SECRET_HASH=${SECRET_HASH}" \ | |
| jq -r .AuthenticationResult |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment