code cleanup and link function allows now query in the url too

This commit is contained in:
Ralf Becker 2005-11-11 23:07:29 +00:00
parent 3bae8c3a00
commit 0be34d315b

View File

@ -1040,6 +1040,7 @@
/** /**
* Additional tracking of user actions - prevents reposts/use of back button * Additional tracking of user actions - prevents reposts/use of back button
* *
* @deprecated not used in eGroupWare
* @author skwashd * @author skwashd
* @return string current history id * @return string current history id
*/ */
@ -1062,6 +1063,7 @@
/** /**
* Detects if the page has already been called before - good for forms * Detects if the page has already been called before - good for forms
* *
* @deprecated not used in eGroupWare
* @author skwashd * @author skwashd
* @param bool $diplay_error when implemented will use the generic error handling code * @param bool $diplay_error when implemented will use the generic error handling code
* @return True if called previously, else False - call ok * @return True if called previously, else False - call ok
@ -1091,35 +1093,29 @@
/** /**
* Generate a url which supports url or cookies based sessions * Generate a url which supports url or cookies based sessions
* *
* @param string $url a url relative to the egroupware install root * Please note, the values of the query get url encoded!
* @param array $extravars query string arguements *
* @param string $url a url relative to the egroupware install root, it can contain a query too
* @param array/string $extravars query string arguements as string or array (prefered)
* @return string generated url * @return string generated url
*/ */
function link($url, $extravars = '') function link($url, $extravars = '')
{ {
//echo "<p>session::link(url='".print_r($url,True)."',extravars='".print_r($extravars,True)."')"; //echo "<p>session::link(url='$url',extravars='".print_r($extravars,True)."')";
/* first we process the $url to build the full scriptname */
$full_scriptname = True; if ($url{0} != '/')
$url_firstchar = substr($url ,0,1);
if ($url_firstchar == '/' && $GLOBALS['egw_info']['server']['webserver_url'] == '/')
{
$full_scriptname = False;
}
if ($url_firstchar != '/')
{ {
$app = $GLOBALS['egw_info']['flags']['currentapp']; $app = $GLOBALS['egw_info']['flags']['currentapp'];
if ($app != 'home' && $app != 'login' && $app != 'logout') if ($app != 'login' && $app != 'logout')
{ {
$url = $app.'/'.$url; $url = $app.'/'.$url;
} }
} }
if($full_scriptname) // append the url to the webserver url, but avoid more then one slash between the parts of the url
if ($url{0} != '/' || $GLOBALS['egw_info']['server']['webserver_url'] != '/')
{ {
$webserver_url_count = strlen($GLOBALS['egw_info']['server']['webserver_url'])-1; if($url{0} != '/' && substr($GLOBALS['egw_info']['server']['webserver_url'],-1) != '/')
if(substr($GLOBALS['egw_info']['server']['webserver_url'] ,$webserver_url_count,1) != '/' && $url_firstchar != '/')
{ {
$url = $GLOBALS['egw_info']['server']['webserver_url'] .'/'. $url; $url = $GLOBALS['egw_info']['server']['webserver_url'] .'/'. $url;
} }
@ -1140,23 +1136,31 @@
$url = str_replace ( 'http:', 'https:', $url); $url = str_replace ( 'http:', 'https:', $url);
} }
} }
/* Now we process the extravars into a proper url format */ // check if the url already contains a query and ensure that vars is an array and all strings are in extravars
/* if its not an array, then we turn it into one */ list($url,$othervars) = explode('?',$url);
/* We do this to help prevent any duplicates from being sent. */ if ($extravars && is_array($extravars))
if (!is_array($extravars) && $extravars != '') {
$vars = $extravars;
$extravars = $othervars;
}
else
{
$vars = array();
if ($othervars) $extravars .= '&'.$othervars;
}
// parse extravars string into the vars array
if ($extravars)
{ {
$new_extravars = Array();
foreach(explode('&',$extravars) as $expr) foreach(explode('&',$extravars) as $expr)
{ {
list($var,$val) = explode('=', $expr,2); list($var,$val) = explode('=', $expr,2);
$new_extravars[$var] = $val; $vars[$var] = $val;
} }
$extravars =& $new_extravars;
unset($new_extravars);
} }
/* add session params if not using cookies */ // add session params if not using cookies
if (!$GLOBALS['egw_info']['server']['usecookies']) if (!$GLOBALS['egw_info']['server']['usecookies'])
{ {
$extravars['sessionid'] = $this->sessionid; $extravars['sessionid'] = $this->sessionid;
@ -1164,11 +1168,11 @@
$extravars['domain'] = $this->account_domain; $extravars['domain'] = $this->account_domain;
} }
/* if we end up with any extravars then we generate the url friendly string */ // if there are vars, we add them urlencoded to the url
if (is_array($extravars) && count($extravars)) if (count($vars))
{ {
$query = array(); $query = array();
foreach($extravars as $key => $value) foreach($vars as $key => $value)
{ {
$query[] = $key.'='.urlencode($value); $query[] = $key.'='.urlencode($value);
} }