So far I have used this rule configuration
{
"rules": {
"items": {
".read" : true,
"$uid": {
".read" : true,
".write": "auth != null && auth.uid == $uid"
}
}
}
}
check and other directories omitted. / details / user1 / Item1 / items / user 2 / item1
Everyone can read catalog items and all user items (without personal items)
What I need?
flat array of elements
"items" : {
"item1": {},
"item2": {}
}
named userId as
"item1" : {
"uid": "userId"
}
Only a user item can edit / delete it, but everyone can see it.
I was thinking about double items in different directories like
"public_items": {
"item1": {},
"item2": {}
}
"items": {
"userId": {
"item1": {},
"item2": {},
}
}
But this is not a good idea.
. , , , . , . https://firebase.google.com/docs/database/security/securing-data#read_and_write_rules_cascade
, ?