0);
}
/**
* Get the real user name for an account name
* @param $strAct (string) Account name of the user to look up
* @return (string) The real name of the user. If the function fails, it returns null.
* Call getLastError() to get more information about the error.
*/
function getRealUserName($strAct) {
$hQuery = db_query("SELECT firstname, lastname FROM users WHERE act = $1;", $strAct);
if(!is_resource($hQuery)) {
// TODO throw exception
setLastError(RS_ERROR_SQL);
return null;
}
if(pg_num_rows($hQuery) == 0) {
return $strAct; // User not found in database, return account name
}
$arResult = pg_fetch_array($hQuery);
return user_join_name($arResult);
}
/**
* Determine if a specified group exists
* @param $strAct (string) Account name of the group
* @return (bool / null) If the function fails, it returns null. Call getLastError() to
* get more information about the error.
*/
function isGroup($strAct) {
$hQuery = db_query("SELECT * FROM groups WHERE act = $1;", $strAct);
if(!is_resource($hQuery)) {
// TODO throw exception
setLastError(RS_ERROR_SQL);
return null;
}
return (pg_num_rows($hQuery) > 0);
}
/**
* Look up the name of a group
* @param $strAct (string) Account name of the group
* @return (string) The name of the group. If the function fails, it returns null.
* Call getLastError() to get more information about the error.
*/
function getGroupName($strAct) {
$hQuery = db_query("SELECT * FROM groups WHERE act = $1;", $strAct);
if(!is_resource($hQuery)) {
// TODO throw exception
setLastError(RS_ERROR_SQL);
return null;
}
if(pg_num_rows($hQuery) == 0) {
return $strAct; // Group not found in database, return account name
}
$arResult = pg_fetch_array($hQuery);
return $arResult["name"];
}
/**
* Create a link to write a mail to the specified account name.
* This function returns a link if the specified account exists, otherwise it returns the
* account name.
* @param $strAct (string) Account name
* @param $strColor (string) Background color for icon()
* @param $strParams (string) additional URL parameters
* @return string
*/
function mailToUserLink($strAct, $strColor = "bl", $strParams = "") {
if(!isAct($strAct)) {
return $strAct;
}
return popup(relroot("msg/write/?to=".user_mail_addr($strAct).$strParams),
600, 400, nobr(icon("mail-reply-usr", array("size" => 16, "bg" =>
$strColor)) . getRealUserName($strAct)));
}
/**
* Determine if a specified string is a valid mail address
* @param $strAddr string
* @return string
*/
function isMailAddress($strAddr) {
return ((preg_match("/([a-zA-Z0-9_\-\.]*(@[a-zA-Z0-9\-\.]*)?(\s*,\s*)?)+/", $strAddr) > 0)
and (preg_match("/(\s*,\s*)$/", $strAddr) == 0));
}
/**
* Module-specific logging function.
* Prefixes the log message with a module-specific string and writes it to the logs.
* @param $strLog (string) Log message
* @return void
*/
function rrInsertLog($strLog) {
log_insert("Raumbelegungsplan: " . $strLog);
}
/**
* Get the SQL day number from a given timestamp.
* @param $ts (timestamp)
* @return (int) 0-6 for Sunday to Monday
*/
function rrDateToSQLDayNumber($ts) {
$aDays = array("Sun" => 0, "Mon" => 1, "Tue" => 2,
"Wed" => 3, "Thu" => 4, "Fri" => 5, "Sat" => 6);
return $aDays[date("D", $ts)];
}
/**
* Convert a UNIX timestamp to an SQL date string
* @param $ts (timestamp)
* @return string
*/
function dateToSql($ts) { return date("Y\-m\-d", intval($ts)); }
/**
* Calculate the timestamp of the monday in the current week
* @param $ts (timestamp) Calculate the value relative to this date
* @return timestamp
*/
function rrGetMonday($ts = null) {
if($ts === null) {
$ts = time();
}
if(date("D", $ts) == "Mon") {
// Today is monday
return strtotime("00:00", $ts);
} else {
return strtotime("last monday", $ts);
}
}
/** (array of strings) Additional CSS rules */
$rsLocalCss = array();
/**
* Add CSS rules to the page
* @param $s (string)
* @return void
*/
function rrAddCss($s) {
rrDebug("rsAddCss: add \"$s\"");
$GLOBALS["rsLocalCss"][] = $s;
}
/**
* Get CSS rules that have been added with rmAddCss()
* @return string
*/
function rrGetCSS() {
rrDebug("rsGetCss: Local CSS is ".var_export($GLOBALS["rsLocalCss"], true));
return implode("\n", $GLOBALS["rsLocalCss"]);
}
function rrDebug($s, $bReturn = false) {
if(isset($_GET["debug"])) {
if(!$bReturn) {
echo "\n";
} else {
return $s;
}
}
}
/**
* sprintf with support for ordinal numbers.
* This version of sprintf replaces all substrings of the type /\\d+#/
* (i.e. a decimal number with a hash sign appended) in the input string with
* the corresponding english ordinal number prefices (st, nd, rd, th).
* @param $str (string) Input string
* @param $args (mixed) Additional parameters to be passed to sprintf()
* @return (string)
*/
function _sprintf_ord($str, $args /*leave this parameters for doxygen*/) {
$args = func_get_args();
if(preg_match_all("/%[bcdufosxX]/", $args[0], $temp) != func_num_args()-1) {
trigger_error("Too few arguments", E_USER_ERROR);
return false;
}
$str = call_user_func_array("sprintf", $args);
while(preg_match("/(.*)(\d+)#(.*)/", $str, $m))
$str = $m[1]._(append_ord_suffix($m[2])).$m[3];
return $str;
}
?>