smarty.php 2.84 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php
/**
 * This software is governed by the CeCILL-B license. If a copy of this license
 * is not distributed with this file, you can obtain one at
 * http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.txt
 *
 * Authors of STUdS (initial project): Guilhem BORGHESI (borghesi@unistra.fr) and Raphaël DROZ
 * Authors of Framadate/OpenSondate: Framasoft (https://github.com/framasoft)
 *
 * =============================
 *
 * Ce logiciel est régi par la licence CeCILL-B. Si une copie de cette licence
 * ne se trouve pas avec ce fichier vous pouvez l'obtenir sur
 * http://www.cecill.info/licences/Licence_CeCILL-B_V1-fr.txt
 *
 * Auteurs de STUdS (projet initial) : Guilhem BORGHESI (borghesi@unistra.fr) et Raphaël DROZ
 * Auteurs de Framadate/OpenSondage : Framasoft (https://github.com/framasoft)
 */
use Framadate\Utils;

require_once __DIR__ . '/../../vendor/smarty/smarty/libs/Smarty.class.php';
$smarty = new \Smarty();
$smarty->setTemplateDir(ROOT_DIR . '/tpl/');
Antonin's avatar
Antonin committed
24
$smarty->setCompileDir(ROOT_DIR . COMPILE_DIR);
25
26
27
28
29
$smarty->setCacheDir(ROOT_DIR . '/cache/');
$smarty->caching = false;

$smarty->assign('APPLICATION_NAME', NOMAPPLICATION);
$smarty->assign('SERVER_URL', Utils::get_server_name());
30
$smarty->assign('SCRIPT_NAME', $_SERVER['SCRIPT_NAME']);
31
$smarty->assign('TITLE_IMAGE', IMAGE_TITRE);
JosephK's avatar
JosephK committed
32
$smarty->assign('use_nav_js', strstr($_SERVER['SERVER_NAME'], 'framadate.org'));
33
$smarty->assign('locale', $locale);
34
35
36
$smarty->assign('langs', $ALLOWED_LANGUAGES);
$smarty->assign('date_format', $date_format);

Antonin's avatar
Antonin committed
37
// Dev Mode
38
if (isset($_SERVER['FRAMADATE_DEVMODE']) && $_SERVER['FRAMADATE_DEVMODE']) {
39
40
41
42
43
44
45
46
47
    $smarty->force_compile = true;
    $smarty->compile_check = true;

} else {
    $smarty->force_compile = false;
    $smarty->compile_check = false;
}


Antonin's avatar
Antonin committed
48
49
function smarty_function_poll_url($params, Smarty_Internal_Template $template) {
    $poll_id =  filter_var($params['id'], FILTER_VALIDATE_REGEXP, ['options' => ['regexp' => POLL_REGEX]]);
50
    $admin =  (isset($params['admin']) && $params['admin']) ? true : false;
51
    $action =  (isset($params['action']) && !empty($params['action'])) ? Utils::htmlEscape($params['action']) : false;
52
    $action_value = (isset($params['action_value']) && !empty($params['action_value'])) ? $params['action_value'] : false;
53
    $vote_unique_id = isset($params['vote_id']) ? filter_var($params['vote_id'], FILTER_VALIDATE_REGEXP, ['options' => ['regexp' => POLL_REGEX]]) : '';
Antonin's avatar
Antonin committed
54
55
56

    // If filter_var fails (i.e.: hack tentative), it will return false. At least no leak is possible from this.

57
    return Utils::getUrlSondage($poll_id, $admin, $vote_unique_id, $action, $action_value);
58
59
60
61
62
63
64
65
66
67
68
}

function smarty_modifier_markdown($md, $clear = false) {
    return Utils::markdown($md, $clear);
}

function smarty_modifier_resource($link) {
    return Utils::get_server_name() . $link;
}

function smarty_modifier_html($html) {
69
    return Utils::htmlEscape($html);
JosephK's avatar
JosephK committed
70
}