发布于 2015-09-10 16:22:04 | 216 次阅读 | 评论: 0 | 来源: 网络整理
Create a user repository with the given namespace and repo_name.
Example Request:
PUT /v1/repositories/foo/bar/ HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
Authorization: Basic akmklmasadalkm==
X-Docker-Token: true
[{"id": "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f"}]
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 200
Vary: Accept
Content-Type: application/json
WWW-Authenticate: Token signature=123abc,repository="foo/bar",access=write
X-Docker-Token: signature=123abc,repository="foo/bar",access=write
X-Docker-Endpoints: registry-1.docker.io [, registry-2.docker.io]
""
	| Status Codes: | 
 | 
|---|
Delete a user repository with the given namespace and repo_name.
Example Request:
DELETE /v1/repositories/foo/bar/ HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
Authorization: Basic akmklmasadalkm==
X-Docker-Token: true
""
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 202
Vary: Accept
Content-Type: application/json
WWW-Authenticate: Token signature=123abc,repository="foo/bar",access=delete
X-Docker-Token: signature=123abc,repository="foo/bar",access=delete
X-Docker-Endpoints: registry-1.docker.io [, registry-2.docker.io]
""
	| Status Codes: | 
 | 
|---|
Create a library repository with the given repo_name. This is a restricted feature only available to docker admins.
When namespace is missing, it is assumed to be library
Example Request:
PUT /v1/repositories/foobar/ HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
Authorization: Basic akmklmasadalkm==
X-Docker-Token: true
[{"id": "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f"}]
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 200
Vary: Accept
Content-Type: application/json
WWW-Authenticate: Token signature=123abc,repository="library/foobar",access=write
X-Docker-Token: signature=123abc,repository="foo/bar",access=write
X-Docker-Endpoints: registry-1.docker.io [, registry-2.docker.io]
""
	| Status Codes: | 
 | 
|---|
Delete a library repository with the given repo_name. This is a restricted feature only available to docker admins.
When namespace is missing, it is assumed to be library
Example Request:
DELETE /v1/repositories/foobar/ HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
Authorization: Basic akmklmasadalkm==
X-Docker-Token: true
""
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 202
Vary: Accept
Content-Type: application/json
WWW-Authenticate: Token signature=123abc,repository="library/foobar",access=delete
X-Docker-Token: signature=123abc,repository="foo/bar",access=delete
X-Docker-Endpoints: registry-1.docker.io [, registry-2.docker.io]
""
	| Status Codes: | 
 | 
|---|
Update the images for a user repo.
Example Request:
PUT /v1/repositories/foo/bar/images HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
Authorization: Basic akmklmasadalkm==
[{"id": "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f",
"checksum": "b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087"}]
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 204
Vary: Accept
Content-Type: application/json
""
	| Status Codes: | 
 | 
|---|
get the images for a user repo.
Example Request:
GET /v1/repositories/foo/bar/images HTTP/1.1
Host: index.docker.io
Accept: application/json
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 200
Vary: Accept
Content-Type: application/json
[{"id": "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f",
"checksum": "b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087"},
{"id": "ertwetewtwe38722009fe6857087b486531f9a779a0c1dfddgfgsdgdsgds",
"checksum": "34t23f23fc17e3ed29dae8f12c4f9e89cc6f0bsdfgfsdgdsgdsgerwgew"}]
	| Status Codes: | 
 | 
|---|
Update the images for a library repo.
Example Request:
PUT /v1/repositories/foobar/images HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
Authorization: Basic akmklmasadalkm==
[{"id": "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f",
"checksum": "b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087"}]
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 204
Vary: Accept
Content-Type: application/json
""
	| Status Codes: | 
 | 
|---|
get the images for a library repo.
Example Request:
GET /v1/repositories/foobar/images HTTP/1.1
Host: index.docker.io
Accept: application/json
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 200
Vary: Accept
Content-Type: application/json
[{"id": "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f",
"checksum": "b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087"},
{"id": "ertwetewtwe38722009fe6857087b486531f9a779a0c1dfddgfgsdgdsgds",
"checksum": "34t23f23fc17e3ed29dae8f12c4f9e89cc6f0bsdfgfsdgdsgdsgerwgew"}]
	| Status Codes: | 
 | 
|---|
authorize a token for a library repo
Example Request:
PUT /v1/repositories/foobar/auth HTTP/1.1
Host: index.docker.io
Accept: application/json
Authorization: Token signature=123abc,repository="library/foobar",access=write
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 200
Vary: Accept
Content-Type: application/json
"OK"
	| Status Codes: | 
 | 
|---|
authorize a token for a user repo
Example Request:
PUT /v1/repositories/foo/bar/auth HTTP/1.1
Host: index.docker.io
Accept: application/json
Authorization: Token signature=123abc,repository="foo/bar",access=write
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 200
Vary: Accept
Content-Type: application/json
"OK"
	| Status Codes: | 
 | 
|---|
If you want to check your login, you can try this endpoint
Example Request:
GET /v1/users HTTP/1.1
Host: index.docker.io
Accept: application/json
Authorization: Basic akmklmasadalkm==
	Example Response:
HTTP/1.1 200 OK
Vary: Accept
Content-Type: application/json
OK
	| Status Codes: | 
 | 
|---|
Registering a new account.
Example request:
POST /v1/users HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
{"email": "sam@dotcloud.com",
 "password": "toto42",
 "username": "foobar"'}
	| Json Parameters: | |
|---|---|
| 
 | |
Example Response:
HTTP/1.1 201 OK
Vary: Accept
Content-Type: application/json
"User Created"
	| Status Codes: | 
 | 
|---|
Change a password or email address for given user. If you pass in an email, it will add it to your account, it will not remove the old one. Passwords will be updated.
It is up to the client to verify that that password that is sent is the one that they want. Common approach is to have them type it twice.
Example Request:
PUT /v1/users/fakeuser/ HTTP/1.1
Host: index.docker.io
Accept: application/json
Content-Type: application/json
Authorization: Basic akmklmasadalkm==
{"email": "sam@dotcloud.com",
 "password": "toto42"}
	| Parameters: | 
 | 
|---|
Example Response:
HTTP/1.1 204
Vary: Accept
Content-Type: application/json
""
	| Status Codes: | 
 | 
|---|
If you need to search the index, this is the endpoint you would use.
Search the Index given a search term. It accepts GET only.
Example request:
GET /v1/search?q=search_term HTTP/1.1
Host: example.com
Accept: application/json
	Example response:
HTTP/1.1 200 OK
Vary: Accept
Content-Type: application/json
{"query":"search_term",
  "num_results": 3,
  "results" : [
     {"name": "ubuntu", "description": "An ubuntu image..."},
     {"name": "centos", "description": "A centos image..."},
     {"name": "fedora", "description": "A fedora image..."}
   ]
 }
	| Query Parameters: | |
|---|---|
| 
 | |
| Status Codes: | 
 |