123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308 |
- <?php
- /* vim: set expandtab sw=4 ts=4 sts=4: */
- /**
- * URL/hidden inputs generating.
- *
- * @package PhpMyAdmin
- */
- if (! defined('PHPMYADMIN')) {
- exit;
- }
- /**
- * Generates text with hidden inputs.
- *
- * @param string|array $db optional database name
- * (can also be an array of parameters)
- * @param string $table optional table name
- * @param int $indent indenting level
- * @param string|array $skip do not generate a hidden field for this parameter
- * (can be an array of strings)
- *
- * @see PMA_URL_getCommon()
- *
- * @return string string with input fields
- *
- * @global string the current language
- * @global string the current conversion charset
- * @global string the current connection collation
- * @global string the current server
- * @global array the configuration array
- * @global boolean whether recoding is allowed or not
- *
- * @access public
- */
- function PMA_URL_getHiddenInputs($db = '', $table = '',
- $indent = 0, $skip = array()
- ) {
- if (is_array($db)) {
- $params =& $db;
- $_indent = empty($table) ? $indent : $table;
- $_skip = empty($indent) ? $skip : $indent;
- $indent =& $_indent;
- $skip =& $_skip;
- } else {
- $params = array();
- if (strlen($db)) {
- $params['db'] = $db;
- }
- if (strlen($table)) {
- $params['table'] = $table;
- }
- }
- if (! empty($GLOBALS['server'])
- && $GLOBALS['server'] != $GLOBALS['cfg']['ServerDefault']
- ) {
- $params['server'] = $GLOBALS['server'];
- }
- if (empty($_COOKIE['pma_lang']) && ! empty($GLOBALS['lang'])) {
- $params['lang'] = $GLOBALS['lang'];
- }
- if (empty($_COOKIE['pma_collation_connection'])
- && ! empty($GLOBALS['collation_connection'])
- ) {
- $params['collation_connection'] = $GLOBALS['collation_connection'];
- }
- $params['token'] = $_SESSION[' PMA_token '];
- if (! is_array($skip)) {
- if (isset($params[$skip])) {
- unset($params[$skip]);
- }
- } else {
- foreach ($skip as $skipping) {
- if (isset($params[$skipping])) {
- unset($params[$skipping]);
- }
- }
- }
- return PMA_getHiddenFields($params);
- }
- /**
- * create hidden form fields from array with name => value
- *
- * <code>
- * $values = array(
- * 'aaa' => aaa,
- * 'bbb' => array(
- * 'bbb_0',
- * 'bbb_1',
- * ),
- * 'ccc' => array(
- * 'a' => 'ccc_a',
- * 'b' => 'ccc_b',
- * ),
- * );
- * echo PMA_getHiddenFields($values);
- *
- * // produces:
- * <input type="hidden" name="aaa" Value="aaa" />
- * <input type="hidden" name="bbb[0]" Value="bbb_0" />
- * <input type="hidden" name="bbb[1]" Value="bbb_1" />
- * <input type="hidden" name="ccc[a]" Value="ccc_a" />
- * <input type="hidden" name="ccc[b]" Value="ccc_b" />
- * </code>
- *
- * @param array $values hidden values
- * @param string $pre prefix
- *
- * @return string form fields of type hidden
- */
- function PMA_getHiddenFields($values, $pre = '')
- {
- $fields = '';
- foreach ($values as $name => $value) {
- if (! empty($pre)) {
- $name = $pre . '[' . $name . ']';
- }
- if (is_array($value)) {
- $fields .= PMA_getHiddenFields($value, $name);
- } else {
- // do not generate an ending "\n" because
- // PMA_URL_getHiddenInputs() is sometimes called
- // from a JS document.write()
- $fields .= '<input type="hidden" name="' . htmlspecialchars($name)
- . '" value="' . htmlspecialchars($value) . '" />';
- }
- }
- return $fields;
- }
- /**
- * Generates text with URL parameters.
- *
- * <code>
- * // OLD (deprecated) style
- * // note the ?
- * echo 'script.php?' . PMA_URL_getCommon('mysql', 'rights');
- * // produces with cookies enabled:
- * // script.php?db=mysql&table=rights
- * // with cookies disabled:
- * // script.php?server=1&lang=en&db=mysql&table=rights
- *
- * // NEW style
- * $params['myparam'] = 'myvalue';
- * $params['db'] = 'mysql';
- * $params['table'] = 'rights';
- * // note the missing ?
- * echo 'script.php' . PMA_URL_getCommon($params);
- * // produces with cookies enabled:
- * // script.php?myparam=myvalue&db=mysql&table=rights
- * // with cookies disabled:
- * // script.php?server=1&lang=en&myparam=myvalue&db=mysql
- * // &table=rights
- *
- * // note the missing ?
- * echo 'script.php' . PMA_URL_getCommon();
- * // produces with cookies enabled:
- * // script.php
- * // with cookies disabled:
- * // script.php?server=1&lang=en
- * </code>
- *
- * @param mixed assoc. array with url params or optional string with database name
- * if first param is an array there is also an ? prefixed to the url
- *
- * @param string - if first param is array: 'html' to use htmlspecialchars()
- * on the resulting URL (for a normal URL displayed in HTML)
- * or something else to avoid using htmlspecialchars() (for
- * a URL sent via a header); if not set,'html' is assumed
- * - if first param is not array: optional table name
- *
- * @param string - if first param is array: optional character to
- * use instead of '?'
- * - if first param is not array: optional character to use
- * instead of '&' for dividing URL parameters
- *
- * @return string string with URL parameters
- * @access public
- */
- function PMA_URL_getCommon()
- {
- $args = func_get_args();
- if (isset($args[0]) && is_array($args[0])) {
- // new style
- $params = $args[0];
- if (isset($args[1])) {
- $encode = $args[1];
- } else {
- $encode = 'html';
- }
- if (isset($args[2])) {
- $questionmark = $args[2];
- } else {
- $questionmark = '?';
- }
- } else {
- // old style
- $params = array();
- if (PMA_isValid($args[0])) {
- $params['db'] = $args[0];
- }
- if (PMA_isValid($args[1])) {
- $params['table'] = $args[1];
- }
- if (isset($args[2]) && $args[2] !== '&') {
- $encode = 'text';
- } else {
- $encode = 'html';
- }
- $questionmark = '';
- }
- $separator = PMA_URL_getArgSeparator();
- // avoid overwriting when creating navi panel links to servers
- if (isset($GLOBALS['server'])
- && $GLOBALS['server'] != $GLOBALS['cfg']['ServerDefault']
- && ! isset($params['server'])
- ) {
- $params['server'] = $GLOBALS['server'];
- }
- if (empty($_COOKIE['pma_lang']) && ! empty($GLOBALS['lang'])) {
- $params['lang'] = $GLOBALS['lang'];
- }
- if (empty($_COOKIE['pma_collation_connection'])
- && ! empty($GLOBALS['collation_connection'])
- ) {
- $params['collation_connection'] = $GLOBALS['collation_connection'];
- }
- if (isset($_SESSION[' PMA_token '])) {
- $params['token'] = $_SESSION[' PMA_token '];
- }
- if (empty($params)) {
- return '';
- }
- $query = $questionmark . http_build_query($params, null, $separator);
- if ($encode === 'html') {
- $query = htmlspecialchars($query);
- }
- return $query;
- }
- /**
- * Returns url separator
- *
- * extracted from arg_separator.input as set in php.ini
- * we do not use arg_separator.output to avoid problems with & and &
- *
- * @param string $encode whether to encode separator or not,
- * currently 'none' or 'html'
- *
- * @return string character used for separating url parts usually ; or &
- * @access public
- */
- function PMA_URL_getArgSeparator($encode = 'none')
- {
- static $separator = null;
- static $html_separator = null;
- if (null === $separator) {
- // use separators defined by php, but prefer ';'
- // as recommended by W3C
- // (see http://www.w3.org/TR/1999/REC-html401-19991224/appendix
- // /notes.html#h-B.2.2)
- $arg_separator = ini_get('arg_separator.input');
- if (strpos($arg_separator, ';') !== false) {
- $separator = ';';
- } elseif (strlen($arg_separator) > 0) {
- $separator = $arg_separator{0};
- } else {
- $separator = '&';
- }
- $html_separator = htmlentities($separator);
- }
- switch ($encode) {
- case 'html':
- return $html_separator;
- break;
- case 'text' :
- case 'none' :
- default :
- return $separator;
- }
- }
- ?>
|