Skip to content

Conversation

@mtrmac
Copy link

@mtrmac mtrmac commented Jul 6, 2017

Store signatures in c/i/docker/daemon/extra (containers/image#288).

Whether or not we are verifying signatures, download them and store them in docker/daemon/extra.

Note that this means that containers/image/docker is now involved on every pull; failures of the c/i/docker client, or inability to download (possibly incorrectly configured but unused) signatures are now fatal.

Alternatively, we could make the storing of signatures to extra silently fail in such cases.

This does not add any user of the signatures, though containers/image#288 shows how the signatures stored by this PR can be used to cryptographically authenticate the expected layer DiffID`s (a prerequisite for verifying extracted layers). See also containers/image#301 for a necessary policy scoping enhancement.

Affects only V2 pulls, and the information is stored only for schema2 images: for schema1 images the daemon itself is creating a new config.json in code, and that config.json cannot be directly authenticated. (We could do another schema1→schema2 conversion and then compare the results, but that’s tricky; let’s start by hoping that schema1 will die out quickly enough, and we can revisit this if necessary later).

@mtrmac
Copy link
Author

mtrmac commented Jul 6, 2017

Do not merge before containers/image#288 !

Note that this rebases containers/image fairly significantly, including some of the deps. Also I guess equivalent changes will need to happen in other branches as well.

@runcom PTAL.

@rh-atomic-bot
Copy link

@mtrmac mtrmac force-pushed the signature-storage branch from 6a760a6 to 357118e Compare July 10, 2017 17:02
@rh-atomic-bot
Copy link

@mtrmac mtrmac force-pushed the signature-storage branch from 357118e to 419a747 Compare July 18, 2017 20:47
@rh-atomic-bot
Copy link

@mtrmac mtrmac force-pushed the signature-storage branch 2 times, most recently from 0641df3 to 0716787 Compare October 14, 2017 18:52
@mtrmac mtrmac force-pushed the signature-storage branch from 0716787 to dc39ceb Compare October 16, 2017 20:30
@mtrmac mtrmac force-pushed the signature-storage branch 5 times, most recently from e640974 to bfba127 Compare December 2, 2017 06:06
@mtrmac mtrmac force-pushed the signature-storage branch from bfba127 to 3022a47 Compare December 9, 2017 03:18
Update dependencies to allow it to build.  Also drop k8s and
dependencies now that we do not import all containers/image transports.

WARNING: This DOES NOT BUILD because it references sirupsen/logrus, not
Sirupsen/logrus.
s/sirupsen/Sirupsen/g
Whether or not we are verifying signatures, download them and store them
in docker/daemon/signatures.

Note that this means that containers/image/docker is now involved on
_every_ pull; failures of the c/i/docker client, or inability to
download (possibly incorrectly configured but unused) signatures are now
fatal.

Alternatively, we could make the storing of signatures to c/i/d/d/s silently
fail in such cases.

WARNING: This DOES NOT BUILD because it references sirupsen/logrus, not
Sirupsen/logrus.
s/sirupsen/Sirupsen/g
i.e. defer parsing of the manifest to obtain the config digest
only after the signatures have been verified.
@mtrmac mtrmac force-pushed the signature-storage branch from 3022a47 to 3ae0ae5 Compare December 9, 2017 03:25
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants