我能够使用服务帐户创建Google工作表,但是无法为用户插入工作表权限:
function createSheet(jwt, apiKey) {
const sheets = google.sheets({version: 'v4'});
var request = {
resource: {
"properties": {
"title": "testSheet"
}
},
auth: jwt
};
以下是来自create sheet API的响应:
config: {transformRequest: {…}, transformResponse: {…}, timeout: 0, xsrfCookieName: "XSRF-TOKEN", xsrfHeaderName: "X-XSRF-TOKEN", …}
data: {spreadsheetId: "XXX", properties: {…}, sheets: Array(1), spreadsheetUrl: "https://docs.google.com/spreadsheets/d/XXX/edit"}
...
status: 200
statusText: "OK"
我的代码。
function insertPermission(fileId) {
var body = {
'value': 'xxx@gmail.com',
'type': 'user',
'role': 'owner'
};
var drive=google.drive({version: 'v3'});
drive.permissions.create({
'fileId': fileId, //sheetID returned from create sheet response
'resource': body
}, function(err, response) {if (err) {
console.error(err);
return;
} else{
console.log(JSON.parse(JSON.stringify(response))) ;
}
});
insertPermission错误:
index.js:114错误:权限不足 在createError
或者,是否可以在sheets.create api中指定文件权限?
答案 0 :(得分:0)
createError权限不足
通常意味着您登录的用户没有执行他们尝试执行的操作的权限。
var fileId = '1sTWaJ_j7PkjzaBWtNc3IzovK5hQf21FbOw9yLeeLPNQ';
var permissions = [
{
'type': 'user',
'role': 'writer',
'emailAddress': 'user@example.com'
}, {
'type': 'domain',
'role': 'writer',
'domain': 'example.com'
}
];
// Using the NPM module 'async'
async.eachSeries(permissions, function (permission, permissionCallback) {
drive.permissions.create({
resource: permission,
fileId: fileId,
fields: 'id',
}, function (err, res) {
if (err) {
// Handle error...
console.error(err);
permissionCallback(err);
} else {
console.log('Permission ID: ', res.id)
permissionCallback();
}
});
}, function (err) {
if (err) {
// Handle error
console.error(err);
} else {
// All permissions inserted
}
});
答案 1 :(得分:0)
此外,gdrive上还有一个设置可以创建文件夹,并授予服务帐户对该文件夹的权限以进行读/写。 MyDrive可通过用户ID而不是服务帐户进行访问。问题已解决。