2020-09-03 15:41:15 +02:00
|
|
|
# Architecture
|
|
|
|
|
|
|
|
This CLI has the following high level design goals:
|
|
|
|
1. Provide a way for the Docker experience to be mapped to different container
|
|
|
|
runtimes
|
|
|
|
1. Provide a way to automatically generate high quality SDKs in popular
|
|
|
|
languages
|
|
|
|
1. Ensure that existing Docker CLI commands continue to work as before
|
|
|
|
|
|
|
|
These constraints resulted in the following architecture:
|
|
|
|
|
|
|
|
![CLI architecture](./images/cli-architecture.png)
|
|
|
|
|
|
|
|
What follows is a list of useful links to help navigate the code:
|
|
|
|
* The CLI UX code is in [`cli/`](../cli)
|
|
|
|
* The backend interface is defined in [`backend/`](../backend)
|
|
|
|
* An example backend can be found in [`example/`](../example)
|
|
|
|
* The API is defined by protobufs that can be found in [`protos/`](../protos)
|
|
|
|
* The API server is in [`server/`](../server)
|
|
|
|
* The context management and interface can be found in [`context/`](../context)
|
2020-09-04 13:20:20 +02:00
|
|
|
* The Node SDK is autogenerated (except for default endpoints managed by Docker Desktop), and can be found in
|
2020-09-03 15:41:15 +02:00
|
|
|
[`docker/node-sdk`](https://github.com/docker/node-sdk)
|