예제 #1
0
 /**
  * @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);
 }
예제 #2
0
    /**
     * 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;
			}
		')));
    }
예제 #3
0
 /**
  * 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);
 }
예제 #4
0
 /**
  * {attr ...}
  * @deprecated
  */
 public function macroOldAttr(MacroNode $node)
 {
     return Strings::replace($node->args . ' ', '#\\)\\s+#', ')->');
 }
예제 #5
0
      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';
          }
예제 #6
0
 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";
 }
예제 #7
0
        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';
예제 #8
0
파일: Helpers.php 프로젝트: riskatlas/micka
    /**
     * 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;
    }
예제 #9
0
파일: Message.php 프로젝트: riskatlas/micka
 /**
  * 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));
     }
 }