Admin Operations

An admin API request will be done on a URI that starts with the configurable ‘admin’ resource entry point. Authorization for the admin API duplicates the S3 authorization mechanism. Some operations require that the user holds special administrative capabilities. The response entity type (XML or JSON) may be specified as the ‘format’ option in the request and defaults to JSON if not specified.

Get Object

Get an existing object. NOTE: Does not require owner to be non-suspended.

Syntax

GET /{admin}/bucket?object&format=json HTTP/1.1
Host {fqdn}

Request Parameters

bucket

Description:

The bucket containing the object to be retrieved.

Type:

String

Example:

foo_bucket

Required:

Yes

object

Description:

The object to be retrieved.

Type:

String

Example:

foo.txt

Required:

Yes

Response Entities

If successful, returns the desired object.

object

Description:

The desired object.

Type:

Object

Special Error Responses

NoSuchObject

Description:

Specified object does not exist.

Code:

404 Not Found

Head Object

Verify the existence of an object. If the object exists, metadata headers for the object will be returned.

Syntax

HEAD /{admin}/bucket?object HTTP/1.1
Host {fqdn}

Request Parameters

bucket

Description:

The bucket containing the object to be retrieved.

Type:

String

Example:

foo_bucket

Required:

Yes

object

Description:

The object to be retrieved.

Type:

String

Example:

foo.txt

Required:

Yes

Response Entities

None.

Special Error Responses

NoSuchObject

Description:

Specified object does not exist.

Code:

404 Not Found

Get Zone Info

Get cluster information.

Syntax

GET /{admin}/zone&format=json HTTP/1.1
Host {fqdn}

Response Entities

If successful, returns cluster pool configuration.

zone

Description:

Contains current cluster pool configuration.

Type:

Container

domain_root

Description:

root of all buckets.

Type:

String

Parent:

cluster

control_pool

Description:

Type:

String

Parent:

cluster

gc_pool

Description:

Garbage collection pool.

Type:

String

Parent:

cluster

log_pool

Description:

Log pool.

Type:

String

Parent:

cluster

intent_log_pool

Description:

Intent log pool.

Type:

String

Parent:

cluster

usage_log_pool

Description:

Usage log pool.

Type:

String

Parent:

cluster

user_keys_pool

Description:

User key pool.

Type:

String

Parent:

cluster

user_email_pool

Description:

User email pool.

Type:

String

Parent:

cluster

user_swift_pool

Description:

Pool of swift users.

Type:

String

Parent:

cluster

Special Error Responses

None.

Example Response

HTTP/1.1 200
Content-Type: application/json

{
  "domain_root": ".rgw",
  "control_pool": ".rgw.control",
  "gc_pool": ".rgw.gc",
  "log_pool": ".log",
  "intent_log_pool": ".intent-log",
  "usage_log_pool": ".usage",
  "user_keys_pool": ".users",
  "user_email_pool": ".users.email",
  "user_swift_pool": ".users.swift",
  "user_uid_pool ": ".users.uid"
}

Add Placement Pool

Make a pool available for data placement.

Syntax

PUT /{admin}/pool?format=json HTTP/1.1
Host {fqdn}

Request Parameters

pool

Description:

The pool to be made available for data placement.

Type:

String

Example:

foo_pool

Required:

Yes

create

Description:

Creates the data pool if it does not exist.

Type:

Boolean

Example:

False [False]

Required:

No

Response Entities

TBD.

Special Error Responses

TBD.

Remove Placement Pool

Make a pool unavailable for data placement.

Syntax

DELETE /{admin}/pool?format=json HTTP/1.1
Host {fqdn}

Request Parameters

pool

Description:

The existing pool to be made available for data placement.

Type:

String

Example:

foo_pool

Required:

Yes

destroy

Description:

Destroys the pool after removing it from the active set.

Type:

Boolean

Example:

False [False]

Required:

No

Response Entities

TBD.

Special Error Responses

TBD.

List Available Data Placement Pools

List current pools available for data placement.

Syntax

GET /{admin}/pool?format=json HTTP/1.1
Host {fqdn}

Response Entities

If successful, returns a list of pools available for data placement.

pools

Description:

Contains currently available pools for data placement.

Type:

Container

List Expired Garbage Collection Items

List objects scheduled for garbage collection.

Syntax

GET /{admin}/garbage?format=json HTTP/1.1
Host {fqdn}

Request Parameters

None.

Response Entities

If expired garbage collection items exist, a list of such objects will be returned.

garbage

Description:

Expired garbage collection items.

Type:

Container

object

Description:

A container garbage collection object information.

Type:

Container

Parent:

garbage

name

Description:

The name of the object.

Type:

String

Parent:

object

expired

Description:

The date at which the object expired.

Type:

String

Parent:

object

Special Error Responses

TBD.

Manually Processes Garbage Collection Items

List objects scheduled for garbage collection.

Syntax

DELETE /{admin}/garbage?format=json HTTP/1.1
Host {fqdn}

Request Parameters

None.

Response Entities

If expired garbage collection items exist, a list of removed objects will be returned.

garbage

Description:

Expired garbage collection items.

Type:

Container

object

Description:

A container garbage collection object information.

Type:

Container

Parent:

garbage

name

Description:

The name of the object.

Type:

String

Parent:

object

expired

Description:

The date at which the object expired.

Type:

String

Parent:

object

Special Error Responses

TBD.

Show Log Objects

Show log objects

Syntax

GET /{admin}/log?format=json HTTP/1.1
Host {fqdn}

Request Parameters

object

Description:

The log object to return.

Type:

String:

Example:

2012-10-11-09-4165.2-foo_bucket

Required:

No

Response Entities

If no object is specified, returns the full list of log objects.

log-objects

Description:

A list of log objects.

Type:

Container

object

Description:

The name of the log object.

Type:

String

log

Description:

The contents of the log object.

Type:

Container

Special Error Responses

None.

Standard Error Responses

AccessDenied

Description:

Access denied.

Code:

403 Forbidden

InternalError

Description:

Internal server error.

Code:

500 Internal Server Error

NoSuchUser

Description:

User does not exist.

Code:

404 Not Found

NoSuchBucket

Description:

Bucket does not exist.

Code:

404 Not Found

NoSuchKey

Description:

No such access key.

Code:

404 Not Found