~ubuntu-branches/ubuntu/feisty/smarty/feisty-security

« back to all changes in this revision

Viewing changes to libs/core/core.load_plugins.php

  • Committer: Bazaar Package Importer
  • Author(s): Dimitri Fontaine
  • Date: 2005-03-29 11:53:20 UTC
  • mfrom: (0.1.1 upstream)
  • Revision ID: james.westby@ubuntu.com-20050329115320-g3rvndgnn75ogm35
Tags: 2.6.8-1
New upstream release

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
<?php
2
 
/**
3
 
 * Smarty plugin
4
 
 * @package Smarty
5
 
 * @subpackage plugins
6
 
 */
7
 
 
8
 
/**
9
 
 * Load requested plugins
10
 
 *
11
 
 * @param array $plugins
12
 
 */
13
 
 
14
 
// $plugins
15
 
 
16
 
function smarty_core_load_plugins($params, &$smarty)
17
 
{
18
 
 
19
 
    foreach ($params['plugins'] as $_plugin_info) {
20
 
        list($_type, $_name, $_tpl_file, $_tpl_line, $_delayed_loading) = $_plugin_info;
21
 
        $_plugin = &$smarty->_plugins[$_type][$_name];
22
 
 
23
 
        /*
24
 
         * We do not load plugin more than once for each instance of Smarty.
25
 
         * The following code checks for that. The plugin can also be
26
 
         * registered dynamically at runtime, in which case template file
27
 
         * and line number will be unknown, so we fill them in.
28
 
         *
29
 
         * The final element of the info array is a flag that indicates
30
 
         * whether the dynamically registered plugin function has been
31
 
         * checked for existence yet or not.
32
 
         */
33
 
        if (isset($_plugin)) {
34
 
            if (empty($_plugin[3])) {
35
 
                if (!is_callable($_plugin[0])) {
36
 
                    $smarty->_trigger_fatal_error("[plugin] $_type '$_name' is not implemented", $_tpl_file, $_tpl_line, __FILE__, __LINE__);
37
 
                } else {
38
 
                    $_plugin[1] = $_tpl_file;
39
 
                    $_plugin[2] = $_tpl_line;
40
 
                    $_plugin[3] = true;
41
 
                    if (!isset($_plugin[4])) $_plugin[4] = true; /* cacheable */
42
 
                }
43
 
            }
44
 
            continue;
45
 
        } else if ($_type == 'insert') {
46
 
            /*
47
 
             * For backwards compatibility, we check for insert functions in
48
 
             * the symbol table before trying to load them as a plugin.
49
 
             */
50
 
            $_plugin_func = 'insert_' . $_name;
51
 
            if (function_exists($_plugin_func)) {
52
 
                $_plugin = array($_plugin_func, $_tpl_file, $_tpl_line, true, false);
53
 
                continue;
54
 
            }
55
 
        }
56
 
 
57
 
        $_plugin_file = $smarty->_get_plugin_filepath($_type, $_name);
58
 
 
59
 
        if (! $_found = ($_plugin_file != false)) {
60
 
            $_message = "could not load plugin file '$_type.$_name.php'\n";
61
 
        }
62
 
 
63
 
        /*
64
 
         * If plugin file is found, it -must- provide the properly named
65
 
         * plugin function. In case it doesn't, simply output the error and
66
 
         * do not fall back on any other method.
67
 
         */
68
 
        if ($_found) {
69
 
            include_once $_plugin_file;
70
 
 
71
 
            $_plugin_func = 'smarty_' . $_type . '_' . $_name;
72
 
            if (!function_exists($_plugin_func)) {
73
 
                $smarty->_trigger_fatal_error("[plugin] function $_plugin_func() not found in $_plugin_file", $_tpl_file, $_tpl_line, __FILE__, __LINE__);
74
 
                continue;
75
 
            }
76
 
        }
77
 
        /*
78
 
         * In case of insert plugins, their code may be loaded later via
79
 
         * 'script' attribute.
80
 
         */
81
 
        else if ($_type == 'insert' && $_delayed_loading) {
82
 
            $_plugin_func = 'smarty_' . $_type . '_' . $_name;
83
 
            $_found = true;
84
 
        }
85
 
 
86
 
        /*
87
 
         * Plugin specific processing and error checking.
88
 
         */
89
 
        if (!$_found) {
90
 
            if ($_type == 'modifier') {
91
 
                /*
92
 
                 * In case modifier falls back on using PHP functions
93
 
                 * directly, we only allow those specified in the security
94
 
                 * context.
95
 
                 */
96
 
                if ($smarty->security && !in_array($_name, $smarty->security_settings['MODIFIER_FUNCS'])) {
97
 
                    $_message = "(secure mode) modifier '$_name' is not allowed";
98
 
                } else {
99
 
                    if (!function_exists($_name)) {
100
 
                        $_message = "modifier '$_name' is not implemented";
101
 
                    } else {
102
 
                        $_plugin_func = $_name;
103
 
                        $_found = true;
104
 
                    }
105
 
                }
106
 
            } else if ($_type == 'function') {
107
 
                /*
108
 
                 * This is a catch-all situation.
109
 
                 */
110
 
                $_message = "unknown tag - '$_name'";
111
 
            }
112
 
        }
113
 
 
114
 
        if ($_found) {
115
 
            $smarty->_plugins[$_type][$_name] = array($_plugin_func, $_tpl_file, $_tpl_line, true, true);
116
 
        } else {
117
 
            // output error
118
 
            $smarty->_trigger_fatal_error('[plugin] ' . $_message, $_tpl_file, $_tpl_line, __FILE__, __LINE__);
119
 
        }
120
 
    }
121
 
}
122
 
 
123
 
/* vim: set expandtab: */
124
 
 
125
 
?>