OBS supports the control of access permission for objects. By default, only the object creator has the read and write permissions for the object. However, the creator can set a public access policy to assign the read permission to all other users. Even if the ACL is configured for an object encrypted in the SSE-KMS mode, the inter-tenant access is unavailable.
You can set an access control policy when uploading an object or make a call of an API operation to modify or obtain the object ACL. An object ACL supports a maximum of 100 grants.
This section explains how to modify an object ACL and change access permission on an object.
By default, this operation modifies the ACL of the latest version of an object. To specify a specified version, the request can carry the versionId parameter.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | PUT /ObjectName?acl HTTP/1.1 Host: bucketname.obs.region.example.com Date: date Authorization: authorization <AccessControlPolicy> <Owner> <ID>ID</ID> </Owner> <Delivered>true</Delivered> <AccessControlList> <Grant> <Grantee> <ID>ID</ID> </Grantee> <Permission>permission</Permission> </Grant> </AccessControlList> </AccessControlPolicy> |
Table 1 describes the request parameters.
This request uses common headers. For details, see Table 3.
In addition to the common request headers, the header listed in Table 2 may be used.
Header |
Type |
Mandatory (Yes/No) |
Description |
|---|---|---|---|
x-obs-request-payer |
String |
No |
Definition: Indicates that the requester agrees to pay for the request and traffic. Constraints: If this header is not included in the request when the requester tries to access a requester-pays bucket, the authentication fails and error "403 Forbidden" is returned. Range: requester Default value: None |
The request message carries the ACL information of the object by using message elements. For the meanings of the elements, see Table 3.
Element |
Description |
Mandatory (Yes/No) |
|---|---|---|
AccessControlPolicy |
Access control policy. AccessControlPolicy is a parent node of Owner, Delivered, and AccessControlList. Type: XML |
Yes |
AccessControlList |
Access control list. AccessControlList is the parent node of Grant. Type: XML |
Yes |
Owner |
Owner information of a bucket. Owner is a parent node of ID. Type: XML |
Yes |
ID |
Domain ID of a user. Type: string |
Yes |
Grant |
Identifies the grantee and the permissions of the grantee. An ACL of an object can contain a maximum of 100 grants. Grant is the parent node of Grantee and Permission. Type: XML |
No |
Grantee |
Used to record user information. Grantee is a parent node of ID. Type: XML |
No |
Canned |
Grants permissions to all users. Range: Everyone Type: string |
No |
Delivered |
Indicates whether an object ACL inherits the ACL of a bucket. Type: boolean Default value: true |
No |
Permission |
Authorized permission. Value options: READ, READ_ACP, WRITE_ACP, FULL_CONTROL Type: string |
No |
1 2 3 | HTTP/1.1 status_code Content-Length: length Content-Type: application/xml |
The response to the request uses common headers. For details, see Table 1.
In addition to the common response headers, the headers listed in Table 4 may be used.
Parameter |
Type |
Description |
|---|---|---|
x-obs-version-id |
String |
Definition: Version ID of the object whose ACL is modified. Range: The value must contain 32 characters. |
x-obs-request-payer |
string |
Definition: Indicates that the requester agrees to pay for the request and traffic. Constraints: If this header is not included in the request when the requester tries to access a requester-pays bucket, the authentication fails and error "403 Forbidden" is returned. Range: requester Default value: None |
This response contains no elements.
No special error responses are returned. For details about error responses, see Table 2.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | PUT /obj2?acl HTTP/1.1 User-Agent: curl/7.29.0 Host: examplebucket.obs.region.example.com Accept: */* Date: WED, 01 Jul 2015 04:42:34 GMT Authorization: OBS H4IPJX0TQTHTHEBQQCEC:8xAODun1ofjkwHm8YhtN0QEcy9M= Content-Length: 727 <AccessControlPolicy xmlns="http://obs.example.com/doc/2015-06-30/"> <Owner> <ID>b4bf1b36d9ca43d984fbcb9491b6fce9</ID> </Owner> <Delivered>false</Delivered> <AccessControlList> <Grant> <Grantee> <ID>b4bf1b36d9ca43d984fbcb9491b6fce9</ID> </Grantee> <Permission>FULL_CONTROL</Permission> </Grant> <Grant> <Grantee> <ID>783fc6652cf246c096ea836694f71855</ID> </Grantee> <Permission>READ</Permission> </Grant> <Grant> <Grantee> <Canned>Everyone</Canned> </Grantee> <Permission>READ</Permission> </Grant> </AccessControlList> </AccessControlPolicy> |
1 2 3 4 5 6 | HTTP/1.1 200 OK Server: OBS x-obs-request-id: 8DF400000163D3F0FD2A03D2D30B0542 x-obs-id-2: 32AAAUgAIAABAAAQAAEAABAAAQAAEAABCTjCqTmsA1XRpIrmrJdvcEWvZyjbztdd Date: WED, 01 Jul 2015 04:42:34 GMT Content-Length: 0 |