/** * @param string * @param array * @return array of [sql, params] */ public function process($sql, $params) { $this->params = $params; $this->counter = 0; $this->remaining = array(); $this->arrayMode = 'assoc'; $sql = Strings::replace($sql, '~\'.*?\'|".*?"|\\?|\\b(?:INSERT|REPLACE|UPDATE)\\b~si', array($this, 'callback')); while ($this->counter < count($params)) { $sql .= ' ' . $this->formatValue($params[$this->counter++]); } return array($sql, $this->remaining); }
/** * Expands %node.word, %node.array, %node.args, %escape(), %modify(), %var, %raw in code. * @param string * @return string */ public function write($mask) { $args = func_get_args(); array_shift($args); $word = strpos($mask, '%node.word') === FALSE ? NULL : $this->argsTokenizer->fetchWord(); $me = $this; $mask = Strings::replace($mask, '#%escape(\\(([^()]*+|(?1))+\\))#', new Callback(create_function('$m', 'extract(NCFix::$vars[' . NCFix::uses(array('me' => $me)) . '], EXTR_REFS); return $me->escape(substr($m[1], 1, -1)); '))); $mask = Strings::replace($mask, '#%modify(\\(([^()]*+|(?1))+\\))#', new Callback(create_function('$m', 'extract(NCFix::$vars[' . NCFix::uses(array('me' => $me)) . '], EXTR_REFS); return $me->formatModifiers(substr($m[1], 1, -1)); '))); return Strings::replace($mask, '#([,+]\\s*)?%(node\\.word|node\\.array|node\\.args|var|raw)(\\?)?(\\s*\\+\\s*)?()#', new Callback(create_function('$m', 'extract(NCFix::$vars[' . NCFix::uses(array('me' => $me, 'word' => $word, 'args' => &$args)) . '], EXTR_REFS); list(, $l, $macro, $cond, $r) = $m; switch ($macro) { case \'node.word\': $code = $me->formatWord($word); break; case \'node.args\': $code = $me->formatArgs(); break; case \'node.array\': $code = $me->formatArray(); $code = $cond && $code === \'array()\' ? \'\' : $code; break; case \'var\': $code = var_export(array_shift($args), TRUE); break; case \'raw\': $code = (string) array_shift($args); break; } if ($cond && $code === \'\') { return $r ? $l : $r; } else { return $l . $code . $r; } '))); }
/** * Creates current HttpRequest object. * @return HttpRequest */ public function createHttpRequest() { // DETECTS URI, base path and script path of the request. $url = new UrlScript(); $url->scheme = !empty($_SERVER['HTTPS']) && strcasecmp($_SERVER['HTTPS'], 'off') ? 'https' : 'http'; $url->user = isset($_SERVER['PHP_AUTH_USER']) ? $_SERVER['PHP_AUTH_USER'] : ''; $url->password = isset($_SERVER['PHP_AUTH_PW']) ? $_SERVER['PHP_AUTH_PW'] : ''; // host & port if (isset($_SERVER['HTTP_HOST'])) { $pair = explode(':', $_SERVER['HTTP_HOST']); } elseif (isset($_SERVER['SERVER_NAME'])) { $pair = explode(':', $_SERVER['SERVER_NAME']); } else { $pair = array(''); } $url->host = preg_match('#^[-._a-z0-9]+$#', $pair[0]) ? $pair[0] : ''; if (isset($pair[1])) { $url->port = (int) $pair[1]; } elseif (isset($_SERVER['SERVER_PORT'])) { $url->port = (int) $_SERVER['SERVER_PORT']; } // path & query if (isset($_SERVER['REQUEST_URI'])) { // Apache, IIS 6.0 $requestUrl = $_SERVER['REQUEST_URI']; } elseif (isset($_SERVER['ORIG_PATH_INFO'])) { // IIS 5.0 (PHP as CGI ?) $requestUrl = $_SERVER['ORIG_PATH_INFO']; if (isset($_SERVER['QUERY_STRING']) && $_SERVER['QUERY_STRING'] != '') { $requestUrl .= '?' . $_SERVER['QUERY_STRING']; } } else { $requestUrl = ''; } $requestUrl = Strings::replace($requestUrl, $this->urlFilters['url']); $tmp = explode('?', $requestUrl, 2); $url->path = Strings::replace($tmp[0], $this->urlFilters['path']); $url->query = isset($tmp[1]) ? $tmp[1] : ''; // normalized url $url->canonicalize(); $url->path = Strings::fixEncoding($url->path); // detect script path if (isset($_SERVER['SCRIPT_NAME'])) { $script = $_SERVER['SCRIPT_NAME']; } elseif (isset($_SERVER['DOCUMENT_ROOT'], $_SERVER['SCRIPT_FILENAME']) && strncmp($_SERVER['DOCUMENT_ROOT'], $_SERVER['SCRIPT_FILENAME'], strlen($_SERVER['DOCUMENT_ROOT'])) === 0) { $script = '/' . ltrim(strtr(substr($_SERVER['SCRIPT_FILENAME'], strlen($_SERVER['DOCUMENT_ROOT'])), '\\', '/'), '/'); } else { $script = '/'; } $path = strtolower($url->path) . '/'; $script = strtolower($script) . '/'; $max = min(strlen($path), strlen($script)); for ($i = 0; $i < $max; $i++) { if ($path[$i] !== $script[$i]) { break; } elseif ($path[$i] === '/') { $url->scriptPath = substr($url->path, 0, $i + 1); } } // GET, POST, COOKIE $useFilter = !in_array(ini_get('filter.default'), array('', 'unsafe_raw')) || ini_get('filter.default_flags'); parse_str($url->query, $query); if (!$query) { $query = $useFilter ? filter_input_array(INPUT_GET, FILTER_UNSAFE_RAW) : (empty($_GET) ? array() : $_GET); } $post = $useFilter ? filter_input_array(INPUT_POST, FILTER_UNSAFE_RAW) : (empty($_POST) ? array() : $_POST); $cookies = $useFilter ? filter_input_array(INPUT_COOKIE, FILTER_UNSAFE_RAW) : (empty($_COOKIE) ? array() : $_COOKIE); $gpc = (bool) get_magic_quotes_gpc(); $old = error_reporting(error_reporting() ^ E_NOTICE); // remove f*****g quotes and check (and optionally convert) encoding if ($gpc || $this->encoding) { $utf = strcasecmp($this->encoding, 'UTF-8') === 0; $list = array(&$query, &$post, &$cookies); while (list($key, $val) = each($list)) { foreach ($val as $k => $v) { unset($list[$key][$k]); if ($gpc) { $k = stripslashes($k); } if ($this->encoding && is_string($k) && (preg_match(self::NONCHARS, $k) || preg_last_error())) { // invalid key -> ignore } elseif (is_array($v)) { $list[$key][$k] = $v; $list[] =& $list[$key][$k]; } else { if ($gpc && !$useFilter) { $v = stripSlashes($v); } if ($this->encoding) { if ($utf) { $v = Strings::fixEncoding($v); } else { if (!Strings::checkEncoding($v)) { $v = iconv($this->encoding, 'UTF-8//IGNORE', $v); } $v = html_entity_decode($v, ENT_QUOTES, 'UTF-8'); } $v = preg_replace(self::NONCHARS, '', $v); } $list[$key][$k] = $v; } } } unset($list, $key, $val, $k, $v); } // FILES and create FileUpload objects $files = array(); $list = array(); if (!empty($_FILES)) { foreach ($_FILES as $k => $v) { if ($this->encoding && is_string($k) && (preg_match(self::NONCHARS, $k) || preg_last_error())) { continue; } $v['@'] =& $files[$k]; $list[] = $v; } } while (list(, $v) = each($list)) { if (!isset($v['name'])) { continue; } elseif (!is_array($v['name'])) { if ($gpc) { $v['name'] = stripSlashes($v['name']); } if ($this->encoding) { $v['name'] = preg_replace(self::NONCHARS, '', Strings::fixEncoding($v['name'])); } $v['@'] = new HttpUploadedFile($v); continue; } foreach ($v['name'] as $k => $foo) { if ($this->encoding && is_string($k) && (preg_match(self::NONCHARS, $k) || preg_last_error())) { continue; } $list[] = array('name' => $v['name'][$k], 'type' => $v['type'][$k], 'size' => $v['size'][$k], 'tmp_name' => $v['tmp_name'][$k], 'error' => $v['error'][$k], '@' => &$v['@'][$k]); } } error_reporting($old); // HEADERS if (function_exists('apache_request_headers')) { $headers = array_change_key_case(apache_request_headers(), CASE_LOWER); } else { $headers = array(); foreach ($_SERVER as $k => $v) { if (strncmp($k, 'HTTP_', 5) == 0) { $k = substr($k, 5); } elseif (strncmp($k, 'CONTENT_', 8)) { continue; } $headers[strtr(strtolower($k), '_', '-')] = $v; } } return new HttpRequest($url, $query, $post, $files, $cookies, $headers, isset($_SERVER['REQUEST_METHOD']) ? $_SERVER['REQUEST_METHOD'] : NULL, isset($_SERVER['REMOTE_ADDR']) ? $_SERVER['REMOTE_ADDR'] : NULL, isset($_SERVER['REMOTE_HOST']) ? $_SERVER['REMOTE_HOST'] : NULL); }
/** * {attr ...} * @deprecated */ public function macroOldAttr(MacroNode $node) { return Strings::replace($node->args . ' ', '#\\)\\s+#', ')->'); }
if ($if) { $this->flashMessage($dobre, 'success'); } else { $this->flashMessage($zle, 'danger'); } } /** Funkcia pre zjednodusenie vypisu flash spravy a presmerovania * @param array|string $redirect Adresa presmerovania * @param string $text Text pre vypis hlasenia * @param string $druh - druh hlasenia */ public function flashRedirect($redirect, $text = "", $druh = "info") { $this->flashMessage($text, $druh); if (is_array($redirect)) { if (count($redirect) > 1) { $this->redirect($redirect[0], $redirect[1]); } elseif (count($redirect) == 1) { $this->redirect($redirect[0]); } } else { $this->redirect($redirect); } } /** * Funkcia pre zjednodusenie vypisu flash spravy a presmerovania aj pre chybovy stav * @param boolean $ok Podmienka * @param array|string $redirect Adresa presmerovania * @param string $textOk Text pre vypis hlasenia ak je podmienka splnena * @param string $textEr Text pre vypis hlasenia ak NIE je podmienka splnena */ public function flashOut($ok, $redirect, $textOk = "", $textEr = "") { if ($ok) { $this->flashRedirect($redirect, $textOk, "success"); } else { $this->flashMessage($textEr, 'danger'); } } /** * Vytvorenie spolocnych helperov pre sablony * @param type $class * @return type */ protected function createTemplate($class = NULL) { $servise = $this; $template = parent::createTemplate($class); $template->addFilter('hlmenuclass', function ($id, $id_registracia, $hl_udaje) { $polozka_class = $id_registracia > 2 ? 'adminPol' : ''; //TODO $classPol .= ' zvyrazni'; if ($id == $hl_udaje) { $polozka_class .= ' active'; }
public static function dump($sql) { $keywords1 = 'CREATE\\s+TABLE|CREATE(?:\\s+UNIQUE)?\\s+INDEX|SELECT|UPDATE|INSERT(?:\\s+INTO)?|REPLACE(?:\\s+INTO)?|DELETE|FROM|WHERE|HAVING|GROUP\\s+BY|ORDER\\s+BY|LIMIT|SET|VALUES|LEFT\\s+JOIN|INNER\\s+JOIN|TRUNCATE'; $keywords2 = 'ALL|DISTINCT|DISTINCTROW|AS|USING|ON|AND|OR|IN|IS|NOT|NULL|LIKE|TRUE|FALSE|INTEGER|CLOB|VARCHAR|DATETIME|TIME|DATE|INT|SMALLINT|BIGINT|BOOL|BOOLEAN|DECIMAL|FLOAT|TEXT|VARCHAR|DEFAULT|AUTOINCREMENT|PRIMARY\\s+KEY'; // insert new lines $sql = " {$sql} "; $sql = self::replace($sql, "#(?<=[\\s,(])({$keywords1})(?=[\\s,)])#", "\n\$1"); if (strpos($sql, "CREATE TABLE") !== FALSE) { $sql = Strings::replace($sql, "#,\\s+#i", ", \n"); } // reduce spaces $sql = self::replace($sql, '#[ \\t]{2,}#', " "); $sql = wordwrap($sql, 100); $sql = htmlSpecialChars($sql); $sql = self::replace($sql, "#([ \t]*\r?\n){2,}#", "\n"); $sql = self::replace($sql, "#VARCHAR\\(#", "VARCHAR ("); // syntax highlight $sql = self::replace($sql, "#(/\\*.+?\\*/)|(\\*\\*.+?\\*\\*)|(?<=[\\s,(])({$keywords1})(?=[\\s,)])|(?<=[\\s,(=])({$keywords2})(?=[\\s,)=])#s", function ($matches) { if (!empty($matches[1])) { // comment return '<em style="color:gray">' . $matches[1] . '</em>'; } if (!empty($matches[2])) { // error return '<strong style="color:red">' . $matches[2] . '</strong>'; } if (!empty($matches[3])) { // most important keywords return '<strong style="color:blue">' . $matches[3] . '</strong>'; } if (!empty($matches[4])) { // other keywords return '<strong style="color:green">' . $matches[4] . '</strong>'; } }); $sql = trim($sql); return '<pre class="dump">' . $sql . "</pre>\n"; }
return $id; } return wp_get_attachment_image_src($post->ID, $size)[0]; }; MangoFilters::$set['wp_thumbnail'] = function ($id, $size = 'thumbnail') { $post = lazy_post($id); if (!$post) { return $id; } return wp_get_attachment_image_src(get_post_thumbnail_id($post->ID), $size)[0]; }; MangoFilters::$set['wp_esc'] = function ($str) { return html_entity_decode($str); }; MangoFilters::$set['number'] = function ($number, $decimal = 2) { if (fmod($number, 1) == 0) { $decimal = 0; } $sep = '.'; $formatted = number_format($number, $decimal, $sep, ","); if ($decimal) { $formatted = Strings::replace($formatted, '~\\.?0$~'); } return $formatted; }; function nbsp($str) { $str = trim($str); return Nette\Utils\Strings::replace($str, '~[ ]~', " "); } MangoFilters::$set['nbsp'] = 'nbsp';
/** * Indents the HTML content from the left. * @param string UTF-8 encoding or 8-bit * @param int * @param string * @return string */ public static function indent($s, $level = 1, $chars = "\t") { if ($level >= 1) { $s = Strings::replace($s, '#<(textarea|pre).*?</\\1#si', new Callback(create_function('$m', ' return strtr($m[0], " \\t\\r\\n", "\\x1F\\x1E\\x1D\\x1A"); '))); $s = Strings::indent($s, $level, $chars); $s = strtr($s, "", " \t\r\n"); } return $s; }
/** * Builds text content. * @return void */ protected function buildText() { $text = $this->getBody(); if ($text instanceof ITemplate) { $text->mail = $this; $this->setBody($text->__toString(TRUE)); } elseif ($text == NULL && $this->html != NULL) { // intentionally == $text = Strings::replace($this->html, array('#<(style|script|head).*</\\1>#Uis' => '', '#<t[dh][ >]#i' => " \$0", '#[\\r\\n]+#' => ' ', '#<(/?p|/?h\\d|li|br|/tr)[ >/]#i' => "\n\$0")); $text = html_entity_decode(strip_tags($text), ENT_QUOTES, 'UTF-8'); $text = Strings::replace($text, '#[ \\t]+#', ' '); $this->setBody(trim($text)); } }