42function getURLContent($url, $postorget =
'GET', $param =
'', $followlocation = 1, $addheaders = array(), $allowedschemes = array(
'http',
'https'), $localurl = 0, $ssl_verifypeer = -1)
52 dol_syslog(
"getURLContent postorget=".$postorget.
" URL=".$url.
" param=".$param);
61 curl_setopt($ch, CURLOPT_VERBOSE, 1);
62 curl_setopt($ch, CURLOPT_USERAGENT,
'Dolibarr geturl function');
66 @curl_setopt($ch, CURLOPT_FOLLOWLOCATION,
false);
68 if (is_array($addheaders) && count($addheaders)) {
69 curl_setopt($ch, CURLOPT_HTTPHEADER, $addheaders);
71 curl_setopt($ch, CURLINFO_HEADER_OUT,
true);
76 curl_setopt($ch, CURLOPT_SSLVERSION,
$conf->global->MAIN_CURL_SSLVERSION);
81 if ($ssl_verifypeer < 0) {
82 global $dolibarr_main_prod;
83 $ssl_verifypeer = ($dolibarr_main_prod ? true :
false);
90 curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, ($ssl_verifypeer ?
true :
false));
91 curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, ($ssl_verifypeer ?
true :
false));
95 $redir_list = array();
96 if (is_array($allowedschemes)) {
97 foreach ($allowedschemes as $allowedscheme) {
98 if ($allowedscheme ==
'http') {
99 $protocols |= CURLPROTO_HTTP;
100 $redir_list[
"HTTP"] = 1;
101 } elseif ($allowedscheme ==
'https') {
102 $protocols |= CURLPROTO_HTTPS;
103 $redir_list[
"HTTPS"] = 1;
104 } elseif ($allowedscheme ==
'ftp') {
105 $protocols |= CURLPROTO_FTP;
106 $redir_list[
"FTP"] = 1;
107 } elseif ($allowedscheme ==
'ftps') {
108 $protocols |= CURLPROTO_FTPS;
109 $redir_list[
"FTPS"] = 1;
114 curl_setopt($ch, CURLOPT_CONNECTTIMEOUT,
getDolGlobalInt(
'MAIN_USE_CONNECT_TIMEOUT', 5));
115 curl_setopt($ch, CURLOPT_TIMEOUT,
getDolGlobalInt(
'MAIN_USE_RESPONSE_TIMEOUT', 30));
119 if ($maxsize && defined(
'CURLOPT_MAXFILESIZE_LARGE')) {
120 curl_setopt($ch, CURLOPT_MAXFILESIZE_LARGE, $maxsize);
122 if ($maxsize && defined(
'CURLOPT_MAXFILESIZE')) {
123 curl_setopt($ch, CURLOPT_MAXFILESIZE, $maxsize);
127 curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
128 if ($postorget ==
'POST') {
129 curl_setopt($ch, CURLOPT_POST, 1);
130 curl_setopt($ch, CURLOPT_POSTFIELDS, $param);
131 } elseif ($postorget ==
'POSTALREADYFORMATED') {
132 curl_setopt($ch, CURLOPT_CUSTOMREQUEST,
'POST');
133 curl_setopt($ch, CURLOPT_POSTFIELDS, $param);
134 } elseif ($postorget ==
'PUT') {
136 curl_setopt($ch, CURLOPT_CUSTOMREQUEST,
'PUT');
137 if (!is_array($param)) {
138 parse_str($param, $array_param);
140 dol_syslog(
"parameter param must be a string", LOG_WARNING);
141 $array_param = $param;
143 curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($array_param));
144 } elseif ($postorget ==
'PUTALREADYFORMATED') {
145 curl_setopt($ch, CURLOPT_CUSTOMREQUEST,
'PUT');
146 curl_setopt($ch, CURLOPT_POSTFIELDS, $param);
147 } elseif ($postorget ==
'HEAD') {
148 curl_setopt($ch, CURLOPT_CUSTOMREQUEST,
'HEAD');
149 curl_setopt($ch, CURLOPT_NOBODY,
true);
150 } elseif ($postorget ==
'DELETE') {
151 curl_setopt($ch, CURLOPT_CUSTOMREQUEST,
'DELETE');
153 curl_setopt($ch, CURLOPT_POST, 0);
158 dol_syslog(
"getURLContent set proxy to ".$PROXY_HOST.
":".$PROXY_PORT.
" - ".$PROXY_USER.
":".$PROXY_PASS);
160 curl_setopt($ch, CURLOPT_PROXY, $PROXY_HOST.
":".$PROXY_PORT);
162 curl_setopt($ch, CURLOPT_PROXYUSERPWD, $PROXY_USER.
":".$PROXY_PASS);
172 if ($maxRedirection < 1) {
176 curl_setopt($ch, CURLOPT_URL, $newUrl);
179 $newUrlArray = parse_url($newUrl);
180 $hosttocheck = $newUrlArray[
'host'];
181 $hosttocheck = str_replace(array(
'[',
']'),
'', $hosttocheck);
184 if (in_array($hosttocheck, array(
'metadata.google.internal'))) {
185 $info[
'http_code'] = 400;
186 $info[
'content'] =
'Error bad hostname '.$hosttocheck.
' (Used by Google metadata). This value for hostname is not allowed.';
191 if (in_array($hosttocheck, array(
'localhost',
'localhost.domain'))) {
192 $iptocheck =
'127.0.0.1';
193 } elseif (in_array($hosttocheck, array(
'ip6-localhost',
'ip6-loopback'))) {
197 if (function_exists(
'gethostbyname')) {
198 $iptocheck = gethostbyname($hosttocheck);
200 $iptocheck = $hosttocheck;
206 if (!filter_var($iptocheck, FILTER_VALIDATE_IP, FILTER_FLAG_IPV4 | FILTER_FLAG_IPV6)) {
213 $info[
'http_code'] = 400;
214 $info[
'content'] = $tmpresult;
221 if (defined(
'CURLOPT_CONNECT_TO')) {
222 $connect_to = array(sprintf(
"%s:%d:%s:%d", $newUrlArray[
'host'], empty($newUrlArray[
'port']) ?
'' : $newUrlArray[
'port'], $iptocheck, empty($newUrlArray[
'port']) ?
'' : $newUrlArray[
'port']));
225 curl_setopt($ch, CURLOPT_CONNECT_TO, $connect_to);
231 curl_setopt($ch, CURLOPT_PROTOCOLS, $protocols);
232 curl_setopt($ch, CURLOPT_REDIR_PROTOCOLS, $protocols);
240 $response = curl_exec($ch);
242 $info = curl_getinfo($ch);
243 $http_code = $info[
'http_code'];
245 if ($followlocation && ($http_code == 301 || $http_code == 302 || $http_code == 303 || $http_code == 307)) {
246 $newUrl = $info[
'redirect_url'];
253 }
while ($http_code);
255 $request = curl_getinfo($ch, CURLINFO_HEADER_OUT);
257 dol_syslog(
"getURLContent request=".$request);
260 dol_syslog(
"getURLContent request=".$request, LOG_DEBUG, 0,
'_curl');
261 dol_syslog(
"getURLContent response =".$response, LOG_DEBUG, 0,
'_curl');
263 dol_syslog(
"getURLContent response size=".strlen($response));
266 if (curl_errno($ch)) {
268 $rep[
'content'] = $response;
271 $rep[
'curl_error_no'] = curl_errno($ch);
272 $rep[
'curl_error_msg'] = curl_error($ch);
274 dol_syslog(
"getURLContent response array is ".implode(
',', $rep));
282 dol_syslog(
"getURLContent http_code=".$rep[
'http_code']);
286 $rep[
'content'] = $response;
288 $rep[
'curl_error_no'] =
'';
289 $rep[
'curl_error_msg'] =
'';