在使用firebase admin SDK创建用户后,如何发送验证电子邮件?
我想合并createUser function
和sendEmailVerification function
有人可以指出一个暗示或答案吗?感谢
用户创建由已在应用程序中登录的管理员用户完成,因此管理员用户只是在仪表板上创建用户。这与注册方法完全不同。
我尝试关注bojeil's answer,我仍然坚持用户使用自定义令牌登录的步骤。它与我当前的管理员用户会话发生冲突,管理员用户被踢出,而新用户已登录,即使我退出新用户,管理员用户仍然不在,需要登录才能重新登录应用程序。
在我获得自定义令牌后,这是我在应用程序中的代码:
$http.post('/.custom-token', {uid: $scope.data.data.uid})
.then(function (response) {
console.log("custom token here:", response.data.token);
firebase.auth().signInWithCustomToken(response.data.token)
.then(function (firebaseUser) {
firebaseUser.sendEmailVerification();
firebase.auth().signOut().then(function() {
// Sign-out successful.
console.log("signed out success");
}, function(error) {
// An error happened.
});
})
.catch(function(error) {
// Handle Errors here.
var errorCode = error.code;
var errorMessage = error.message;
// ...
});
});
所以,我获得令牌,登录新用户,发送电子邮件验证链接,然后注销新用户。 但我正在执行此操作的管理员用户也会退出。 我在这里错过了什么?
答案 0 :(得分:11)
好的,这是你可以做的,但你可能会达到配额限制:
答案 1 :(得分:2)
您甚至不需要使用Firebase Admin SDK。您可以使用常规的Firebase客户端SDK:
firebase.auth().createUserWithEmailAndPassword(email, password)
.then(function(user) {
console.log("User successfully created:", user.uid);
return user.sendEmailVerification();
})
.then(function() {
console.log("Email verification email successfully sent!");
})
.catch(function(error) {
console.log("Error:", error);
});
答案 2 :(得分:2)
一个比较干净的解决方案是实际使用REST API。
curl 'https://www.googleapis.com/identitytoolkit/v3/relyingparty/getOobConfirmationCode?key=[API_KEY]' \
-H 'Content-Type: application/json' \
--data-binary '{"requestType":"PASSWORD_RESET","email":"[user@example.com]"}'
[API KEY]是一个Web客户端api密钥,可以从Project Settings中检索>添加一个应用程序>>单击Web,您将获得带有JSON的配置,在JSON中有一个APIKey就是一个您需要使用的。
答案 3 :(得分:1)
根据firebase,admin-sdk目前不支持此功能。在这里查看他们的回复 https://stackoverflow.com/a/44557980/8177355
每当电子邮件/密码验证用户登录并尝试使用需要验证的功能时,我都会调用onAuthStateChanged(),然后检查用户的电子邮件验证记录。
如果电子邮件未经过验证,我之前没有发过验证邮件,我会自动发送。我返回一个错误,要求用户验证他们的电子邮件。 (我将一个变量存储在firestore中的用户的配置文件设置中,以指示它是否先前已发送过。)
在将来尝试使用该应用时,如果仍未验证该电子邮件,我会返回相同的错误,并在标有&#34的错误中包含一个按钮;重新发送验证电子邮件"按下时会触发发送验证邮件。 (这样,每次用户尝试执行某些操作时,我都不会自动发送大量验证电子邮件。)