0

在过去的两周里,我一直在大量使用Google APIs Client Library for JS来访问某些文件的修订历史记录,并查看它们是否在 web 上发布,并使用 drive.readonly.metadata 范围。

以下代码工作到今天早上

function checkRevision(childItem, language) {
    var requestRevision = gapi.client.drive.revisions.list({
        'fileId': childItem.id,
        'fields': 'items/publishedOutsideDomain'
    });

    var fileId = childItem.id;
    requestRevision.execute(function(revisions) {

        //Check if the latest revision is published
        if (revisions && !revisions.error) {
            if (revisions.items[revisions.items.length - 1].publishedOutsideDomain) {
                addBlogPostToMenu(fileId, language);//the file is ok do the real job
            }
        }
    });
}

不是我得到的回应requestRevision.execute

403 Forbidden

    {
     "error": {
      "errors": [
       {
        "domain": "global",
        "reason": "forbidden",
        "message": "Forbidden"
       }
      ],
      "code": 403,
      "message": "Forbidden"
     }
    }

该网络应用程序已正确授权

    gapi.auth.authorize({
        'client_id': CLIENT_ID,
        'scope': 'https://www.googleapis.com/auth/drive.readonly.metadata',
        'immediate': true
    },
    handleAuthResult); 

更改范围以drive.readonly修复它,但我认为修订是元数据而不是实际文件,因此drive.readonly.metadata应该是最合适的范围。

PS 甚至尝试使用APIs Explorer,我得到了同样的错误。

示例文件 ID:

1ppLjLg2_ItTGHn_tVSEyOm2bwOtfqiGEb4MZQyAnE7c

4

1 回答 1

2

这是预期的行为,同样,如果您仅被授权,则files.list 不会以exportLinks或 a回复。downloadUrldrive.readonly.metadata

于 2013-09-05T22:52:25.943 回答