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