WP_SimplePie_File::__construct( string $url, int $timeout = 10, int $redirects = 5, string|array $headers = null, string $useragent = null, bool $force_fsockopen = false )
Constructor.
Parameters
- $url
-
(Required) Remote file URL.
- $timeout
-
(Optional) How long the connection should stay open in seconds.<br>
Default value: 10
- $redirects
-
(Optional) The number of allowed redirects.
Default value: 5
- $headers
-
(Optional) Array or string of headers to send with the request.<br>
Default value: null
- $useragent
-
(Optional) User-agent value sent.
Default value: null
- $force_fsockopen
-
(Optional) Whether to force opening internet or unix domain socket connection or not.
Default value: false
Source
File: wp-includes/class-wp-simplepie-file.php
public function __construct($url, $timeout = 10, $redirects = 5, $headers = null, $useragent = null, $force_fsockopen = false) {
$this->url = $url;
$this->timeout = $timeout;
$this->redirects = $redirects;
$this->headers = $headers;
$this->useragent = $useragent;
$this->method = SIMPLEPIE_FILE_SOURCE_REMOTE;
if ( preg_match('/^http(s)?:\/\//i', $url) ) {
$args = array(
'timeout' => $this->timeout,
'redirection' => $this->redirects,
);
if ( !empty($this->headers) )
$args['headers'] = $this->headers;
if ( SIMPLEPIE_USERAGENT != $this->useragent ) //Use default WP user agent unless custom has been specified
$args['user-agent'] = $this->useragent;
$res = wp_safe_remote_request($url, $args);
if ( is_wp_error($res) ) {
$this->error = 'WP HTTP Error: ' . $res->get_error_message();
$this->success = false;
} else {
$this->headers = wp_remote_retrieve_headers( $res );
$this->body = wp_remote_retrieve_body( $res );
$this->status_code = wp_remote_retrieve_response_code( $res );
}
} else {
$this->error = '';
$this->success = false;
}
}
Changelog
Version | Description |
---|---|
5.6.1 | Multiple headers are concatenated into a comma-separated string, rather than remaining an array. |
3.2.0 | Updated to use a PHP5 constructor. |
2.8.0 | Introduced. |