drupify / version-resolver
A PHP library for resolving version, supported releases etc. for Drupal Core, modules, themes, and other related projects.
Requires
- php: ^8.1
- guzzlehttp/guzzle: ^7.9
- hassankhan/config: ^3.1
Requires (Dev)
- acquia/coding-standards: ^3.0
- ergebnis/composer-normalize: ^2.43
- php-coveralls/php-coveralls: ^2.7
- php-parallel-lint/php-parallel-lint: ^1.4
- phpro/grumphp: ^1.5 || ^2.7
- phpunit/phpunit: ^9.6
README
Drupal Version Resolver Library
The Drupal Version Resolver Library is a PHP library designed to help you easily resolve Drupal project versions, supported releases, and retrieve all releases hosted on Drupal.org. Whether you need to fetch release information for Drupal core or contributed modules/themes, this library offers a simple API to access such data.
Features
- Fetch supported releases for a given Drupal module or theme.
- Get all available releases for any Drupal project.
- Resolve different Drupal core versions, including the current version, development versions, and next minor versions.
Requirements
- PHP 8.1 and above.
- Composer for installation.
- Internet access to query data from drupal.org.
Installation
To install, you can run below command:
composer require drupify/version-resolver
Example Usage
Here’s an example to retrieve the releases of a module hosted on Drupal.org:
use Drupify\Resolver\VersionResolver; // Initialize the resolver with the project name. $resolver = new VersionResolver('token'); // Get supported releases for the project. $supported = $resolver->getSupportedReleases(); // Output format example: [ "8.x-1.x" => [ "stable" => [ "name" => "token 8.x-1.15", "version" => "8.x-1.15", "tag" => "8.x-1.15", "core_compatibility" => "^9.2 || ^10 || ^11" ], "dev" => [ "name" => "token 8.x-1.x-dev", "version" => "8.x-1.x-dev", "tag" => "8.x-1.x", "core_compatibility" => "^9.2 || ^10 || ^11" ] ] ]
Fetching All Releases
If you need to retrieve all releases (including older versions), you can do so with the following:
$all = $resolver->getAllReleases();
Note: This method returns all releases, but it does not include projects compatible with Drupal Core 7.x and below.
Resolving Drupal Core Versions
The library also provides methods to resolve various types of Drupal core versions:
- Current Stable: Returns the current stable version (e.g.,
10.3
). - Current Dev: Returns the current development version (e.g.,
10.3.x-dev
). - Next Minor: Returns the next minor version (e.g.,
11.0.0-rc1
). - Next Minor Dev: Returns the next minor development version (e.g.,
11.0.x-dev
) and so on.
Example usage:
use Drupify\Resolver\CoreVersionResolver; $resolver = new CoreVersionResolver(); $currentVersion = $resolver->findCurrent(); $currentDevVersion = $resolver->findCurrentDev(); $nextMinorVersion = $resolver->findNextMinor(); $nextMinorDevVersion = $resolver->findNextMinorDev();
Example Output
echo $currentVersion; // 10.3 echo $currentDevVersion; // 10.3.x-dev echo $nextMinorVersion; // 11.0.0-rc1 echo $nextMinorDevVersion; // 11.0.x-dev
Contact
If you have any questions or issues, feel free to open a GitHub issue or contact the maintainers directly.