{"files": [{"pattern"或"aql": "[必选]","target": "[可选,默认值:。/]","props": "[可选]","递归":"[可选,默认值:true]", "flat": "[可选,默认值:false]", "build": "[可选]"," explosive ": "[可选,默认值:false]", "排他":["[可选]"],"sortBy":["[可选]"],"sortOrder": "[可选,默认值:'asc']", "limit":[可选],"offset":[可选]}]}
地点:
元素 |
描述 |
---|---|
模式 |
[如果未指定'aql'则为必选项] |
目标 |
(可选) 为灵活地指定目标路径,可以以。的形式包含占位符 |
aql |
[如果没有指定'pattern'则为必选项] |
道具 |
(可选) |
平 |
(默认值:false) |
递归 |
(默认值:真实) |
构建 |
(可选) 属性格式为build-name/build-number。 如果未指定版本号,或对版本号使用关键字LATEST,则使用最新发布的版本号。 |
爆炸 |
(默认值:false) 如果为true,则下载完成后会提取下载的归档文件。存档文件本身在本地删除。支持的归档类型为:zip、tar;tar.gz;和tgz |
除外责任 |
(可选的。仅当指定'pattern'时适用] 模式的数组(用方括号括起来)禁止下载。与“pattern”属性不同,“exclusions”不能将存储库作为模式路径的一部分。您可以使用通配符来指定多个工件。 例如:["*.sha1","*.md5"] |
sortBy | (可选) 由分号分隔的字段组成的排序列表。字段必须是“items”AQL域的一部分。有关更多信息,请阅读AQL文档. |
排序方式 | (默认值:asc) 控件中字段的顺序sortBy选项应该排序。接受asc或desc. |
限制 | (可选) 要获取的最大项数。通常与the连用sortBy选择。 |
抵消 | (可选) 获取项的偏移量(即应该跳过多少项)。通常与the连用sortBy选择。 |
目前sortBy,排序方式,限制而且抵消在TeamCity中不支持。
上传规格模式
[{{“文件”:“模式”:“(强制性)”,“目标”:“(强制性)”,“道具”:“(可选)”,“递归”:“可选的,默认值是“真正的””、“平”:“(可选的,默认值是“真正的”)”,“正则表达式”:“[可选的,默认值:'假']”、“爆炸”:“(可选的,默认值:false)”,“除外责任”:["(可选)"]}]}
地点:
元素 |
描述 |
---|---|
模式 |
(强制) 指定应该上传到Artifactory的工件的本地文件系统路径。您可以使用regexp属性指定的通配符或正则表达式来指定多个工件。 |
目标 |
(强制) 在Artifactory中指定目标路径,格式如下:[repository_name]/[repository_path] 如果模式以斜杠结束,例如“repo-name/a/b/”,那么“b”被假设为Artifactory中的一个文件夹,文件被上传到其中。以“repo-name/a/b”为例,在Artifactory中将上传的文件重命名为“b”。 为灵活地指定上载路径,可以以的形式包含占位符 |
道具 |
(可选) |
平 |
(默认值:真实) |
递归 |
(默认值:真实) |
正则表达式 |
(默认值:false) 如果为真,该命令将把pattern属性解释为正则表达式,该属性描述要上传的工件的本地文件系统路径。 如果为false,该命令将模式属性解释为通配符表达式。 |
爆炸 |
(默认值:false) 如果为true,则上传的归档文件在上传后会被提取。存档文件本身并不保存在Artifactory中。支持的归档类型为:zip、tar;tar.gz;和tgz |
除外责任 |
(可选) 不允许上传的模式数组(用方括号括起来)。
允许使用由regexp属性指定的通配符或正则表达式。如果使用regexp,则需要使用反斜杠“\”来转义表达式中使用的任何保留字符(例如“。”、“?”等)。
例如:["*.sha1","*.md5"] |
使用占位符
文件规格提供了巨大的灵活性上传,或下载文件通过使用通配符或带有占位符的正则表达式。
模式属性中括号内的任何通配符都可以与目标属性中相应的占位符相匹配,以便在下载或上传后确定工件的名称。目录的根路径下的所有zip文件将被下载my-local-repo
存储库,它们的名称中包含破折号。文件在下载时重命名,用两个破折号替换破折号。
{“文件”:[{“模式”:“my-local-repo / (*) - (*) . zip”,“目标”:“法国人/ {1},{2}. zip”、“递归”:“false”}]}
例子
示例1:文件下的所有文件all-my-frogs
目录中的my-local-repo
存储库到法国人/ all-my-frogs
目录中。
{“文件”:[{“模式”:“my-local-repo / all-my-frogs /”,“目标”:“讨厌的/”}]}
示例2:将AQL查询检索的所有文件下载到本地/输出
目录中。
{"files": [{"aql":{"项。找到":{“回购”:“my-local-repo”,“或“美元:[{”和“美元:[{“路径”:{" $匹配”:“。”}, "name": {"$match": "a1. "在" } } ] }, { "$and": [ { "path": { "$match": "*" }, "name": { "$match": "a1.in" } } ] } ] } }, "target": "local/output/" } ] }
示例3:上传
- 目录下的所有zip文件
2022世界杯阿根廷预选赛赛程
目录到邮政编码
文件夹,在all-my-frogs存储库。
和 - 目录下的所有TGZ文件
2022世界杯阿根廷预选赛赛程
目录到tgz文件夹,在all-my-frogs存储库。 - 用type = zip和status = ready标记所有zip文件。
- 用type = tgz和status = ready标记所有tgz文件。
{“文件”:[{“模式”:“资源/ * . zip”,2022世界杯阿根廷预选赛赛程“目标”:“my-repo / zip /”,“道具”:“type =邮政;状态=准备”},{/ *”模式”:“资源。tgz”、“目标”:“my-repo / tgz”、“道具”:“类型= tgz;状态=准备”}]}
示例4:文件下的所有文件all-my-frogs
目录中的my-local-repo
存储库除了用于“。zip”文件和“道具”。的文件
{“文件”:[{“模式”:“my-local-repo / all-my-frogs /”,“除外责任”:[“* . zip”、“all-my-frogs /道具。*"]}]}
例5:从my-local-repo存储库下载三个最旧的zip文件到local/output目录。
{“文件”:[{“模式”:“my-local-repo / * . zip”、“sortBy”:“创造”,“限制”:3,“目标”:“本地/输出/}]}
例6:从my-local-repo存储库下载三个最旧的zip文件到local/output目录。本文件规范使用AQL。
{"files": [{"aql":{"项。找到":{“回购”:“my-local-repo”,“或“美元:[{”和“美元:[{“路径”:{" $匹配 ": "*" }, " 名称”:{" $匹配”:“* . zip " } } ] } ] } }, " sortBy”:“创造”,“限制”:3,“目标”:“本地/输出/“}}
例7:从generic-local存储库,它属于以下版本,已经发布到Artifactory - build名称:构建以及建筑编号:10.
{“文件”:[{“模式”:“generic-local”、“构建”:“构建/ 10”}]}
例8:从generic-local存储库,它属于构建build,已经发布到Artifactory。发布到Artifactory的最新构建号的构件将被下载。
{“文件”:[{“模式”:“generic-local”、“构建”:“构建”}]}
模式验证
JSON模式允许您注释和验证JSON文件。JFrog文件规范模式可在JSON模式存储目录和以下链接:https://github.com/jfrog/jfrog-cli/blob/v2/schema/filespec-schema.json.
使用Jetbrains ide (Intellij IDEA, Webstorm, Goland等)?
文件规范模式自动应用于以下文件模式:
* * / * . json文件规范
* * . json文件规范
* .filespec
使用Visual Studio代码?
要应用文件规范模式验证,请安装JFrog VS-Code扩展.
或者,将以下内容复制到设置中。json文件:
“json。schema ": [{"fileMatch": ["**/filespecs/*. schema ": ["json”、“*文件规范*。json”、“*。Filespec "], "url": "https://raw.githubusercontent.com/jfrog/jfrog-cli/v2/schema/filespec-schema.json"}]