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

oras push --artifact-platform is not compatible with oras pull --platform and similar commands #1517

Closed
1 task done
Wwwsylvia opened this issue Oct 25, 2024 · 1 comment · Fixed by #1518 or #1519
Closed
1 task done
Labels
bug Something isn't working
Milestone

Comments

@Wwwsylvia
Copy link
Member

Wwwsylvia commented Oct 25, 2024

What happened in your environment?

The PR #1500 introduced a new --artifact-platform option to the oras push command, which adds platform information to the artifact configuration using the media type "application/vnd.unknown.config.v1+json" by default.

However, this implementation of oras push --artifact-platform is incompatible with other commands that provide the --platform option, such as oras pull --platform, oras manifest fetch-config --platform, and oras copy --platform.

Symptom

For example, if one pushes an artifact with platform metadata like this:

oras push localhost:5000/myartifact:v1 blob --artifact-platform linux/amd64

and then pulls it specifying the platform as well:

oras pull localhost:5000/myartifact:v1 --platform linux/amd64

They would get this error message:

Error: fail to recognize platform from unknown config application/vnd.unknown.config.v1+json: expect application/vnd.oci.image.config.v1+json

Root Cause

This is because the oras-go backing library only extracts platform information from the image config media type "application/vnd.oci.image.config.v1+json" and throws errors for any other config media type.

Workaround

To temporarily address this issue, we can use "application/vnd.oci.image.config.v1+json" as the default config media type. While this solution is not ideal and introduces other problems, it serves as a workaround to enable the end-to-end workflow. Ultimately, we may need to reconsider the design for adding the platform information.

What did you expect to happen?

No response

How can we reproduce it?

  1. Push an artifact with platform information:

    oras push localhost:5000/myartifact:v1 blob --artifact-platform linux/amd64
  2. Pull the same artifact specifying the platform:

    oras pull localhost:5000/myartifact:v1 --platform linux/amd64

What is the version of your ORAS CLI?

Version: 1.2.0+unreleased
Go version: go1.23.0
Git commit: 97cb376
Git tree state: clean

What is your OS environment?

Ubuntu 22.04.1

Are you willing to submit PRs to fix it?

  • Yes, I am willing to fix it.
@Wwwsylvia Wwwsylvia added bug Something isn't working triage New issues or PRs to be acknowledged by maintainers labels Oct 25, 2024
@FeynmanZhou FeynmanZhou removed the triage New issues or PRs to be acknowledged by maintainers label Oct 29, 2024
@FeynmanZhou FeynmanZhou added this to the v1.3.0 milestone Oct 29, 2024
@qweeah
Copy link
Contributor

qweeah commented Oct 29, 2024

Checked the oras-go function that does the platform matching, sounds like --artifact-type should not be used with --aritfact-platform for when image spec is set tov1.0

oras git:(main) ✗ ./bin/linux/amd64/oras push localhost:5000/test:config-type --artifact-platform linux/amd64 --artifact-type billy/test --image-spec v1.0
✓ Exists    billy/test                                                                                                         37/37  B 100.00%     0s
  └─ sha256:9d99a75171aea000c711b34c0e5e3f28d3d537dd99d110eafbfbc2bd8e52c2bf
✓ Uploaded  application/vnd.oci.image.manifest.v1+json                                                                       291/291  B 100.00%     0s
  └─ sha256:42f833fb2750fab31688457d69c57e5a7f4b6dbd13c8bffbdbd2e5a56bdf6e87
Pushed [registry] localhost:5000/test:config-type
ArtifactType: billy/test
Digest: sha256:42f833fb2750fab31688457d69c57e5a7f4b6dbd13c8bffbdbd2e5a56bdf6e87oras git:(main) ✗ ./bin/linux/amd64/oras pull localhost:5000/test:config-type --platform linux/amd64
Error: fail to recognize platform from unknown config billy/test: expect application/vnd.oci.image.config.v1+json

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
3 participants