示例:
如果用户是管理员而不是公司,则我希望角色节点仅具有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
}
}
}
}
答案 0 :(得分:0)
您需要添加一个包罗万象的规则以拒绝不匹配的子节点:
{
"rules": {
"roles": {
"$key": {
"admin": {
".validate": "newData.isBoolean()"
},
"$other": {
".validate": false
}
}
}
}
因此,根据上述规则,每个role
只能具有一个布尔值的admin
属性。如果客户端尝试写入其他任何属性,则该写入将被拒绝。