Download the PHP package oat-sa/tao-dependency-resolver without Composer
On this page you can find all versions of the php package oat-sa/tao-dependency-resolver. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download oat-sa/tao-dependency-resolver
More information about oat-sa/tao-dependency-resolver
Files in oat-sa/tao-dependency-resolver
Package tao-dependency-resolver
Short Description Resolves TAO extensions dependencies
License proprietary
Informations about the package tao-dependency-resolver
Tao dependency resolver
Resolves the dependency requirement tree from manifest.php in each extension needed.
Default result is to displays a corresponding composer.json require
array.
If you need to write this to a file, just redirect the standard output.
Now works with both extension names and repository names.
A more extensive explanation of the problematics and solutions is exposed in the documentation.
Installation
Clone this repository.
Install dependencies :
Minimal PHP version required: 7.1
PHP extensions required: php7.1-xml, php7.1-mbstring
Authentication
Create a .env
file in the root directory with your github token and organization name (you can copy and populate the existing .env.dist template file).
You need to provide a valid GitHub token with "repo" access rights.
The tools
There are two tools in this repository:
Dependency resolver
Read more about this tool here.
main repository name
: repository name, e.g. "oat-sa/extension-tao-testqti" of the repository to resolve.main extension name
: "manifest name", e.g. "taoQtiTest" of the extension to resolve.main repository branch
: the branch of the extension to be resolved.dependency branches
: desired branches to download include for each dependency. In the form of "extensionName1:branchName1,extensionName2:branchName2,...", e.g. "tao:develop,taoQtiItem:fix/tao-1234,generis:10.12.14". Branches for all non given extensions will default to "develop".repositories
: flag to indicate that composer repositories information must be included. In case of private repositories, ssh authentication must be set up to use the generated composer.json file.file
: when given, the command will generate the composer.json into this file along the stdout. The target need to be writeable, and can be either a relative or absolute path. For instance,--file output/composer.json
will generate the composer.json in theoutput
directory (within the current working directory).
Only one of the two options repository-name
and extension-name
must be provided.
Usage examples
Resolve dependencies for repository oat-sa/extension-tao-items
with no branch specified (defaults to develop
) and write the result to /dest/dir/composer.json
with verbose output:
Will display the following in the console:
And write the following to /dest/dir/composer.json
:
Resolve dependencies for extension taoQtiTest
with main branch feature/tao-1234, branch feature/tao-1234 for tao, branch master for generis and display the result to console:
Will display the following in the console:
Requiring a non-existing branch will result in a exception both for main repository and dependencies:
Trying to resolve dependencies for unknown repository will result in a exception:
Trying to resolve dependencies for unknown extension will also result in a exception:
But if it is a newly added extension, it may just not be in the extension map. If this is the case, you can update the extension map with the second tool:
Repository lister
Read more about this tool here.
This tool reads every oat-sa repositories in Github and maintains the map of extension name to repository name.
/!\ This is not needed each time, there is an up-to-date map currently provided in <project config dir>/repositoryMap.json
and it is quite time consuming...
Update repositories
Reads and analyzes repositories from Github.
--reload-list
: reloads the list of oat-sa repositories in addition to analyzing every repositorylimit
: number of repositories to analyze at a time
Dump repository list
Dumps the repository map to a CSV file for human reading and analysis.
filename
: CSV filename. Defaults to<project root dir>/repositories.csv
All versions of tao-dependency-resolver with dependencies
ext-ctype Version *
ext-iconv Version *
ext-json Version *
knplabs/github-api Version ^2.11
knplabs/packagist-api Version ^1.5
league/flysystem Version ^1.0
mikey179/vfsstream Version ^1.6
nikic/php-parser Version ^4.2
php-http/guzzle6-adapter Version ^1.1
symfony/console Version 4.2.*
symfony/dotenv Version 4.2.*
symfony/expression-language Version 4.2.*
symfony/flex Version ^1.1
symfony/framework-bundle Version 4.2.*
symfony/monolog-bundle Version ^3.3
symfony/yaml Version 4.2.*