云客户?
免费开始>
在MyJFrog中升级>
云的新功能>





概述

Artifactory支持CocoaPods存储库在其之上。现有的支持用于高级工件管理。

对CocoaPods的人工支持提供:

  1. 能够从本地和远程存储库将CocoaPods包从Artifactory提供给pod命令行工具。
  2. 计算托管在Artifactory本地存储库中的pod的元数据。
  3. 访问远程CocoaPods Specs存储库(例如https://github.com/CocoaPods/Specs)通过远程存储库它提供了通常的代理和缓存功能。
  4. 根据项目或开发团队分配访问权限的能力。

配置

局部存储库

启用CocoaPods包元数据集的计算CocoaPods成为包类型当您创建本地CocoaPods存储库时。

新增CocoaPods本地存储库

页面内容

部署豆荚

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库,请遵循以下步骤:

  1. 创建一个新的远程存储库并设置CocoaPods成为它的包类型
  2. 设置库的关键值,然后输入https://github.comURL字段,如下所示
    CocoaPods远程存储库

  3. 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,请执行以下步骤:

  1. 安装cocoapods-art插件:

    Gem安装cocoapods-art

    使用自制程序?

    我们建议将CocoaPods客户端和cocoapod-art插件都作为gem安装。与Homebrew一起安装可能会导致插件所依赖的CocoaPods钩子机制出现问题。

  2. 的方法添加一个Artifactory存储库Pod 'repo-art add'命令:

    Pod repo-art add  http://localhost:8081/artifactory/api/pods/


  3. 添加存储库后,在您的Podfile

    在Podfile中添加人工源代码
    插件'cocoapods-art',:sources => ['']


在没有主仓库的情况下工作?

如果您已经从系统中删除了CocoaPods Master存储库,由于已知的问题使用CocoaPods stats插件,你需要在你的Podfile中添加以下内容,或者在你的环境中添加相应的变量:

ENV['COCOAPODS_DISABLE_STATS'] = 'true'

详情请参考JFrogJira

其中本地回购名称是您在添加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文件:

. netc文件示例
机器artprod.company.com登录管理员密码密码

因为Artifactory还支持使用您的API密匙你可以用这个代替你的密码:

. netc文件使用您的API密钥
登录admin密码AKCp2TfQM58F8FTkXo8qSJ8NymwJivmagefBqoJeEBQLSHCZusEH6Z2dmhS1siSxZTHoPPyUW

使用加密密码

我们建议使用加密密码,而不是明文密码。详情请参阅集中安全密码


清理本地Pod缓存

pod客户机保存已下载的pod的缓存以及元数据。
我们建议在第一次使用Artifactory之前删除CocoaPods缓存(包和元数据响应)。这是为了确保您的缓存只包含来自Artifactory请求的元素,而不是直接来自其他spec仓库的元素。

清除pod缓存使用:

清洁舱缓存
豆荚缓存清理

观看视频

观看这个简短的屏幕演示,了解在Artifactory中托管rpm是多么容易。

版权所有©2022 JFrog Ltd.