2017-07-04 23:07:06 +12:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The version provider will look up configured modules and examine the composer.lock file
|
|
|
|
* to find the current version installed for each. This is used for the logo title in the CMS
|
|
|
|
* via {@link LeftAndMain::CMSVersion()}
|
|
|
|
*
|
|
|
|
* Example configuration:
|
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* SilverStripeVersionProvider:
|
|
|
|
* modules:
|
|
|
|
* # package/name: Package Title
|
|
|
|
* silverstripe/framework: Framework
|
|
|
|
* silverstripe/cms: CMS
|
|
|
|
* </code>
|
|
|
|
*/
|
|
|
|
class SilverStripeVersionProvider
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Gets a comma delimited string of package titles and versions
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getVersion()
|
|
|
|
{
|
|
|
|
$modules = $this->getModules();
|
|
|
|
$lockModules = $this->getModuleVersionFromComposer(array_keys($modules));
|
|
|
|
$output = array();
|
|
|
|
foreach ($modules as $module => $title) {
|
|
|
|
$version = isset($lockModules[$module])
|
|
|
|
? $lockModules[$module]
|
|
|
|
: _t('SilverStripeVersionProvider.VERSIONUNKNOWN', 'Unknown');
|
|
|
|
$output[] = $title . ': ' . $version;
|
|
|
|
}
|
|
|
|
return implode(', ', $output);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the configured core modules to use for the SilverStripe application version. Filtering
|
|
|
|
* is used to ensure that modules can turn the result off for other modules, e.g. CMS can disable Framework.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getModules()
|
|
|
|
{
|
|
|
|
$modules = Config::inst()->get(get_class($this), 'modules');
|
|
|
|
return array_filter($modules);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tries to obtain version number from composer.lock if it exists
|
|
|
|
*
|
|
|
|
* @param array $modules
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getModuleVersionFromComposer($modules = array())
|
|
|
|
{
|
|
|
|
$versions = array();
|
2017-07-11 12:21:53 +12:00
|
|
|
$lockData = $this->getComposerLock();
|
|
|
|
if ($lockData && !empty($lockData['packages'])) {
|
|
|
|
foreach ($lockData['packages'] as $package) {
|
|
|
|
if (in_array($package['name'], $modules) && isset($package['version'])) {
|
|
|
|
$versions[$package['name']] = $package['version'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $versions;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load composer.lock's contents and return it
|
|
|
|
*
|
|
|
|
* @param bool $cache
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
protected function getComposerLock($cache = true)
|
|
|
|
{
|
2017-07-04 23:07:06 +12:00
|
|
|
$composerLockPath = BASE_PATH . '/composer.lock';
|
2017-07-11 12:21:53 +12:00
|
|
|
if (!file_exists($composerLockPath)) {
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
|
|
|
$lockData = array();
|
|
|
|
if ($cache) {
|
2017-07-04 23:07:06 +12:00
|
|
|
$cache = SS_Cache::factory('SilverStripeVersionProvider_composerlock');
|
|
|
|
$cacheKey = filemtime($composerLockPath);
|
2017-07-11 12:21:53 +12:00
|
|
|
if ($versions = $cache->load($cacheKey)) {
|
|
|
|
$lockData = json_decode($versions, true);
|
2017-07-04 23:07:06 +12:00
|
|
|
}
|
2017-07-11 12:21:53 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
if (empty($lockData) && $jsonData = file_get_contents($composerLockPath)) {
|
|
|
|
$lockData = json_decode($jsonData, true);
|
|
|
|
|
|
|
|
if ($cache) {
|
|
|
|
$cache->save(json_encode($lockData), $cacheKey);
|
2017-07-04 23:07:06 +12:00
|
|
|
}
|
|
|
|
}
|
2017-07-11 12:21:53 +12:00
|
|
|
|
|
|
|
return $lockData;
|
2017-07-04 23:07:06 +12:00
|
|
|
}
|
|
|
|
}
|