123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- <?php
- /*
- * This file is part of the symfony package.
- * (c) 2004-2006 Fabien Potencier <fabien.potencier@symfony-project.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- /**
- * The functions are primarily used by the output escaping component.
- *
- * Each function specifies a way for applying a transformation to a string
- * passed to it. The purpose is for the string to be "escaped" so it is
- * suitable for the format it is being displayed in.
- *
- * For example, the string: "It's required that you enter a username & password.\n"
- * If this were to be displayed as HTML it would be sensible to turn the
- * ampersand into '&' and the apostrophe into '&aps;'. However if it were
- * going to be used as a string in JavaScript to be displayed in an alert box
- * it would be right to leave the string as-is, but c-escape the apostrophe and
- * the new line.
- *
- * For each function there is a define to avoid problems with strings being
- * incorrectly specified.
- *
- * @package symfony
- * @subpackage helper
- * @author Mike Squire <mike@somosis.co.uk>
- * @version SVN: $Id: EscapingHelper.php 9101 2008-05-20 08:38:20Z FabianLange $
- */
- /**
- * Runs the PHP function htmlentities on the value passed.
- *
- * @param string $value the value to escape
- * @return string the escaped value
- */
- function esc_entities($value)
- {
- // Numbers and boolean values get turned into strings which can cause problems
- // with type comparisons (e.g. === or is_int() etc).
- return is_string($value) ? htmlentities($value, ENT_QUOTES, sfConfig::get('sf_charset')) : $value;
- }
- define('ESC_ENTITIES', 'esc_entities');
- /**
- * Runs the PHP function htmlspecialchars on the value passed.
- *
- * @param string $value the value to escape
- * @return string the escaped value
- */
- function esc_specialchars($value)
- {
- // Numbers and boolean values get turned into strings which can cause problems
- // with type comparisons (e.g. === or is_int() etc).
- return is_string($value) ? htmlspecialchars($value, ENT_QUOTES, sfConfig::get('sf_charset')) : $value;
- }
- define('ESC_SPECIALCHARS', 'esc_specialchars');
- /**
- * An identity function that merely returns that which it is given, the purpose
- * being to be able to specify that the value is not to be escaped in any way.
- *
- * @param string $value the value to escape
- * @return string the escaped value
- */
- function esc_raw($value)
- {
- return $value;
- }
- define('ESC_RAW', 'esc_raw');
- /**
- * A function that c-escapes a string after applying {@link esc_entities()}. The
- * assumption is that the value will be used to generate dynamic HTML in some
- * way and the safest way to prevent mishap is to assume the value should have
- * HTML entities set properly.
- *
- * The {@link esc_js_no_entities()} method should be used to escape a string
- * that is ultimately not going to end up as text in an HTML document.
- *
- * @param string $value the value to escape
- * @return string the escaped value
- */
- function esc_js($value)
- {
- return esc_js_no_entities(esc_entities($value));
- }
- define('ESC_JS', 'esc_js');
- /**
- * A function the c-escapes a string, making it suitable to be placed in a
- * JavaScript string.
- *
- * @param string $value the value to escape
- * @return string the escaped value
- */
- function esc_js_no_entities($value)
- {
- return addcslashes($value, "\0..\37\\'\"\177..\377\/");
- }
- define('ESC_JS_NO_ENTITIES', 'esc_js_no_entities');
|