3 +--------------------------------------------------------------------+
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2019 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2019
37 * Main page for getting started dashlet
39 class CRM_Dashlet_Page_GettingStarted
extends CRM_Core_Page
{
41 const CHECK_TIMEOUT
= 5;
43 const GETTING_STARTED_URL
= 'https://alert.civicrm.org/welcome?prot=1&ver={ver}&uf={uf}&sid={sid}&lang={lang}&co={co}';
46 * Define tokens available for getting started
48 static $_tokens = array(
50 'configbackend' => 'civicrm/admin/configtask',
55 * Get the final, usable URL string (after interpolating any variables)
57 * @return FALSE|string
59 public function gettingStartedUrl() {
60 // Note: We use "*default*" as the default (rather than self::GETTING_STARTED_URL) so that future
61 // developers can change GETTING_STARTED_URL without needing to update {civicrm_setting}.
62 $url = Civi
::settings()->get('gettingStartedUrl');
63 if ($url === '*default*') {
64 $url = self
::GETTING_STARTED_URL
;
66 return CRM_Utils_System
::evalUrl($url);
70 * List gettingStarted page as dashlet.
72 public function run() {
73 $context = CRM_Utils_Request
::retrieve('context', 'Alphanumeric', $this, FALSE, 'dashlet');
75 // Assign smarty variables.
76 $this->assign('context', $context);
77 $this->assign('gettingStarted', $this->_gettingStarted());
79 // Use smarty to generate page.
84 * Load gettingStarted page from cache.
85 * Refresh cache if expired
89 private function _gettingStarted() {
90 $value = Civi
::cache('community_messages')->get('dashboard_gettingStarted');
93 $value = $this->_getHtml($this->gettingStartedUrl());
96 Civi
::cache('community_messages')->set('dashboard_gettingStarted', $value, (60 * 60 * 24 * self
::CACHE_DAYS
));
109 * array of gettingStarted items; or NULL if not available
111 public function _getHtml($url) {
112 $httpClient = new CRM_Utils_HttpClient(self
::CHECK_TIMEOUT
);
113 list ($status, $html) = $httpClient->get($url);
115 if ($status !== CRM_Utils_HttpClient
::STATUS_OK
) {
119 $tokensList = CRM_Utils_Token
::getTokens($html);
120 $this->replaceLinkToken($tokensList, $html);
126 * @param array $tokensList
130 public function replaceLinkToken($tokensList, &$str) {
131 foreach ($tokensList as $categories => $tokens) {
132 foreach ($tokens as $token) {
134 if (!empty(self
::$_tokens[$categories][$token])) {
135 $value = self
::$_tokens[$categories][$token];
136 if ($categories == 'crmurl') {
137 $value = CRM_Utils_System
::url($value, "reset=1");
140 CRM_Utils_Token
::token_replace($categories, $token, $value, $str);