X-Git-Url: https://vcs.fsf.org/?a=blobdiff_plain;f=CRM%2FDashlet%2FPage%2FBlog.php;h=1c3d78c7be3088bd0c923e9e57d5c209576fc427;hb=368b491a511dae319823cb1c635aadb872cdb795;hp=40e355f9dfdb9b42ac22f395b5c37f3dde787f31;hpb=cd98cf0398eb53d025a2b7e8783548654e0605b5;p=civicrm-core.git diff --git a/CRM/Dashlet/Page/Blog.php b/CRM/Dashlet/Page/Blog.php index 40e355f9df..1c3d78c7be 100644 --- a/CRM/Dashlet/Page/Blog.php +++ b/CRM/Dashlet/Page/Blog.php @@ -42,6 +42,21 @@ class CRM_Dashlet_Page_Blog extends CRM_Core_Page { const CACHE_DAYS = 1; const BLOG_URL = 'https://civicrm.org/blog/feed'; + /** + * Get the final, usable URL string (after interpolating any variables) + * + * @return FALSE|string + */ + public function getBlogUrl() { + // Note: We use "*default*" as the default (rather than self::BLOG_URL) so that future + // developers can change BLOG_URL without needing to update {civicrm_setting}. + $url = CRM_Core_BAO_Setting::getItem(CRM_Core_BAO_Setting::SYSTEM_PREFERENCES_NAME, 'blogUrl', NULL, '*default*'); + if ($url === '*default*') { + $url = self::BLOG_URL; + } + return CRM_Utils_System::evalUrl($url); + } + /** * List blog articles as dashlet * @@ -72,7 +87,7 @@ class CRM_Dashlet_Page_Blog extends CRM_Core_Page { $expire = time() - (60 * 60 * 24 * self::CACHE_DAYS); // Refresh data after CACHE_DAYS if (strtotime($cache->created_date) < $expire) { - $new_data = $this->_getFeed(); + $new_data = $this->_getFeed($this->getBlogUrl()); // If fetching the new rss feed was successful, return it // Otherwise use the old cached data - it's better than nothing if ($new_data) { @@ -81,7 +96,7 @@ class CRM_Dashlet_Page_Blog extends CRM_Core_Page { } return unserialize($cache->data); } - return $this->_getFeed(); + return $this->_getFeed($this->getBlogUrl()); } /** @@ -91,7 +106,7 @@ class CRM_Dashlet_Page_Blog extends CRM_Core_Page { * * @access public */ - public function _getFeed( $url = self::BLOG_URL) { + public function _getFeed($url) { $httpClient = new CRM_Utils_HttpClient(self::CHECK_TIMEOUT); list ($status, $rawFeed) = $httpClient->get($url); if ($status !== CRM_Utils_HttpClient::STATUS_OK) {