This plugin enables the movement of package files outside of the standard composer vendor directory via symlink or copying.
This plugin enables the following:
- Linking of entire package directory to a custom installation folder
- Linking of specific files from within a package to a custom install folder
- Linked files can be renamed as required
Packages (or their specific files) will be linked as per configuration when it is either installed or updated and unlinked when uninstalled.
Any linked package will still exist within the composer vendor directory as well as any configured custom installation path.
- A composer based PHP project.
- Composer
^2
- PHP
^7.3 || ^8.0
This plugin knowingly consumes deprecated functionality within composer core to ensure its compatibility with all current versions of composer 2.x. Update to the latest version of composer to ensure that when this deprecated code is removed from the plugin your installation will not be effected.
$ composer require jparkinson1991/composer-linker-plugin
This plugin will invoke automatically after a package is installed, updated or uninstalled.
To have that package handled by this plugin simply provide configuration for it. Packages will
be linked
as per configuration on install and update. Packages will be unlinked
as per configuration on uninstall.
All defined configuration will be processed when this plugin is installed and uninstalled. On
install all configuration will be linked
. On uninstall all configuration will be unlinked
.
Commands can be used manually trigger a link
/unlink
. Commands will only be able to process that which exists in configuration.
Link all packages as defined in configuration.
$ composer composer-linker-plugin:link
$ composer clp-link
Link a single package from configuration. Package must be installed and configuration must exist for it.
$ composer composer-linker-plugin:link package/name
$ composer clp-link package/name
Link a multiple packages from configuration. Packages must be installed and configuration must exist for them.
$ composer composer-linker-plugin:link package/name second/package third/package ...
$ composer clp-link package/name second/package third/package ...
Unlink all packages as defined in configuration.
$ composer composer-linker-plugin:unlink
$ composer clp-unlink
Unlink a single package from configuration. Package must be installed and configuration must exist for it.
$ composer composer-linker-plugin:unlink package/name
$ composer clp-unlink package/name
Unlink a multiple packages from configuration. Packages must be installed and configuration must exist for them.
$ composer composer-linker-plugin:unlink package/name second/package third/package ...
$ composer clp-unlink package/name second/package third/package ...
All plugin configuration exists within the extra
section of the project's composer.json
file under the linker-plugin
key.
In it's simplest form, this plugin can link a package directory to a given installation path.
{
"extra": {
"linker-plugin": {
"links": {
"vendor/package": "custom/install/dir"
}
}
}
}
Relative custom installation directories will be resolved from the project root. I.e. The directory containing the composer.json file. Absolute paths will be treat as is.
For more granular control of links, complex link objects can be defined using an object with the structure below.
{
"extra": {
"linker-plugin": {
"links": {
"vendor/package": {
"dir": "custom/install/dir",
"files": ...,
"options": ...
}
}
}
}
}
When defining complex link objects the dir
element is required. Both the files
and options
elements are optional. Empty files
or options
objects will be treat as an error. Do not include them if they are not needed.
A selection of files from within the package directory can be handpicked to be linked only. If the files
element of a complex link exists, only those files will be linked.
When definining file mappings:
Source files
are always treat as relative to the package's install directory.File destinations
- If relative, are resolved from the link's custom installation directory.
- If absolute, are treat as is.
Important: The same source file may be mapped to multiple destinations however each destination must be unique within the link definition.
File mappings can be defined as both objects and arrays.
{
"extra": {
"linker-plugin": {
"links": {
"vendor/package": {
"dir": "custom/install/dir",
"files": [
"PackageFile1.php",
{
"PackageFile2.php": "includes/PackageFile2.php",
"PackageFile3.php": {
"PackageFile3-Dest1.php",
"PackageFile3-Dest2.php"
}
}
]
}
}
}
}
}
When using an array to define file mappings:
- Flat strings (
PackageFile1.php
)- Will be treat as having the source and destination
- Key Value pairs (
PackageFile2.php
)- Key will be treat as the source file
- Value will be treat as the destination
- Key to Multi Value objects (
PackageFile3.php
)- Key will be treat as the source file
- Each value of the object will be treat as a separate destination for that source file.
{
"extra": {
"linker-plugin": {
"links": {
"vendor/package": {
"dir": "custom/install/dir",
"files": {
"PackageFile1.php": "includes/PackageFile1.php",
"PackageFile2.php": {
"PackageFile2-Dest1.php",
"PackageFile2-Dest2.php"
}
}
}
}
}
}
}
When defining file mappings as an object, all mappings must define a source file
.
- Key Value pairs (
PackageFile1.php
)- Key will be treat as the source file
- Value will be treat as the destination
- Key to Multi Value objects (
PackageFile2.php
)- Key will be treat as the source file
- Each value of the object will be treat as a separate destination for the source file.
To define link level options, include the options
object within a complex link configuration.
{
"extra": {
"linker-plugin": {
"links": {
"vendor/package": {
"dir": "custom/install/dir",
"options": {}
}
}
}
}
}
Any of the plugin options can be placed within a complex link configuration's options
object.
Link level options will override any global options set for the plugin.
Plugin level options can be defined in the options
object.
The options
object is optional and if not included the default implied options will be used.
{
"extra": {
"linker-plugin": {
"links": {},
"options": {}
}
}
}
Any defined plugin option will be applied to all link configurations unless overridden.
To enable the copying of files when linking, define the copy
option with a boolean
value.
{
"extra": {
"linker-plugin": {
"links": {},
"options": {
"copy": true
}
}
}
}
If linking package's or their files to nested directories within a project, it may be useful to have the plugin delete the orphan directories of the link when it's associated package is uninstalled.
Directories are only treat as orphans if they are empty.
Orphan directories will not be cleaned outside of the composer project's root directory.
As an example
- Project root:
/var/www/composer-project
- Linked directory:
/var/www/composer-project/nested/link/directory
- Orphan directories after uninstall
/var/www/composer-project/nested/link
/var/www/composer-project/nested
To enable deletion of a link configurations's orphan directories after it's associated package is uninstalled, define the delete-orphans
option with a boolean
value.
{
"extra": {
"linker-plugin": {
"links": {},
"options": {
"delete-orphans": true
}
}
}
}
The default implied options are as follows
{
"extra": {
"linker-plugin": {
"links": {},
"options": {
"copy": false
"delete-orphans": false
}
}
}
}
SemVer for versioning. For the versions available, see the tags on this repository.
This project is licensed under the GNU GPLv3 License - see the LICENSE file for details