3 namespace _CiviVersion_
{
8 * Get the CiviCRM version
10 public static function findVersion() {
11 $verFile = implode(DIRECTORY_SEPARATOR
, [dirname(__FILE__
), 'xml', 'version.xml']);
12 if (file_exists($verFile)) {
13 $str = file_get_contents($verFile);
14 $xmlObj = simplexml_load_string($str);
15 return (string) $xmlObj->version_no
;
18 trigger_error("Unknown version", E_USER_ERROR
);
25 public static function findCMS() {
26 if (defined('CIVICRM_UF')) {
29 elseif (defined('BACKDROP_VERSION')) {
32 elseif (function_exists('drupal_bootstrap') && version_compare(VERSION
, '6.0', '>=') && version_compare(VERSION
, '7.0', '<')) {
35 elseif (function_exists('drupal_bootstrap') && version_compare(VERSION
, '7.0', '>=') && version_compare(VERSION
, '8.0', '<')) {
39 // guess CMS name from the current path
40 list($cmsType,) = self
::findCMSRootPath();
42 if (!empty($cmsType)) {
49 * Get the CMS root path and CMS name
51 public static function findCMSRootPath() {
54 'wp-includes/version.php',
55 // Future? 'vendor/civicrm/wordpress/civicrm.php' => 'wp',
58 'administrator/components/com_civicrm/civicrm/civicrm-version.php',
61 'modules/system/system.module', // D7
64 'core/core.services.yml', // D8
67 'core/modules/layout/layout.module',
71 $parts = explode('/', str_replace('\\', '/', self
::getSearchDir()));
72 while (!empty($parts)) {
73 $basePath = implode('/', $parts);
75 foreach ($cmsPatterns as $cmsType => $relPaths) {
76 foreach ($relPaths as $relPath) {
77 $matches = glob("$basePath/$relPath");
78 if (!empty($matches)) {
79 return [$cmsType, $basePath];
89 * Get the current path
91 public static function getSearchDir() {
92 if ($_SERVER['SCRIPT_FILENAME']) {
93 return dirname($_SERVER['SCRIPT_FILENAME']);
95 // getenv('PWD') works better with symlinked source trees, but it's
96 // not portable to Windows.
97 if (strtoupper(substr(PHP_OS
, 0, 3)) === 'WIN') {
101 return getenv('PWD');
110 * Get the CiviCRM version.
111 * TODO : For now this function is not included in \Civi\Version class so not to break any code
112 * which directly call civicrmVersion(). So those call need to replaced with \Civi\Version::civicrmVersion()
113 * when included in the class
115 function civicrmVersion() {
117 'version' => \_CiviVersion_\Util
::findVersion(),
118 'cms' => \_CiviVersion_\Util
::findCMS(),