Firestore 安全 - 仅允许已知字段 [英] Firestore Security - allow only known fields

查看:22
本文介绍了Firestore 安全 - 仅允许已知字段的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我不知道如何在 Firestore 中正确设置.validate"规则.基本上,我想允许用户文档包含我知道的字段:

I can’t figure out how to properly set the ‘.validate’ rule in Firestore. Basically, I want to allow a User document to contain only the fields I know:

user {
 name: "John"
 phone: "2342222"
 address: "5th Avenue"
}

除了上述 3 个字段(姓名、电话、地址)之外,我不想要任何其他字段.

I dont want any other fields besides the 3 above (name, phone, address).

不会同时保存这些字段.姓名电话将首先保存,地址仅在用户想要编辑其个人资料时保存.

The fields WON’T be saved at the same time. name and phone will be saved first, and address will be saved only when user wants to edit his profile.

我已经尝试了以下规则,但似乎不起作用:

I've tried the rules below but don’t seem to work:

allow read: if request.auth.uid == uid;
allow write: if request.auth.uid == uid && 
 request.resource.data.keys() in ["name", "phone", "address"]

感谢您的帮助.

推荐答案

您可以将您的规则分开以包含不同的 createupdate(以及 delete) 逻辑:

You can separate your rules to include different create and update (as well as delete) logic:

// allows for creation with name and phone fields
allow create: if request.resource.data.size() == 2
              && request.resource.data.hasAll(['name', 'phone'])
              && request.resource.data.name is string
              && request.resource.data.phone is string;
// allows a single update adding the address field
// OR (||) in additional constraints
allow update: if request.resource.data.size() == resource.data.size() + 1
              && !('address' in resource.data)
              && request.resource.data.address is string;

这篇关于Firestore 安全 - 仅允许已知字段的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆