mirror of
https://github.com/go-gitea/gitea.git
synced 2026-03-12 02:24:21 -05:00
401 Unauthorized HTTP Response When Pulling Container Image Manifest Owned By Public Gitea Organization #14467
Closed
opened 2025-11-02 11:13:41 -06:00 by GiteaMirror
·
1 comment
No Branch/Tag Specified
main
release/v1.25
release/v1.24
release/v1.23
release/v1.22
release/v1.21
release/v1.20
release/v1.19
release/v1.18
release/v1.17
release/v1.16
release/v1.15
release/v1.14
release/v1.13
release/v1.12
release/v1.11
release/v1.10
release/v1.9
release/v1.8
v1.25.3
v1.25.2
v1.25.1
v1.25.0
v1.24.7
v1.25.0-rc0
v1.26.0-dev
v1.24.6
v1.24.5
v1.24.4
v1.24.3
v1.24.2
v1.24.1
v1.24.0
v1.23.8
v1.24.0-rc0
v1.25.0-dev
v1.23.7
v1.23.6
v1.23.5
v1.23.4
v1.23.3
v1.23.2
v1.23.1
v1.23.0
v1.23.0-rc0
v1.24.0-dev
v1.22.6
v1.22.5
v1.22.4
v1.22.3
v1.22.2
v1.22.1
v1.22.0
v1.23.0-dev
v1.22.0-rc1
v1.21.11
v1.22.0-rc0
v1.21.10
v1.21.9
v1.21.8
v1.21.7
v1.21.6
v1.21.5
v1.21.4
v1.21.3
v1.21.2
v1.20.6
v1.21.1
v1.21.0
v1.21.0-rc2
v1.21.0-rc1
v1.20.5
v1.22.0-dev
v1.21.0-rc0
v1.20.4
v1.20.3
v1.20.2
v1.20.1
v1.20.0
v1.19.4
v1.21.0-dev
v1.20.0-rc2
v1.20.0-rc1
v1.20.0-rc0
v1.19.3
v1.19.2
v1.19.1
v1.19.0
v1.19.0-rc1
v1.20.0-dev
v1.19.0-rc0
v1.18.5
v1.18.4
v1.18.3
v1.18.2
v1.18.1
v1.18.0
v1.17.4
v1.18.0-rc1
v1.19.0-dev
v1.18.0-rc0
v1.17.3
v1.17.2
v1.17.1
v1.17.0
v1.17.0-rc2
v1.16.9
v1.17.0-rc1
v1.18.0-dev
v1.16.8
v1.16.7
v1.16.6
v1.16.5
v1.16.4
v1.16.3
v1.16.2
v1.16.1
v1.16.0
v1.15.11
v1.17.0-dev
v1.16.0-rc1
v1.15.10
v1.15.9
v1.15.8
v1.15.7
v1.15.6
v1.15.5
v1.15.4
v1.15.3
v1.15.2
v1.15.1
v1.14.7
v1.15.0
v1.15.0-rc3
v1.14.6
v1.15.0-rc2
v1.14.5
v1.16.0-dev
v1.15.0-rc1
v1.14.4
v1.14.3
v1.14.2
v1.14.1
v1.14.0
v1.13.7
v1.14.0-rc2
v1.13.6
v1.13.5
v1.14.0-rc1
v1.15.0-dev
v1.13.4
v1.13.3
v1.13.2
v1.13.1
v1.13.0
v1.12.6
v1.13.0-rc2
v1.14.0-dev
v1.13.0-rc1
v1.12.5
v1.12.4
v1.12.3
v1.12.2
v1.12.1
v1.11.8
v1.12.0
v1.11.7
v1.12.0-rc2
v1.11.6
v1.12.0-rc1
v1.13.0-dev
v1.11.5
v1.11.4
v1.11.3
v1.10.6
v1.12.0-dev
v1.11.2
v1.10.5
v1.11.1
v1.10.4
v1.11.0
v1.11.0-rc2
v1.10.3
v1.11.0-rc1
v1.10.2
v1.10.1
v1.10.0
v1.9.6
v1.9.5
v1.10.0-rc2
v1.11.0-dev
v1.10.0-rc1
v1.9.4
v1.9.3
v1.9.2
v1.9.1
v1.9.0
v1.9.0-rc2
v1.10.0-dev
v1.9.0-rc1
v1.8.3
v1.8.2
v1.8.1
v1.8.0
v1.8.0-rc3
v1.7.6
v1.8.0-rc2
v1.7.5
v1.8.0-rc1
v1.9.0-dev
v1.7.4
v1.7.3
v1.7.2
v1.7.1
v1.7.0
v1.7.0-rc3
v1.6.4
v1.7.0-rc2
v1.6.3
v1.7.0-rc1
v1.7.0-dev
v1.6.2
v1.6.1
v1.6.0
v1.6.0-rc2
v1.5.3
v1.6.0-rc1
v1.6.0-dev
v1.5.2
v1.5.1
v1.5.0
v1.5.0-rc2
v1.5.0-rc1
v1.5.0-dev
v1.4.3
v1.4.2
v1.4.1
v1.4.0
v1.4.0-rc3
v1.4.0-rc2
v1.3.3
v1.4.0-rc1
v1.3.2
v1.3.1
v1.3.0
v1.3.0-rc2
v1.3.0-rc1
v1.2.3
v1.2.2
v1.2.1
v1.2.0
v1.2.0-rc3
v1.2.0-rc2
v1.1.4
v1.2.0-rc1
v1.1.3
v1.1.2
v1.1.1
v1.1.0
v1.0.2
v1.0.1
v1.0.0
v0.9.99
Labels
Clear labels
$20
$250
$50
$500
backport/done
💎 Bounty
docs-update-needed
good first issue
hacktoberfest
issue/bounty
issue/confirmed
issue/critical
issue/duplicate
issue/needs-feedback
issue/not-a-bug
issue/regression
issue/stale
issue/workaround
lgtm/need 2
modifies/api
modifies/translation
outdated/backport/v1.18
outdated/theme/markdown
outdated/theme/timetracker
performance/bigrepo
performance/cpu
performance/memory
performance/speed
pr/breaking
proposal/accepted
proposal/rejected
pr/wip
pull-request
reviewed/wontfix
💰 Rewarded
skip-changelog
status/blocked
topic/accessibility
topic/api
topic/authentication
topic/build
topic/code-linting
topic/commit-signing
topic/content-rendering
topic/deployment
topic/distribution
topic/federation
topic/gitea-actions
topic/issues
topic/lfs
topic/mobile
topic/moderation
topic/packages
topic/pr
topic/projects
topic/repo
topic/repo-migration
topic/security
topic/theme
topic/ui
topic/ui-interaction
topic/ux
topic/webhooks
topic/wiki
type/bug
type/deprecation
type/docs
type/enhancement
type/feature
type/miscellaneous
type/proposal
type/question
type/refactoring
type/summary
type/testing
type/upstream
Mirrored from GitHub Pull Request
Milestone
No items
No Milestone
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: github-starred/gitea#14467
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Originally created by @zombiemaker on GitHub (May 8, 2025).
Description
Gitea version: gitea:1.23.7-rootless container image
Gitea organization: myorg
Gitea organization visibility: public
Trying to pull OCI distribution spec container image manifest of image owned by myorg: https://mygitea.mydomain.com/v2/myorg/mycontainer/manifests/mytag
Receive 401 HTTP response when requesting without credentials
Using PowerShell invoke-webrequest without credentials
invoke-webrequest -uri https://mygitea.mydomain.com/v2/myorg/mycontaine/manifests/mytag -method head
Invoke-WebRequest: Response status code does not indicate success: 401 (Unauthorized).
Using PowerShell invoke-webrequest with credentials
invoke-webrequest -uri https://mygitea.mydomain.com/v2/myorg/mycontaine/manifests/mytag -method head -Authentication Basic -Credential $credential
StatusCode : 200
StatusDescription : OK
Content : {}
RawContent : HTTP/1.1 200 OK
Docker-Content-Digest: sha256:01b0ca90f68d7dc269584904b2597718987a98bcf0159624858dee4a9aa98cad
Docker-Distribution-Api-Version: registry/2.0
ETag: "sha256:01b0ca90f68d7dc269584904b2…
Headers : {[Docker-Content-Digest, System.String[]], [Docker-Distribution-Api-Version, System.String[]], [ETag, System.String[]], [Date, System.String[]]…}
RawContentLength : 0
RelationLink : {}
invoke-webrequest -uri https://demo.gitea.com/v2/testcontainerregistry/haproxy/manifests/3.1.3-bookworm -method head
Invoke-WebRequest: Response status code does not indicate success: 401 (Unauthorized).
invoke-webrequest -uri https://demo.gitea.com/v2/testcontainerregistry/haproxy/manifests/3.1.3-bookworm -method head -Authentication Basic -Credential $credential2
StatusCode : 200
StatusDescription : OK
Content : {}
RawContent : HTTP/1.1 200 OK
Alt-Svc: h3=":443"; ma=2592000
Date: Thu, 08 May 2025 14:57:50 GMT
Docker-Content-Digest: sha256:52353496966c190b1a7e0ed10f1bceb30b3dfa920db028c9cd9cca788a5bfc8d
Docker-Distributio…
Headers : {[Alt-Svc, System.String[]], [Date, System.String[]], [Docker-Content-Digest, System.String[]], [Docker-Distribution-Api-Version, System.String[]]…}
RawContentLength : 0
RelationLink : {}
Gitea Version
1.23.7
Can you reproduce the bug on the Gitea demo site?
Yes
Log Gist
No response
Screenshots
No response
Git Version
2.47.2
Operating System
container image gitea:1.23.7-rootless
How are you running Gitea?
Database
SQLite
@techknowlogick commented on GitHub (May 8, 2025):
The OCI API that's implemented in Gitea (based on the OCI token auth spec, due to various requirements) always expects a "token". Not a token as in a Gitea app token, but one provided by the OCI token auth service (something that transforms a gitea token into an OCI token that matches their spec, or accepts no token and the returns an anon token) with scopes allowed, even for "anon" requests. More details on the implemented spec: https://distribution.github.io/distribution/spec/auth/token/
This means that to achieve what you are looking to do to fetch the manifest via powershell webrequests, you'll need to first request an empty token, and then pass that token to the manifest route.
OCI clients have this flow built in, as you can see by the following screenshot of a docker pull on a computer that has not done a docker login:

Something you could do is to use a lightweight client such as skopeo that will do that back and forth to get you the manifest json: an example can be found here: https://github.com/containers/skopeo/blob/main/docs/skopeo-inspect.1.md#examples