Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/firebase/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何始终获得用户';从GitHub Auth获取的显示名称_Javascript_Firebase_Firebase Realtime Database_Firebase Authentication_Google Cloud Functions - Fatal编程技术网

Javascript 如何始终获得用户';从GitHub Auth获取的显示名称

Javascript 如何始终获得用户';从GitHub Auth获取的显示名称,javascript,firebase,firebase-realtime-database,firebase-authentication,google-cloud-functions,Javascript,Firebase,Firebase Realtime Database,Firebase Authentication,Google Cloud Functions,目前,我有一个Firebase云函数initUser,它位于functions.auth.user().onCreate触发器上。它从auth提供者(仅GitHub)获取用户的显示名称,并在实时数据库中为用户创建一个条目。我会说,这是三分之一的作品。对于其他两次,从事件中获取用户,然后获取显示名称,返回未定义。目前,我只需检查用户的displayName是否undefined,是否将用户名设置为其uid,如果没有,我将设置为displayNameI已通过 当前功能: exports.initUs

目前,我有一个Firebase云函数
initUser
,它位于
functions.auth.user().onCreate
触发器上。它从auth提供者(仅GitHub)获取用户的显示名称,并在实时数据库中为用户创建一个条目。我会说,这是三分之一的作品。对于其他两次,从
事件中获取
用户
,然后获取
显示名称
,返回
未定义
。目前,我只需检查用户的
displayName
是否
undefined
,是否将用户名设置为其
uid
,如果没有,我将设置为
displayName
I已通过

当前功能:

exports.initUser = functions.auth.user().onCreate(event => {
    //Adds the Player To Users and Scores Node
    const user = event.data;
    const uid = user.uid;
    const score = 0;
    admin.database().ref('users/' + uid).child('score').set(score);

    var name = "";
    if(user.displayName === undefined) {
        name = uid;
    } else {
        name = validator.escape(user.displayName);
    }

    admin.database().ref('users/' + uid).child('name').set(name);
    admin.database().ref('scores').child(uid).set(score);
    console.log("Created User: " + name);
    return true;
});
因此,我的问题是:这是最好的方法还是有更好的方法或已知的解决方法来一致地从GitHub获取用户显示名称

注意:我在其他地方看到有人建议增加延迟,但不接受这一点作为答案

编辑:建议的答案是对代码的改进,但这不是错误持续存在的根本原因。要澄清的问题是,我如何才能始终避免github中的用户显示名
未定义
,特别是在
initUser
云函数中。

将数据写入Firebase(以及大多数现代web API)是异步进行的。当您调用
admin.database()…set(…)
时,它只开始写入数据,写入操作可能需要一段时间才能完成。但是,只要您在代码末尾
返回true
,云功能系统就会假定您的代码已经完成,并且可以自由取消任何剩余的操作。这种竞争状况是导致写操作丢失的最常见原因

要修复竞态条件,您需要返回一个
Promise
,在代码实际完成时发出信号。在本例中,您有三个写操作,因此您返回一个承诺,当所有三个操作都完成时,该承诺将得到解决:

exports.initUser = functions.auth.user().onCreate(event => {
    //Adds the Player To Users and Scores Node 
    var promises = [];
    const user = event.data;
    const uid = user.uid;
    const score = 0;
    promises.push(admin.database().ref('users/' + uid).child('score').set(score));

    var name = "";
    if(user.displayName === undefined) {
        name = uid;
    } else {
        name = validator.escape(user.displayName);
    }

    promises.push(admin.database().ref('users/' + uid).child('name').set(name));
    promises.push(admin.database().ref('scores').child(uid).set(score));
    console.log("Created User: " + name);
    return Promise.all(promises);
});

我建议您也查看一些其他的。

。onAuthStateChanged
驱动应用程序的用户/身份验证状态

firebase.auth().onAuthStateChanged(function(user) { // THIS IS ASYNCH
    if (user) { //USER IS SIGNED IN NOW
        // NOW GET .displayName
    }
    else { //USER IS NOT SIGNED IN

    }
});

感谢您对我的代码提出的改进建议。但是,问题是(据我所知),
event.data.displayName
在开始写操作之前是未定义的,我的意思是在initUser函数中。您会注意到
。在页面刷新之后,user
最初是
未定义的
null
。它“闪烁”直到asynch
.auth()
子系统返回用户状态。只需依赖.onAuthStateChanged和set.displayName,而不依赖于onCreate。要查看它,
console.log(firebase.auth()。你会看到它闪烁。我理解这一点,并在我的客户端中实现了这一点,但问题是指firebase云函数,特别是initUser触发器。啊..好的。现在明白了。