1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
|
<?php
/**
* Copyright (c) Xerox Corporation, Codendi Team, 2001-2009. All rights reserved
*
* This file is a part of Fusionforge.
*
* Fusionforge is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* Fusionforge 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Codendi. If not, see <http://www.gnu.org/licenses/>.
*/
require_once 'common/include/Codendi_Request.class.php';
/**
* @package Codendi
*/
class HTTPRequest extends Codendi_Request {
/**
* Constructor
*/
function HTTPRequest() {
parent::Codendi_Request($_REQUEST);
}
/**
* Get the value of $variable in $this->params (server side values).
*
* @param string $variable Name of the parameter to get.
* @return mixed If the variable exist, the value is returned (string)
* otherwise return false;
*/
function getFromServer($variable) {
return $this->_get($variable, $_SERVER);
}
/**
* Check if current request is send via 'post' method.
*
* This method is useful to test if the current request comes from a form.
*
* @return boolean
*/
function isPost() {
if($_SERVER['REQUEST_METHOD'] == 'POST') {
return true;
} else {
return false;
}
}
/**
* Return true if browser used to submit the request is netscape 4.
*
* @return boolean
*/
function browserIsNetscape4() {
return browser_is_netscape4();
}
/**
* Singleton method for the class.
*
* @return mixed HTTPRequest Object.
*/
static function &instance() {
static $_httprequest_instance;
if (!$_httprequest_instance) {
$_httprequest_instance = new HTTPRequest();
}
return $_httprequest_instance;
}
/**
* Validate file upload.
*
* @param Valid_File Validator for files.
* @return Boolean
*/
function validFile(&$validator) {
if(is_a($validator, 'Valid_File')) {
$this->_validated_input[$validator->getKey()] = true;
return $validator->validate($_FILES, $validator->getKey());
} else {
return false;
}
}
/**
* Remove slashes in $value. If $value is an array, remove slashes for each
* element.
*
* @access private
* @param mixed $value
* @return mixed
*/
function _stripslashes($value) {
if (is_string($value)) {
$value = stripslashes($value);
} elseif (is_array($value)) {
foreach($value as $key => $val) {
$value[$key] = $this->_stripslashes($val);
}
}
return $value;
}
/**
* Get the value of $variable in $array. If magic_quotes are enabled, the
* value is escaped.
*
* @access private
* @param string $variable Name of the parameter to get.
* @param array $array Name of the parameter to get.
* @return bool|mixed
*/
function _get($variable, $array) {
if ($this->_exist($variable, $array)) {
return (get_magic_quotes_gpc()?$this->_stripslashes($array[$variable]):$array[$variable]);
} else {
return false;
}
}
}
|