【发布时间】:2020-09-08 14:14:51
【问题描述】:
我正在尝试在用户注册后添加自定义用户声明,以定义用户角色,使用 setCustomUserClaims:
/api/users/addUser.js
export default async (req, res) => {
const { displayName, email, password, role } = req.body;
if (!displayName || !password || !email || !role) {
return res.status(400).send({ message: 'Missing fields' });
}
try {
const { uid } = await admin.auth().createUser({
displayName,
email,
password,
});
await admin.auth().setCustomUserClaims(uid, role);
res.status(201).send(uid);
} catch (error) {
handleError(res, error);
}
};
此代码检查身份验证状态的任何更改并将 user 设置为当前登录的用户:
/utils/use-auth.js
useEffect(() => {
const unsubscribe = firebase.auth().onAuthStateChanged((user) => {
if (user) {
setUser(user);
} else {
setUser(false);
// Router.push('/login');
}
});
在我的 /pages/user/home,jsx:
import { useAuth } from '../../utils/use-auth';
function home() {
const { user } = useAuth();
return (
<div>
<pre>{JSON.stringify(user, null, 4)}</pre>
<AdminLayout componentProps={{ selected: '1' }} Component={HomeContent} />
</div>
);
}
显示的对象没有任何自定义声明。 当我检查firebase控制台时,我发现实际上添加了用户。
【问题讨论】:
-
你是如何检查它们是否传播的?客户端只有在刷新其 ID 令牌后才能看到更新的声明,这会每小时自动发生一次,或者当您强制刷新时。
-
@FrankvanPuffelen 实际上我没有清楚地解释这个问题,我的意思是他们没有得到设置
-
这里没有足够的信息。请将问题编辑为:1)检查错误并显示任何错误消息,2)清楚地说明您要设置的声明,3)解释您如何观察到代码未按您预期的方式工作。我建议阅读:stackoverflow.com/help/minimal-reproducible-example
-
@DougStevenson 我添加了更多细节
-
那么您观察到的究竟是什么表明未设置声明?您是否期待
JSON.stringify(user, null, 4)}以某种方式显示这一点?有一个用于从用户对象访问自定义声明的特定 API - 请改用它。
标签: javascript firebase firebase-authentication firebase-admin