07 February 2020
Authenticating Firebase JWT Tokens
Door: Sem Postma
data:image/s3,"s3://crabby-images/c63d4/c63d4bd1ae07a9db3d82464031037193d194823a" alt="Authenticating Firebase JWT Tokens image"
There might be circumstances where you would want to verify if a certain user is authenticated with firebase.
You don’t need the firebase admin module to verify and decode firebase JWT tokens. In the example below you can find a full implementation of this. I’m only using the default node.js modules http, https and crypto.
Example response JSON
{
"data": {
"iss": "https://securetoken.google.com/<project_id>",
"aud": "<project_id>",
"auth_time": 1581009428,
"user_id": "9jnxi9kmz76ajnc4do47emrk8s1s",
"sub": "9jnxi9kmz76ajnc4do47emrk8s1s",
"iat": 1581082417,
"exp": 1581086017,
"email": "[email protected]",
"email_verified": true,
"firebase": {
"identities": {
"email": [
"[email protected]"
]
},
"sign_in_provider": "password"
}
}
}
You can optionally check if the “iss” value is equal to “https://securetoken.google.com/<project_id>
” to ensure the user is signed in with a specific firebase project.
data:image/s3,"s3://crabby-images/e76a1/e76a1b6c5801adee697c6226a3f26613d420428f" alt="rss icon"
data:image/s3,"s3://crabby-images/ba081/ba081d975d0974b8a9281b9f6569e3f7775d7d82" alt="follow us in feedly"