部署豆荚
CocoaPods客户端不提供部署包的方法,并且主要(尽管不是唯一)依赖于Git存储库来托管pod的代码。
要将pod部署到Artifactory中,您需要使用Artifactory的REST API或者是Web UI。
豆荚很简单tar.gz
文件,其中包含项目代码以及.podspec或.podspec.json描述包元数据的文件。
豆荚的文件
尽管客户端支持更多扩展,但Artifactory CocoaPods本地存储库目前只支持归档为tar.gz的pod
远程存储库
公众CocoaPods Specs回购不包含任何实际的二进制包;它是一个git存储库,包含podspec.json
从包名和版本指向其存储端点的文件。
由于大多数包都托管在GitHub上,因此您需要创建一个远程存储库哪个作为缓存代理github.com。如果有必要,你也可以这样做bitbucket.org或者其他的要访问的远程存储库。
使用版本低于5.1的Stash ?
如果你的包托管在Bitbucket(以前的Stash)上,你需要确保你的Bitbucket服务器上安装了Stash存档插件。
从远程存储库请求的工件(如tar.gz文件)将按需缓存。您可以从远程存储库缓存中删除下载的构件,但是您不能手动将构件部署到远程存储库。
要定义一个远程存储库来代理github.com以及公共Specs库,请遵循以下步骤:
- 创建一个新的远程存储库并设置CocoaPods成为它的包类型
- 设置库的关键值,然后输入
https://github.com
在URL字段,如下所示 - 在CocoaPods设置部分中,选择GitHub随着Git提供者,并保留默认值注册网址(https://github.com/CocoaPods/Specs)。
最后,点击“保存并完成”
规格回购网址
通常,你会指向规格回购网址字段,如上所示。
但是,如果您使用的是私有spec repo,请将URL设置为与配置的URL相同URL字段。
如果远程URL是一个Artifactory实例,则需要在它的URL后面加上/ api /豆荚回购> / <
即。http://art-prod.company.com/artifactory/api/pods/pods-local
Bitbucket专用服务器
使用私人Bitbucket服务器?设置“Git Provider”为“Stash”,然后不Bitbucket都。公共Bitbucket端点会响应私有Bitbucket服务器无法响应的一些API调用,因此,当使用私有Bitbucket服务器时,将Git Provider设置为Stash是很重要的。在这种情况下,URL字段应该是Bitbucket服务器的根目录,Specs Repo URL应该是Bitbucket中Specs Repo的完整URL。
使用Pod命令行
CocoaPods存储库必须在路径中以api/pods作为前缀
当通过Artifactory访问CocoaPods存储库时,存储库URL必须以api /豆荚在小路上。这适用于Pod报告艺术添加命令。
例如,如果您使用Artifactory独立或作为本地服务,您将使用以下URL访问您的CocoaPods存储库:
http://localhost:8081/artifactory/api /豆荚<库关键>
或者,如果您正在使用Artifactory Cloud, URL将是:
https:// < server name > .jfrog.io / artifactory /api /豆荚<库关键>
Artifactory已经更新,可以与最新版本的CocoaPods客户端(0.39.0)无缝协作
使用cocoapods-art
为了在Artifactory中使用CocoaPods,你需要CocoaPods -art插件,它将Artifactory存储库呈现为Specs库和pod源。
你可以下载cocoapods-art插件作为Gem,其源代码可以在GitHub。
要在CocoaPods中使用Artifactory,请执行以下步骤:
安装cocoapods-art插件:
Gem安装cocoapods-art
使用自制程序?
我们建议将CocoaPods客户端和cocoapod-art插件都作为gem安装。与Homebrew一起安装可能会导致插件所依赖的CocoaPods钩子机制出现问题。
的方法添加一个Artifactory存储库Pod 'repo-art add'命令:
Pod repo-art add
http://localhost:8081/artifactory/api/pods/ 添加存储库后,在您的Podfile:
在Podfile中添加人工源代码插件'cocoapods-art',:sources => ['
']
在没有主仓库的情况下工作?
其中本地回购名称是您在添加spec时在本地回购的名称。
Pod repo-art命令
的cocoapods-artPlugin公开了通常使用的大多数命令豆荚回购(即添加,更新,列表等)。使用豆荚repo-art而不是豆荚回购无论何时处理手工支持的规范存储库。
CocoaPods本地规格的仓库位置
~ / .cocoapods /回购
一旦配置了pod命令行工具,每个圆荚体安装
命令将从上面指定的CocoaPods存储库中获取pod。
同步的cocoapods-art
插件的仓库与Artifactory
与cocoapods客户端的默认行为相反,cocoapods-art插件不会在您运行客户端命令(例如install)时自动更新其索引。为了使你的插件索引与你的CocoaPods存储库保持同步,你需要通过执行以下命令来更新它:
Pod报告艺术更新
在没有匿名访问的情况下使用Artifactory
默认情况下,Artifactory允许匿名访问CocoaPods存储库。它的定义是安全|通用配置。详情请参阅允许匿名访问。
如果希望能够跟踪用户与存储库的交互方式,则需要取消选中允许匿名访问设置。这意味着用户需要输入他们的用户名和密码。
不幸的是,pod命令行工具不支持针对http端点的身份验证。的cocoapods-artPlugin通过强制curl (pod用于所有HTTP请求)使用. netrc文件:
机器artprod.company.com登录管理员密码密码
因为Artifactory还支持使用您的API密匙你可以用这个代替你的密码:
登录admin密码AKCp2TfQM58F8FTkXo8qSJ8NymwJivmagefBqoJeEBQLSHCZusEH6Z2dmhS1siSxZTHoPPyUW
使用加密密码
我们建议使用加密密码,而不是明文密码。详情请参阅集中安全密码。
清理本地Pod缓存
pod客户机保存已下载的pod的缓存以及元数据。
我们建议在第一次使用Artifactory之前删除CocoaPods缓存(包和元数据响应)。这是为了确保您的缓存只包含来自Artifactory请求的元素,而不是直接来自其他spec仓库的元素。
清除pod缓存使用:
豆荚缓存清理
观看视频
观看这个简短的屏幕演示,了解在Artifactory中托管rpm是多么容易。