This is for i-MSCP composer package authors to require in their composer.json.
It will install their package to the correct location based on the specified
package type.
| Installer | Types |
|---|---|
| i-MSCP | imscp-pluginimscp-themeimscp-tool |
| Roundcube | roundcube-plugin |
This is an example for the i-MSCP PhpMyAdmin composer package. The only
important parts to set in the composer.json file are "type": "imscp-tool"
which describes what package is and "require": { "imscp/composer-installers": "^1.0" }
which tells composer to load the custom installers.
{
"name": "imscp/phpmyadmin",
"type": "imscp-tool",
"require": {
"imscp/composer-installers": "^1.0"
}
}This would install the package to the gui/public/tools/phpmyadmin/ path.
i-MSCP developers and/or administrators can override the install paths in
different ways, using the installer-paths extra in the composer.json of the
i-MSCP instance :
{
"extra": {
"installer-paths": {
"custom/path/{$name}/": [
"konzeptplus/imscp-api",
"imscp/dns-provisioning"
]
}
}
}would install both the konzeptplus/imscp-api and imscp/dns-provisioning
packages into the custom/path/{$name}/ path.
{
"extra": {
"installer-paths": {
"custom/path/{$name}/": [
"type:imscp-plugin"
]
}
}
}would install any package of type imscp-plugin into the
custom/path/{$name}/ path.
{
"extra": {
"installer-paths": {
"custom/path/{$name}/": [
"vendor:konzeptplus"
]
}
}
}would install any package provided by the konzeptplus vendor into the
custom/path/{$name}/ path.
In all the above cases, the following variables are available for use in paths:
{$name}: Package name{$vendor}Vendor name{$type}Package type
As a package author, you can name it differently when installed by using the
installer-name extra in the package composer.json.
If you have a package named imscp/roundcube of type imscp-tool, it would
be installed in the gui/public/tools/roundcube path. To provide this
package as default Webmail, you need override its name as follows:
{
"name": "imscp/roundcube",
"type": "imscp-tool",
"extra": {
"installer-name": "webmail"
}
}By doing so, the package would be installed in the gui/public/tools/webmail
path.
There may be time when you want to disable one or more installers from
imscp/composer-installers. For instance, if you are managing a package that
uses a specific installer that conflicts with imscp/composer-installers but
also have a dependency on a package that depends on imscp/composer-installers.
Installers can be disabled by specifying the extra installer-disable
property. If set to true, "all", or "*" all installers will be disabled.
{
"extra": {
"installer-disable": true
}
}Otherwise a single installer or an array of installers may be specified.
{
"extra": {
"installer-disable": [
"imscp",
"roundcube"
]
}
}Note: Using a global disable value (true, "all", or "*") will take
precedence over individual installer names if used in an array. The example
below will disable all installers.
{
"extra": {
"installer-disable": [
"imscp",
"all"
]
}
}