3 * library/htmlspecialchars.inc.php Escaping Functions
5 * Copyright © 2011 Boyd Stephen Smith Jr.
6 * This file is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
11 * This file is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
20 * @author Boyd Stephen Smith Jr.
24 * Escape a PHP string for use as (part of) an HTML / XML text node.
26 * It only escapes a few special chars: the ampersand (&) and both the left-
27 * pointing angle bracket (<) and the right-pointing angle bracket (>), since
28 * these are the only characters that are special in a text node. Minimal
29 * quoting is preferred because it produces smaller and more easily human-
32 * Some characters simply cannot appear in valid XML documents, even
33 * as entities but, this function does not attempt to handle them.
35 * NOTE: Attribute values are NOT text nodes, and require additional escaping.
37 * @param string $text The string to escape, possibly including "&", "<",
39 * @return string The string, with "&", "<", and ">" escaped.
41 function text($text) {
42 return htmlspecialchars($text, ENT_NOQUOTES
);
46 * Escape a PHP string for use as (part of) an HTML / XML attribute value.
48 * It escapes several special chars: the ampersand (&), the double quote
49 * ("), the singlequote ('), and both the left-pointing angle bracket (<)
50 * and the right-pointing angle bracket (>), since these are the characters
51 * that are special in an attribute value.
53 * Some characters simply cannot appear in valid XML documents, even
54 * as entities but, this function does not attempt to handle them.
56 * NOTE: This can be used as a "generic" HTML escape since it does maximal
57 * quoting. However, some HTML and XML contexts (CDATA) don't provide
58 * escape mechanisms. Also, further pre- or post-escaping might need to
59 * be done when embdedded other languages (like JavaScript) inside HTML /
62 * @param string $text The string to escape, possibly including (&), (<),
64 * @return string The string, with (&), (<), (>), ("), and (') escaped.
66 function attr($text) {
67 return htmlspecialchars($text, ENT_QUOTES
);
71 * This function is a compatibility replacement for the out function removed
72 * from the CDR Admin framework.
74 * @param string $text The string to escape, possibly including (&), (<),
76 * @return string The string, with (&), (<), (>), ("), and (') escaped.
83 * Don't call this function. You don't see this function. This function
86 * TODO: Hide this function so it can be called from this file but not from
87 * PHP that includes / requires this file. Either that, or write reasonable
88 * documentation and clean up the name.
90 function hsc_private_xl_or_warn($key) {
91 if (function_exists('xl')) {
95 'Translation via xl() was requested, but the xl()'
96 . ' function is not defined, yet.',
104 * Translate via xl() and then escape via text().
106 * @param string $key The string to escape, possibly including "&", "<",
108 * @return string The string, with "&", "<", and ">" escaped.
111 return text(hsc_private_xl_or_warn($key));
115 * Translate via xl() and then escape via attr().
117 * @param string $key The string to escape, possibly including (&), (<),
119 * @return string The string, with (&), (<), (>), ("), and (') escaped.
122 return attr(hsc_private_xl_or_warn($key));
126 Translate via xl() and then escape via addslashes for use with javascript literals
129 return addslashes(hsc_private_xl_or_warn($key));
131 return; // Stop include / require from going any further (non-PHP)