title | description | keywords |
---|---|---|
HTTP API V2 |
Specification for the Registry API. |
registry, on-prem, images, tags, repository, distribution, api, advanced |
This specification defines an API protocol to facilitate distribution of images.
The goal of this specification is to standardize container image distribution based on the specification for the Docker Registry HTTP API V2 protocol.
- Introduction
- Notational Conventions
- Historical Context
- Scope
- Use Cases
- Changes
- Overview
- Detail
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" are to be interpreted as described in RFC 2119 (Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, March 1997).
The key words "unspecified", "undefined", and "implementation-defined" are to be interpreted as described in the [rationale for the C99 standard][c99-unspecified].
An implementation is not compliant if it fails to satisfy one or more of the MUST, MUST NOT, REQUIRED, SHALL, or SHALL NOT requirements for the protocols it implements. An implementation is compliant if it satisfies all the MUST, MUST NOT, REQUIRED, SHALL, and SHALL NOT requirements for the protocols it implements.
For relevant details and a history leading up to this specification, please see the following issues:
This specification covers URL layout and protocols for interaction between a registry and registry client. Registry implementations MAY implement other API endpoints, but they are not covered by this specification.
This specification includes the following features:
- Namespace-oriented URI Layout
- PUSH/PULL registry server for V2 image manifest format
- Resumable layer PUSH support
- V2 Client (Consumer) requirements
The following is an incomplete list of features, discussed during the process of cutting this specification, which MAY be out of the scope of this specification, MAY be the purview of another specification, or MAY be deferred to a future version:
- Authentication and authorization support: While authentication and authorization support will influence this specification, those details MAY be left to a future specification. However, relevant header definitions and error codes are present to provide an indication of what a client MAY encounter.
- Immutable image references
- Multiple architecture support
- Migration from v2compatibility representation
A container engine would like to run verified image named "library/ubuntu", with the tag "latest". The engine contacts the registry, requesting the manifest for "library/ubuntu:latest". An untrusted registry returns a manifest. Before proceeding to download the individual layers, the engine verifies the manifest's signature, ensuring that the content was produced from a trusted source and no tampering has occurred. After each layer is downloaded, the engine verifies the digest of the layer, ensuring that the content matches that specified by the manifest.
Company X's build servers lose connectivity to a distribution endpoint before completing an image layer transfer. After connectivity returns, the build server attempts to re-upload the image. The registry notifies the build server that the upload has already been partially attempted. The build server responds by only sending the remaining data to complete the image file.
Company X is having more connectivity problems but this time in their deployment datacenter.
When downloading an image, the connection is interrupted before completion.
The client keeps the partial data and uses http Range
requests to avoid downloading repeated data.
Company Y's build system creates two identical layers from build processes A and B. Build process A completes uploading the layer before B. When process B attempts to upload the layer, the registry indicates that its not necessary because the layer is already known.
If process A and B upload the same layer at the same time, both operations will proceed and the first to complete will be stored in the registry (Note: we MAY modify this to prevent dogpile with some locking mechanism).
The V2 specification has been written to work as a living document, specifying only what is certain and leaving what is not specified open or to future changes. Only non-conflicting additions SHOULD be made to the API and accepted changes SHOULD avoid preventing future changes from happening.
The changes.md doc SHOULD be updated when changes are made to the specification, indicating what is different. Optionally, we MAY start marking parts of the specification to correspond with the versions enumerated here.
This section covers client flows and details of the API endpoints. The URI layout of the new API is structured to support a rich authentication and authorization model by leveraging namespaces. All endpoints will be prefixed by the API version and the repository name:
/v2/<name>/
For example, an API endpoint that will work with the library/ubuntu
repository, the URI prefix will be:
/v2/library/ubuntu/
This scheme provides rich access control over various operations and methods using the URI prefix and http methods that can be controlled in variety of ways.
Classically, repository names have always been two path components where each path component is less than 30 characters. The V2 registry API does not enforce this. The rules for a repository name are as follows:
- A repository name is broken up into path components.
A component of a repository name MUST begin with one or more lowercase alpha-numeric characters. Subsequent lowercase alpha-numeric characters are OPTIONAL and MAY be separated by periods, dashes or underscores.
More strictly, it MUST match the regular expression
[a-z0-9]+(?:[._-][a-z0-9]+)*
. - If a repository name has two or more path components, they MUST be separated by a forward slash ("/").
- The total length of a repository name, including slashes, MUST be less than 256 characters.
These name requirements only apply to the registry API and SHOULD accept a superset of what is supported by other components.
All endpoints SHOULD support aggressive http caching, compression and range headers, where appropriate. The new API attempts to leverage HTTP semantics where possible but MAY break from standards to implement targeted features.
For detail on individual endpoints, please see the Detail section.
Actionable failure conditions, covered in detail in their relevant sections, are reported as part of 4xx responses, in a json response body. One or more errors will be returned in the following format:
{
"errors": [
{
"code": "<error identifier>",
"message": "<message describing condition>",
"detail": "<unstructured>"
},
...
]
}
The code
field will be a unique identifier, all caps with underscores by convention.
The message
field will be a human readable string.
The OPTIONAL detail
field MAY contain arbitrary json data providing information the client can use to resolve the issue.
While the client can take action on certain error codes, the registry MAY add new error codes over time.
All client implementations SHOULD treat unknown error codes as UNKNOWN
, allowing future error codes to be added without breaking API compatibility.
For the purposes of the specification error codes will only be added and never removed.
For a complete account of all error codes, please see the Errors section.
A minimal endpoint, mounted at /v2/
will provide version support information based on its response statuses.
The request format is as follows:
GET /v2/
If a 200 OK
response is returned, the registry implements the V2(.1) registry API and the client MAY proceed safely with other V2 operations.
Optionally, the response MAY contain information about the supported paths in the response body.
The client SHOULD be prepared to ignore this data.
If a 401 Unauthorized
response is returned, the client SHOULD take action based on the contents of the "WWW-Authenticate" header and try the endpoint again.
Depending on access control setup, the client MAY still have to authenticate against different resources, even if this check succeeds.
If 404 Not Found
response status, or other unexpected status, is returned, the client SHOULD proceed with the assumption that the registry does not implement V2 of the API.
When a 200 OK
or 401 Unauthorized
response is returned, the "Docker-Distribution-API-Version" header SHOULD be set to "registry/2.0".
Clients MAY require this header value to determine if the endpoint serves this API.
When this header is omitted, clients MAY fallback to an older API version.
This API design is driven heavily by content addressability. The core of this design is the concept of a content addressable identifier. It uniquely identifies content by taking a collision-resistant hash of the bytes.
Such an identifier can be independently calculated and verified by selection of a common algorithm. If such an identifier can be communicated in a secure manner, one can retrieve the content from an insecure source, calculate it independently and be certain that the correct content was obtained. Put simply, the identifier is a property of the content.
To disambiguate from other concepts, we call this identifier a digest. A digest is a serialized hash result, consisting of a algorithm and hex portion. The algorithm identifies the methodology used to calculate the digest. The hex portion is the hex-encoded result of the hash.
We define a digest string to match the following grammar:
digest := algorithm ":" hex
algorithm := /[A-Za-z0-9_+.-]+/
hex := /[A-Fa-f0-9]+/
Some examples of digests include the following:
digest | description |
---|---|
sha256:6c3c624b58dbbcd3c0dd82b4c53f04194d1247c6eebdaab7c610cf7d66709b3b |
Common sha256 based digest format |
Compliant implementations SHOULD use algorithm of sha256. The algorithm does allow one to implement a wide variety of algorithms, though for portability sake it is best to keep this consistent because a translation of hashing algorithm used would produce a new object and new documents that reference it. Heavy processing of input before calculating a hash is discouraged to avoid degrading the uniqueness of the digest but some canonicalization MAY be performed to ensure consistent identifiers.
Let's use a simple example in pseudo-code to demonstrate a digest calculation:
let C = 'a small string'
let B = sha256(C)
let D = 'sha256:' + EncodeHex(B)
let ID(C) = D
Above, we have bytestring C
passed into a function, SHA256
, that returns a bytestring B
, which is the hash of C
.
D
gets the algorithm concatenated with the hex encoding of B
.
We then define the identifier of C
to ID(C)
as equal to D
.
A digest can be verified by independently calculating D
and comparing it with identifier ID(C)
.
To provide verification of http content, any response MAY include a Docker-Content-Digest
header.
This will include the digest of the target entity returned in the response.
For blobs, this is the entire blob content.
For manifests, this is the manifest body without the signature content, also known as the JWS payload.
Note that the commonly used canonicalization for digest calculation MAY be dependent on the mediatype of the content, such as with manifests.
The client MAY choose to ignore the header or MAY verify it to ensure content integrity and transport security. This is most important when fetching by a digest. To ensure security, the content SHOULD be verified against the digest used to fetch the content. At times, the returned digest MAY differ from that used to initiate a request. Such digests are considered to be from different domains, meaning they have different values for algorithm. In such a case, the client MAY choose to verify the digests in both domains or ignore the server's digest. To maintain security, the client MUST always verify the content against the digest used to fetch the content.
IMPORTANT: If a digest is used to fetch content, the client SHOULD use the same digest used to fetch the content to verify it. The header
Docker-Content-Digest
SHOULD NOT be trusted over the "local" digest.
An "image" is a combination of a JSON manifest and individual layer files. The process of pulling an image centers around retrieving these two components.
The first step in pulling an image is to retrieve the manifest. For details on manifest formats and their content types, refer to the OCI Image Specification's manifest property description.
When the manifest is in hand, the client MUST verify the signature to ensure the names and layers are valid. Once confirmed, the client will then use the digests to download the individual layers. Layers are stored in as blobs in the V2 registry API, keyed by their digest.
The image manifest can be fetched with the following url:
GET /v2/<name>/manifests/<reference>
The name
and reference
parameter identify the image and are REQUIRED.
The reference MAY include a tag or digest.
The client SHOULD include an Accept header indicating which manifest content types it supports. In a successful response, the Content-Type header will indicate which manifest type is being returned.
A 404 Not Found
response will be returned if the image is unknown to the registry.
If the image exists and the response is successful, the image manifest will be returned:
{
"annotations": {
"com.example.key1": "value1",
"com.example.key2": "value2"
},
"config": {
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.config.v1+json",
"size": 452
},
"layers": [
{
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.layer.v1.tar+gzip",
"size": 78343
}
],
"schemaVersion": 2
}
The client SHOULD verify the returned manifest signature for authenticity before fetching layers.
The image manifest can be checked for existence with the following url:
HEAD /v2/<name>/manifests/<reference>
The name
and reference
parameter identify the image and are REQUIRED.
The reference MAY include a tag or digest.
A 404 Not Found
response will be returned if the image is unknown to the registry.
If the image exists and the response is successful the response will be as follows:
200 OK
Content-Length: <length of manifest>
Docker-Content-Digest: <digest>
Layers are stored in the blob portion of the registry, keyed by digest. Pulling a layer is carried out by a standard http request. The URL is as follows:
GET /v2/<name>/blobs/<digest>
Access to a layer will be gated by the name
of the repository but is identified uniquely in the registry by digest
.
This endpoint MAY issue a 307 (302 for < HTTP 1.1) redirect to another service for downloading the layer and clients SHOULD be prepared to handle redirects.
This endpoint SHOULD support aggressive HTTP caching for image layers.
Support for Etags, modification dates and other cache control headers SHOULD be included.
To allow for incremental downloads, Range
requests SHOULD be supported, as well.
Pushing an image works in the opposite order as a pull. After assembling the image manifest, the client MUST first push the individual layers. When the layers are fully pushed into the registry, the client SHOULD upload the signed manifest.
The details of each step of the process are covered in the following sections.
All layer uploads use two steps to manage the upload process. The first step starts the upload in the registry service, returning a url to carry out the second step. The second step uses the upload url to transfer the actual data. Uploads are started with a POST request which returns a url that can be used to push data and check upload status.
The Location
header will be used to communicate the upload location after each request.
While it won't change in the this specification, clients SHOULD use the most recent value returned by the API.
Location
header value returned MUST either be absolute or relative as described in
RFC 7231.
To begin the process, a POST request SHOULD be issued in the following format:
POST /v2/<name>/blobs/uploads/
The parameters of this request are the image namespace under which the layer will be linked. Responses to this request are covered below.
The existence of a layer can be checked via a HEAD
request to the blob store API.
The request SHOULD be formatted as follows:
HEAD /v2/<name>/blobs/<digest>
If the layer with the digest specified in digest
is available, a 200 OK response will be received, with no actual body content (this is according to http specification).
The response will look as follows:
200 OK
Content-Length: <length of blob>
Docker-Content-Digest: <digest>
When this response is received, the client can assume that the layer is already available in the registry under the given name and SHOULD take no further action to upload the layer. Note that the binary digests MAY differ for the existing registry layer, but the digests will be guaranteed to match.
If the POST request is successful, a 202 Accepted
response will be returned with the upload URL in the Location
header:
202 Accepted
Location: /v2/<name>/blobs/uploads/<session_id>
Range: bytes=0-<offset>
Content-Length: 0
The rest of the upload process can be carried out with the returned url, called the "Upload URL" from the Location
header.
All responses to the upload url, whether sending data or getting status, will be in this format.
Though the URI format (/v2/<name>/blobs/uploads/<session_id>
) for the Location
header is specified, clients SHOULD treat it as an opaque url and SHOULD never try to assemble it.
While the session_id
parameter MAY be an actual UUID, this proposal imposes no constraints on the format and clients SHOULD never impose any.
Header Blob-Upload-Session-ID
OPTIONAL: If clients need to correlate local upload state with remote upload state, largely for resumable uploads.
Header Docker-Upload-UUID
OPTIONAL: legacy compatibility. Not contstrained to being an official UUID.
The progress and chunk coordination of the upload process will be coordinated through the Range
header.
While this is a non-standard use of the Range
header, there are examples of similar approaches in APIs with heavy use.
For an upload that just started, for an example with a 1000 byte layer file, the Range
header would be as follows:
Range: bytes=0-0
To get the status of an upload, issue a GET request to the upload URL:
GET /v2/<name>/blobs/uploads/<session_id>
Host: <registry host>
The response will be similar to the above, except will return 204 status:
204 No Content
Location: /v2/<name>/blobs/uploads/<session_id>
Range: bytes=0-<offset>
Note that the HTTP Range
header byte ranges are inclusive and that will be honored, even in non-standard use cases.
A monolithic upload is simply a chunked upload with a single chunk and MAY be favored by clients that would like to avoided the complexity of chunking. To carry out a "monolithic" upload, one can simply put the entire content blob to the provided URL:
PUT /v2/<name>/blobs/uploads/<session_id>?digest=<digest>
Content-Length: <size of layer>
Content-Type: application/octet-stream
<Layer Binary Data>
The "digest" parameter MUST be included with the PUT request. Please see the Completed Upload section for details on the parameters and expected responses.
To carry out an upload of a chunk, the client can specify a range header and only include that part of the layer file:
PATCH /v2/<name>/blobs/uploads/<session_id>
Content-Length: <size of chunk>
Content-Range: <start of range>-<end of range>
Content-Type: application/octet-stream
<Layer Chunk Binary Data>
There is no enforcement on layer chunk splits other than that the server MUST receive them in order.
The server MAY enforce a minimum chunk size.
If the server cannot accept the chunk, a 416 Requested Range Not Satisfiable
response will be returned and will include a Range
header indicating the current status:
416 Requested Range Not Satisfiable
Location: /v2/<name>/blobs/uploads/<session_id>
Range: 0-<last valid range>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
If this response is received, the client SHOULD resume from the "last valid range" and upload the subsequent chunk. A 416 will be returned under the following conditions:
- Invalid Content-Range header format
- Out of order chunk: the range of the next chunk MUST start immediately after the "last valid range" from the previous response.
When a chunk is accepted as part of the upload, a 202 Accepted
response will be returned, including a Range
header with the current upload status:
202 Accepted
Location: /v2/<name>/blobs/uploads/<session_id>
Range: bytes=0-<offset>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
For an upload to be considered complete, the client MUST submit a PUT
request on the upload endpoint with a digest parameter.
If it is not provided, the upload will not be considered complete.
The format for the final chunk will be as follows:
PUT /v2/<name>/blobs/uploads/<session_id>?digest=<digest>
Content-Length: <size of chunk>
Content-Range: <start of range>-<end of range>
Content-Type: application/octet-stream
<Last Layer Chunk Binary Data>
Optionally, if all chunks have already been uploaded, a PUT
request with a digest
parameter and zero-length body MAY be sent to complete and validate the upload.
Multiple "digest" parameters MAY be provided with different digests.
The server MAY verify none or all of them but MUST notify the client if the content is rejected.
When the last chunk is received and the layer has been validated, the client will receive a 201 Created
response:
201 Created
Location: /v2/<name>/blobs/<digest>
Content-Length: 0
Docker-Content-Digest: <digest>
The Location
header will contain the registry URL to access the accepted layer file.
The Docker-Content-Digest
header returns the canonical digest of the uploaded blob which MAY differ from the provided digest.
Most clients MAY ignore the value but if it is used, the client SHOULD verify the value against the uploaded blob data.
The "digest" parameter is designed as an opaque parameter to support verification of a successful transfer. For example, an HTTP URI parameter might be as follows:
sha256:6c3c624b58dbbcd3c0dd82b4c53f04194d1247c6eebdaab7c610cf7d66709b3b
Given this parameter, the registry will verify that the provided content does match this digest.
An upload can be cancelled by issuing a DELETE request to the upload endpoint. The format will be as follows:
DELETE /v2/<name>/blobs/uploads/<session_id>
After this request is issued, the upload session_id
will no longer be valid and the registry server will dump all intermediate data.
While uploads will time out if not completed, clients SHOULD issue this request if they encounter a fatal error but still have the ability to issue an http request.
A blob MAY be mounted from another repository that the client has read access to, removing the need to upload a blob already known to the registry. To issue a blob mount instead of an upload, a POST request SHOULD be issued in the following format:
POST /v2/<name>/blobs/uploads/?mount=<digest>&from=<repository name>
Content-Length: 0
If the blob is successfully mounted, the client will receive a 201 Created
response:
201 Created
Location: /v2/<name>/blobs/<digest>
Content-Length: 0
Docker-Content-Digest: <digest>
The Location
header will contain the registry URL to access the accepted layer file.
The Docker-Content-Digest
header returns the canonical digest of the uploaded blob which MAY differ from the provided digest.
Most clients MAY ignore the value but if it is used, the client SHOULD verify the value against the uploaded blob data.
If a mount fails due to invalid repository or digest arguments, the registry will fall back to the standard upload behavior and return a 202 Accepted
with the upload URL in the Location
header:
202 Accepted
Location: /v2/<name>/blobs/uploads/<session_id>
Range: bytes=0-<offset>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
This behavior is consistent with older versions of the registry, which do not recognize the repository mount query parameters.
Note: a client MAY issue a HEAD request to check existence of a blob in a source repository to distinguish between the registry not supporting blob mounts and the blob not existing in the expected repository.
If an 502, 503 or 504 error is received, the client SHOULD assume that the download can proceed due to a temporary condition, honoring the appropriate retry mechanism. Other 5xx errors SHOULD be treated as terminal.
If there is a problem with the upload, a 4xx error will be returned indicating the problem. After receiving a 4xx response (except 416, as called out above), the upload will be considered failed and the client SHOULD take appropriate action.
Note that the upload url will not be available forever.
If the upload session_id
is unknown to the registry, a 404 Not Found
response will be returned and the client MUST restart the upload process.
A layer MAY be deleted from the registry via its name
and digest
.
A delete MAY be issued with the following request format:
DELETE /v2/<name>/blobs/<digest>
If the blob exists and has been successfully deleted, the following response will be issued:
202 Accepted
Content-Length: None
If the blob had already been deleted or did not exist, a 404 Not Found
response will be issued instead.
If a layer is deleted which is referenced by a manifest in the registry, then the complete images will not be resolvable.
Once all of the layers for an image are uploaded, the client can upload the image manifest. An image can be pushed using the following request format:
PUT /v2/<name>/manifests/<reference>
Content-Type: <manifest media type>
{
"annotations": {
"com.example.key1": "value1",
"com.example.key2": "value2"
},
"config": {
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.config.v1+json",
"size": 452
},
"layers": [
{
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.layer.v1.tar+gzip",
"size": 78343
}
],
"schemaVersion": 2
}
The name
and reference
fields of the response body MUST match those specified in the URL.
The reference
field MAY be a "tag" or a "digest".
The content type SHOULD match the type of the manifest being uploaded, as specified in manifest-v2-1.md and manifest-v2-2.md.
If there is a problem with pushing the manifest, a relevant 4xx response will be returned with a JSON error message. Please see the PUT Manifest section for details on possible error codes that MAY be returned.
If one or more layers are unknown to the registry, BLOB_UNKNOWN
errors are returned.
The detail
field of the error response will have a digest
field identifying the missing blob.
An error is returned for each unknown blob.
The response format is as follows:
{
"errors": [
{
"code": "BLOB_UNKNOWN",
"message": "blob unknown to registry",
"detail": {
"digest": "<digest>"
}
},
...
]
}
Repository listing is reserved for a future version of the distribution spec.
The _catalog
api is reserved for historical usage. Registries MAY implement _catalog
, but are NOT required.
It MAY be necessary to list all of the tags under a given repository. The tags for an image repository can be retrieved with the following request:
GET /v2/<name>/tags/list
The response will be in the following format:
200 OK
Content-Type: application/json
{
"name": "<name>",
"tags": [
"<tag>",
...
]
}
For repositories with a large number of tags, this response MAY be quite large. If such a response is expected, one SHOULD use the pagination.
Paginated tag results can be retrieved by adding an n
parameter to the request URL, declaring that the response SHOULD be limited to n
results. Starting a paginated flow MAY begin as follows:
GET /v2/<name>/tags/list?n=<integer>
The above specifies that a tags response SHOULD be returned, from the start of the result set, ordered lexically, limiting the number of results to n
. The response to such a request would look as follows:
200 OK
Content-Type: application/json
Link: <<url>?n=<n from the request>&last=<last tag value from previous response>>; rel="next"
{
"name": "<name>",
"tags": [
"<tag>",
...
]
}
To get the next n
entries, one can create a URL where the argument last
has the value from tags[len(tags)-1]
.
If there are indeed more results, the URL for the next block is encoded in an RFC5988 Link
header, as a "next" relation.
The presence of the Link
header communicates to the client that the entire result set has not been returned and another request MAY be issued.
If the header is not present, the client can assume that all results have been received.
NOTE: In the request template above, note that the brackets are required. For example, if the url is
http://example.com/v2/hello-world/tags/list?n=20&last=b
, the value of the header would be<http://example.com/v2/hello-world/tags/list?n=20&last=b>; rel="next"
. Please see RFC5988 for details.
Compliant client implementations SHOULD always use the Link
header value when proceeding through results linearly. The client MAY construct URLs to skip forward in the list of tags.
To get the next result set, a client would issue the request as follows, using the URL encoded in the described Link
header:
GET /v2/<name>/tags/list?n=<n from the request>&last=<last tag value from previous response>
The above process should then be repeated until the Link
header is no longer set in the response.
The tag list result set is represented abstractly as a lexically sorted list, where the position in that list can be specified by the query term last
. The entries in the response start after the term specified by last
, up to n
entries.
The behavior of last
is quite simple when demonstrated with an example. Let us say a repository has the following tags:
v1
v2
v3
v4
If the value of n
is 2, v1 and v2 will be returned on the first response.
The Link
header returned on the response will have n
set to 2 and last set
to v2:
Link: <<url>?n=2&last=v2>; rel="next"
The client can then issue the request with the above value from the Link
header, receiving the values v3 and v4. Note that n
may change on the second
to last response or be fully omitted, depending on the server implementation.
An image MAY be deleted from the registry via its name
and reference
.
A delete MAY be issued with the following request format:
DELETE /v2/<name>/manifests/<reference>
For deletes, reference
MUST be a digest or the delete will fail.
If the image exists and has been successfully deleted, the following response will be issued:
202 Accepted
Content-Length: None
If the image had already been deleted or did not exist, a 404 Not Found
response will be issued instead.
Note: When deleting a manifest from a registry version 2.3 or later, the following header MUST be used when
HEAD
orGET
-ing the manifest to obtain the correct digest to delete:
Accept: application/vnd.docker.distribution.manifest.v2+json
for more details, see: compatibility.md
Note: This section is still under construction. For the purposes of implementation, if any details below differ from the described request flows above, the section below SHOULD be corrected. When they match, this note SHOULD be removed.
The behavior of the endpoints are covered in detail in this section, organized by route and entity. All aspects of the request and responses are covered, including headers, parameters and body formats. Examples of requests and their corresponding responses, with success and failure, are enumerated.
Note: The sections on endpoint detail are arranged with an example request, a description of the request, followed by information about that request.
A list of methods and URIs are covered in the table below:
Method | Path | Entity | Description |
---|---|---|---|
GET | /v2/ |
Base | Check that the endpoint implements distribution API. |
GET | /v2/<name>/tags/list |
Tags | Fetch the tags under the repository identified by name . |
GET | /v2/<name>/manifests/<reference> |
Manifest | Fetch the manifest identified by name and reference where reference can be a tag or digest. A HEAD request can also be issued to this endpoint to obtain resource information without receiving all data. |
PUT | /v2/<name>/manifests/<reference> |
Manifest | Put the manifest identified by name and reference where reference can be a tag or digest. |
DELETE | /v2/<name>/manifests/<reference> |
Manifest | Delete the manifest identified by name and reference . Note that a manifest can only be deleted by digest . |
GET | /v2/<name>/blobs/<digest> |
Blob | Retrieve the blob from the registry identified by digest . A HEAD request can also be issued to this endpoint to obtain resource information without receiving all data. |
DELETE | /v2/<name>/blobs/<digest> |
Blob | Delete the blob identified by name and digest |
POST | /v2/<name>/blobs/uploads/ |
Initiate Blob Upload | Initiate a resumable blob upload. If successful, an upload location will be provided to complete the upload. Optionally, if the digest parameter is present, the request body will be used to complete the upload in a single request. |
GET | /v2/<name>/blobs/uploads/<session_id> |
Blob Upload | Retrieve status of upload identified by session_id . The primary purpose of this endpoint is to resolve the current status of a resumable upload. |
PATCH | /v2/<name>/blobs/uploads/<session_id> |
Blob Upload | Upload a chunk of data for the specified upload. |
PUT | /v2/<name>/blobs/uploads/<session_id> |
Blob Upload | Complete the upload specified by session_id , optionally appending the body as the final chunk. |
DELETE | /v2/<name>/blobs/uploads/<session_id> |
Blob Upload | Cancel outstanding upload processes, releasing associated resources. If this is not called, the unfinished uploads will eventually timeout. |
The detail for each endpoint is covered in the following sections. |
The error codes encountered via the API are enumerated in the following table:
Code | Message | Description |
---|---|---|
BLOB_UNKNOWN |
blob unknown to registry | This error MAY be returned when a blob is unknown to the registry in a specified repository. This can be returned with a standard get or if a manifest references an unknown layer during upload. |
BLOB_UPLOAD_INVALID |
blob upload invalid | The blob upload encountered an error and can no longer proceed. |
BLOB_UPLOAD_UNKNOWN |
blob upload unknown to registry | If a blob upload has been cancelled or was never started, this error code MAY be returned. |
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client. The error MAY include a detail structure with the key "digest", including the invalid digest string. This error MAY also be returned when a manifest includes an invalid layer digest. |
MANIFEST_BLOB_UNKNOWN |
blob unknown to registry | This error MAY be returned when a manifest blob is unknown to the registry. |
MANIFEST_INVALID |
manifest invalid | During upload, manifests undergo several checks ensuring validity. If those checks fail, this error MAY be returned, unless a more specific error is included. The detail will contain information the failed validation. |
MANIFEST_UNKNOWN |
manifest unknown | This error is returned when the manifest, identified by name and tag is unknown to the repository. |
MANIFEST_UNVERIFIED |
manifest failed signature verification | During manifest upload, if the manifest fails signature verification, this error will be returned. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
SIZE_INVALID |
provided length did not match content length | When a layer is uploaded, the provided size will be checked against the uploaded content. If they do not match, this error will be returned. |
TAG_INVALID |
manifest tag did not match URI | During a manifest upload, if the tag in the manifest does not match the uri tag, this error will be returned. |
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client. Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
UNSUPPORTED |
The operation is unsupported. | The operation was unsupported due to a missing implementation or invalid set of parameters. |
Base V2 API route. Typically, this can be used for lightweight version checks and to validate registry authentication.
Check that the endpoint implements the distribution API.
GET /v2/
Host: <registry host>
Authorization: <scheme> <token>
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header. SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
200 OK
The API implements V2 protocol and is accessible.
404 Not Found
The registry does not implement the V2 API.
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client. Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Retrieve information about tags.
Fetch the tags under the repository identified by name
.
GET /v2/<name>/tags/list
Host: <registry host>
Authorization: <scheme> <token>
Return all tags for the repository. The implementation MAY impose a maximum limit and return a partial set with pagination links.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header. SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
200 OK
Content-Length: <length>
Content-Type: application/json
{
"name": "<name>",
"tags": [
"<tag>",
...
]
}
A list of tags for the named repository.
The following headers will be returned with the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client. Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
GET /v2/<name>/tags/list?n=<integer>&last=<integer>
Return a portion of the tags for the specified repository. The implementation MAY impose a maximum limit and return a partial set with pagination links.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
name |
path | Name of the target repository. |
n |
query | Limit the number of entries in each response. If not present, all entries will be returned. |
last |
query | Result set will include values lexically after last. |
200 OK
Content-Length: <length>
Link: <<url>?n=<last n value>&last=<last entry from response>>; rel="next"
Content-Type: application/json
{
"name": "<name>",
"tags": [
"<tag>",
...
],
}
A list of tags for the named repository.
The following headers will be returned with the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
Link |
RFC5988 compliant rel='next' with URL to next result set, if available |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client. Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Create, update, delete and retrieve manifests.
Fetch the manifest identified by name
and reference
where reference
can be a tag or digest.
A HEAD
request can also be issued to this endpoint to obtain resource information without receiving all data.
GET /v2/<name>/manifests/<reference>
Host: <registry host>
Authorization: <scheme> <token>
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header. SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
reference |
path | Tag or digest of the target manifest. |
200 OK
Docker-Content-Digest: <digest>
Content-Type: <media type of manifest>
{
"annotations": {
"com.example.key1": "value1",
"com.example.key2": "value2"
},
"config": {
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.config.v1+json",
"size": 452
},
"layers": [
{
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.layer.v1.tar+gzip",
"size": 78343
}
],
"schemaVersion": 2
}
The manifest identified by name
and reference
.
The contents can be used to identify and resolve resources required to run the specified image.
The following headers will be returned with the response:
Name | Description |
---|---|
Docker-Content-Digest |
Digest of the targeted content for the request. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The name or reference was invalid.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
TAG_INVALID |
manifest tag did not match URI | During a manifest upload, if the tag in the manifest does not match the uri tag, this error will be returned. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client. Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Put the manifest identified by name
and reference
where reference
can be a tag or digest.
PUT /v2/<name>/manifests/<reference>
Host: <registry host>
Authorization: <scheme> <token>
Content-Type: <media type of manifest>
{
"annotations": {
"com.example.key1": "value1",
"com.example.key2": "value2"
},
"config": {
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.config.v1+json",
"size": 452
},
"layers": [
{
"digest": "sha256:6f4e69a5ff18d92e7315e3ee31c62165ebf25bfa05cad05c0d09d8f412dae401",
"mediaType": "application/vnd.oci.image.layer.v1.tar+gzip",
"size": 78343
}
],
"schemaVersion": 2
}
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
reference |
path | Tag or digest of the target manifest. |
201 Created
Location: <url>
Content-Length: 0
Docker-Content-Digest: <digest>
The manifest has been accepted by the registry and is stored under the specified name
and tag
.
The following headers will be returned with the response:
Name | Description |
---|---|
Location |
The canonical location url of the uploaded manifest. |
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Docker-Content-Digest |
Digest of the targeted content for the request. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The received manifest was invalid in some way, as described by the error codes. The client SHOULD resolve the issue and retry the request.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
TAG_INVALID |
manifest tag did not match URI | During a manifest upload, if the tag in the manifest does not match the uri tag, this error will be returned. |
MANIFEST_INVALID |
manifest invalid | During upload, manifests undergo several checks ensuring validity. If those checks fail, this error MAY be returned, unless a more specific error is included.The detail will contain information the failed validation. |
MANIFEST_UNVERIFIED |
manifest failed signature verification | During manifest upload, if the manifest fails signature verification, this error will be returned. |
BLOB_UNKNOWN |
blob unknown to registry | This error MAY be returned when a blob is unknown to the registry in a specified repository.This can be returned with a standard get or if a manifest references an unknown layer during upload. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "BLOB_UNKNOWN",
"message": "blob unknown to registry",
"detail": {
"digest": "<digest>"
}
},
...
]
}
One or more layers MAY be missing during a manifest upload. If so, the missing layers will be enumerated in the error response.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
BLOB_UNKNOWN |
blob unknown to registry | This error MAY be returned when a blob is unknown to the registry in a specified repository.This can be returned with a standard get or if a manifest references an unknown layer during upload. |
405 Method Not Allowed
Manifest put is not allowed because the registry is configured as a pull-through cache or for some other reason
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNSUPPORTED |
The operation is unsupported. | The operation was unsupported due to a missing implementation or invalid set of parameters. |
Delete the manifest identified by name
and reference
.
Note that a manifest can only be deleted by digest
.
DELETE /v2/<name>/manifests/<reference>
Host: <registry host>
Authorization: <scheme> <token>
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header. SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
reference |
path | Tag or digest of the target manifest. |
202 Accepted
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The specified name
or reference
were invalid and the delete was unable to proceed.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
TAG_INVALID |
manifest tag did not match URI | During a manifest upload, if the tag in the manifest does not match the uri tag, this error will be returned. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The specified name
or reference
are unknown to the registry and the delete was unable to proceed.
Clients can assume the manifest was already deleted if this response is returned.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
MANIFEST_UNKNOWN |
manifest unknown | This error is returned when the manifest, identified by name and tag is unknown to the repository. |
405 Method Not Allowed
Manifest delete is not allowed because the registry is configured as a pull-through cache or delete
has been disabled.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNSUPPORTED |
The operation is unsupported. | The operation was unsupported due to a missing implementation or invalid set of parameters. |
Operations on blobs identified by name
and digest
.
Used to fetch or delete layers by digest.
Retrieve the blob from the registry identified by digest
.
A HEAD
request can also be issued to this endpoint to obtain resource information without receiving all data.
GET /v2/<name>/blobs/<digest>
Host: <registry host>
Authorization: <scheme> <token>
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
digest |
path | Digest of desired blob. |
200 OK
Content-Length: <length>
Docker-Content-Digest: <digest>
Content-Type: application/octet-stream
<blob binary data>
The blob identified by digest
is available.
The blob content will be present in the body of the request.
The following headers will be returned with the response:
Name | Description |
---|---|
Content-Length |
The length of the requested blob content. |
Docker-Content-Digest |
Digest of the targeted content for the request. |
307 Temporary Redirect
Location: <blob location>
Docker-Content-Digest: <digest>
The blob identified by digest
is available at the provided location.
The following headers will be returned with the response:
Name | Description |
---|---|
Location |
The location where the layer SHOULD be accessible. |
Docker-Content-Digest |
Digest of the targeted content for the request. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
There was a problem with the request that needs to be addressed by the client, such as an invalid name
or tag
.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The blob, identified by name
and digest
, is unknown to the registry.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
BLOB_UNKNOWN |
blob unknown to registry | This error MAY be returned when a blob is unknown to the registry in a specified repository.This can be returned with a standard get or if a manifest references an unknown layer during upload. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
GET /v2/<name>/blobs/<digest>
Host: <registry host>
Authorization: <scheme> <token>
Range: bytes=<start>-<end>
This endpoint MAY also support RFC7233 compliant range requests.
Support can be detected by issuing a HEAD request.
If the header Accept-Range: bytes
is returned, range requests can be used to fetch partial content.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
Range |
header | HTTP Range header specifying blob chunk. |
name |
path | Name of the target repository. |
digest |
path | Digest of desired blob. |
206 Partial Content
Content-Length: <length>
Content-Range: bytes <start>-<end>/<size>
Content-Type: application/octet-stream
<blob binary data>
The blob identified by digest
is available.
The specified chunk of blob content will be present in the body of the request.
The following headers will be returned with the response:
Name | Description |
---|---|
Content-Length |
The length of the requested blob chunk. |
Content-Range |
Content range of blob chunk. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
There was a problem with the request that needs to be addressed by the client, such as an invalid name
or tag
.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
BLOB_UNKNOWN |
blob unknown to registry | This error MAY be returned when a blob is unknown to the registry in a specified repository.This can be returned with a standard get or if a manifest references an unknown layer during upload. |
416 Requested Range Not Satisfiable
The range specification cannot be satisfied for the requested content. This can happen when the range is not formatted correctly or if the range is outside of the valid size of the content.
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Delete the blob identified by name
and digest
DELETE /v2/<name>/blobs/<digest>
Host: <registry host>
Authorization: <scheme> <token>
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
digest |
path | Digest of desired blob. |
202 Accepted
Content-Length: 0
Docker-Content-Digest: <digest>
The following headers will be returned with the response:
Name | Description |
---|---|
Content-Length |
0 |
Docker-Content-Digest |
Digest of the targeted content for the request. |
400 Bad Request
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The blob, identified by name
and digest
, is unknown to the registry.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
BLOB_UNKNOWN |
blob unknown to registry | This error MAY be returned when a blob is unknown to the registry in a specified repository.This can be returned with a standard get or if a manifest references an unknown layer during upload. |
405 Method Not Allowed
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
Blob delete is not allowed because the registry is configured as a pull-through cache or delete
has been disabled
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNSUPPORTED |
The operation is unsupported. | The operation was unsupported due to a missing implementation or invalid set of parameters. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Initiate a blob upload. This endpoint can be used to create resumable uploads or monolithic uploads.
Initiate a resumable blob upload.
If successful, an upload location will be provided to complete the upload.
Optionally, if the digest
parameter is present, the request body will be used to complete the upload in a single request.
POST /v2/<name>/blobs/uploads/?digest=<digest>
Host: <registry host>
Authorization: <scheme> <token>
Content-Length: <length of blob>
Content-Type: application/octet-stream
<binary data>
Upload a blob identified by the digest
parameter in single request.
This upload will not be resumable unless a recoverable error is returned.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
Content-Length |
header | |
name |
path | Name of the target repository. |
digest |
query | Digest of uploaded blob.If present, the upload will be completed, in a single request, with contents of the request body as the resulting blob. |
201 Created
Location: <blob location>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
The blob has been created in the registry and is available at the provided location.
The following headers will be returned with the response:
Name | Description |
---|---|
Location |
|
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Blob-Upload-Session-ID |
Identifies the upload session_id for the current request. |
400 Bad Request
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
405 Method Not Allowed
Blob upload is not allowed because the registry is configured as a pull-through cache or for some other reason
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNSUPPORTED |
The operation is unsupported. | The operation was unsupported due to a missing implementation or invalid set of parameters. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
POST /v2/<name>/blobs/uploads/
Host: <registry host>
Authorization: <scheme> <token>
Content-Length: 0
Initiate a resumable blob upload with an empty request body.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
Content-Length |
header | The Content-Length header MUST be zero and the body MUST be empty. |
name |
path | Name of the target repository. |
202 Accepted
Content-Length: 0
Location: /v2/<name>/blobs/uploads/<session_id>
Range: 0-0
Blob-Upload-Session-ID: <session_id>
The upload has been created.
The Location
header MUST be used to complete the upload.
The response SHOULD be identical to a GET
request on the contents of the returned Location
header.
The following headers will be returned with the response:
Name | Description |
---|---|
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Location |
The location of the created upload.Clients SHOULD use the contents verbatim to complete the upload, adding parameters where required. |
Range |
Range header indicating the progress of the upload.When starting an upload, it will return an empty range, since no content has been received. |
Blob-Upload-Session-ID |
Identifies the upload session_id for the current request. |
400 Bad Request
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
POST /v2/<name>/blobs/uploads/?mount=<digest>&from=<repository name>
Host: <registry host>
Authorization: <scheme> <token>
Content-Length: 0
Mount a blob identified by the mount
parameter from another repository.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
Content-Length |
header | The Content-Length header MUST be zero and the body MUST be empty. |
name |
path | Name of the target repository. |
mount |
query | Digest of blob to mount from the source repository. |
from |
query | Name of the source repository. |
201 Created
Location: <blob location>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
The blob has been mounted in the repository and is available at the provided location.
The following headers will be returned with the response:
Name | Description |
---|---|
Location |
|
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Blob-Upload-Session-ID |
Identifies the upload session_id for the current request. |
400 Bad Request
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
405 Method Not Allowed
Blob mount is not allowed because the registry is configured as a pull-through cache or for some other reason
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNSUPPORTED |
The operation is unsupported. | The operation was unsupported due to a missing implementation or invalid set of parameters. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Interact with blob uploads.
Clients SHOULD never assemble URLs for this endpoint and SHOULD only take it through the Location
header on related API requests.
The Location
header and its parameters SHOULD be preserved by clients, using the latest value returned via upload related API calls.
Retrieve status of upload identified by session_id
.
The primary purpose of this endpoint is to resolve the current status of a resumable upload.
GET /v2/<name>/blobs/uploads/<session_id>
Host: <registry host>
Authorization: <scheme> <token>
Retrieve the progress of the current upload, as reported by the Range
header.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
session_id |
path | A unique string identifying session of the particular upload.This field can accept characters that match [a-zA-Z0-9-_.=]+ . |
204 No Content
Range: 0-<offset>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
The upload is known and in progress.
The last received offset is available in the Range
header.
The following headers will be returned with the response:
Name | Description |
---|---|
Range |
Range indicating the current progress of the upload. |
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Blob-Upload-Session-ID |
Identifies the upload session ID for the current request. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
There was an error processing the upload and it MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
BLOB_UPLOAD_INVALID |
blob upload invalid | The blob upload encountered an error and can no longer proceed. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The upload is unknown to the registry. The upload MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
BLOB_UPLOAD_UNKNOWN |
blob upload unknown to registry | If a blob upload has been cancelled or was never started, this error code MAY be returned. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Upload a chunk of data for the specified upload.
PATCH /v2/<name>/blobs/uploads/<session_id>
Host: <registry host>
Authorization: <scheme> <token>
Content-Type: application/octet-stream
<binary data>
Upload a stream of data to upload without completing the upload.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
name |
path | Name of the target repository. |
session_id |
path | A unique string identifying the upload.This field can accept characters that match [a-zA-Z0-9-_.=]+ . |
202 Accepted
Location: /v2/<name>/blobs/uploads/<session_id>
Range: 0-<offset>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
The stream of data has been accepted and the current progress is available in the range header.
The updated upload location is available in the Location
header.
The following headers will be returned with the response:
Name | Description |
---|---|
Location |
The location of the upload.Clients SHOULD assume this changes after each request.Clients SHOULD use the contents verbatim to complete the upload, adding parameters where required. |
Range |
Range indicating the current progress of the upload. |
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Blob-Upload-Session-ID |
Identifies the upload session ID for the current request. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
There was an error processing the upload and it MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client. The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
BLOB_UPLOAD_INVALID |
blob upload invalid | The blob upload encountered an error and can no longer proceed. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The upload is unknown to the registry. The upload MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
BLOB_UPLOAD_UNKNOWN |
blob upload unknown to registry | If a blob upload has been cancelled or was never started, this error code MAY be returned. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
PATCH /v2/<name>/blobs/uploads/<session_id>
Host: <registry host>
Authorization: <scheme> <token>
Content-Range: <start of range>-<end of range, inclusive>
Content-Length: <length of chunk>
Content-Type: application/octet-stream
<binary chunk>
Upload a chunk of data to specified upload without completing the upload. The data will be uploaded to the specified Content Range.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
Content-Range |
header | Range of bytes identifying the desired block of content represented by the body.Start MUST the end offset retrieved via status check plus one.Note that this is a non-standard use of the Content-Range header. |
Content-Length |
header | Length of the chunk being uploaded, corresponding the length of the request body. |
name |
path | Name of the target repository. |
session_id |
path | A unique string identifying session of the particular upload.This field can accept characters that match [a-zA-Z0-9-_.=]+ . |
202 Accepted
Location: /v2/<name>/blobs/uploads/<session_id>
Range: 0-<offset>
Content-Length: 0
Blob-Upload-Session-ID: <session_id>
The chunk of data has been accepted and the current progress is available in the range header.
The updated upload location is available in the Location
header.
The following headers will be returned with the response:
Name | Description |
---|---|
Location |
The location of the upload.Clients SHOULD assume this changes after each request.Clients SHOULD use the contents verbatim to complete the upload, adding parameters where required. |
Range |
Range indicating the current progress of the upload. |
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Blob-Upload-Session-ID |
Identifies the upload session ID for the current request. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
There was an error processing the upload and it MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
BLOB_UPLOAD_INVALID |
blob upload invalid | The blob upload encountered an error and can no longer proceed. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The upload is unknown to the registry. The upload MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
BLOB_UPLOAD_UNKNOWN |
blob upload unknown to registry | If a blob upload has been cancelled or was never started, this error code MAY be returned. |
416 Requested Range Not Satisfiable
The Content-Range
specification cannot be accepted, either because it does not overlap with the current progress or it is invalid.
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Complete the upload specified by session_id
, optionally appending the body as the final chunk.
PUT /v2/<name>/blobs/uploads/<session_id>?digest=<digest>
Host: <registry host>
Authorization: <scheme> <token>
Content-Length: <length of data>
Content-Type: application/octet-stream
<binary data>
Complete the upload, providing all the data in the body, if necessary. A request without a body will just complete the upload with previously uploaded content.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
Content-Length |
header | Length of the data being uploaded, corresponding to the length of the request body.May be zero if no data is provided. |
name |
path | Name of the target repository. |
session_id |
path | A unique string identifying session of the particular upload.This field can accept characters that match [a-zA-Z0-9-_.=]+ . |
digest |
query | Digest of uploaded blob. |
204 No Content
Location: <blob location>
Content-Range: <start of range>-<end of range, inclusive>
Content-Length: 0
Docker-Content-Digest: <digest>
The upload has been completed and accepted by the registry.
The canonical location will be available in the Location
header.
The following headers will be returned with the response:
Name | Description |
---|---|
Location |
The canonical location of the blob for retrieval |
Content-Range |
Range of bytes identifying the desired block of content represented by the body.Start MUST match the end of offset retrieved via status check.Note that this is a non-standard use of the Content-Range header. |
Content-Length |
The Content-Length header MUST be zero and the body MUST be empty. |
Docker-Content-Digest |
Digest of the targeted content for the request. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
There was an error processing the upload and it MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DIGEST_INVALID |
provided digest did not match uploaded content | When a blob is uploaded, the registry will check that the content matches the digest provided by the client.The error MAY include a detail structure with the key "digest", including the invalid digest string.This error MAY also be returned when a manifest includes an invalid layer digest. |
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
BLOB_UPLOAD_INVALID |
blob upload invalid | The blob upload encountered an error and can no longer proceed. |
UNSUPPORTED |
The operation is unsupported. | The operation was unsupported due to a missing implementation or invalid set of parameters. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The upload is unknown to the registry. The upload MUST be restarted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
BLOB_UPLOAD_UNKNOWN |
blob upload unknown to registry | If a blob upload has been cancelled or was never started, this error code MAY be returned. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |
Cancel outstanding upload processes, releasing associated resources. If this is not called, the unfinished uploads will eventually timeout.
DELETE /v2/<name>/blobs/uploads/<session_id>
Host: <registry host>
Authorization: <scheme> <token>
Content-Length: 0
Cancel the upload specified by session_id
.
The following parameters SHOULD be specified on the request:
Name | Kind | Description |
---|---|---|
Host |
header | Standard HTTP Host Header.SHOULD be set to the registry host. |
Authorization |
header | An RFC7235 compliant authorization header. |
Content-Length |
header | The Content-Length header MUST be zero and the body MUST be empty. |
name |
path | Name of the target repository. |
session_id |
path | A unique string identifying session of the particular upload.This field can accept characters that match [a-zA-Z0-9-_.=]+ . |
204 No Content
Content-Length: 0
The upload has been successfully deleted.
The following headers will be returned with the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
400 Bad Request
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
An error was encountered processing the delete. The client MAY ignore this error.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_INVALID |
invalid repository name | Invalid repository name encountered either during manifest validation or any API operation. |
BLOB_UPLOAD_INVALID |
blob upload invalid | The blob upload encountered an error and can no longer proceed. |
404 Not Found
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The upload is unknown to the registry. The client MAY ignore this error and assume the upload has been deleted.
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
BLOB_UPLOAD_UNKNOWN |
blob upload unknown to registry | If a blob upload has been cancelled or was never started, this error code MAY be returned. |
401 Unauthorized
WWW-Authenticate: <scheme> realm="<realm>", ..."
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client is not authenticated.
The following headers will be returned on the response:
Name | Description |
---|---|
WWW-Authenticate |
An RFC7235 compliant authentication challenge header. |
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
UNAUTHORIZED |
authentication required | The access controller was unable to authenticate the client.Often this will be accompanied by a Www-Authenticate HTTP response header indicating how to authenticate. |
404 Not Found
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The repository is not known to the registry.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
NAME_UNKNOWN |
repository name not known to registry | This is returned if the name used during an operation is unknown to the registry. |
403 Forbidden
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client does not have required access to the repository.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
DENIED |
requested access to the resource is denied | The access controller denied access for the operation on a resource. |
429 Too Many Requests
Content-Length: <length>
Content-Type: application/json
{
"errors": [
{
"code": "<error code>",
"message": "<error message>",
"detail": ...
},
...
]
}
The client made too many requests within a time interval.
The following headers will be returned on the response:
Name | Description |
---|---|
Content-Length |
Length of the JSON response body. |
The error codes that MAY be included in the response body are enumerated below:
Code | Message | Description |
---|---|---|
TOOMANYREQUESTS |
too many requests | Returned when a client attempts to contact a service too many times |