在 Firebase Authentication 中,可以使用 Custom Claims 在用户身份认证时添加自定义数据,而 AngularFire 应该支持这些自定义声明的获取和设置。但是,在某些情况下(特别是在 v6 中),AngularFire 的 hasCustomClaim 和 customClaims 方法可能会出现问题,导致无法正常工作。
要解决此问题,可以使用 Firebase 的原生 SDK(而不是 AngularFire)来直接操作用户的声明。以下是一个示例代码:
import { AngularFireAuth } from "@angular/fire/auth";
import firebase from "firebase/app";
// ...
constructor(private afAuth: AngularFireAuth) {}
// ...
// 以异步方式获取当前用户的 ID token 和声明:
const { uid, accessToken } = (await this.afAuth.currentUser).toJSON();
const idTokenResult = await firebase.auth().currentUser.getIdTokenResult(accessToken);
// 获取或设置 Custom Claim:
const myCustomClaim = idTokenResult.claims["myCustomClaim"];
await firebase.auth().setCustomUserClaims(uid, { myCustomClaim: !myCustomClaim });
在这个示例中,我们首先使用 AngularFireAuth 获取我们的当前用户,然后获取他们的 ID token 和访问令牌。接下来,我们使用 Firebase 的原生 SDK 来获取 ID token 的声明,并使用 setCustomUserClaims 来更新用户的声明。
需要注意的是,您可能需要在 Firebase 控制台中启用 Custom Claims 才能使用此代码。您还可以针对您的应用程序编写更复杂的逻辑,以根据您自己的需要管理 Custom Claims。
总之,尽管 hasCustomClaim 和 customClaims 方法可能无法正常工作,但您仍然可以使用 Firebase SDK 来处理自定义声明。