This chapter will describe the config
section of the composer.json
schema.
The timeout in seconds for process executions, defaults to 300 (5mins). The duration processes like git clones can run before Composer assumes they died out. You may need to make this higher if you have a slow connection or huge vendors.
To disable the process timeout on a custom command under scripts
, a static
helper is available:
{
"scripts": {
"test": [
"Composer\\Config::disableProcessTimeout",
"phpunit"
]
}
}
Defaults to false
. If true
, the Composer autoloader will also look for classes
in the PHP include path.
Defaults to auto
and can be any of source
, dist
or auto
. This option
allows you to set the install method Composer will prefer to use. Can
optionally be a hash of patterns for more granular install preferences.
{
"config": {
"preferred-install": {
"my-organization/stable-package": "dist",
"my-organization/*": "source",
"partner-organization/*": "auto",
"*": "dist"
}
}
}
Note: Order matters. More specific patterns should be earlier than more relaxed patterns. When mixing the string notation with the hash configuration in global and package configurations the string notation is translated to a
*
package pattern.
What to do after prompting for authentication, one of: true
(always store),
false
(do not store) and "prompt"
(ask every time), defaults to "prompt"
.
Defaults to ["https", "ssh", "git"]
. A list of protocols to use when cloning
from github.com, in priority order. By default git
is present but only if secure-http
is disabled, as the git protocol is not encrypted. If you want your origin remote
push URLs to be using https and not ssh ([email protected]:...
), then set the protocol
list to be only ["https"]
and Composer will stop overwriting the push URL to an ssh
URL.
A list of domain names and oauth keys. For example using {"github.com": "oauthtoken"}
as the value of this option will use oauthtoken
to access
private repositories on github and to circumvent the low IP-based rate limiting
of their API. Composer may prompt for credentials when needed, but these can also be
manually set. Read more on how to get an OAuth token for GitHub and cli syntax
here.
A list of domain names and oauth keys. For example using {"gitlab.com": "oauthtoken"}
as the value of this option will use oauthtoken
to access
private repositories on gitlab. Please note: If the package is not hosted at
gitlab.com the domain names must be also specified with the
gitlab-domains
option.
Further info can also be found here
A list of domain names and private tokens. Private token can be either simple
string, or array with username and token. For example using {"gitlab.com": "privatetoken"}
as the value of this option will use privatetoken
to access
private repositories on gitlab. Using {"gitlab.com": {"username": "gitlabuser", "token": "privatetoken"}}
will use both username and token for gitlab deploy
token functionality (https://docs.gitlab.com/ee/user/project/deploy_tokens/)
Please note: If the package is not hosted at
gitlab.com the domain names must be also specified with the
gitlab-domains
option. The token must have
api
or read_api
scope.
Further info can also be found here
Defaults to false
. If set to true all HTTPS URLs will be tried with HTTP
instead and no network level encryption is performed. Enabling this is a
security risk and is NOT recommended. The better way is to enable the
php_openssl extension in php.ini. Enabling this will implicitly disable the
secure-http
option.
Defaults to true
. If set to true only HTTPS URLs are allowed to be
downloaded via Composer. If you really absolutely need HTTP access to something
then you can disable it, but using Let's Encrypt to
get a free SSL certificate is generally a better alternative.
A list of domain names and consumers. For example using {"bitbucket.org": {"consumer-key": "myKey", "consumer-secret": "mySecret"}}
.
Read more here.
Location of Certificate Authority file on local filesystem. In PHP 5.6+ you should rather set this via openssl.cafile in php.ini, although PHP 5.6+ should be able to detect your system CA file automatically.
If cafile is not specified or if the certificate is not found there, the directory pointed to by capath is searched for a suitable certificate. capath must be a correctly hashed certificate directory.
A list of domain names and username/passwords to authenticate against them. For
example using {"example.org": {"username": "alice", "password": "foo"}}
as the
value of this option will let Composer authenticate against example.org.
More info can be found here.
A list of domain names and tokens to authenticate against them. For example using
{"example.org": "foo"}
as the value of this option will let Composer authenticate
against example.org using an Authorization: Bearer foo
header.
Lets you fake platform packages (PHP and extensions) so that you can emulate a
production env or define your target platform in the config. Example: {"php": "7.0.3", "ext-something": "4.0.3"}
.
This will make sure that no package requiring more than PHP 7.0.3 can be installed regardless of the actual PHP version you run locally. However it also means the dependencies are not checked correctly anymore, if you run PHP 5.6 it will install fine as it assumes 7.0.3, but then it will fail at runtime.
Therefore if you use this it is recommended, and safer, to also run the
check-platform-reqs
command as part of your
deployment strategy.
If a dependency requires some extension that you do not have installed locally
you may ignore it instead by passing --ignore-platform-req=ext-foo
to update
,
install
or require
. In the long run though you should install required
extensions as if you ignore one now and a new package you add a month later also
requires it, you may introduce issues in production unknowingly.
Defaults to vendor
. You can install dependencies into a different directory if
you want to. $HOME
and ~
will be replaced by your home directory's path in
vendor-dir and all *-dir
options below.
Defaults to vendor/bin
. If a project includes binaries, they will be symlinked
into this directory.
Defaults to C:\Users\<user>\AppData\Roaming\Composer
on Windows,
$XDG_DATA_HOME/composer
on unix systems that follow the XDG Base Directory
Specifications, and $home
on other unix systems. Right now it is only
used for storing past composer.phar files to be able to rollback to older
versions. See also COMPOSER_HOME.
Defaults to C:\Users\<user>\AppData\Local\Composer
on Windows,
$XDG_CACHE_HOME/composer
on unix systems that follow the XDG Base Directory
Specifications, and $home/cache
on other unix systems. Stores all the caches
used by Composer. See also COMPOSER_HOME.
Defaults to $cache-dir/files
. Stores the zip archives of packages.
Defaults to $cache-dir/repo
. Stores repository metadata for the composer
type and the VCS repos of type svn
, fossil
, github
and bitbucket
.
Defaults to $cache-dir/vcs
. Stores VCS clones for loading VCS repository
metadata for the git
/hg
types and to speed up installs.
Defaults to 15552000
(6 months). Composer caches all dist (zip, tar, ...)
packages that it downloads. Those are purged after six months of being unused by
default. This option allows you to tweak this duration (in seconds) or disable
it completely by setting it to 0.
Defaults to 300MiB
. Composer caches all dist (zip, tar, ...) packages that it
downloads. When the garbage collection is periodically ran, this is the maximum
size the cache will be able to use. Older (less used) files will be removed
first until the cache fits.
Defaults to false
. Whether to use the Composer cache in read-only mode.
Defaults to auto
. Determines the compatibility of the binaries to be installed.
If it is auto
then Composer only installs .bat proxy files when on Windows. If
set to full
then both .bat files for Windows and scripts for Unix-based
operating systems will be installed for each binary. This is mainly useful if you
run Composer inside a linux VM but still want the .bat proxies available for use
in the Windows host OS.
Defaults to true
. If false
, the Composer autoloader will not be prepended to
existing autoloaders. This is sometimes required to fix interoperability issues
with other autoloaders.
Defaults to null
. String to be used as a suffix for the generated Composer
autoloader. When null a random one will be generated.
Defaults to false
. If true
, always optimize when dumping the autoloader.
Defaults to false
. If true
, the require
command keeps packages sorted
by name in composer.json
when adding a new package.
Defaults to false
. If true
, the Composer autoloader will only load classes
from the classmap. Implies optimize-autoloader
.
Defaults to false
. If true
, the Composer autoloader will check for APCu and
use it to cache found/not-found classes when the extension is enabled.
Defaults to ["github.com"]
. A list of domains to use in github mode. This is
used for GitHub Enterprise setups.
Defaults to true
. If false
, the OAuth tokens created to access the
github API will have a date instead of the machine hostname.
Defaults to ["gitlab.com"]
. A list of domains of GitLab servers.
This is used if you use the gitlab
repository type.
Defaults to true
. Similar to the no-api
key on a specific repository,
setting use-github-api
to false
will define the global behavior for all
GitHub repositories to clone the repository as it would with any other git
repository instead of using the GitHub API. But unlike using the git
driver directly, Composer will still attempt to use GitHub's zip files.
Defaults to true
. Composer allows repositories to define a notification URL,
so that they get notified whenever a package from that repository is installed.
This option allows you to disable that behavior.
Defaults to false
and can be any of true
, false
or "stash"
. This option
allows you to set the default style of handling dirty updates when in
non-interactive mode. true
will always discard changes in vendors, while
"stash"
will try to stash and reapply. Use this for CI servers or deploy
scripts if you tend to have modified vendors.
Defaults to tar
. Overrides the default format used by the archive command.
Defaults to .
. Default destination for archives created by the archive
command.
Example:
{
"config": {
"archive-dir": "/home/user/.composer/repo"
}
}
Defaults to true
. If set to false
, Composer will not create .htaccess
files
in the composer home, cache, and data directories.
Defaults to true
. If set to false
, Composer will not create a composer.lock
file.
Defaults to php-only
which only checks the PHP version. Set to true
to also
check the presence of extension. If set to false
, Composer will not create and
require a platform_check.php
file as part of the autoloader bootstrap.
← Repositories | Runtime →