跳至主要内容
版本:1.23.6

Swift 套件註冊表

為您的用戶或組織發布 Swift 套件。

需求

要使用 Swift 套件註冊表,您需要使用 swift 來消費和使用 HTTP 客戶端(如 curl)來發布套件。

配置套件註冊表

要註冊套件註冊表並提供憑證,請執行:

swift package-registry set https://gitea.example.com/api/packages/{owner}/swift
swift package-registry login https://gitea.example.com/api/packages/{owner}/swift --username {username} --password {password}
佔位符描述
owner套件的擁有者。
username您的 Gitea 用戶名。
password您的 Gitea 密碼。如果您使用 2FA 或 OAuth,請使用 個人訪問令牌 代替密碼。

登錄是可選的,僅在套件註冊表是私有時需要。

發布套件

首先,您需要打包套件的內容:

swift package archive-source

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

curl -X PUT --user {username}:{password} \
-H "Accept: application/vnd.swift.registry.v1+json" \
-F source-archive=@/path/to/package.zip \
-F metadata={metadata} \
https://gitea.example.com/api/packages/{owner}/swift/{scope}/{name}/{version}
佔位符描述
username您的 Gitea 用戶名。
password您的 Gitea 密碼。如果您使用 2FA 或 OAuth,請使用 個人訪問令牌 代替密碼。
owner套件的擁有者。
scope套件範圍。
name套件名稱。
version套件版本。
metadata(可選)套件的元數據。JSON 編碼的 https://schema.org/SoftwareSourceCode 子集

如果已經存在同名同版本的套件,您不能發布該套件。您必須先刪除現有的套件。

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

HTTP 狀態碼含義
201 Created套件已發布。
400 Bad Request套件無效。
409 Conflict套件中已存在具有相同參數組合的文件。

安裝套件

要從套件註冊表中安裝 Swift 套件,請在 Package.swift 文件的依賴項列表中添加:

dependencies: [
.package(id: "{scope}.{name}", from:"{version}")
]
參數描述
scope套件範圍。
name套件名稱。
version套件版本。

之後執行以下命令來安裝它:

swift package resolve