我想知道关于带有Firestore安全规则的未定义属性的约定是什么。
例如,在以下检查自定义声明的规则中:
allow read: if request.auth.token.claims.admin;
未定义属性错误有很多要点,到目前为止,很可能是如果用户未通过身份验证,则request.auth
将是未定义的,因此request.auth.token.claims.admin
将尝试访问不确定的值。
我注意到文档request.auth.uid
是常规检查,他们不检查是否首先定义了request.auth
。但是,在我的研究中,我发现有些人确实对类似的查询进行了检查,例如in this stack overflow answer。
下面是模拟器返回的注释屏幕截图。我的理解是,对于安全性,不需要检查未定义的属性。我的问题是标准是什么,如果不检查未定义的属性就是标准,那么模拟器为什么会引发错误?
请注意,以下哪种情况(隐式或显式布尔条件)是首选,为什么:
allow read: if request.auth.token.claims.admin;
allow read: if request.auth.token.claims.admin == true;
答案 0 :(得分:1)
首先:规则评估中的所有错误都会导致错误。没有任何条件的错误会导致拒绝访问。因此,如果您尝试访问null或未定义对象的属性,则会出现错误(因为该属性不存在),并且会导致立即拒绝访问。
如果您想在规则中显式检查null,那很好。这可能有助于提高这些规则的可读性。但是由于立即拒绝访问,您没有义务这样做。这完全取决于您。