我有点卡在这里,因为没有办法调试这些规则.我很感激以下规则的帮助.
我想访问:
/modules/module-id/sessions/session-id/parts/
与null
第一部分的比较hasCompletedPrerequisiteSession()
效果很好,第二部分没有!
该路径/modules/moduleId/sessions/sessionId/prerequisite
指向参考字段.
service cloud.firestore {
match /databases/{database}/documents {
function hasCompletedPrerequisiteSession(moduleId,sessionId) {
// this part works well
return getPrerequisiteSession(moduleId,sessionId) == null ||
// !!! this part does not work !!!
hasCompleted(getPrerequisiteSession(moduleId,sessionId).id);
}
function getPrerequisiteSession(moduleId,sessionId) {
return get(/databases/$(database)/documents/modules/$(moduleId)/sessions/$(sessionId)).data.prerequisite;
}
function hasCompleted(sessionId) {
return exists(/databases/$(database)/documents/progress/$(request.auth.uid)/sessions/$(sessionId));
}
match /modules/{moduleId}/sessions/{sessionId}/parts/{partId} {
allow read: if hasCompletedPrerequisiteSession(moduleId,sessionId);
}
}
}
Run Code Online (Sandbox Code Playgroud)
(如果我将会话ID存储为字符串而不是对会话的引用,它可以正常工作.)
编辑
问题
modules/moduleId/owner
指向该类型的字段reference
.获取引用文档的id的正确方法是什么?get(../modules/moduleId).data.owner.data.id
或者get(../modules/moduleId).data.owner
还是其他什么东西?我想通过烧瓶连接到mysql服务器
app.config['SQLALCHEMY_DATABASE_URI'] = 'mysql://your-username:your-password@localhost/schema'
Run Code Online (Sandbox Code Playgroud)
如何在连接中添加ca-cert,client-key和client-cert?