【发布时间】:2016-06-03 11:50:42
【问题描述】:
要将组创建者与组成员链接在一起,我希望组创建者提交一个连接字符串,然后组成员可以使用该连接字符串加入组。
然而,一旦创建了连接字符串,我不希望除了创建者之外的任何人删除或覆盖字符串或字符串下的数据。
在我的 javascript 中,我可以轻松地编写一个检查函数来查看它是否存在:
function tryToAddConnectionString(uid, desiredConnectionString)
{
firebase.database().ref('/connectionStrings/' + desiredConnectionString).once('value').then(function(snapshot){
if(snapshot.val()==null)
{
//There is no data therefore there is no connection string, so create one.
firebase.database().ref('connectionStrings/' + desiredConnectionString).set({
owner: uid });
}
else
{
//Connection String already exists. Throw "already exists" message
}
});
}
但这并不能阻止恶意黑客进入他/她的控制台并输入
firebase.database().ref('connectionStrings/' + desiredConnectionString).set(null);
这将删除/接管该组。
我可以设置一个规则来解决这个问题吗?另外,在
'/connectionStrings/'+desiredConnectionString+'members'
我希望人们能够将自己添加为成员。
回顾一下:我正在寻找一个允许任何人创建连接字符串的规则,但只有创建者可以删除连接字符串或更改所有者子文件夹,但任何人都可以读/写成员文件夹。
提前致谢。
【问题讨论】:
标签: javascript firebase firebase-realtime-database