如何定义只将一个字段写入特定节点?

时间:2018-09-25 12:20:07

标签: firebase firebase-realtime-database firebase-security-rules

示例:

如果用户是管理员而不是公司,则我希望角色节点仅具有admin:true(并且我不希望另一个孩子的公司:false),或者如果用户是公司,则为true(不是)管理员:false)

{
// BAD
{
    "roles": {
        "$key": {
            "admin": true,   // or admin: false
            "company": false // or company: true
        }
    }
}
// GOOD (but how to make?)
{
    "roles": {
        "$key": {
            "admin": true, // or company: true
        }
    }
}

}

1 个答案:

答案 0 :(得分:0)

您需要添加一个包罗万象的规则以拒绝不匹配的子节点:

{
  "rules": {
    "roles": {
      "$key": {
        "admin": {
          ".validate": "newData.isBoolean()"
        },
        "$other": {
          ".validate": false
        }
      }
    }
}

因此,根据上述规则,每个role只能具有一个布尔值的admin属性。如果客户端尝试写入其他任何属性,则该写入将被拒绝。