1
0
Fork 0
mirror of https://github.com/moby/moby.git synced 2022-11-09 12:21:53 -05:00
moby--moby/pkg
Tonis Tiigi 38d914cc96 Implement content addressability for plugins
Move plugins to shared distribution stack with images.

Create immutable plugin config that matches schema2 requirements.

Ensure data being pushed is same as pulled/created.

Store distribution artifacts in a blobstore.

Run init layer setup for every plugin start.

Fix breakouts from unsafe file accesses.

Add support for `docker plugin install --alias`

Uses normalized references for default names to avoid collisions when using default hosts/tags.

Some refactoring of the plugin manager to support the change, like removing the singleton manager and adding manager config struct.

Signed-off-by: Tonis Tiigi <tonistiigi@gmail.com>
Signed-off-by: Derek McGowan <derek@mcgstyle.net>
(cherry picked from commit 3d86b0c79b)
2016-12-27 13:31:14 -08:00
..
aaparser fix apparmor load profile 2016-12-09 14:10:58 -08:00
archive Windows: Use sequential file access 2016-11-16 11:05:23 -08:00
authorization Rename Remote API to Engine API 2016-11-22 16:49:58 -08:00
broadcaster
chrootarchive Merge pull request #28047 from cpuguy83/27773_chrootarchive_rbind 2016-11-09 10:52:14 -08:00
devicemapper fix a few golint errors 2016-11-19 23:50:06 -08:00
directory
discovery fix typo 2016-11-18 13:27:01 -08:00
filenotify project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
fileutils all: use strings.Contains instead Index 2016-10-13 15:55:41 -07:00
fsutils overlay: warn if overlay backing fs doesn't support d_type 2016-11-09 07:18:27 +00:00
gitutils
graphdb Windows: Factor out sqlite 2016-12-02 13:40:06 -08:00
homedir
httputils
idtools Remove use of pkg/integration in pkg/idtools 2016-11-08 17:21:02 +01:00
integration Remove use of pkg/integration in pkg/idtools 2016-11-08 17:21:02 +01:00
ioutils s/bCap/bLen/ 2016-11-18 13:31:39 -08:00
jsonlog
jsonmessage pkg/jsonmessage: Avoid undefined ANSI escape codes. 2016-11-10 14:10:47 +00:00
listeners
locker
longpath
loopback
mount Add functional support for Docker sub commands on Solaris 2016-11-07 09:06:34 -08:00
namesgenerator Add some adjectives to the namesgenerator 2016-11-30 14:07:37 -08:00
parsers
pidfile mkdirall on the PID file path 2016-10-25 09:11:20 -07:00
platform Swap usage of LazyDLL and LoadDLL to LazySystemDLL. 2016-11-22 18:40:35 -08:00
plugingetter Refcount graphdriver plugins properly 2016-12-13 19:56:51 -08:00
plugins plugins: container-rootfs-relative paths 2016-12-09 14:16:04 -08:00
pools pkg/pool: no need for double pointer for sync.Pool 2016-10-20 15:27:38 -07:00
progress Implement content addressability for plugins 2016-12-27 13:31:14 -08:00
promise
pubsub
random
reexec
registrar
signal Move stack dump dir to exec root 2016-11-30 14:02:24 -08:00
stdcopy stdcopy: remove logrus debug messages; makes it easier to vendor without the dependency. 2016-10-26 16:29:37 -07:00
streamformatter
stringid
stringutils
symlink Don't attempt to evaluate drive root on Windows 2016-09-08 13:52:54 -07:00
sysinfo Swap usage of LazyDLL and LoadDLL to LazySystemDLL. 2016-11-22 18:40:35 -08:00
system Swap usage of LazyDLL and LoadDLL to LazySystemDLL. 2016-11-22 18:40:35 -08:00
tailfile Change reading order of tailfile 2016-11-14 11:58:01 -08:00
tarsum
term Windows: Fix crash in docker system prune 2016-12-12 13:25:01 -08:00
testutil Fix broken JSON support in cli/command/formatter 2016-10-17 08:07:17 +00:00
tlsconfig Use system ca pool from tlsconfig 2016-10-31 14:52:07 -07:00
truncindex
urlutil
useragent
README.md

pkg/ is a collection of utility packages used by the Docker project without being specific to its internals.

Utility packages are kept separate from the docker core codebase to keep it as small and concise as possible. If some utilities grow larger and their APIs stabilize, they may be moved to their own repository under the Docker organization, to facilitate re-use by other projects. However that is not the priority.

The directory pkg is named after the same directory in the camlistore project. Since Brad is a core Go maintainer, we thought it made sense to copy his methods for organizing Go code :) Thanks Brad!

Because utility packages are small and neatly separated from the rest of the codebase, they are a good place to start for aspiring maintainers and contributors. Get in touch if you want to help maintain them!