-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
e23fcca
commit ceb50b8
Showing
36 changed files
with
9,553 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
name: CI | ||
|
||
on: | ||
push: | ||
branches: [ 1.x, 2.x ] | ||
pull_request: | ||
branches: [ 1.x, 2.x ] | ||
|
||
permissions: | ||
contents: read | ||
|
||
jobs: | ||
|
||
build: | ||
runs-on: ${{ matrix.os }} | ||
strategy: | ||
matrix: | ||
include: | ||
- os: "ubuntu-latest" | ||
php: "7.4" | ||
env: 'HIGHEST_LOWEST="update --prefer-lowest"' | ||
coverage: "none" | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- uses: shivammathur/setup-php@v2 | ||
with: | ||
php-version: ${{ matrix.php }} | ||
# Only report coverage once | ||
coverage: ${{ matrix.coverage }} | ||
|
||
- name: Validate composer.json and composer.lock | ||
run: composer validate --strict | ||
|
||
- name: Cache Composer packages | ||
id: composer-cache | ||
uses: actions/cache@v3 | ||
with: | ||
path: vendor | ||
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }} | ||
restore-keys: | | ||
${{ runner.os }}-php- | ||
- name: Install dependencies | ||
run: composer -n ${HIGHEST_LOWEST-install} --prefer-dist -o | ||
|
||
- name: Run test suite | ||
if: matrix.coverage == 'none' | ||
run: composer run-script test | ||
|
||
- name: Run coverage | ||
if: matrix.coverage == 'pcov' | ||
run: composer run-script coverage | ||
|
||
- name: Upload coverage results to Coveralls | ||
if: matrix.coverage == 'pcov' | ||
env: | ||
COVERALLS_REPO_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||
run: composer run-script coveralls |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
vendor/ | ||
.idea/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,94 @@ | ||
# version-resolver | ||
A PHP library for resolving version, supported releases etc. for Drupal Core, modules, themes, and other related projects. | ||
[![CI](https://github.com/grasmash/yaml-expander/actions/workflows/php.yml/badge.svg)](https://github.com/vishalkhode1/version-resolver/actions/workflows/ci.yml) [![Coverage Status](https://coveralls.io/repos/github/vishalkhode1/version-resolver/badge.svg)](https://coveralls.io/github/vishalkhode1/version-resolver) | ||
|
||
## Drupal Version Resolver PHP 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](https://www.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 7.4** and above. | ||
- **Composer** for installation. | ||
- Internet access to query data from drupal.org. | ||
|
||
### Installation | ||
To install this library, run below command: | ||
|
||
```shell | ||
composer require vkhode/version-resolver | ||
``` | ||
|
||
### Example Usage | ||
Here’s an example to retrieve the releases of a module hosted on Drupal.org: | ||
|
||
```php | ||
use Drupal\Tool\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: | ||
|
||
```php | ||
$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: | ||
```php | ||
use Drupal\Tool\Drupal\Resolver\CoreVersionResolver; | ||
|
||
$resolver = new CoreVersionResolver(); | ||
|
||
$currentVersion = $resolver->findCurrent(); | ||
$currentDevVersion = $resolver->findCurrentDev(); | ||
$nextMinorVersion = $resolver->findNextMinor(); | ||
$nextMinorDevVersion = $resolver->findNextMinorDev(); | ||
``` | ||
|
||
Example Output | ||
```php | ||
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. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,70 @@ | ||
{ | ||
"name": "vkhode/version-resolver", | ||
"description": "A PHP library for resolving version, supported releases etc. for Drupal Core, modules, themes, and other related projects.", | ||
"license": "MIT", | ||
"keywords": [ | ||
"drupal", | ||
"version resolver", | ||
"php library", | ||
"drupal tools" | ||
], | ||
"authors": [ | ||
{ | ||
"name": "Vishal Khode" | ||
} | ||
], | ||
"homepage": "https://github.com/vishalkhode1/version-resolver", | ||
"require": { | ||
"php": "^7.4", | ||
"ext-json": "*", | ||
"ext-libxml": "*", | ||
"ext-simplexml": "*", | ||
"guzzlehttp/guzzle": "^7.9" | ||
}, | ||
"require-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 || ^10" | ||
}, | ||
"minimum-stability": "stable", | ||
"autoload": { | ||
"psr-4": { | ||
"Drupal\\Tool\\": "src/" | ||
} | ||
}, | ||
"autoload-dev": { | ||
"psr-4": { | ||
"Drupal\\Tool\\Tests\\": "tests/src/" | ||
} | ||
}, | ||
"config": { | ||
"allow-plugins": { | ||
"dealerdirect/phpcodesniffer-composer-installer": true, | ||
"ergebnis/composer-normalize": true, | ||
"phpro/grumphp": true | ||
}, | ||
"optimize-autoloader": true, | ||
"sort-packages": true | ||
}, | ||
"scripts": { | ||
"cbf": "phpcbf", | ||
"coverage": "php -d pcov.enabled=1 vendor/bin/phpunit tests/src --coverage-clover build/logs/clover.xml", | ||
"coveralls": [ | ||
"php-coveralls -vvv" | ||
], | ||
"cs": "phpcs", | ||
"lint": [ | ||
"find src -name '*.php' -print0 | xargs -0 -n1 php -l", | ||
"find tests -name '*.php' -print0 | xargs -0 -n1 php -l" | ||
], | ||
"test": [ | ||
"@lint", | ||
"@unit", | ||
"@cs" | ||
], | ||
"unit": "phpunit" | ||
} | ||
} |
Oops, something went wrong.