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