solid / bundle_version
Ready to use AppStore and Google Play package version resolver tools
Installs: 6
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 1
pkg:composer/solid/bundle_version
Requires
- php: ^7.1.3
- ext-dom: *
- ext-json: *
- ext-libxml: *
- guzzlehttp/guzzle: ~6.0
Requires (Dev)
- phpunit/phpunit: ^7.5
This package is auto-updated.
Last update: 2025-11-20 15:28:07 UTC
README
Small tool set which enables you to check currently deployed GooglePlay and AppStore application revision
Installation
composer require solid/bundle_version
Usage
Each store has separate BundleVersionResolverInterface concrete
i.e GooglePlayVersionResolver, AppStoreVersionResolver, you simply need to provide
$bundleId into it's resolve($bundleId) method. On success you will receive
VersionQueryResultDTO result containing $bundleId and $currentRevision values or
instance of FailedToResolveGooglePlayVersionException on exception
GooglePlay sample
use Solid\VersionChecker\Clients\GooglePlay\Exceptions\FailedToResolveGooglePlayVersionException; use Solid\VersionChecker\Clients\GooglePlay\GooglePlayVersionResolver; use GuzzleHttp\Client; try { $resolver = new GooglePlayVersionResolver(new Client); $version = $this->resolver->resolve('com.app.example'); echo $version->getBundleId() . ':' . $version->getCurrentRevision(); } catch(FailedToResolveGooglePlayVersionException $e) { echo 'Failed to resolve version'; }
which will output com.app.example:1.0.0 or Failed to resolve version in case of error
AppStore sample
use Solid\VersionChecker\Clients\AppStore\AppStoreVersionResolver; use Solid\VersionChecker\Clients\AppStore\Exceptions\FailedToResolveAppStoreVersionException; use GuzzleHttp\Client; try { $resolver = new AppStoreVersionResolver(new Client); $version = $this->resolver->resolve('com.app.example'); echo $version->getBundleId() . ':' . $version->getCurrentRevision(); } catch(FailedToResolveAppStoreVersionException $e) { echo 'Failed to resolve version'; }
which will output com.app.example:1.0.0 or Failed to resolve version in case of error
Version comparator
Package also provides ready to use version compare algorithm which enables you to perform version checks
use Solid\VersionChecker\Clients\GooglePlay\Exceptions\FailedToResolveGooglePlayVersionException; use Solid\VersionChecker\Clients\GooglePlay\GooglePlayVersionResolver; use Solid\VersionChecker\Clients\AppStore\AppStoreVersionResolver; use Solid\VersionChecker\Clients\AppStore\Exceptions\FailedToResolveAppStoreVersionException; use Solid\VersionChecker\Comparators\SemverComparator; use Solid\VersionChecker\Enums\VersionCompareResultEnum; use GuzzleHttp\Client; try { $httpClient = new Client; $appStoreResolver = new AppStoreVersionResolver($httpClient); $googlePlayResolver = new GooglePlayVersionResolver($httpClient); $appStoreVersion = $this->resolver->resolve('com.app.example'); $googlePlayVersion = $this->resolver->resolve('com.app.example'); $comparator = new SemverComparator(); $versionCompareResult = $comparator->compare($appStoreVersion->getCurrentRevision(), $googlePlayVersion->getCurrentRevision()) if($versionCompareResult->is(VersionCompareResultEnum::MAJOR)) { echo 'App store has newer major release than play store'; } else if($versionCompareResult->is(VersionCompareResultEnum::MINOR)) { echo 'App store has newer minor release than play store'; } else if($versionCompareResult->is(VersionCompareResultEnum::PATCH)) { echo 'App store has newer patch release than play store'; } else { echo 'App store and google play share same version'; } } catch(FailedToResolveAppStoreVersionException $e) { echo 'Failed to resolve app store version'; } catch(FailedToResolveGooglePlayVersionException $e) { echo 'Failed to resolve google play version'; }