首页 > 解决方案 > 如果我正在检查数组,我可以在 firebase 规则中使用包含吗?

问题描述

我有一组邀请,但出现权限不足错误。

数据

"inviteID" : {
  playerEmail: 'jon@doe.com',
  teamID: 'abcdefg'
}

和一个团队

"teamID" : {
  ...
  managers: [managerID, ...]
  ...
}

使用以下查询:

团队经理

查询似乎很简单

db.collections('invites').where('teamID', '==', myTeamID)

但是规则必须检查查询的人是否是经理...

match /invites/{inviteID} {
      function isManager() {
        // managers is an array
        return get(/databases/$(database)/documents/teams/$(resource.data.teamID)).data.managers.includes(request.auth.uid)     
      }
            allow read: if (isManager())
    }

我也有这条会失败的规则有关系吗?

    // Allow user to read his own invites
    match /invites/{inviteID} {
        allow read: if (request.auth.token.email == resource.data.playerEmail)
    }

匹配同一文档的第二条规则将失败,因为显然邀请与经理的电子邮件不同。我需要这条规则作为一个单独的查询,允许用户查询他们的邀请。

好像没看懂,权限问题。感谢帮助!

标签: firebasegoogle-cloud-firestorenosqlfirebase-security

解决方案


所以我将规则更改为

return request.auth.uid in get(/databases/$(database)/documents/teams/$(resource.data.teamID)).data.managers

这似乎解决了我的权限错误


推荐阅读