Configuring disk access permissions
To grant a user, group, or service account access to a disk, assign a role for it.
Assigning a role
- In the management console
, select the folder the disk belongs to. - Select Compute Cloud.
- In the left-hand panel, select
Disks. - Select a disk from the list.
- Go to
Access bindings. - Click Assign bindings.
- In the window that opens, select a group, user, or service account to be granted access to the disk.
- Click
Add role and select the required roles. - Click Save.
If you do not have the Yandex Cloud command line interface yet, install and initialize it.
The folder specified in the CLI profile is used by default. You can specify a different folder using the --folder-name
or --folder-id
parameter.
-
See the CLI command description for assigning a role for a disk:
yc compute disk add-access-binding --help
-
Get a list of disks in the default folder:
yc compute disk list
Result:
+----------------------+-------------+-------------+-------------------+--------+----------------------+-----------------+-------------+ | ID | NAME | SIZE | ZONE | STATUS | INSTANCE IDS | PLACEMENT GROUP | DESCRIPTION | +----------------------+-------------+-------------+-------------------+--------+----------------------+-----------------+-------------+ | epd557pch3uk******** | first-disk | 68719476736 | ru-central1-a | READY | epd5ieqbii7l******** | | | | epdusilqgq3m******** | second-disk | 68719476736 | ru-central1-a | READY | epd37ebcdf36******** | | | +----------------------+-------------+-------------+-------------------+--------+----------------------+-----------------+-------------+
-
View the list of roles already assigned for the resource:
yc compute disk list-access-bindings <disk_name_or_ID>
-
Assign the role using the command:
-
To a user:
yc compute disk add-access-binding <disk_name_or_ID> \ --user-account-id <user_ID> \ --role <role>
Where:
-
To a service account:
yc compute disk add-access-binding <disk_name_or_ID> \ --service-account-id <service_account_ID> \ --role <role>
Where:
--service-account-id
: Service account ID.--role
: Role being assigned.
-
Use the updateAccessBindings REST API method for the Disk resource or the DiskService/UpdateAccessBindings gRPC API call. In the request body, specify ADD
in the action
property, and user type and ID in the subject
property.
Assign multiple roles
- In the management console
, select the folder the disk belongs to. - Select Compute Cloud.
- In the left-hand panel, select
Disks. - Select a disk from the list.
- Go to
Access bindings. - Click Assign bindings.
- In the window that opens, select a group, user, or service account to be granted access to the disk.
- Click
Add role and select the required roles. - Use the Add role button to add another role.
- Click Save.
If you do not have the Yandex Cloud command line interface yet, install and initialize it.
The folder specified in the CLI profile is used by default. You can specify a different folder using the --folder-name
or --folder-id
parameter.
You can assign multiple roles using the set-access-bindings
command.
Alert
The set-access-bindings
command completely rewrites the access permissions for the resource. All current resource roles will be deleted.
-
Make sure the resource has no roles assigned that you would rather not lose:
yc compute disk list-access-bindings <disk_name_or_ID>
-
See the CLI command description for assigning roles for a disk:
yc compute disk set-access-bindings --help
-
Assign roles:
yc compute disk set-access-bindings <disk_name_or_ID> \ --access-binding role=<role>,subject=<subject_type>:<subject_ID>
Where:
-
--access-binding
: Assigned role:role
: Assigned role ID.subject
: Type and ID of the subject getting the role.
For example, assign roles to multiple users and a service account:
yc compute disk set-access-bindings my-disk \ --access-binding role=editor,subject=userAccount:gfei8n54hmfh******** --access-binding role=viewer,subject=userAccount:helj89sfj80a******** --access-binding role=editor,subject=serviceAccount:ajel6l0jcb9s********
-
Use the setAccessBindings REST API method for the Disk resource or the DiskService/SetAccessBindings gRPC API call.
Revoking a role
- In the management console
, select the folder the disk belongs to. - Select Compute Cloud.
- In the left-hand panel, select
Disks. - Select a disk from the list.
- Go to
Access bindings. - Click Assign bindings.
- In the line of the required user, click
and select Edit roles. - Click
next to a role to delete it. - Click Save.
If you do not have the Yandex Cloud command line interface yet, install and initialize it.
The folder specified in the CLI profile is used by default. You can specify a different folder using the --folder-name
or --folder-id
parameter.
-
See the CLI command description for revoking a role for a disk:
yc compute disk remove-access-binding --help
-
View the roles and assignees for the resource:
yc compute disk list-access-bindings <disk_name_or_ID>
-
To delete an access binding, run:
yc compute disk remove-access-binding <disk_name_or_ID> \ --role <role_ID> \ --subject <subject_type>:<subject_ID>
Where:
--role
: ID of the role to be revoked.--subject
: Subject to revoke the role from.
For example, to revoke the
viewer
role for a disk from a user with theajel6l0jcb9s********
ID:yc compute disk remove-access-binding my-disk \ --role viewer \ --subject userAccount:ajel6l0jcb9s********
To revoke disk roles, use the updateAccessBindings REST API method for the Disk resource or the DiskService/UpdateAccessBindings gRPC API call. In the request body, specify REMOVE
in the action
property, and user type and ID in the subject
property.