'); // line break # Make the app and l10n play nice with Windows. if (substr(PHP_OS, 0, 3) === 'WIN') { // || strpos(@php_uname(), 'ARCH') define('WINDOWS', true); } else { define('WINDOWS', false); } define('FORMAT_DB_DATETIME', 'Y-m-d H:i:s'); // date(...) define('FORMAT_DB_DATE', 'Y-m-d'); define('FORMAT_DB_TIME', 'H:i:s'); define('DEFAULT_DATETIME', '0000-00-00 00:00:00'); define('DEFAULT_DATE', '0000-00-00'); define('DEFAULT_TIME', '00:00:00'); # workpaths define('FILES', APP . 'files' . DS); define('LOCALE', APP . 'locale' . DS); if (!defined('CLASS_USER')) { define('CLASS_USER', 'User'); } # Validation ## (minus should be "hyphen") /** Valid characters: letters only */ define('VALID_ALPHA', '/^[a-zA-Z]+$/'); /** Valid characters: letters,underscores only */ define('VALID_ALPHA_UNDERSCORES', '/^[a-zA-Z_]+$/'); /** Valid characters: letters,underscores,minus only */ define('VALID_ALPHA_MINUS_UNDERSCORES', '/^[a-zA-Z_-]+$/'); /** Valid characters: letters,spaces only */ define('VALID_ALPHA_WHITESPACES', '/^[a-zA-Z ]+$/'); /** Valid characters: letters,numbers,underscores only */ define('VALID_ALPHANUMERIC_UNDERSCORES', '/^[\da-zA-Z_]+$/'); /** Valid characters: letters,numbers,underscores,minus only */ define('VALID_ALPHANUMERIC_MINUS_UNDERSCORES', '/^[\da-zA-Z_-]+$/'); /** Valid characters: letters,numbers,spaces only */ define('VALID_ALPHANUMERIC_WHITESPACES', '/^[\da-zA-Z ]+$/'); /** Valid characters: letters,numbers,spaces,underscores only */ define('VALID_ALPHANUMERIC_WHITESPACES_UNDERSCORES', '/^[\da-zA-Z _]+$/'); /** Valid characters: numbers,underscores only */ define('VALID_NUMERIC_UNDERSCORES', '/^[\d_]+$/'); /** Valid characters: numbers,spaces only */ define('VALID_NUMERIC_WHITESPACES', '/^[\d ]+$/'); /** Valid characters: numbers,spaces,underscores only */ define('VALID_NUMERIC_WHITESPACES_UNDERSCORES', '/^[\d _]+$/'); /** Valid integers: > 0 */ define('VALID_INTEGERS', '/^[\d]+$/'); //?? if (!defined('FORMAT_NICE_YMDHMS')) { define('FORMAT_NICE_YMDHMS', 'd.m.Y, H:i:s'); define('FORMAT_NICE_YMDHM', 'd.m.Y, H:i'); define('FORMAT_NICE_YM', 'm.Y'); define('FORMAT_NICE_YMD', 'd.m.Y'); define('FORMAT_NICE_MD', 'd.m.'); define('FORMAT_NICE_D', 'd'); # xx define('FORMAT_NICE_W_NUM', 'w'); # xx (0=sunday to 6=saturday) define('FORMAT_NICE_W_ABBR', 'D'); # needs manual translation define('FORMAT_NICE_W_FULL', 'l'); # needs manual translation define('FORMAT_NICE_M', 'm'); # xx define('FORMAT_NICE_M_ABBR', 'M'); # needs manual translation define('FORMAT_NICE_M_FULL', 'F'); # needs manual translation define('FORMAT_NICE_Y_ABBR', 'y'); # xx define('FORMAT_NICE_Y', 'Y'); # xxxx define('FORMAT_NICE_HM', 'H:i'); define('FORMAT_NICE_HMS', 'H:i:s'); # localDate strings define('FORMAT_LOCAL_WA_YMDHMS', '%a, %d.%m.%Y, %H:%M:%S'); define('FORMAT_LOCAL_WF_YMDHMS', '%A, %d.%m.%Y, %H:%M:%S'); define('FORMAT_LOCAL_WA_YMDHM', '%a, %d.%m.%Y, %H:%M'); define('FORMAT_LOCAL_WF_YMDHM', '%A, %d.%m.%Y, %H:%M'); define('FORMAT_LOCAL_YMDHMS', '%d.%m.%Y, %H:%M:%S'); define('FORMAT_LOCAL_YMDHM', '%d.%m.%Y, %H:%M'); define('FORMAT_LOCAL_YMD', '%d.%m.%Y'); define('FORMAT_LOCAL_MD', '%d.%m.'); define('FORMAT_LOCAL_D', '%d'); # xx define('FORMAT_LOCAL_W_NUM', '%w'); # xx (0=sunday to 6=saturday) define('FORMAT_LOCAL_W_ABBR', '%a'); # needs translation define('FORMAT_LOCAL_W_FULL', '%A'); # needs translation define('FORMAT_LOCAL_M', '%m'); # xx define('FORMAT_LOCAL_M_ABBR', '%b'); # needs translation define('FORMAT_LOCAL_M_FULL', '%B'); # needs translation define('FORMAT_LOCAL_Y_ABBR', '%y'); # xx define('FORMAT_LOCAL_Y', '%Y'); # xxxx define('FORMAT_LOCAL_H', '%H'); define('FORMAT_LOCAL_S', '%S'); define('FORMAT_LOCAL_HM', '%H:%i'); define('FORMAT_LOCAL_HMS', '%H:%M:%S'); } /*** chars ***/ /* see http://www.htmlcodetutorial.com/characterentities_famsupp_69.html */ define('CHAR_LESS', '<'); # < define('CHAR_GREATER', '>'); # > define('CHAR_QUOTE', '"'); # " define('CHAR_APOSTROPHE', '''); # ' define('CHAR_ARROWS', '»'); # » define('CHAR_ARROWS_R', '»'); # » define('CHAR_ARROWS_L', '«'); # « define('CHAR_AVERAGE', 'Ø'); # Ø define('CHAR_INFIN', '∞'); # 8 define('CHAR_MILL', '‰'); # ‰ (per mille) / or ‰ define('CHAR_PLUSMN', '±'); # 8 define('CHAR_HELLIP', '…'); # … (horizontal ellipsis = three dot leader) define('CHAR_CIRCA', '≈'); # ˜ (almost equal to) define('CHAR_CHECKBOX_EMPTY', '☐]'); # define('CHAR_CHECKBOX_MAKRED', '☑'); # define('CHAR_CHECKMARK', '✓'); define('CHAR_CHECKMARK_BOLD', '✔'); define('CHAR_BALLOT', '✗'); define('CHAR_BALLOT_BOLD', '✘'); define('CHAR_ABOUT', '≈'); # … (horizontal ellipsis = three dot leader) /* not very often used */ define('CHAR_RPIME', '′'); # ' (minutes) define('CHAR_DOUBLE_RPIME', '″'); # ? (seconds) /** BASIC FUNCTIONS **/ /** * Own slug function - containing extra char replacement * * //TODO move to TextLib? * * @return string */ function slug($string, $separator = null, $low = true) { $additionalSlugElements = array( '/º|°/' => 0, '/¹/' => 1, '/²/' => 2, '/³/' => 3, # new utf8 char "capitel ß" still missing here! '/.../' => 'SS', (TODO in 2009) '/@/' => 'at', '/æ/' => 'ae', '/©/' => 'C', '/ç|¢/' => 'c', '/Ð/' => 'D', '/€/' => 'EUR', '/™/' => 'TM', # more missing? ); if ($separator === null) { $separator = defined('SEO_SEPARATOR') ? SEO_SEPARATOR : '-'; } $res = Inflector::slug($string, $separator, $additionalSlugElements); if ($low) { $res = strtolower($res); } return $res; } /** * Since nl2br doesn't remove the line breaks when adding in the
tags, * it is necessary to strip those off before you convert all of the tags, otherwise you will get double spacing * * //TODO: move to TextLib? * * @param string $str * @return string */ function br2nl($str) { $str = preg_replace("/(\r\n|\r|\n)/", "", $str); return preg_replace("=
=i", "\n", $str); } /** * Replaces CRLF with spaces * * //TODO: move to TextLib? * * @param string $text Any text * @return string Safe string without new lines */ function safenl($str) { //$str = str_replace(chr(13).chr(10), " ", $str); # \r\n //$str = str_replace(chr(13), " ", $str); # \r //$str = str_replace(chr(10), " ", $str); # \n $str = preg_replace("/(\r\n|\r|\n)/", " ", $str); return $str; } /** * Convenience function to check on "empty()" * * @param mixed $var * @return boolean Result */ function isEmpty($var = null) { if (empty($var)) { return true; } return false; } /** * Return of what type the specific value is * * //TODO: use Debugger::exportVar() instead? * * @param mixed $value * @return type (NULL, array, bool, float, int, string, object, unknown) + value */ function returns($value) { if ($value === null) { return 'NULL'; } elseif (is_array($value)) { return '(array)' . '
' . print_r($value, true) . '
'; } elseif ($value === true) { return '(bool)TRUE'; } elseif ($value === false) { return '(bool)FALSE'; } elseif (is_numeric($value) && is_float($value)) { return '(float)' . $value; } elseif (is_numeric($value) && is_int($value)) { return '(int)' . $value; } elseif (is_string($value)) { return '(string)' . $value; } elseif (is_object($value)) { return '(object)' . get_class($value) . '
' . print_r($value, true) .
			'
'; } else { return '(unknown)' . $value; } } /** * Quickly dump a $var * * @param mixed $var * @return void */ function dump($var) { if (class_exists('Debugger')) { App::uses('Debugger', 'Utility'); } return Debugger::dump($var); } /** * Returns htmlentities - string * * ENT_COMPAT = Will convert double-quotes and leave single-quotes alone. * ENT_QUOTES = Will convert both double and single quotes. !!! * ENT_NOQUOTES= Will leave both double and single quotes unconverted. */ function ent($text) { return (!empty($text) ? htmlentities($text, ENT_QUOTES, 'UTF-8') : ''); } /** * Convenience method for htmlspecialchars_decode * * @param string $text Text to wrap through htmlspecialchars_decode * @return string Wrapped text */ function hDec($text, $quoteStyle = ENT_QUOTES) { if (is_array($text)) { return array_map('hDec', $text); } return trim(htmlspecialchars_decode($text, $quoteStyle)); } /** * Convenience method for html_entity_decode * * @param string $text Text to wrap through htmlspecialchars_decode * @return string Wrapped text */ function entDec($text, $quoteStyle = ENT_QUOTES) { if (is_array($text)) { return array_map('entDec', $text); } return (!empty($text) ? trim(html_entity_decode($text, $quoteStyle, 'UTF-8')) : ''); } /** * Focus is on the filename (without path) * * //TODO: switch parameters!!! * * @return mixed */ function extractFileInfo($type = null, $filename) { if ($info = extractPathInfo($type, $filename)) { return $info; } $pos = strrpos($filename, '.'); $res = ''; switch ($type) { case 'extension': case 'ext': $res = ($pos !== false) ? substr($filename, $pos + 1) : ''; break; case 'filename': case 'file': $res = ($pos !== false) ? substr($filename, 0, $pos) : ''; break; default: break; } return $res; } /** * Uses native PHP function to retrieve infos about a filename etc. * Improves it by not returning non-file-name characters from url files if specified. * So "filename.ext?foo=bar#hash" would simply be "filename.ext" then. * * //TODO: switch parameters!!! * * @param string type (extension/ext, filename/file, basename/base, dirname/dir) * @param string filename to check on * @return mixed */ function extractPathInfo($type = null, $filename, $fromUrl = false) { switch ($type) { case 'extension': case 'ext': $infoType = PATHINFO_EXTENSION; break; case 'filename': case 'file': $infoType = PATHINFO_FILENAME; break; case 'basename': case 'base': $infoType = PATHINFO_BASENAME; break; case 'dirname': case 'dir': $infoType = PATHINFO_DIRNAME; break; default: $infoType = null; } $result = pathinfo($filename, $infoType); if ($fromUrl) { if (($pos = strpos($result, '#')) !== false) { $result = substr($result, 0, $pos); } if (($pos = strpos($result, '?')) !== false) { $result = substr($result, 0, $pos); } } return $result; } /** * Shows pr() messages, even with debug=0 * * @param mixed $content * @param boolean $collapsedAndExpandable * @param array $options * - class, showHtml, showFrom, jquery, returns, debug * @return string HTML */ function pre($var, $collapsedAndExpandable = false, $options = array()) { $defaults = array( 'class' => 'cake-debug', 'showHtml' => false, # escape < and > (or manually escape with h() prior to calling this function) 'showFrom' => false, # display file + line 'jquery' => null, # auto - use jQuery (true/false to manually decide), 'returns' => false, # returns(), 'debug' => false # showOnlyOnDebug ); $options = array_merge($defaults, $options); if ($options['debug'] && !Configure::read('debug')) { return ''; } $res = '
'; $pre = ''; if ($collapsedAndExpandable) { $js = 'if (this.parentNode.getElementsByTagName(\'pre\')[0].style.display==\'block\') {this.parentNode.getElementsByTagName(\'pre\')[0].style.display=\'none\'} else {this.parentNode.getElementsByTagName(\'pre\')[0].style.display=\'block\'}'; $jsJquery = 'jQuery(this).parent().children(\'pre\').slideToggle(\'fast\')'; if ($options['jquery'] === true) { $js = $jsJquery; } elseif ($options['jquery'] !== false) { # auto $js = 'if (typeof jQuery == \'undefined\') {' . $js . '} else {' . $jsJquery . '}'; } $res .= 'Debug'; if ($options['showFrom']) { $calledFrom = debug_backtrace(); $from = '' . substr(str_replace(ROOT, '', $calledFrom[0]['file']), 1) . ''; $from .= ' (line ' . $calledFrom[0]['line'] . ')'; $res .= '
' . $from . '
'; } $pre = ' style="display: none"'; } if ($options['returns']) { $var = returns($var); } else { $var = print_r($var, true); } $res .= '' . $var . ''; $res .= '
'; return $res; } /** * Checks if the string [$haystack] contains [$needle] * * @param string $haystack Input string. * @param string $needle Needed char or string. * @return boolean */ function contains($haystack, $needle, $caseSensitive = false) { $result = !$caseSensitive ? stripos($haystack, $needle) : strpos($haystack, $needle); return ($result !== false); } /** * Checks if the string [$haystack] starts with [$needle] * * @param string $haystack Input string. * @param string $needle Needed char or string. * @return boolean */ function startsWith($haystack, $needle, $caseSensitive = false) { if ($caseSensitive) { return (mb_strpos($haystack, $needle) === 0); } return (mb_stripos($haystack, $needle) === 0); } /** * Checks if the String [$haystack] ends with [$needle] * * @param string $haystack Input string. * @param string $needle Needed char or string * @return boolean */ function endsWith($haystack, $needle, $caseSensitive = false) { if ($caseSensitive) { return mb_strrpos($haystack, $needle) === mb_strlen($haystack) - mb_strlen($needle); } return mb_strripos($haystack, $needle) === mb_strlen($haystack) - mb_strlen($needle); } /** * Base64 encode and replace chars base64 uses that would mess up the url * only needed for named params to be safely passed (if urlencode is not used) * * @deprecated Use Utility::urlEncode(). * @return string or NULL */ function base64UrlEncode($fieldContent) { if (empty($fieldContent)) { return null; } $tmp = base64_encode($fieldContent); return str_replace(array('/', '='), array('-', '_'), $tmp); } /** * Base64 decode and undo replacing of chars base64 uses that would mess up the url * only needed for named params to be safely passed (if urlencode is not used) * * @deprecated Use Utility::urlDecode(). * @return string or NULL */ function base64UrlDecode($fieldContent) { if (empty($fieldContent)) { return null; } $tmp = str_replace(array('-', '_'), array('/', '='), $fieldContent); return base64_decode($tmp); } /** * PrettyJson * * @link https://github.com/ndejong/pretty_json/blob/master/pretty_json.php * @param string $json - the original JSON string * @param string $ind - the string to indent with * @return string */ function prettyJson($json, $ind = "\t") { // Replace any escaped \" marks so we don't get tripped up on quotemarks_counter $tokens = preg_split('|([\{\}\]\[,])|', str_replace('\"', '~~PRETTY_JSON_QUOTEMARK~~', $json), -1, PREG_SPLIT_DELIM_CAPTURE); $indent = 0; $result = ''; $quotemarksCounter = 0; $nextTokenUsePrefix = true; foreach ($tokens as $token) { $quotemarksCounter = $quotemarksCounter + (count(explode('"', $token)) - 1); if ($token === '') { continue; } if ($nextTokenUsePrefix) { $prefix = str_repeat($ind, $indent); } else { $prefix = null; } // Determine if the quote marks are open or closed if ($quotemarksCounter & 1) { // odd - thus quotemarks open $nextTokenUsePrefix = false; $newLine = null; } else { // even - thus quotemarks closed $nextTokenUsePrefix = true; $newLine = "\n"; } if ($token === "{" || $token === "[") { $indent++; $result .= $token . $newLine; } elseif ($token === "}" || $token === "]") { $indent--; if ($indent >= 0) { $prefix = str_repeat($ind, $indent); } if ($nextTokenUsePrefix) { $result .= $newLine . $prefix . $token; } else { $result .= $newLine . $token; } } elseif ($token === ",") { $result .= $token . $newLine; } else { $result .= $prefix . $token; } } $result = str_replace('~~PRETTY_JSON_QUOTEMARK~~', '\"', $result); return $result; }