* * and Joseph Engo * * This is the central class for the phpGroupWare API * * Copyright (C) 2000, 2001 Dan Kuykendall * * -------------------------------------------------------------------------* * This library is part of the phpGroupWare API * * http://www.phpgroupware.org/api * * ------------------------------------------------------------------------ * * This library is free software; you can redistribute it and/or modify it * * under the terms of the GNU Lesser General Public License as published by * * the Free Software Foundation; either version 2.1 of the License, * * or any later version. * * This library is distributed in the hope that it will be useful, but * * WITHOUT ANY WARRANTY; without even the implied warranty of * * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * See the GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * * along with this library; if not, write to the Free Software Foundation, * * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * \**************************************************************************/ /* $Id$ */ /** * Parent class for the phpgwAPI * Parent class. Has a few functions but is more importantly used as a parent class for everything else. * @author Dan Kuykendall * @copyright LGPL * @package phpgwapi * @access public */ class phpgw { var $accounts; var $applications; var $acl; var $auth; var $db; /** * Turn on debug mode. Will output additional data for debugging purposes. * @var string $debug * @access public */ var $debug = 0; // This will turn on debugging information. var $crypto; var $categories; var $common; var $datetime; var $hooks; var $network; var $nextmatchs; var $preferences; var $session; var $send; var $template; var $translation; var $utilities; var $vfs; var $calendar; var $msg; var $addressbook; var $todo; /**************************************************************************\ * Core functions * \**************************************************************************/ /** * Strips out html chars * * Used as a shortcut for stripping out html special chars. * * @access public * @param $s string The string to have its html special chars stripped out. * @return string The string with html special characters removed * @syntax strip_html($string) * @example $reg_string = strip_html($urlencode_string); */ function strip_html($s) { return htmlspecialchars(stripslashes($s)); } /** * Link url generator * * Used for backwards compatibility and as a shortcut. If no url is passed, it will use PHP_SELF. Wrapper to session->link() * * @access public * @param string $string The url the link is for * @param string $extravars Extra params to be passed to the url * @return string The full url after processing * @see session->link() * @syntax link($string, $extravars) * @example None yet */ function link($url = '', $extravars = '') { return $this->session->link($url, $extravars); } /** * Handles redirects under iis and apache * * This function handles redirects under iis and apache it assumes that $phpgw->link() has already been called * * @access public * @param string The url ro redirect to * @syntax redirect(key as string) * @example None yet */ function redirect($url = '') { $iis = @strpos($GLOBALS['HTTP_ENV_VARS']['SERVER_SOFTWARE'], 'IIS', 0); if (!$url) { $url = $GLOBALS['PHP_SELF']; } if(@isset($GLOBALS['phpgw_info']['server']['enforce_ssl']) && $GLOBALS['phpgw_info']['server']['enforce_ssl'] && !$GLOBALS['HTTP_SERVER_VARS']['HTTPS']) { if(substr($url ,0,4) != 'http') { $url = 'https://'.$GLOBALS['phpgw_info']['server']['hostname'].$url; } else { $url = str_replace ( 'http:', 'https:', $url); } } // if(@isset($GLOBALS['HTTP_GET_VARS']['framepart'])) // { // $url .= '" target="_parent"'; // } if ($iis) { echo "\n\n\nRedirecting to $url"; echo "\n"; echo "\n"; echo "

Please continue to this page

"; echo "\n"; exit; } else { Header("Location: $url"); print("\n\n"); exit; } } /** * Shortcut to translation class * * This function is a basic wrapper to translation->translate() * * @access public * @param string The key for the phrase * @param string the first additional param * @param string the second additional param * @param string the thrid additional param * @param string the fourth additional param * @see translation->translate() */ function lang($key, $m1 = '', $m2 = '', $m3 = '', $m4 = '') { return $this->translation->translate($key); } } /* end of class */ ?>