与大多数 JFrog 客户端一样,Jenkins Artifactory 插件支持用于下载和上传通用文件的文件规范。文件规范架构在此处描述。在为下载文件创建文件规范时,您可以选择使用“模式”属性,其中可以包含通配符。例如,以下规范将 my-local-repo 存储库中的所有 zip 文件下载到本地 froggy 目录中:
{
"files": [
{
"pattern": "my-local-repo/*.zip",
"target": "froggy/"
}
]
}
或者,您可以使用“aql”而不是“模式”。以下规范提供与前一个相同的结果:
{
"files": [
{
"aql": {
"items.find": {
"repo": "my-local-repo",
"$or": [
{
"$and": [
{
"path": {
"$match": "*"
},
"name": {
"$match": "*.zip"
}
}
]
}
]
}
},
"target": "froggy/"
}
]
}
File Specs 中允许的 AQL 语法不包括 Artifactory Query Language 允许的所有内容。例如,您不能使用“include”或“sort”子句。这些限制已经到位,以使响应结构已知且恒定。
但是,无论您选择使用“模式”还是“aql”,文件规范仍然可以进行排序。支持抛出“sortBy”、“sortOrder”、“limit”和“offset”文件规范属性。例如,以下 File Spec 将仅下载 3 个最大的 zip 文件:
{
"files": [
{
"aql": {
"items.find": {
"repo": "my-local-repo",
"$or": [
{
"$and": [
{
"path": {
"$match": "*"
},
"name": {
"$match": "*.zip"
}
}
]
}
]
}
},
"sortBy": ["size"],
"sortOrder": "desc",
"limit": 3,
"target": "froggy/"
}
]
}
你可以用“pattern”代替“aql”做同样的事情:
{
"files": [
{
"pattern": "my-local-repo/*.zip",
"sortBy": ["size"],
"sortOrder": "desc",
"limit": 3,
"target": "local/output/"
}
]
}
您可以在此处阅读有关文件规范的更多信息。
(在此处回答此问题后,我们还使用这些示例更新了 File Specs 文档)。