【问题标题】:Firebase Auth setCustomClaims() not workingFirebase Auth setCustomClaims()不起作用
【发布时间】:2020-10-17 07:04:07
【问题描述】:

我在为 Firebase 身份验证服务的令牌设置自定义声明时遇到问题。我正在使用 Cloud 功能为 Hasura 设置自定义声明。云功能在新用户创建事件时执行以设置自定义声明。这是我在云函数中运行的代码

const functions = require('firebase-functions');
const admin = require('firebase-admin');

admin.initializeApp();

exports.processSignup = functions.auth.user().onCreate(user => {
    // create custom claims for hasura
    const hasuraClaims = {
        "x-hasura-default-role": "user",
        "x-hasura-allowed-roles": ["user"],
        "x-hasura-user-id": user.uid
    }

    // attach claims to user auth object
    return admin.auth().setCustomUserClaims(user.uid, hasuraClaims)
        .then(_ => {
            functions.logger.info('SUCCESS: Custom claims attached');
        })
        .catch(err => {
            console.log('ERROR: ', err);
        })
})

在我的前端网页中,我正在运行以下代码来获取idToken

// subscribe to user state change
firebase.auth().onAuthStateChanged(async user => {
    console.log('Firebase auth state changed');

    if (user) {
        // User is signed in.
        window.User = user;

        let idToken = await user.getIdTokenResult();
        console.log('idToken: ', idToken);
    }
})

我不知道自己做错了什么,但令牌不包含我在云函数 processSignup() 中设置的自定义声明。我知道函数执行没有错误,因为我可以检查我的函数日志并找到信息条目SUCCESS: Custom claims attached

谁能帮我解决这个问题?

【问题讨论】:

    标签: javascript firebase firebase-authentication jwt google-cloud-functions


    【解决方案1】:

    更新声明不会触发onAuthStateChanged(登录或未登录的身份验证状态没有改变,但用户的声明有)并且令牌被铸造然后使用约1小时.

    您正在调用getIdTokenResult,但没有强制刷新,请尝试:

    let idToken = await user.getIdTokenResult(true);
    

    这将强制从服务器获取一个新令牌,并将(希望)包含您的自定义声明。

    【讨论】:

    • 感谢@Michael Bleigh 这么快的回复。你是对的。需要强制刷新令牌。
    猜你喜欢
    • 2017-03-16
    • 2020-08-17
    • 2021-06-06
    • 2018-07-29
    • 2020-06-04
    • 2018-12-15
    • 2021-10-06
    • 2021-04-05
    • 2020-01-06
    相关资源
    最近更新 更多