mirror of
https://github.com/go-gitea/gitea.git
synced 2026-03-13 02:57:44 -05:00
Cannot get file SHA over API when LFS is in use #14632
Closed
opened 2025-11-02 11:18:23 -06:00 by GiteaMirror
·
5 comments
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#14632
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 @hramrach on GitHub (Jun 21, 2025).
Description
The contents API lists SHA of the LFS redirect, not SHA of the file, with no indication that the file is stored in LFS.
{'Access-Control-Expose-Headers': 'Content-Disposition', 'Cache-Control': 'private, max-age=300', 'Content-Disposition': 'inline; filename="config.tar.bz2"; filename*=UTF-8''config.tar.bz2', 'Content-Length': '131', 'Content-Type': 'text/plain; charset=utf-8', 'Etag': '"d948b9b700b0a9248e131b58f6544aebbda4e3c553602a4747330aa7b4391b4b"', 'Last-Modified': 'Fri, 20 Jun 2025 18:38:24 GMT', 'No-Gzip-Compression': '1', 'X-Content-Type-Options': 'nosniff', 'X-Frame-Options': 'SAMEORIGIN', 'X-Gitea-Object-Type': 'file', 'Date': 'Sat, 21 Jun 2025 11:08:03 GMT'}
version https://git-lfs.github.com/spec/v1
oid sha256:9db9f10cacfc0121f762bba4dbe6572a51a09924245ec358a1b66abd9fb68888
size 306922
[{'name': 'config.tar.bz2', 'path': 'config.tar.bz2', 'sha': 'd948b9b700b0a9248e131b58f6544aebbda4e3c553602a4747330aa7b4391b4b', 'last_commit_sha': 'cecfa1db758fa52082558a5b0c05541a63bf46549441a625666822d6291c54ba', 'type': 'file', 'size': 131, 'encoding': None, 'content': None, 'target': None, 'url': 'https://src.opensuse.org/api/v1/repos/michals/kernel-source/contents/config.tar.bz2?ref=home%2Fmichals%2Fkernel-git', 'html_url': 'https://src.opensuse.org/michals/kernel-source/src/branch/home/michals/kernel-git/config.tar.bz2', 'git_url': '
d948b9b700', 'download_url': 'https://src.opensuse.org/michals/kernel-source/raw/branch/home/michals/kernel-git/config.tar.bz2', 'submodule_git_url': None, '_links': {'self': 'https://src.opensuse.org/api/v1/repos/michals/kernel-source/contents/config.tar.bz2?ref=home%2Fmichals%2Fkernel-git', 'git': 'd948b9b700', 'html': 'https://src.opensuse.org/michals/kernel-source/src/branch/home/michals/kernel-git/config.tar.bz2'}}]The file can be retrieved through the media API so gitea knows that the file is stored in LFS:
{'Accept-Ranges': 'bytes', 'Access-Control-Expose-Headers': 'Content-Disposition', 'Cache-Control': 'private, max-age=300', 'Content-Disposition': 'inline; filename="config.tar.bz2"; filename*=UTF-8''config.tar.bz2', 'Content-Length': '306922', 'Content-Type': 'application/octet-stream', 'Etag': '"9db9f10cacfc0121f762bba4dbe6572a51a09924245ec358a1b66abd9fb68888"', 'Last-Modified': 'Fri, 20 Jun 2025 18:38:24 GMT', 'No-Gzip-Compression': '1', 'X-Content-Type-Options': 'nosniff', 'X-Frame-Options': 'SAMEORIGIN', 'X-Gitea-Object-Type': 'file', 'Date': 'Sat, 21 Jun 2025 11:08:02 GMT'}
but then the whole file is sent. It does not seem feasible to get the actual file SHA without retrieving the whole file. The content API is already very time-consuming but does not provide the file SHA. HEAD on the media URL does not provide the SHA header.
https://demo.gitea.com/hramrach/kernel-source/src/branch/home/hramrach/kernel-git
https://src.opensuse.org/michals/kernel-source/src/branch/home/michals/kernel-git/
Gitea Version
1.23.8
Can you reproduce the bug on the Gitea demo site?
Yes
Log Gist
No response
Screenshots
No response
Git Version
unknown
Operating System
Linux
How are you running Gitea?
All of the above
Database
None
@wxiaoguang commented on GitHub (Jun 23, 2025):
The "contents" API was written to follow GitHub's behavior, it has many problems.
So I proposed a new "contents-ext" API: Refactor repo contents API and add "contents-ext" API #34822
Then we can do something like
/repos/{owner}/{repo}/contents-ext/{filepath}?includes=file_content,lfs_meta,lfs_content, etc.Could you elaborate the details about you need? For example: the use cases, and what you'd like to see in the API response (with some examples).
@hramrach commented on GitHub (Jun 23, 2025):
The use case for me is to sync a directory into git repository without downloading the previous content of the repository.
@hramrach commented on GitHub (Jun 23, 2025):
An example of what I would want to see is some flag that says the file is in fact stored as LFS so that I know reliably that I should download the raw content and interpret it as LFS link (which happens to work for sha256 repository).
Even easier to use would be to provide the actual media SHA rather than the raw file SHA.
In general I want to get the SHA of the actual content, as opposed to the SHA of the LFS link which is currently provided.
Given that uploading a file should transparently store it in LFS it is broken that listing content is not transparent to LFS.
@wxiaoguang commented on GitHub (Jun 23, 2025):
See Refactor repo contents API and add "contents-ext" API #34822 :
Request
/repos/{owner}/{repo}/contents-ext/{filepath}?includes=lfs_metadata, then there will belfs_oidandlfs_sizein response if the file is a valid lfs pointer file.@hramrach commented on GitHub (Jun 23, 2025):
Thanks, that sounds like it will be useful for this use case