为什么验证规则的行为(仅)与 onDisconnect 更新不同?
Why validation rules behave differently (only) with onDisconnect update?
我用 firebase 进行了一些测试,发现 onDisconnect().update()
和在规则中使用 newData.parent()
的简单 update()
之间的规则验证存在差异。
当我使用 update()
时它起作用了。但是 onDisonnect().update()
我有 PERMISSION_DENIED!
数据库规则:
{
"rules": {
"$id": {
".read": true,
".write": true,
"a": { ".validate": true },
"b": { ".validate": "newData.parent().child('a').val() == 'a'" },
}
}
}
Javascript:
const valid = {
a: 'a',
b: 'b'
};
function update(obj) {
console.log('update', obj);
return ref.update(obj);
}
function onDisconnectUpdate(obj) {
console.log('onDisconnectUpdate', obj);
return ref.onDisconnect().update(obj);
}
update(valid);
onDisconnectUpdate(valid);
希望你能帮助我。
firebaser 在这里
在 onDisconnect()
操作期间,每个 属性 在我们验证规则时都被视为单独的写入操作。这意味着在您的情况下操作失败。虽然这是一个不幸的设计,但在不久的将来不太可能改变。出于这个原因,我建议在 onDisconnect()
处理程序中使用更简单的写操作。
我用 firebase 进行了一些测试,发现 onDisconnect().update()
和在规则中使用 newData.parent()
的简单 update()
之间的规则验证存在差异。
当我使用 update()
时它起作用了。但是 onDisonnect().update()
我有 PERMISSION_DENIED!
数据库规则:
{
"rules": {
"$id": {
".read": true,
".write": true,
"a": { ".validate": true },
"b": { ".validate": "newData.parent().child('a').val() == 'a'" },
}
}
}
Javascript:
const valid = {
a: 'a',
b: 'b'
};
function update(obj) {
console.log('update', obj);
return ref.update(obj);
}
function onDisconnectUpdate(obj) {
console.log('onDisconnectUpdate', obj);
return ref.onDisconnect().update(obj);
}
update(valid);
onDisconnectUpdate(valid);
希望你能帮助我。
firebaser 在这里
在 onDisconnect()
操作期间,每个 属性 在我们验证规则时都被视为单独的写入操作。这意味着在您的情况下操作失败。虽然这是一个不幸的设计,但在不久的将来不太可能改变。出于这个原因,我建议在 onDisconnect()
处理程序中使用更简单的写操作。