我不确定我是否遇到错误或者我做错了什么。我正在开发一个应用程序,允许用户在他们的 Google Drive 上创建和共享一个文件夹,以便他们可以就文件夹的内容进行协作。该文件夹是在用户的 Google Drive 的根目录下创建的,最初包含几个文件和一个包含更多文件的子文件夹。
第一个问题是,在主文件夹上插入新权限后,权限通常会向下传播到所有文件和子文件夹,但有时无法在子目录中的某个文件上插入权限。这种将权限传播到子目录的功能是官方支持的,还是我想分别在所有文件中插入权限?
我遇到的第二个问题涉及使用文件的 userPermission 属性来检查当前用户的角色是否已更改。似乎 userPermission 属性有时包含最近用户而不是当前用户的权限。我正在尝试实现的功能是共享文件夹的用户能够定期检查他们的权限角色是否已更改。例如,用户权限角色是否从“读者”更改为“作者”,反之亦然。这通常通过列出具有 fileId 的文件夹并检查文件的 userPermission 属性的角色属性来工作。但是,如果我正在与共享用户和共享它的用户在同一个客户端中测试此功能,获取文件结果通常会将 userPermission 列为访问文件的最后一个,而不是当前用户。我已经测试了这是否是因为我在请求标头中使用了错误的 oauth 信息,但我已经排除了这种可能性,oauth 标头对于每个单独的获取文件的调用都是正确的。在调用获取文件以确认授权用户是谁之前,我添加了一个关于女巫列表用户permissionId 的测试调用。为错误的用户显示带有“我”名称的 userPermission。就在调用获取文件以确认授权用户是谁之前。为错误的用户显示带有“我”名称的 userPermission。就在调用获取文件以确认授权用户是谁之前。为错误的用户显示带有“我”名称的 userPermission。
我发现的解决方法是使用列表文件,它返回列表中具有正确用户权限的文件。
在位于https://developers.google.com/drive/v2/reference/files#resource的参考中,userPermission 属性的描述是“经过身份验证的用户对此文件的权限”。
我错误地将其解释为 userPermission 将始终显示当前用户的角色?如果它显示错误的权限,可能是什么原因?