-
Notifications
You must be signed in to change notification settings - Fork 952
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Problem with transfer permissions to new copied sheet #1507
Comments
I've done some debugging of this as the same is occurring in my case, so here are some of my findings so far. I found that this is getting raised in the latest version due to the change in the Lines 368 to 383 in fd9e0fe
I've added a print to the try-except block: So therefore, the Lines 312 to 335 in abb8b10
Seems like this was the issue beforehand as well, but we just never noticed it because of the try-except 😅 I'll look into it a bit later again when I get more time to do so |
Again me... I think I found the source of the issue. The {
"id": "01100....",
"displayName": "some_name",
"type": "user",
"kind": "drive#permission",
"permissionDetails":
[
{
"permissionType": "member",
"role": "organizer",
"inherited": true
}
],
"photoLink": "photo_link_to_picture",
"emailAddress": "[email protected]",
"role": "organizer",
"teamDrivePermissionDetails":
[
{
"teamDrivePermissionType": "member",
"role": "organizer",
"inherited": true
}
],
"deleted": false
} {
"id": "0337188...",
"displayName": "[email protected]",
"type": "group",
"kind": "drive#permission",
"permissionDetails":
[
{
"permissionType": "member",
"role": "fileOrganizer",
"inherited": true
},
{
"permissionType": "file",
"inheritedFrom": "",
"role": "fileOrganizer",
"inherited": true
}
],
"emailAddress": "[email protected]",
"role": "fileOrganizer",
"teamDrivePermissionDetails":
[
{
"teamDrivePermissionType": "member",
"role": "fileOrganizer",
"inherited": true
},
{
"teamDrivePermissionType": "file",
"inheritedFrom": "",
"role": "fileOrganizer",
"inherited": true
}
],
"deleted": false
} And then this is how the JSON is for user manually added as Editor/Commenter/Viewer: {
"id": "1314136....",
"displayName": "some_name",
"type": "user",
"kind": "drive#permission",
"permissionDetails":
[
{
"permissionType": "file",
"role": "writer",
"inherited": false
}
],
"photoLink": "photo_link_to_picture",
"emailAddress": "[email protected]",
"role": "writer",
"teamDrivePermissionDetails":
[
{
"teamDrivePermissionType": "file",
"role": "writer",
"inherited": false
}
],
"deleted": false
} The permissions are as follows:
|
I came up with a couple of suggestions to fix this, Suggestion 1 (just look for three permissions that can be assigned through the UI): if copy_permissions is True:
original = self.open_by_key(file_id)
permissions = original.list_permissions()
for p in permissions:
# We ignore permissions that are applied to the folder and take
# only the file permissions (writer, commenter, reader)
if p.get("deleted") or str(p["role"]) not in ("writer", "commenter", "reader"):
continue
# In case of domain type the domain extract the domain
# In case of user/group extract the emailAddress
# Otherwise use None for type 'Anyone' Suggestion 2 (opposite of suggestion 1; check if the roles are folder roles, aka if copy_permissions is True:
original = self.open_by_key(file_id)
permissions = original.list_permissions()
for p in permissions:
# If the role is a folder role (due to it being inherited
# from the parent folder), skip it.
if p.get("deleted") or p.get("role") in ("organizer", "fileOrganizer"):
continue
# In case of domain type the domain extract the domain
# In case of user/group extract the emailAddress
# Otherwise use None for type 'Anyone' Suggestion 3 (check if if copy_permissions is True:
original = self.open_by_key(file_id)
permissions = original.list_permissions()
for p in permissions:
if p.get("deleted"):
continue
# If the permission is inherited from a parent folder, we
# ignore it. Permission types we're looking for are 'file'
# and 'member'.
perm_details = {p_details.get("permissionType"): p_details.get("inherited") for p_details in p.get("permissionDetails")}
if perm_details.get("file") or perm_details.get("member"):
continue
# In case of domain type the domain extract the domain
# In case of user/group extract the emailAddress
# Otherwise use None for type 'Anyone' |
@wobYY I have concerns that your suggested options may cause problems in other places. Examples 1 and 2 will skip users whose |
@P-Arti-A could you send a JSON response for the |
I have little knowledge about access in Google Drive. I didn't know that if the access level is "organizer" or "fileOrganizer", then the access to the spreadsheet is usually "Editor". |
Hi everyone ! @P-Arti-A thank you for raising this issue. @wobYY I like your approach on solving this issue. I will go for the option 1 partially. To me we should only copy permissions that we can actually set on the spreadsheet. So I will take some time to run some tests and I will try to set permissions with different roles ("writer", "fileOrganizer",...) then all those which succeeded will be kept and we'll only allow those roles to be set. To keep in mind here, whatever where the permissions are set on the original spreadsheet we are still blocked by what the API lets us set. And that is our limitations and it becomes the specs for that bug fix. I might need someone to help me in testing these on corporate shared drives. I don't think I have access to one. For reference here is the file permission documentation with all possible values for the Depending on the results either we can update the current PR or I can create a new one depending on if you want to contribute to the project or not. Just let me know 🙃 |
Hey @lavigne958 I can provide a couple API responses for the shared drive. Although worth mentioning, I can only provide them for the users and groups. I'm fine with both updating the current PR or closing that one and creating a new one, fully up to you |
thanks for the help provided, the API responses will be helpful, we can simply keep the currently open PR and just edit the code, this will add you as contributor of this project too ! I'll come back here once I had time to test different |
Here are the JSON objects for users and groups. I've just changed the User JSON object: [
{
"id": "131413",
"displayName": "preset-username",
"type": "user",
"kind": "drive#permission",
"permissionDetails": [
{
"permissionType": "file",
"role": "writer",
"inherited": false
}
],
"photoLink": "https://external-content.duckduckgo.com/iu/?u=https%3A%2F%2Fwww.shareicon.net%2Fdata%2F512x512%2F2016%2F07%2F10%2F119930_google_512x512.png&f=1&nofb=1&ipt=cdf36d48d2382b227bec2c6735f71833a4714a69b4f06109cab41990a184484d&ipo=images",
"emailAddress": "[email protected]",
"role": "writer",
"teamDrivePermissionDetails": [
{
"teamDrivePermissionType": "file",
"role": "writer",
"inherited": false
}
],
"deleted": false
},
{
"id": "131413",
"displayName": "preset-username",
"type": "user",
"kind": "drive#permission",
"permissionDetails": [
{
"permissionType": "file",
"role": "commenter",
"inherited": false
}
],
"photoLink": "https://external-content.duckduckgo.com/iu/?u=https%3A%2F%2Fwww.shareicon.net%2Fdata%2F512x512%2F2016%2F07%2F10%2F119930_google_512x512.png&f=1&nofb=1&ipt=cdf36d48d2382b227bec2c6735f71833a4714a69b4f06109cab41990a184484d&ipo=images",
"emailAddress": "[email protected]",
"role": "commenter",
"teamDrivePermissionDetails": [
{
"teamDrivePermissionType": "file",
"role": "commenter",
"inherited": false
}
],
"deleted": false
},
{
"id": "131413",
"displayName": "preset-username",
"type": "user",
"kind": "drive#permission",
"permissionDetails": [
{
"permissionType": "file",
"role": "reader",
"inherited": false
}
],
"photoLink": "https://external-content.duckduckgo.com/iu/?u=https%3A%2F%2Fwww.shareicon.net%2Fdata%2F512x512%2F2016%2F07%2F10%2F119930_google_512x512.png&f=1&nofb=1&ipt=cdf36d48d2382b227bec2c6735f71833a4714a69b4f06109cab41990a184484d&ipo=images",
"emailAddress": "[email protected]",
"role": "reader",
"teamDrivePermissionDetails": [
{
"teamDrivePermissionType": "file",
"role": "reader",
"inherited": false
}
],
"deleted": false
}
] Groups JSON object: [
{
"id": "0199",
"displayName": "group-name",
"type": "group",
"kind": "drive#permission",
"permissionDetails": [
{
"permissionType": "file",
"role": "writer",
"inherited": false
}
],
"emailAddress": "[email protected]",
"role": "writer",
"teamDrivePermissionDetails": [
{
"teamDrivePermissionType": "file",
"role": "writer",
"inherited": false
}
],
"deleted": false
},
{
"id": "0199",
"displayName": "group-name",
"type": "group",
"kind": "drive#permission",
"permissionDetails": [
{
"permissionType": "file",
"role": "commenter",
"inherited": false
}
],
"emailAddress": "[email protected]",
"role": "commenter",
"teamDrivePermissionDetails": [
{
"teamDrivePermissionType": "file",
"role": "commenter",
"inherited": false
}
],
"deleted": false
},
{
"id": "0199",
"displayName": "group-name",
"type": "group",
"kind": "drive#permission",
"permissionDetails": [
{
"permissionType": "file",
"role": "reader",
"inherited": false
}
],
"emailAddress": "[email protected]",
"role": "reader",
"teamDrivePermissionDetails": [
{
"teamDrivePermissionType": "file",
"role": "reader",
"inherited": false
}
],
"deleted": false
}
] |
Describe the bug
When using
gspread.authorize(self.credentials).copy(file_id=file_id, title=title, copy_permissions=True, folder_id=folder_id)
on enterprise shared drives, the error occurs:gspread.exceptions.APIError: APIError: [403]: FileOrganizer role is only allowed on folders.
To Reproduce
Steps to reproduce the behavior:
copy_permissions=True
Expected behavior
Set access roles in a new Google spreadsheet and continue running the script without error
Code example*
Environment info:
Additional context
I was able to fix this issue manually by opening client.py on line 329 and adding the following code there:
The error no longer appears
The text was updated successfully, but these errors were encountered: