我正在尝试在firebase中的google函数中设置自定义声明。这是我的代码。
admin.auth().setCustomUserClaims(user.uid,{
activeNetworkProfile: networkProfile,
activeCompanyProfile: companyProfile,
activeUserProfile: profiles[0]
});
在客户端,我有以下内容:
public updateProfiles(){
return this.afAuth.idToken.pipe(
switchMap(idToken => this.httpClient.post<any>('https://us-central1-company-database.cloudfunctions.net/updateProfiles',{
"token": idToken,
"np":"hzlNpVEdwqOKRTcsdfPG",
"cp":"D7nKYrS235A9vnvfB9oD"
}))
);
}
然后测试已经做出的改变:
public validateToken(){
return this.afAuth.idToken.pipe(
switchMap(idToken => this.httpClient.post<any>('https://us-central1-company-database.cloudfunctions.net/validateToken',{
"token": idToken
}))
);
}
在服务器上我有以下内容:
export const validateToken = functions.https.onRequest((req, res) => {
return cors(req, res, () => {
const db = admin.firestore();
let token = req.body.token;
admin.auth().verifyIdToken(token).then(decodedToken=>{
res.status(200).send(decodedToken);
})
.catch(error=>{
res.status(401).send(error.message);
});
});
});
我没有在回复中得到索赔。我已经尝试通过将参数设置为true来强制更新angularfire2
public getToken(){
return this.afAuth.auth.currentUser.getIdToken(true);
}
但是如果它导致firebase令牌更新进入无限循环,这没有任何改变。
答案 0 :(得分:0)
我能够通过在设置声明后添加以下代码来解决问题。
const metadataRef = admin.database().ref("metadata/" + user.uid);
return metadataRef.set({refreshTime: new Date().getTime()});