}
catch (CRM_Extension_Exception $e) {
// file has more detailed info, but we'll fallback to DB if it's missing -- DB has enough info to uninstall
- $this->infos[$key] = CRM_Extension_System::singleton()->getManager()->createInfoFromDB($key);
- if (!$this->infos[$key]) {
+ $dbInfo = CRM_Extension_System::singleton()->getManager()->createInfoFromDB($key);
+ if (!$dbInfo) {
throw $e;
}
+ $this->infos[$key] = $dbInfo;
}
}
return $this->infos[$key];
*/
public function getAllInfos() {
foreach ($this->container->getKeys() as $key) {
- $this->keyToInfo($key);
+ try {
+ $this->keyToInfo($key);
+ }
+ catch (CRM_Extension_Exception_ParseException $e) {
+ CRM_Core_Session::setStatus(ts('Parse error in extension: %1', [
+ 1 => $e->getMessage(),
+ ]), '', 'error');
+ CRM_Core_Error::debug_log_message("Parse error in extension: " . $e->getMessage());
+ continue;
+ }
}
return $this->infos;
}
CRM_Extension_System::singleton()->getClassLoader()->refresh();
}
+ /**
+ * This returns a formatted string containing an extension upgrade link for the UI.
+ * @todo We should improve this to return more appropriate text. eg. when an extension is not installed
+ * it should not say "version xx is installed".
+ *
+ * @param array $remoteExtensionInfo
+ * @param array $localExtensionInfo
+ *
+ * @return string
+ */
+ public function getUpgradeLink($remoteExtensionInfo, $localExtensionInfo) {
+ if (!empty($remoteExtensionInfo) && version_compare($localExtensionInfo['version'], $remoteExtensionInfo->version, '<')) {
+ return ts('Version %1 is installed. <a %2>Upgrade to version %3</a>.', [
+ 1 => $localExtensionInfo['version'],
+ 2 => 'href="' . CRM_Utils_System::url('civicrm/admin/extensions', "action=update&id={$localExtensionInfo['key']}&key={$localExtensionInfo['key']}") . '"',
+ 3 => $remoteExtensionInfo->version,
+ ]);
+ }
+ }
+
}