跳至主要内容
版本:1.24.5

Arch 儲存庫

在您的使用者或組織中發佈 Arch 軟體包。 Arch 儲存庫的功能像是一個完整的[鏡像Arch 儲存庫](https://wiki.archlinux.org/title/mirrors\),需要調整系統的`/etc/pacman.conf`文件。

需求

系統需要安裝有HTTP客戶端像是curl來下載文件,且必須安裝有pacman軟體包管理工具。

配置 Arch 儲存庫

Arch 儲存庫的軟體都有gpg簽名驗證,所以需要匯入驗證需要的公鑰,下面是下載公鑰的範例。

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

匯入公鑰之前,請先確認是否為該 Arch 儲存庫的公鑰,下面是檢視公鑰的範例。確認完成請記第二行的16為的key id

gpg --show-keys repository.key

接下來要匯入到pacman的鑰匙圈中,下面是匯入的範例。

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

匯入驗證的公鑰,接下來要修改pacman的配置檔,位置是/etc/pacman.conf,內容如下。

[{owner}.gitea.example.com]
SigLevel = Required
Server = https://gitea.example.com/api/packages/{owner}/arch/{repository}/{architecture}
占位符描述
owner軟體包所有者
repository要使用的存放庫名
architecture軟體包的架构

如果註冊表是私有的,請在 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要使用的存放庫名

使用 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

如果您使用的是双重身份驗證或 OAuth,請使用個人訪問令牌代替密碼。 您不能将具有相同名稱的文件两次發佈到一个包中。您必須首先删除現有的包文件。

服务器将以以下的 HTTP 狀態碼回應:

HTTP 狀態碼含义
201 Created軟體包已發佈。
400 Bad Request軟體包的名稱、版本、分支、存放庫或架构無效。
409 Conflict具有相同參數组合的包文件已存在于軟體包中。

安裝軟體包

要从 AArch 儲存庫安裝軟體包,請執行以下命令:

pacman -Sy {package_name}
Parameter含义
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未找到軟體包或文件