From 904c2a0fc353ba08e93decf169baa4ea35fe35a8 Mon Sep 17 00:00:00 2001 From: Ken Cochrane Date: Wed, 1 May 2013 12:31:46 -0400 Subject: [PATCH] added the registry API to the docker docs --- docs/sources/index.rst | 1 + docs/sources/registry/api.rst | 464 ++++++++++++++++++ docs/sources/registry/index.rst | 15 + .../static_files/docker_pull_chart.png | Bin 0 -> 24445 bytes .../static_files/docker_push_chart.png | Bin 0 -> 30219 bytes 5 files changed, 480 insertions(+) create mode 100644 docs/sources/registry/api.rst create mode 100644 docs/sources/registry/index.rst create mode 100644 docs/sources/static_files/docker_pull_chart.png create mode 100644 docs/sources/static_files/docker_push_chart.png diff --git a/docs/sources/index.rst b/docs/sources/index.rst index cc21a69bf5..4e724a0cd2 100644 --- a/docs/sources/index.rst +++ b/docs/sources/index.rst @@ -15,6 +15,7 @@ This documentation has the following resources: examples/index contributing/index commandline/index + registry/index faq diff --git a/docs/sources/registry/api.rst b/docs/sources/registry/api.rst new file mode 100644 index 0000000000..1cca9fb244 --- /dev/null +++ b/docs/sources/registry/api.rst @@ -0,0 +1,464 @@ +=================== +Docker Registry API +=================== + +.. contents:: Table of Contents + +1. The 3 roles +=============== + +1.1 Index +--------- + +The Index is responsible for centralizing information about: +- User accounts +- Checksums of the images +- Public namespaces + +The Index has different components: +- Web UI +- Meta-data store (comments, stars, list public repositories) +- Authentication service +- Tokenization + +The index is authoritative for those information. + +We expect that there will be only one instance of the index, run and managed by dotCloud. + +1.2 Registry +------------ +- It stores the images and the graph for a set of repositories +- It does not have user accounts data +- It has no notion of user accounts or authorization +- It delegates authentication and authorization to the Index Auth service using tokens +- It supports different storage backends (S3, cloud files, local FS) +- It doesn’t have a local database +- It will be open-sourced at some point + +We expect that there will be multiple registries out there. To help to grasp the context, here are some examples of registries: + +- **sponsor registry**: such a registry is provided by a third-party hosting infrastructure as a convenience for their customers and the docker community as a whole. Its costs are supported by the third party, but the management and operation of the registry are supported by dotCloud. It features read/write access, and delegates authentication and authorization to the Index. +- **mirror registry**: such a registry is provided by a third-party hosting infrastructure but is targeted at their customers only. Some mechanism (unspecified to date) ensures that public images are pulled from a sponsor registry to the mirror registry, to make sure that the customers of the third-party provider can “docker pull” those images locally. +- **vendor registry**: such a registry is provided by a software vendor, who wants to distribute docker images. It would be operated and managed by the vendor. Only users authorized by the vendor would be able to get write access. Some images would be public (accessible for anyone), others private (accessible only for authorized users). Authentication and authorization would be delegated to the Index. The goal of vendor registries is to let someone do “docker pull basho/riak1.3” and automatically push from the vendor registry (instead of a sponsor registry); i.e. get all the convenience of a sponsor registry, while retaining control on the asset distribution. +- **private registry**: such a registry is located behind a firewall, or protected by an additional security layer (HTTP authorization, SSL client-side certificates, IP address authorization...). The registry is operated by a private entity, outside of dotCloud’s control. It can optionally delegate additional authorization to the Index, but it is not mandatory. + +.. note:: + + Mirror registries and private registries which do not use the Index don’t even need to run the registry code. They can be implemented by any kind of transport implementing HTTP GET and PUT. Read-only registries can be powered by a simple static HTTP server. + +.. note:: + + The latter implies that while HTTP is the protocol of choice for a registry, multiple schemes are possible (and in some cases, trivial): + - HTTP with GET (and PUT for read-write registries); + - local mount point; + - remote docker addressed through SSH. + +The latter would only require two new commands in docker, e.g. “registryget” and “registryput”, wrapping access to the local filesystem (and optionally doing consistency checks). Authentication and authorization are then delegated to SSH (e.g. with public keys). + +1.3 Docker +---------- + +On top of being a runtime for LXC, Docker is the Registry client. It supports: +- Push / Pull on the registry +- Client authentication on the Index + +2. Workflow +=========== + +2.1 Pull +-------- + +.. image:: /static_files/docker_pull_chart.png + +1. Contact the Index to know where I should download “samalba/busybox” +2. Index replies: + a. “samalba/busybox” is on Registry A + b. here are the checksums for “samalba/busybox” (for all layers) + c. token +3. Contact Registry A to receive the layers for “samalba/busybox” (all of them to the base image). Registry A is authoritative for “samalba/busybox” but keeps a copy of all inherited layers and serve them all from the same location. +4. registry contacts index to verify if token/user is allowed to download images +5. Index returns true/false lettings registry know if it should proceed or error out +6. Get the payload for all layers + +It’s possible to run docker pull https:///repositories/samalba/busybox. In this case, docker bypasses the Index. However the security is not guaranteed (in case Registry A is corrupted) because there won’t be any checksum checks. + +Currently registry redirects to s3 urls for downloads, going forward all downloads need to be streamed through the registry. The Registry will then abstract the calls to S3 by a top-level class which implements sub-classes for S3 and local storage. + +Token is only returned when it is a private repo, public repos do not require tokens to be returned. The Registry will still contact the Index to make sure the pull is authorized (“is it ok to download this repos without a Token?”). + +API (pulling repository foo/bar): +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +1. (Docker -> Index) GET /v1/repositories/foo/bar/images + **Headers**: + Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ== + X-Docker-Token: true + **Action**: + (looking up the foo/bar in db and gets images and checksums for that repo (all if no tag is specified, if tag, only checksums for those tags) see part 4.4.1) + +2. (Index -> Docker) HTTP 200 OK + + **Headers**: + - Authorization: Token signature=123abc,repository=”foo/bar”,access=write + - X-Docker-Endpoints: registry.docker.io [, registry2.docker.io] + **Body**: + Jsonified checksums (see part 4.4.1) + +3. (Docker -> Registry) GET /v1/repositories/foo/bar/tags/latest + **Headers**: + Authorization: Token signature=123abc,repository=”foo/bar”,access=write + +4. (Registry -> Index) GET /v1/repositories/foo/bar/images + + **Headers**: + Authorization: Token signature=123abc,repository=”foo/bar”,access=read + + **Body**: + + + **Action**: + ( Lookup token see if they have access to pull.) + + If good: + HTTP 200 OK + Index will invalidate the token + If bad: + HTTP 401 Unauthorized + +5. (Docker -> Registry) GET /v1/images/928374982374/ancestry + **Action**: + (for each image id returned in the registry, fetch /json + /layer) + +.. note:: + + If someone makes a second request, then we will always give a new token, never reuse tokens. + +2.2 Push +-------- + +.. image:: /static_files/docker_push_chart.png + +1. Contact the index to allocate the repository name “samalba/busybox” (authentication required with user credentials) +2. If authentication works and namespace available, “samalba/busybox” is allocated and a temporary token is returned (namespace is marked as initialized in index) +3. Push the image on the registry (along with the token) +4. Registry A contacts the Index to verify the token (token must corresponds to the repository name) +5. Index validates the token. Registry A starts reading the stream pushed by docker and store the repository (with its images) +6. docker contacts the index to give checksums for upload images + +.. note:: + + **It’s possible not to use the Index at all!** In this case, a deployed version of the Registry is deployed to store and serve images. Those images are not authentified and the security is not guaranteed. + +.. note:: + + **Index can be replaced!** For a private Registry deployed, a custom Index can be used to serve and validate token according to different policies. + +Docker computes the checksums and submit them to the Index at the end of the push. When a repository name does not have checksums on the Index, it means that the push is in progress (since checksums are submitted at the end). + +API (pushing repos foo/bar): +^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +1. (Docker -> Index) PUT /v1/repositories/foo/bar/ + **Headers**: + Authorization: Basic sdkjfskdjfhsdkjfh== + X-Docker-Token: true + + **Action**:: + - in index, we allocated a new repository, and set to initialized + + **Body**:: + (The body contains the list of images that are going to be pushed, with empty checksums. The checksums will be set at the end of the push):: + + [{“id”: “9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f”}] + +2. (Index -> Docker) 200 Created + **Headers**: + - WWW-Authenticate: Token signature=123abc,repository=”foo/bar”,access=write + - X-Docker-Endpoints: registry.docker.io [, registry2.docker.io] + +3. (Docker -> Registry) PUT /v1/images/98765432_parent/json + **Headers**: + Authorization: Token signature=123abc,repository=”foo/bar”,access=write + +4. (Registry->Index) GET /v1/repositories/foo/bar/images + **Headers**: + Authorization: Token signature=123abc,repository=”foo/bar”,access=write + **Action**:: + - Index: + will invalidate the token. + - Registry: + grants a session (if token is approved) and fetches the images id + +5. (Docker -> Registry) PUT /v1/images/98765432_parent/json + **Headers**:: + - Authorization: Token signature=123abc,repository=”foo/bar”,access=write + - Cookie: (Cookie provided by the Registry) + +6. (Docker -> Registry) PUT /v1/images/98765432/json + **Headers**: + Cookie: (Cookie provided by the Registry) + +7. (Docker -> Registry) PUT /v1/images/98765432_parent/layer + **Headers**: + Cookie: (Cookie provided by the Registry) + +8. (Docker -> Registry) PUT /v1/images/98765432/layer + **Headers**: + X-Docker-Checksum: sha256:436745873465fdjkhdfjkgh + +9. (Docker -> Registry) PUT /v1/repositories/foo/bar/tags/latest + **Headers**: + Cookie: (Cookie provided by the Registry) + **Body**: + “98765432” + +10. (Docker -> Index) PUT /v1/repositories/foo/bar/images + + **Headers**: + Authorization: Basic 123oislifjsldfj== + X-Docker-Endpoints: registry1.docker.io (no validation on this right now) + + **Body**: + (The image, id’s, tags and checksums) + + [{“id”: “9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f”, + “checksum”: “b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087”}] + + **Return** HTTP 204 + +.. note:: + + If push fails and they need to start again, what happens in the index, there will already be a record for the namespace/name, but it will be initialized. Should we allow it, or mark as name already used? One edge case could be if someone pushes the same thing at the same time with two different shells. + + If it's a retry on the Registry, Docker has a cookie (provided by the registry after token validation). So the Index won’t have to provide a new token. + +3. How to use the Registry in standalone mode +============================================= + +The Index has two main purposes (along with its fancy social features): + +- Resolve short names (to avoid passing absolute URLs all the time) + - username/projectname -> https://registry.docker.io/users//repositories// + - team/projectname -> https://registry.docker.io/team//repositories// +- Authenticate a user as a repos owner (for a central referenced repository) + +3.1 Without an Index +-------------------- +Using the Registry without the Index can be useful to store the images on a private network without having to rely on an external entity controlled by dotCloud. + +In this case, the registry will be launched in a special mode (--standalone? --no-index?). In this mode, the only thing which changes is that Registry will never contact the Index to verify a token. It will be the Registry owner responsibility to authenticate the user who pushes (or even pulls) an image using any mechanism (HTTP auth, IP based, etc...). + +In this scenario, the Registry is responsible for the security in case of data corruption since the checksums are not delivered by a trusted entity. + +As hinted previously, a standalone registry can also be implemented by any HTTP server handling GET/PUT requests (or even only GET requests if no write access is necessary). + +3.2 With an Index +----------------- + +The Index data needed by the Registry are simple: +- Serve the checksums +- Provide and authorize a Token + +In the scenario of a Registry running on a private network with the need of centralizing and authorizing, it’s easy to use a custom Index. + +The only challenge will be to tell Docker to contact (and trust) this custom Index. Docker will be configurable at some point to use a specific Index, it’ll be the private entity responsibility (basically the organization who uses Docker in a private environment) to maintain the Index and the Docker’s configuration among its consumers. + +4. The API +========== + +The first version of the api is available here: https://github.com/jpetazzo/docker/blob/acd51ecea8f5d3c02b00a08176171c59442df8b3/docs/images-repositories-push-pull.md + +4.1 Images +---------- + +The format returned in the images is not defined here (for layer and json), basically because Registry stores exactly the same kind of information as Docker uses to manage them. + +The format of ancestry is a line-separated list of image ids, in age order. I.e. the image’s parent is on the last line, the parent of the parent on the next-to-last line, etc.; if the image has no parent, the file is empty. + +GET /v1/images//layer +PUT /v1/images//layer +GET /v1/images//json +PUT /v1/images//json +GET /v1/images//ancestry +PUT /v1/images//ancestry + +4.2 Users +--------- + +4.2.1 Create a user (Index) +^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +POST /v1/users + +**Body**: + {"email": "sam@dotcloud.com", "password": "toto42", "username": "foobar"'} + +**Validation**: + - **username** : min 4 character, max 30 characters, all lowercase no special characters. + - **password**: min 5 characters + +**Valid**: return HTTP 200 + +Errors: HTTP 400 (we should create error codes for possible errors) +- invalid json +- missing field +- wrong format (username, password, email, etc) +- forbidden name +- name already exists + +.. note:: + + A user account will be valid only if the email has been validated (a validation link is sent to the email address). + +4.2.2 Update a user (Index) +^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +PUT /v1/users/ + +**Body**: + {"password": "toto"} + +.. note:: + + We can also update email address, if they do, they will need to reverify their new email address. + +4.2.3 Login (Index) +^^^^^^^^^^^^^^^^^^^ +Does nothing else but asking for a user authentication. Can be used to validate credentials. HTTP Basic Auth for now, maybe change in future. + +GET /v1/users + +**Return**: + - Valid: HTTP 200 + - Invalid login: HTTP 401 + - Account inactive: HTTP 403 Account is not Active + +4.3 Tags (Registry) +------------------- + +The Registry does not know anything about users. Even though repositories are under usernames, it’s just a namespace for the registry. Allowing us to implement organizations or different namespaces per user later, without modifying the Registry’s API. + +4.3.1 Get all tags +^^^^^^^^^^^^^^^^^^ + +GET /v1/repositories///tags + +**Return**: HTTP 200 + { + "latest": "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f", + “0.1.1”: “b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087” + } + +4.3.2 Read the content of a tag (resolve the image id) +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +GET /v1/repositories///tags/ + +**Return**: + "9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f" + +4.3.3 Delete a tag (registry) +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +DELETE /v1/repositories///tags/ + +4.4 Images (Index) +------------------ + +For the Index to “resolve” the repository name to a Registry location, it uses the X-Docker-Endpoints header. In other terms, this requests always add a “X-Docker-Endpoints” to indicate the location of the registry which hosts this repository. + +4.4.1 Get the images +^^^^^^^^^^^^^^^^^^^^^ + +GET /v1/repositories///images + +**Return**: HTTP 200 + [{“id”: “9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f”, “checksum”: “md5:b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087”}] + + +4.4.2 Add/update the images +^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +You always add images, you never remove them. + +PUT /v1/repositories///images + +**Body**: + [ {“id”: “9e89cc6f0bc3c38722009fe6857087b486531f9a779a0c17e3ed29dae8f12c4f”, “checksum”: “sha256:b486531f9a779a0c17e3ed29dae8f12c4f9e89cc6f0bc3c38722009fe6857087”} ] + +**Return** 204 + +5. Chaining Registries +====================== + +It’s possible to chain Registries server for several reasons: +- Load balancing +- Delegate the next request to another server + +When a Registry is a reference for a repository, it should host the entire images chain in order to avoid breaking the chain during the download. + +The Index and Registry use this mechanism to redirect on one or the other. + +Example with an image download: +On every request, a special header can be returned: + +X-Docker-Endpoints: server1,server2 + +On the next request, the client will always pick a server from this list. + +6. Authentication & Authorization +================================= + +6.1 On the Index +----------------- + +The Index supports both “Basic” and “Token” challenges. Usually when there is a “401 Unauthorized”, the Index replies this:: + + 401 Unauthorized + WWW-Authenticate: Basic realm="auth required",Token + +You have 3 options: + +1. Provide user credentials and ask for a token + + **Header**: + - Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ== + - X-Docker-Token: true + + In this case, along with the 200 response, you’ll get a new token (if user auth is ok): + + **Response**: + - 200 OK + - X-Docker-Token: Token signature=123abc,repository=”foo/bar”,access=read + +2. Provide user credentials only + + **Header**: + Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ== + +3. Provide Token + + **Header**: + Authorization: Token signature=123abc,repository=”foo/bar”,access=read + +6.2 On the Registry +------------------- + +The Registry only supports the Token challenge:: + + 401 Unauthorized + WWW-Authenticate: Token + +The only way is to provide a token on “401 Unauthorized” responses:: + + Authorization: Token signature=123abc,repository=”foo/bar”,access=read + +Usually, the Registry provides a Cookie when a Token verification succeeded. Every time the Registry passes a Cookie, you have to pass it back the same cookie.:: + + 200 OK + Set-Cookie: session="wD/J7LqL5ctqw8haL10vgfhrb2Q=?foo=UydiYXInCnAxCi4=×tamp=RjEzNjYzMTQ5NDcuNDc0NjQzCi4="; Path=/; HttpOnly + +Next request:: + + GET /(...) + Cookie: session="wD/J7LqL5ctqw8haL10vgfhrb2Q=?foo=UydiYXInCnAxCi4=×tamp=RjEzNjYzMTQ5NDcuNDc0NjQzCi4=" diff --git a/docs/sources/registry/index.rst b/docs/sources/registry/index.rst new file mode 100644 index 0000000000..d3788f53cc --- /dev/null +++ b/docs/sources/registry/index.rst @@ -0,0 +1,15 @@ +:title: docker Registry documentation +:description: Documentation for docker Registry and Registry API +:keywords: docker, registry, api, index + + + +Registry +======== + +Contents: + +.. toctree:: + :maxdepth: 2 + + api diff --git a/docs/sources/static_files/docker_pull_chart.png b/docs/sources/static_files/docker_pull_chart.png new file mode 100644 index 0000000000000000000000000000000000000000..73a145239c46c7eced1c7919258cddcc7ebdd443 GIT binary patch literal 24445 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 literal 0 HcmV?d00001 diff --git a/docs/sources/static_files/docker_push_chart.png b/docs/sources/static_files/docker_push_chart.png new file mode 100644 index 0000000000000000000000000000000000000000..6486355e914b842c3ce1a04d1924b081a301244b GIT binary patch literal 30219 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 rkf8rt>W}uZK&FE>|sM8TNkwiM(eX literal 0 HcmV?d00001