Download the PHP package vaimo/composer-repository-bundle without Composer
On this page you can find all versions of the php package vaimo/composer-repository-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download vaimo/composer-repository-bundle
More information about vaimo/composer-repository-bundle
Files in vaimo/composer-repository-bundle
Package composer-repository-bundle
Short Description Allow packages to be installed from a repository or tarball bundle that have multiple packages in the sub-folders
License MIT
Informations about the package composer-repository-bundle
Vaimo Composer Repository Bundle
Allows composer package installation from repositories or zip files that have multiple packages inside of them or declare certain folder within the project as local repository.
In short: it removes the need to declare each local package as PATH repository and allows users to install things from remote .zip files (by downloading them and registering them - again - as PATH repositories).
More information on recent changes HERE.
Overview
Environment variables can be defined as key value pairs in the project's composer.json
These values will be declared for system-wide use. The main idea of the module is to provide a way to pre-configure any flags for any of the composer plugins in case the flag setting has not been properly exposed to the end-user.
Quick-start
If you want to make local folder behave as if it's a package repository.
- require this plugin
composer require vaimo/composer-repository-bundle
- configure it (see above)
- add module under modules/mypackage with a composer.json (let's say that package name inside composer.json will be myvendor/module-mypackage).
- install it with
composer require myvendor/module-mypackage:dev-my-bundle
The installation will be done from packages that are declared as ...
If you want the files to be mirrored instead on sym-linked, which is the default behaviour, configure the deploy mode for your bundle.
If you have a plan to group your local packages different sub-folders, use wildcards in path definition.
Configuration: adding bundle definition
Can be done against zip file ...
Same can be done against repository (in which case either branch name of change-set reference is required)
Configuration: local directory as repository
The plugin can also be used to configure local project-embedded bundle folders from where modules will become installable.
This allows any module to be installed from
The above (due to it's minimalistic setup) can also be configred as:
Configuration: deploy mode
By default the module makes its own decision on how to deploy the package.
- symlink - done when bundle situated under the project root (bundle is part of the project).
- mirror - done when bundle situates in composer package cache (bundle is part of global composer).
Developer can override this by providing the mode in the bundle configuration.
Configuration: group by vendor
By default, all the packages will be included from the main level of the path that you pointed the bundle towards. This can be changed by using GLOB pattern in the path definition.
This configuration will make it possible to define packages under several folders in format of ...
Configuration: defining bundle sub-folders as repository root
By default, the bundle repository will consider every sub-folder on the main level of the bundle as potential installable package, in case the packages are available in some sub-folder(s), relative paths can be defined.
Configuration: package template
In case some of the installable sub-folders of the bundle are not directly installable (lack composer.json), the bundle plugin will create the missing package definitions. The only requirement is that the package.
If there are special parts of the composer.json that need to be defined, declare those under 'extra-package' as in same format as one would be declaring normal package configuration. The contents will be used as default values for generated package definitions:
Configuration: custom target path for bundle download
In case you want bundle to be downloaded into the root of your directory, configure a target folder for it.
Note that the package installation in this case will result in packages being sym-linked instead of being mirrored.
Usage: installing packages from bundle
Make sure that you have installed this plugin separately before you start installing packages from registered bundles.
After bundles have been registered in composer.json, user can just install them as any other composer package. Note that package versions are ignored, use dev-bundle instead.
composer require magento/theme-frontend-venia:'dev-my-bundle'
Note that 'composer require' is somewhat special as a command and does require a non-version string to be used when adding the module to the repository.
The constraint will be generated from bundle repository name, so in case you want to require the package as "dev-local", use the following:
Note that this configuration will use the folder
composer require vaimo/some-package:'dev-local'
Usage: updating the package
The Composer run will be provided with MD5 fingerprint of all the contents of every file in the pacakges, so updating a package (in case it was not symlinked to vendor). Can be done by just running normal composer update command.
composer update vaimo/some-package
Development: debugging
In case the packages don't become installable, the developer is advised to run the require command with verbose mode.
composer require vaimo/some-package:'dev-local' -vvv
This should expose output similar to this one (if everything has been configured correctly):
If something similar to this was not visible in the console output then the packages in the bundle folders are not visible for the Compsoer to install.
All versions of composer-repository-bundle with dependencies
composer-plugin-api Version ^1.0 || ^2.0