跳至主要内容
版本:1.23.6

Arch 套件註冊表

為您的用戶或組織發布 Arch 套件。該註冊表可以作為一個完全運行的 Arch linux 鏡像,直接連接到 /etc/pacman.conf

需求

要使用 Arch 註冊表,您需要使用像 curl 這樣的 HTTP 客戶端來上傳,並使用像 pacman 這樣的套件管理器來消費套件。

以下範例使用 pacman

配置套件註冊表

在您可以使用套件註冊表之前,您需要下載套件驗證密鑰並將註冊表添加到 pacman 配置中。

下載套件驗證密鑰。

wget https://gitea.example.com/api/packages/{owner}/arch/repository.key

顯示密鑰的 ID(帶有十六進制字符的長行)。

gpg --show-keys repository.key

將密鑰添加到 pacman 並簽署它(使用上一步中的密鑰 ID)。

pacman-key --add repository.key
pacman-key --lsign-key {key id}

現在將註冊表配置添加到 /etc/pacman.conf

[{owner}.gitea.example.com]
SigLevel = Required
Server = https://gitea.example.com/api/packages/{owner}/arch/{repository}/{architecture}
佔位符描述
owner套件的擁有者。
repository要使用的倉庫。
architecture要使用的架構。

請參閱擁有者的套件概述以查看可用的 repositoryarchitecture

如果註冊表是私有的,請在 URL 中提供憑證。您可以使用密碼或 個人訪問令牌

Server = https://{username}:{your_password_or_token}@gitea.example.com/api/packages/{owner}/arch/{repository}/{architecture}

發布套件

要發布 Arch 套件,請執行 HTTP PUT 操作,請求體中包含套件內容。

PUT https://gitea.example.com/api/packages/{owner}/arch/{repository}
參數描述
owner套件的擁有者。
repository倉庫可以用來分組套件或只是 core 或類似的。

使用 HTTP 基本身份驗證的範例請求:

curl --user your_username:your_password_or_token \
--upload-file path/to/file.pkg.tar.zst \
https://gitea.example.com/api/packages/testuser/arch/core

如果您使用 2FA 或 OAuth,請使用 個人訪問令牌 代替密碼。

您不能將同名文件兩次發布到套件中。您必須先刪除現有的套件文件。

服務器響應以下 HTTP 狀態碼。

HTTP 狀態碼含義
201 Created套件已發布。
400 Bad Request套件的某些部分無效。錯誤消息包含更多信息。
409 Conflict套件中已存在具有相同參數組合的套件文件。

安裝套件

要安裝套件,請運行 pacman 同步命令:

pacman -Sy {package_name}
參數描述
package_name套件名稱。

刪除套件

要刪除 Arch 套件,請執行 HTTP DELETE 操作。如果沒有文件剩餘,這也會刪除套件版本。

DELETE https://gitea.example.com/api/packages/{owner}/arch/{repository}/{package_name}/{package_version}/{architecture}
參數描述
owner套件的擁有者。
repository要使用的倉庫。
architecture套件架構。
package_name套件名稱。
package_version套件版本。

使用 HTTP 基本身份驗證的範例請求:

curl --user your_username:your_token_or_password -X DELETE \
https://gitea.example.com/api/packages/testuser/arch/core/test-package/1.0.0/x86-64

服務器響應以下 HTTP 狀態碼。

HTTP 狀態碼含義
204 No Content成功
404 Not Found未找到套件或文件。