Properties

$php_handling

$php_handling : integer

This determines how Smarty handles "<?php .

.. ?>" tags in templates. possible values:

  • Smarty::PHP_PASSTHRU -> echo PHP tags as they are
  • Smarty::PHP_QUOTE -> escape tags as entities
  • Smarty::PHP_REMOVE -> remove php tags
  • Smarty::PHP_ALLOW -> execute php tags

Type

integer

$secure_dir

$secure_dir : array

This is the list of template directories that are considered secure.

$template_dir is in this list implicitly.

Type

array

$trusted_dir

$trusted_dir : array

This is an array of directories where trusted php scripts reside.

\$security is disabled during their inclusion/execution.

Type

array

$trusted_uri

$trusted_uri : array

List of regular expressions (PCRE) that include trusted URIs

Type

array

$trusted_constants

$trusted_constants : array

List of trusted constants names

Type

array

$static_classes

$static_classes : array

This is an array of trusted static classes.

If empty access to all static classes is allowed. If set to 'none' none is allowed.

Type

array

$trusted_static_methods

$trusted_static_methods : array

This is an nested array of trusted classes and static methods.

If empty access to all static classes and methods is allowed. Format: array ( 'class_1' => array('method_1', 'method_2'), // allowed methods listed 'class_2' => array(), // all methods of class allowed ) If set to null none is allowed.

Type

array

$trusted_static_properties

$trusted_static_properties : array

This is an array of trusted static properties.

If empty access to all static classes and properties is allowed. Format: array ( 'class_1' => array('prop_1', 'prop_2'), // allowed properties listed 'class_2' => array(), // all properties of class allowed ) If set to null none is allowed.

Type

array

$php_functions

$php_functions : array

This is an array of trusted PHP functions.

If empty all functions are allowed. To disable all PHP functions set $php_functions = null.

Type

array

$php_modifiers

$php_modifiers : array

This is an array of trusted PHP modifiers.

If empty all modifiers are allowed. To disable all modifier set $php_modifiers = null.

Type

array

$allowed_tags

$allowed_tags : array

This is an array of allowed tags.

If empty no restriction by allowed_tags.

Type

array

$disabled_tags

$disabled_tags : array

This is an array of disabled tags.

If empty no restriction by disabled_tags.

Type

array

$allowed_modifiers

$allowed_modifiers : array

This is an array of allowed modifier plugins.

If empty no restriction by allowed_modifiers.

Type

array

$disabled_modifiers

$disabled_modifiers : array

This is an array of disabled modifier plugins.

If empty no restriction by disabled_modifiers.

Type

array

$disabled_special_smarty_vars

$disabled_special_smarty_vars : array

This is an array of disabled special $smarty variables.

Type

array

$streams

$streams : array

This is an array of trusted streams.

If empty all streams are allowed. To disable all streams set $streams = null.

Type

array

$allow_constants

$allow_constants : boolean

+ flag if constants can be accessed from template

Type

boolean

$allow_super_globals

$allow_super_globals : boolean

+ flag if super globals can be accessed from template

Type

boolean

$max_template_nesting

$max_template_nesting : integer

max template nesting level

Type

integer

$_resource_dir

$_resource_dir : array

Cache for $resource_dir lookup

Type

array

$_template_dir

$_template_dir : array

Cache for $template_dir lookup

Type

array

$_config_dir

$_config_dir : array

Cache for $config_dir lookup

Type

array

$_secure_dir

$_secure_dir : array

Cache for $secure_dir lookup

Type

array

$_php_resource_dir

$_php_resource_dir : array

Cache for $php_resource_dir lookup

Type

array

$_trusted_dir

$_trusted_dir : array

Cache for $trusted_dir lookup

Type

array

$_include_path_status

$_include_path_status : boolean

Cache for include path status

Type

boolean

$_include_dir

$_include_dir : array

Cache for $_include_array lookup

Type

array

$_current_template_nesting

$_current_template_nesting : integer

current template nesting level

Type

integer

Methods

__construct()

__construct(\Smarty  $smarty) 

Parameters

\Smarty $smarty

isTrustedPhpFunction()

isTrustedPhpFunction(string  $function_name, object  $compiler) : boolean

Check if PHP function is trusted.

Parameters

string $function_name
object $compiler

compiler object

Throws

\SmartyCompilerException

if php function is not trusted

Returns

boolean —

true if function is trusted

isTrustedStaticClass()

isTrustedStaticClass(string  $class_name, object  $compiler) : boolean

Check if static class is trusted.

Parameters

string $class_name
object $compiler

compiler object

Throws

\SmartyCompilerException

if static class is not trusted

Returns

boolean —

true if class is trusted

isTrustedStaticClassAccess()

isTrustedStaticClassAccess(string  $class_name, string  $params, object  $compiler) : boolean

Check if static class method/property is trusted.

Parameters

string $class_name
string $params
object $compiler

compiler object

Throws

\SmartyCompilerException

if static class method is not trusted

Returns

boolean —

true if class method is trusted

isTrustedPhpModifier()

isTrustedPhpModifier(string  $modifier_name, object  $compiler) : boolean

Check if PHP modifier is trusted.

Parameters

string $modifier_name
object $compiler

compiler object

Throws

\SmartyCompilerException

if modifier is not trusted

Returns

boolean —

true if modifier is trusted

isTrustedTag()

isTrustedTag(string  $tag_name, object  $compiler) : boolean

Check if tag is trusted.

Parameters

string $tag_name
object $compiler

compiler object

Throws

\SmartyCompilerException

if modifier is not trusted

Returns

boolean —

true if tag is trusted

isTrustedSpecialSmartyVar()

isTrustedSpecialSmartyVar(string  $var_name, object  $compiler) : boolean

Check if special $smarty variable is trusted.

Parameters

string $var_name
object $compiler

compiler object

Throws

\SmartyCompilerException

if modifier is not trusted

Returns

boolean —

true if tag is trusted

isTrustedModifier()

isTrustedModifier(string  $modifier_name, object  $compiler) : boolean

Check if modifier plugin is trusted.

Parameters

string $modifier_name
object $compiler

compiler object

Throws

\SmartyCompilerException

if modifier is not trusted

Returns

boolean —

true if tag is trusted

isTrustedConstant()

isTrustedConstant(string  $const, object  $compiler) : boolean

Check if constants are enabled or trusted

Parameters

string $const

constant name

object $compiler

compiler object

Returns

boolean

isTrustedStream()

isTrustedStream(string  $stream_name) : boolean

Check if stream is trusted.

Parameters

string $stream_name

Throws

\SmartyException

if stream is not trusted

Returns

boolean —

true if stream is trusted

isTrustedResourceDir()

isTrustedResourceDir(string  $filepath, null|boolean  $isConfig = null) : boolean

Check if directory of file resource is trusted.

Parameters

string $filepath
null|boolean $isConfig

Throws

\SmartyException

if directory is not trusted

Returns

boolean —

true if directory is trusted

isTrustedPHPDir()

isTrustedPHPDir(string  $filepath) : boolean

Check if directory of file resource is trusted.

Parameters

string $filepath

Throws

\SmartyException

if PHP directory is not trusted

Returns

boolean —

true if directory is trusted

enableSecurity()

enableSecurity(\Smarty  $smarty, string|\Smarty_Security  $security_class) : \Smarty

Loads security class and enables security

Parameters

\Smarty $smarty
string|\Smarty_Security $security_class

if a string is used, it must be class-name

Throws

\SmartyException

when an invalid class name is provided

Returns

\Smarty

current Smarty instance for chaining

startTemplate()

startTemplate(  $template) 

Start template processing

Parameters

$template

Throws

\SmartyException

endTemplate()

endTemplate() 

Exit template processing

registerCallBacks()

registerCallBacks(\Smarty_Internal_Template  $template) 

Register callback functions call at start/end of template rendering

Parameters

\Smarty_Internal_Template $template

_checkDir()

_checkDir(string  $filepath, array  $dirs) : array

Check if file is inside a valid directory

Parameters

string $filepath
array $dirs

valid directories

Throws

\SmartyException

Returns

array