0b1b9c409d
Repository archives are always named `<project>-<ref>-<sha>` even if the ref is a commit. A consequence of always including the sha even for tags is that packaging a release is more difficult because both the ref and sha must be known by the packager. - add append_sha option (defaults true) to provide a method for toggling this feature. Support added to GitLab Workhorse by gitlab-org/gitlab-workhorse!232
41 lines
1.4 KiB
Ruby
41 lines
1.4 KiB
Ruby
# Helpers to send Git blobs, diffs, patches or archives through Workhorse.
|
|
# Workhorse will also serve files when using `send_file`.
|
|
module WorkhorseHelper
|
|
# Send a Git blob through Workhorse
|
|
def send_git_blob(repository, blob)
|
|
headers.store(*Gitlab::Workhorse.send_git_blob(repository, blob))
|
|
headers['Content-Disposition'] = 'inline'
|
|
headers['Content-Type'] = safe_content_type(blob)
|
|
head :ok # 'render nothing: true' messes up the Content-Type
|
|
end
|
|
|
|
# Send a Git diff through Workhorse
|
|
def send_git_diff(repository, diff_refs)
|
|
headers.store(*Gitlab::Workhorse.send_git_diff(repository, diff_refs))
|
|
headers['Content-Disposition'] = 'inline'
|
|
head :ok
|
|
end
|
|
|
|
# Send a Git patch through Workhorse
|
|
def send_git_patch(repository, diff_refs)
|
|
headers.store(*Gitlab::Workhorse.send_git_patch(repository, diff_refs))
|
|
headers['Content-Disposition'] = 'inline'
|
|
head :ok
|
|
end
|
|
|
|
# Archive a Git repository and send it through Workhorse
|
|
def send_git_archive(repository, **kwargs)
|
|
headers.store(*Gitlab::Workhorse.send_git_archive(repository, **kwargs))
|
|
head :ok
|
|
end
|
|
|
|
# Send an entry from artifacts through Workhorse
|
|
def send_artifacts_entry(build, entry)
|
|
headers.store(*Gitlab::Workhorse.send_artifacts_entry(build, entry))
|
|
head :ok
|
|
end
|
|
|
|
def set_workhorse_internal_api_content_type
|
|
headers['Content-Type'] = Gitlab::Workhorse::INTERNAL_API_CONTENT_TYPE
|
|
end
|
|
end
|