Ultimate Guide for Docker APIs
Throughout our Docker Tutorial Series, we have discussed many significant Docker components and commands. In today’s series installment, we dig deeper into Docker and uncover Docker APIs.
The first item worth noting is that Docker provides the following APIs, making it easier to use. Those APIs also come in four flavours:
- Docker Registry API
- Docker Hub API
- Docker OAuth API
- Docker Remote API
Specifically to this post, let’s discuss Docker Registry API and Docker Hub API.
Docker Registry API
Docker Registry API is a REST API for the Docker Registry, which eases the storage of images and repositories. The API does not have access to user accounts or its authorization. Read part four of the Docker Tutorial Series to learn more about registry types.
Extract image layer:
GET /v1/images/(image_id)/layer
Insert image layer:
PUT /v1/images/(image_id)/layer
Retrieve an image:
GET /v1/images/(image_id)/json
Retrieve roots of an image:
GET /v1/images/(image_id)/ancestry
Obtain all tags or specific tag of a repository:
GET /v1/repositories/(namespace)/(repository)/tags
or
GET /v1/repositories/(namespace)/(repository)/tags/(tag*)
Delete a tag:
DELETE /v1/repositories/(namespace)/(repository)/tags/(tag*)
Status check of registry:
GET /v1/_ping
Docker Hub API
Docker Hub API is a simple REST API for Docker Hub. Once again, please refer to part four of this series to learn more about Docker Hub. Docker Hub controls user accounts, authentication by managing checksums, and public namespaces. This API also allows operations pertaining to user and library repositories.
First, let’s explore commands that are specific to library repositories (requires admin access):
Create a new repository - A new library repository can be created using the command
PUT /v1/repositories/(repo_name)/
where repo_name refers to the name of the new repository
Delete existing repository - The following command is used to delete an existing repository:
DELETE /v1/repositories/(repo_name)/
where repo_name indicates the name of the library repository to be deleted.
Update repository images - Images that are already in a library repository can be updated using the command
PUT /v1/repositories/(repo_name)/images
- Get images from a repository - To fetch an image from any given library, use the command
GET /v1/repositories/(repo_name)/images
- Authorization - A library repository is authorized using a token which can be created using the command
PUT /v1/repositories/(repo_name)/auth
Now, let’s list the commands specific to user repositories. The major difference between library-specific and user-specific commands is the use of namespace.
- Create a new user repository - A new user repository can be created using the command
PUT /v1/repositories/(namespace)/(repo_name)/
- Delete existing repository - Delete the user repository using the command
DELETE /v1/repositories/(namespace)/(repo_name)/
- Update images - Update user repository images with
PUT /v1/repositories/(namespace)/(repo_name)/images
- Get images from a repository - To fetch images from an existing repository, execute the following command:
There are a few other simple commands you can use. They are:GET /v1/repositories/(namespace)/(repo_name)/images
Verify a user login using the command:
GET /v1/users
Create a new user executing the command:
POST /v1/users
Update user details:
PUT /v1/users/(username)/
Now that we’ve taken you on the first leg of this ultimate journey about Docker APIs, look for the second leg about Docker OAuth and Remote APIs in an upcoming post as part of this on-going Docker Tutorial Series.