pact-foundation/composer-downloads-plugin
最新稳定版本:v2.1.1
Composer 安装命令:
composer require pact-foundation/composer-downloads-plugin
包简介
Composer plugin for downloading additional files within any composer package.
README 文档
README
This plugin allows you to download extra files and extract them within your package.
This is an updated version of civicrm/composer-downloads-plugin. It adds support for more archive files and allow custom variables.
Example
Suppose your PHP package foo/bar relies on an external archive file (examplelib-1.1.0-windows-amd64.zip on Windows, or examplelib-1.1.0-linux-x86_64.tar.gz on Linux, or examplelib-1.1.0-darwin-x86_64.tar.gz on MacOS):
{
"name": "foo/bar",
"require": {
"pact-foundation/composer-downloads-plugin": "^1.0"
},
"extra": {
"downloads": {
"examplelib": {
"url": "https://example.com/examplelib-{$version}-{$os}-{$architecture}${$musl}.{$extension}",
"path": "extern/{$id}",
"version": "1.1.0",
"variables": {
"{$musl}": "PHP_OS === 'Linux' && musl() === true ? '-musl' : ''",
"{$os}": "strtolower(PHP_OS_FAMILY)",
"{$architecture}": "strtolower(php_uname('m'))",
"{$extension}": "PHP_OS_FAMILY === 'Windows' ? 'zip' : 'tar.gz'",
},
"ignore": ["tests", "doc", "*.md"],
"hash": {
"algo": "sha256",
"value": "08fbce50f84d89fdf1fdef425c7dd1a13c5c023fa87f453ba77db4df27d273c0"
}
}
}
}
}
When a downstream user of foo/bar runs composer require foo/bar, it will download and extract the archive file to vendor/foo/bar/extern/examplelib.
Attribute:
-
url: The URL to the extra file. -
path: The releative path where content will be extracted. -
type: (Optional) Determines how the download is handled. If omit, the extension inurlwill be used to detect.- Archive types (The archive file
urlwill be downloaded and extracted topath):zip: . Support extension*.ziprar: Support extension*.rarxz: Support extension*.tar.xztar: Support extensions*.tar.gz,*.tar.bz2,*.tar,*.tgz
- File types (The file
urlwill be downloaded and placed atpath):filephar: The file will be mark as executable.gzip: The*.gzfile will be extracted to a file that will be placed atpath.
- Archive types (The archive file
-
ignore: (Optional) A list of a files that should be omited from the extracted folder.- This supports a subset of
.gitignorenotation. - Only useful with archive types.
- This supports a subset of
-
executable: (Optional) Indicate list of files should be mark as executable.- For archive types: the value should be a list of extracted files
- For file types: the value should be boolean (true/false)
-
version: (Optional) A version number for the downloaded artifact.- This has no functional impact on the lifecycle of the artifact.
- It can affect the console output.
- It can be used as a variable.
-
variables: (Optional) List of custom variables. -
hash: (Optional) Verify contents of the file downloaded fromurl. If hash values are not the same: file will be deleted & composer will throw exception.algo: Name of selected hashing algorithm (i.e. "md5", "sha256", "haval160,4", etc..). For a list of supported algorithms seehash_algos()value: Expected value of hash function
Variables
Supported Attribute
Only following attribute support variables:
urlpathignore
Default Variables
{$id}: The identifier of the download. (In the example, it would beexamplelib.){$version}: Just a text defined in theversionattribute, if not defined, the value will be empty string ("").
Custom Variables
- The format will be
"{$variable-name}": "EXPRESSION-SYNTAX-EVALUATED-TO-STRING" - More about the syntax at Expression Syntax.
- The syntax must be evaluated into a
string.
Methods
Custom variable support these methods:
rangestrtolowerphp_unamein_arraystr_containsstr_starts_withstr_ends_withmatchesmusl
Constants
Custom variable support these constants:
PHP_OSPHP_OS_FAMILYPHP_SHLIB_SUFFIXDIRECTORY_SEPARATOR
Default Attributes
You may set default attributes for all downloads. Place them under *, as in:
{
"extra": {
"downloads": {
"*": {
"path": "bower_components/{$id}",
"ignore": ["test", "tests", "doc", "docs"],
"variables": {
"{$extension}": "zip"
}
},
"jquery": {
"url": "https://github.com/jquery/jquery-dist/archive/1.12.4.{$extension}"
},
"jquery-ui": {
"url": "https://github.com/components/jqueryui/archive/1.12.1.{$extension}"
}
}
}
}
Document
See more at Doc
Contributing
Pull requests are welcome, please send pull requests.
If you found any bug, please report issues.
Authors
- Rob Bayliss - Composer Extra Files
- Tim Otten and contributors - Composer Download Plugin
- Tien Vo and contributors - this project
License
This package is available under the MIT license.
统计信息
- 总下载量: 285.04k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 1
- 依赖项目数: 2
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2024-03-27