Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

do not register sha384 by default #97

Merged
merged 1 commit into from
Jan 16, 2025

Conversation

thaJeztah
Copy link
Member

related:

The SHA-384 algorithm is not documented in the OCI image-spec (1, 2), and is not encouraged to be used. Commit 084376b registered all algorithms by default, but also included SHA-384.

This patch disables SHA-384 by default, to discourage its use.

sha.go Outdated
@@ -18,6 +18,5 @@ const (

func init() {
RegisterAlgorithm(SHA256, crypto.SHA256)
RegisterAlgorithm(SHA384, crypto.SHA384)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is a breaking change, do we need to bump up the major version?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hm.. good question. Before 084376b (not yet part of a release), neither of them would work out of the box unless the algorithms were registered, so perhaps some wiggle room, but you may be right that it could be a v2 worth if we decide to remove.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(honestly not sure why SHA384 and SHA512 ever made it in at all, but 🤷‍♂️)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We don't have full support in distribution-spec for clients changing the algorithm (e.g. clients cannot control the algorithm when pushing a manifest by tag). And I've managed to break (waves arms wildly) just about everything by testing sha512. So I think this would be a fairly safe breaking change to make without a major version bump (which would be the bigger breaking change IMO). We'll eventually fix distribution-spec, so leaving this could create more problems later.

A middle ground would have been a "Deprecated" comment, but there's no exported field to set that on.

@thaJeztah
Copy link
Member Author

Let me move this one to draft; I rebased #98 to not depend on this PR.

@thaJeztah thaJeztah marked this pull request as draft January 30, 2024 11:02
@thaJeztah thaJeztah mentioned this pull request Jan 30, 2024
Copy link
Contributor

@stevvooe stevvooe left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This needs to be rebased because we made a big move in another PR.

@thaJeztah thaJeztah force-pushed the remove_SHA384_default branch from 5dee832 to dead9ba Compare April 24, 2024 08:42
@thaJeztah
Copy link
Member Author

I rebased this, but kept it in draft for now, pending the discussion on this being a breaking change (and warranting a v2 of this module)

@AkihiroSuda
Copy link
Member

I rebased this, but kept it in draft for now, pending the discussion on this being a breaking change (and warranting a v2 of this module)

What should we do with this?

@dmcgowan
Copy link
Member

I vote rebase and merge this, if that is being used it is likely for non-OCI stuff and the impact would be too small to worry about.

The SHA-384 algorithm is not documented in the OCI image-spec ([1], [2]), and
is not encouraged to be used. Commit 084376b
registered all algorithms by default, but also included SHA-384.

This patch disables SHA-384 by default, to discourage its use.

[1]: https://github.com/opencontainers/image-spec/blob/v1.0.2/descriptor.md#digests
[2]: https://github.com/opencontainers/image-spec/blob/v1.0.2/descriptor.md#registered-algorithms

Signed-off-by: Sebastiaan van Stijn <[email protected]>
@thaJeztah thaJeztah force-pushed the remove_SHA384_default branch from dead9ba to 528a663 Compare January 15, 2025 23:56
@thaJeztah thaJeztah marked this pull request as ready for review January 15, 2025 23:56
@AkihiroSuda AkihiroSuda merged commit 8f8f897 into opencontainers:master Jan 16, 2025
11 checks passed
@thaJeztah thaJeztah deleted the remove_SHA384_default branch January 16, 2025 00:01
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.

5 participants