Firestore 安全规则:检查地图列表的值
Firestore Security Rules: check for value of list of map
文档看起来像这样
matches: [
{uid: ___ , ...},
{uid: ___ , ...},
]
如何检查请求此操作的用户的 uid 是否在匹配的 uid 之一中?我试过了,但没用。
uid 在 get(/databases/$(database)/documents/users/$(request.auth.uid)).data.matches.uid
感谢您的帮助!
你不能。安全规则语言不支持 for
循环或 map
之类的东西。您需要以不同方式存储数据。这些模式中的任何一个都可以工作:
// data structure
matches: ["uid1", "uid2", "uid3"]
// rules
allow: if uid in resource.data.matches;
// data structure
matches: {"uid1": true, "uid2": true}
// rules
allow: if resource.data.matches[uid] == true;
或者,如果您知道 matches
数组的长度永远不会超过五个元素,您可以手动展开语句:
allow: if resource.data.matches[0].uid == uid ||
resource.data.matches[1].uid == uid ||
// ...repeat three more times
文档看起来像这样
matches: [
{uid: ___ , ...},
{uid: ___ , ...},
]
如何检查请求此操作的用户的 uid 是否在匹配的 uid 之一中?我试过了,但没用。
uid 在 get(/databases/$(database)/documents/users/$(request.auth.uid)).data.matches.uid
感谢您的帮助!
你不能。安全规则语言不支持 for
循环或 map
之类的东西。您需要以不同方式存储数据。这些模式中的任何一个都可以工作:
// data structure
matches: ["uid1", "uid2", "uid3"]
// rules
allow: if uid in resource.data.matches;
// data structure
matches: {"uid1": true, "uid2": true}
// rules
allow: if resource.data.matches[uid] == true;
或者,如果您知道 matches
数组的长度永远不会超过五个元素,您可以手动展开语句:
allow: if resource.data.matches[0].uid == uid ||
resource.data.matches[1].uid == uid ||
// ...repeat three more times