mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Using composer.lock for LeftAndMain->CMSVersion()
See https://github.com/silverstripe/silverstripe-cms/pull/289 for context
This commit is contained in:
parent
e6fffb9ef9
commit
2b6d735182
@ -1339,19 +1339,67 @@ class LeftAndMain extends Controller implements PermissionProvider {
|
||||
|
||||
/**
|
||||
* Return the version number of this application.
|
||||
* Uses the subversion path information in <mymodule>/silverstripe_version
|
||||
* (automacially replaced by build scripts).
|
||||
*
|
||||
* Uses the number in <mymodule>/silverstripe_version
|
||||
* (automatically replaced by build scripts).
|
||||
* If silverstripe_version is empty,
|
||||
* then attempts to get it from composer.lock
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function CMSVersion() {
|
||||
$frameworkVersion = file_get_contents(FRAMEWORK_PATH . '/silverstripe_version');
|
||||
if(!$frameworkVersion) $frameworkVersion = _t('LeftAndMain.VersionUnknown', 'Unknown');
|
||||
|
||||
return sprintf(
|
||||
"Framework: %s",
|
||||
$frameworkVersion
|
||||
$versions = array();
|
||||
$modules = array(
|
||||
'silverstripe/framework' => array(
|
||||
'title' => 'Framework',
|
||||
'versionFile' => FRAMEWORK_PATH . '/silverstripe_version',
|
||||
)
|
||||
);
|
||||
if(defined('CMS_PATH')) {
|
||||
$modules['silverstripe/cms'] = array(
|
||||
'title' => 'CMS',
|
||||
'versionFile' => CMS_PATH . '/silverstripe_version',
|
||||
);
|
||||
}
|
||||
|
||||
// Tries to obtain version number from composer.lock if it exists
|
||||
$composerLockPath = BASE_PATH . '/composer.lock';
|
||||
if (file_exists($composerLockPath)) {
|
||||
$cache = SS_Cache::factory('LeftAndMain_CMSVersion');
|
||||
$cacheKey = filemtime($composerLockPath);
|
||||
$versions = $cache->load($cacheKey);
|
||||
if(!$versions) $versions = array();
|
||||
if(!$versions && $jsonData = file_get_contents($composerLockPath)) {
|
||||
$lockData = json_decode($jsonData);
|
||||
if($lockData && isset($lockData->packages)) {
|
||||
foreach ($lockData->packages as $package) {
|
||||
if(
|
||||
array_key_exists($package->name, $modules)
|
||||
&& isset($package->version)
|
||||
) {
|
||||
$versions[$package->name] = $package->version;
|
||||
}
|
||||
}
|
||||
$cache->save(json_encode($versions), $cacheKey);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Fall back to static version file
|
||||
foreach($modules as $moduleName => $moduleSpec) {
|
||||
if(!isset($versions[$moduleName])) {
|
||||
if($staticVersion = file_get_contents($moduleSpec['versionFile'])) {
|
||||
$versions[$moduleName] = $staticVersion;
|
||||
} else {
|
||||
$versions[$moduleName] = _t('LeftAndMain.VersionUnknown', 'Unknown');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$out = array();
|
||||
foreach($modules as $moduleName => $moduleSpec) {
|
||||
$out[] = $modules[$moduleName]['title'] . ': ' . $versions[$moduleName];
|
||||
}
|
||||
return implode(', ', $out);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
x
Reference in New Issue
Block a user