Skip to content
This repository has been archived by the owner on May 3, 2022. It is now read-only.

Leverage distribution/reference for local index #505

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

Leverage distribution/reference for local index #505

wants to merge 1 commit into from

Conversation

simonferquel
Copy link
Contributor

This has 2 upside:

  • it enforces bundle names in the local index are valid repo names
  • it uses a proven image reference parser instead of relying on raw strings package

This has 2 upside:
- it enforces bundle names in the local index are valid repo names
- it uses a proven image reference parser instead of relying on raw strings package

Signed-off-by: Simon Ferquel <[email protected]>
@bacongobbler
Copy link
Contributor

bacongobbler commented Nov 23, 2018

Hey Simon, we intentionally forked pkg/reference so we could remove the default docker.io domain on normalized names. We should still keep it in and use that instead. See #485

@simonferquel
Copy link
Contributor Author

Hmm, ok. We have to check on the implication for push/pull to a registry though

@simonferquel
Copy link
Contributor Author

I keep this one as is, for after Monday's discussion (e.g.: should we remove the custom registry and adopt image registries instead leveraging #442 until we get the proper manifest-list based OCI representation)

func (i Index) Add(name, version string, digest string) {
if tags, ok := i[name]; ok {
tags[version] = digest
func (i Index) Add(ref reference.NamedTagged, digest string) {
Copy link
Contributor

@bacongobbler bacongobbler Nov 23, 2018

Choose a reason for hiding this comment

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

I'm not too fond of the idea of having such a tight dependency on reference in this package unless there was some gain in utility. The only two changes this package makes is by using ref.Tag() and reference.FamiliarName(), which could've been achieved by using idx.Add(reference.FamiliarName(ref), ref.Tag()) prior to this PR. From an external consumer's point of view, relying on strings rather than references makes the package more easily consumable, testable and maintainable. Most of the changes proposed in this package just add another dependency to the package without gaining much in the way of maintainability/cleanliness IMO.

For example, we've talked about potentially restricting version specifiers to a semver tag, which would be much easier to parse as strings rather than a reference which would require de-serializing into a tag, then parsed into a string to be passed along to a semver checker.

Any opposing thoughts on this?

@bacongobbler
Copy link
Contributor

bacongobbler commented Nov 23, 2018

e.g.: should we remove the custom registry and adopt image registries instead leveraging #442 until we get the proper manifest-list based OCI representation)

FYI we're already kinda going ahead with that. We've hidden all repo-related commands and removed them from the documentation to focus primarily on the CNAB runtime while we figure out what we want to do with the bundle registry API. See #491 for more context on that discussion

@bacongobbler
Copy link
Contributor

We have to check on the implication for push/pull to a registry though

yeah fair enough. For pushing and pulling Docker images we should probably use distribution's reference package, but for bundles we don't want the tight dependency on DockerHub as the default registry of choice. There's some discussion on that over in #426 (comment) if you have an opinion :)

Copy link
Contributor

@bacongobbler bacongobbler left a comment

Choose a reason for hiding this comment

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

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants