3 use Shaarli\Config\ConfigManager
;
4 use Shaarli\Thumbnailer
;
7 * This class is in charge of building the final page.
8 * (This is basically a wrapper around RainTPL which pre-fills some fields.)
9 * $p = new PageBuilder();
10 * $p->assign('myfield','myvalue');
11 * $p->renderPage('mytemplate');
16 * @var RainTPL RainTPL instance.
21 * @var ConfigManager $conf Configuration Manager instance.
26 * @var array $_SESSION
31 * @var LinkDB $linkDB instance.
36 * @var null|string XSRF token
40 /** @var bool $isLoggedIn Whether the user is logged in **/
41 protected $isLoggedIn = false;
44 * PageBuilder constructor.
45 * $tpl is initialized at false for lazy loading.
47 * @param ConfigManager $conf Configuration Manager instance (reference).
48 * @param array $session $_SESSION array
49 * @param LinkDB $linkDB instance.
50 * @param string $token Session token
51 * @param bool $isLoggedIn
53 public function __construct(&$conf, $session, $linkDB = null, $token = null, $isLoggedIn = false)
57 $this->session
= $session;
58 $this->linkDB
= $linkDB;
59 $this->token
= $token;
60 $this->isLoggedIn
= $isLoggedIn;
64 * Initialize all default tpl tags.
66 private function initialize()
68 $this->tpl
= new RainTPL();
71 $version = ApplicationUtils
::checkUpdate(
73 $this->conf
->get('resource.update_check'),
74 $this->conf
->get('updates.check_updates_interval'),
75 $this->conf
->get('updates.check_updates'),
77 $this->conf
->get('updates.check_updates_branch')
79 $this->tpl
->assign('newVersion', escape($version));
80 $this->tpl
->assign('versionError', '');
82 } catch (Exception
$exc) {
83 logm($this->conf
->get('resource.log'), $_SERVER['REMOTE_ADDR'], $exc->getMessage());
84 $this->tpl
->assign('newVersion', '');
85 $this->tpl
->assign('versionError', escape($exc->getMessage()));
88 $this->tpl
->assign('is_logged_in', $this->isLoggedIn
);
89 $this->tpl
->assign('feedurl', escape(index_url($_SERVER)));
90 $searchcrits = ''; // Search criteria
91 if (!empty($_GET['searchtags'])) {
92 $searchcrits .= '&searchtags=' . urlencode($_GET['searchtags']);
94 if (!empty($_GET['searchterm'])) {
95 $searchcrits .= '&searchterm=' . urlencode($_GET['searchterm']);
97 $this->tpl
->assign('searchcrits', $searchcrits);
98 $this->tpl
->assign('source', index_url($_SERVER));
99 $this->tpl
->assign('version', SHAARLI_VERSION
);
102 ApplicationUtils
::getVersionHash(SHAARLI_VERSION
, $this->conf
->get('credentials.salt'))
104 $this->tpl
->assign('scripturl', index_url($_SERVER));
105 $visibility = ! empty($_SESSION['visibility']) ? $_SESSION['visibility'] : '';
106 $this->tpl
->assign('visibility', $visibility);
107 $this->tpl
->assign('untaggedonly', !empty($_SESSION['untaggedonly']));
108 $this->tpl
->assign('pagetitle', $this->conf
->get('general.title', 'Shaarli'));
109 if ($this->conf
->exists('general.header_link')) {
110 $this->tpl
->assign('titleLink', $this->conf
->get('general.header_link'));
112 $this->tpl
->assign('shaarlititle', $this->conf
->get('general.title', 'Shaarli'));
113 $this->tpl
->assign('openshaarli', $this->conf
->get('security.open_shaarli', false));
114 $this->tpl
->assign('showatom', $this->conf
->get('feed.show_atom', true));
115 $this->tpl
->assign('feed_type', $this->conf
->get('feed.show_atom', true) !== false ? 'atom' : 'rss');
116 $this->tpl
->assign('hide_timestamps', $this->conf
->get('privacy.hide_timestamps', false));
117 $this->tpl
->assign('token', $this->token
);
119 if ($this->linkDB
!== null) {
120 $this->tpl
->assign('tags', $this->linkDB
->linksCountPerTag());
124 'thumbnails_enabled',
125 $this->conf
->get('thumbnails.mode', Thumbnailer
::MODE_NONE
) !== Thumbnailer
::MODE_NONE
127 $this->tpl
->assign('thumbnails_width', $this->conf
->get('thumbnails.width'));
128 $this->tpl
->assign('thumbnails_height', $this->conf
->get('thumbnails.height'));
130 if (! empty($_SESSION['warnings'])) {
131 $this->tpl
->assign('global_warnings', $_SESSION['warnings']);
132 unset($_SESSION['warnings']);
135 // To be removed with a proper theme configuration.
136 $this->tpl
->assign('conf', $this->conf
);
140 * The following assign() method is basically the same as RainTPL (except lazy loading)
142 * @param string $placeholder Template placeholder.
143 * @param mixed $value Value to assign.
145 public function assign($placeholder, $value)
147 if ($this->tpl
=== false) {
150 $this->tpl
->assign($placeholder, $value);
154 * Assign an array of data to the template builder.
156 * @param array $data Data to assign.
158 * @return false if invalid data.
160 public function assignAll($data)
162 if ($this->tpl
=== false) {
166 if (empty($data) || !is_array($data)){
170 foreach ($data as $key => $value) {
171 $this->assign($key, $value);
177 * Render a specific page (using a template file).
178 * e.g. $pb->renderPage('picwall');
180 * @param string $page Template filename (without extension).
182 public function renderPage($page)
184 if ($this->tpl
=== false) {
188 $this->tpl
->draw($page);
192 * Render a 404 page (uses the template : tpl/404.tpl)
193 * usage : $PAGE->render404('The link was deleted')
195 * @param string $message A messate to display what is not found
197 public function render404($message = '')
199 if (empty($message)) {
200 $message = t('The page you are trying to reach does not exist or has been deleted.');
202 header($_SERVER['SERVER_PROTOCOL'] .' '. t('404 Not Found'));
203 $this->tpl
->assign('error_message', $message);
204 $this->renderPage('404');