HTTP_Request2
[ class tree: HTTP_Request2 ] [ index: HTTP_Request2 ] [ all elements ]

Class: HTTP_Request2

Source Location: /HTTP_Request2-0.1.0/Request2.php

Class Overview


Class representing a HTTP request


Author(s):

Version:

  • Release: 0.1.0

Variables

Methods


Inherited Variables

Inherited Methods


Class Details

[line 63]
Class representing a HTTP request


[ Top ]


Class Variables

$adapter =

[line 178]

Adapter used to perform actual HTTP request
  • Access: protected



[ Top ]

$auth =

[line 119]

Authentication data

Type:   array


[ Top ]

$body =  ''

[line 160]

Request body

Type:   string|resource


[ Top ]

$config = array(
        'adapter'           => 'HTTP_Request2_Adapter_Socket',
        'connect_timeout'   => 10,
        'use_brackets'      => true,
        'protocol_version'  => '1.1',
        'buffer_size'       => 16384,
        'proxy_host'        => '',
        'proxy_port'        => '',
        'proxy_user'        => '',
        'proxy_password'    => '',
        'proxy_auth_scheme' => self::AUTH_BASIC
    )

[line 132]

Configuration parameters

Type:   array


[ Top ]

$headers = array()

[line 125]

Request headers
  • Access: protected

Type:   array


[ Top ]

$lastEvent = array(
        'name' => 'start',
        'data' => null
    )

[line 150]

Last event in request / response handling, intended for observers

Type:   array


[ Top ]

$method =  self::METHOD_GET

[line 112]

Request method
  • Access: protected

Type:   string


[ Top ]

$observers = array()

[line 100]

Observers attached to the request (instances of SplObserver)
  • Access: protected

Type:   array


[ Top ]

$postParams = array()

[line 166]

Array of POST parameters
  • Access: protected

Type:   array


[ Top ]

$uploads = array()

[line 172]

Array of file uploads (for multipart/form-data POST requests)
  • Access: protected

Type:   array


[ Top ]

$url =

[line 106]

Request URL
  • Access: protected

Type:   Net_URL2


[ Top ]



Method Detail

__construct (Constructor)   [line 190]

HTTP_Request2 __construct( [string|Net_Url2 $url = null], [string $method = self::METHOD_GET], [array $config = array()])

Constructor. Can set request URL, method and configuration array.

Also sets a default value for User-Agent header.

  • Access: public

Parameters:

string|Net_Url2   $url   —  Request URL
string   $method   —  Request method
array   $config   —  Configuration for this Request instance

[ Top ]

addCookie   [line 434]

HTTP_Request2 addCookie( string $name, string $value)

Appends a cookie to "Cookie:" header
  • Throws: HTTP_Request2_Exception
  • Access: public

Parameters:

string   $name   —  cookie name
string   $value   —  cookie value

[ Top ]

addPostParameter   [line 562]

HTTP_Request2 addPostParameter( string|array $name, [mixed $value = null])

Adds POST parameter(s) to the request.
  • Access: public

Parameters:

string|array   $name   —  parameter name or array ('name' => 'value')
mixed   $value   —  parameter value (can be an array)

[ Top ]

addUpload   [line 515]

HTTP_Request2 addUpload( string $fieldName, mixed $filename, [string $sendFilename = null], [string $contentType = null])

Adds a file to form-based file upload

Used to emulate file upload via a HTML form. The method also sets Content-Type of HTTP request to 'multipart/form-data'.

If you just want to send the contents of a file as the body of HTTP request you should use setBody() method.

  • Throws: HTTP_Request2_Exception
  • Access: public

Parameters:

string   $fieldName   —  name of file-upload field
mixed   $filename   —  full name of local file
string   $sendFilename   —  filename to send in the request
string   $contentType   —  content-type of file being uploaded

[ Top ]

attach   [line 583]

void attach( SplObserver $observer)

Attaches a new observer
  • Access: public

Parameters:

SplObserver   $observer   — 

[ Top ]

detach   [line 598]

void detach( SplObserver $observer)

Detaches an existing observer
  • Access: public

Parameters:

SplObserver   $observer   — 

[ Top ]

detectMimeType   [line 767]

string detectMimeType( string $filename)

Tries to detect MIME type of a file

The method will try to use fileinfo extension if it is available, deprecated mime_content_type() function in the other case. If neither works, default 'application/octet-stream' MIME type is returned

  • Return: file MIME type
  • Access: protected

Parameters:

string   $filename   —  filename

[ Top ]

getAuth   [line 354]

array getAuth( )

Returns the authentication data

The array has the keys 'user', 'password' and 'scheme', where 'scheme' is one of the HTTP_Request2::AUTH_* constants.

  • Access: public

[ Top ]

getBody   [line 477]

string|resource|HTTP_Request2_MultipartBody getBody( )

Returns the request body
  • Access: public

[ Top ]

getConfigValue   [line 315]

mixed getConfigValue( $name)

Returns the value of the configuration parameter
  • Throws: HTTP_Request2_Exception If the parameter is unknown
  • Access: public

Parameters:

   $name   — 

[ Top ]

getHeaders   [line 421]

array getHeaders( )

Returns the request headers

The array is of the form ('header name' => 'header value'), header names are lowercased

  • Access: public

[ Top ]

getLastEvent   [line 663]

array getLastEvent( )

Returns the last event

Observers should use this method to access the last change in request. The following event names are possible:

  • 'connect' - after connection to remote server, data is the destination (string)
  • 'disconnect' - after disconnection from server
  • 'sentHeaders' - after sending the request headers, data is the headers sent (string)
  • 'sentBodyPart' - after sending a part of the request body, data is the length of that part (int)
  • 'receivedHeaders' - after receiving the response headers, data is HTTP_Request2_Response object
  • 'receivedBodyPart' - after receiving a part of the response body, data is that part (string)
  • 'receivedEncodedBodyPart' - as 'receivedBodyPart', but data is still encoded by Content-Encoding
  • 'receivedBody' - after receiving the complete response body, data is HTTP_Request2_Response object
Different adapters may not send all the event types. Mock adapter does not send any events to the observers.

  • Return: The array has two keys: 'name' and 'data'
  • Access: public

[ Top ]

getMethod   [line 271]

string getMethod( )

Returns the request method
  • Access: public

[ Top ]

getUrl   [line 243]

Net_URL2 getUrl( )

Returns the request URL
  • Access: public

[ Top ]

notify   [line 611]

void notify( )

Notifies all observers
  • Access: public

[ Top ]

send   [line 714]

HTTP_Request2_Response send( )

Sends the request and returns the response
  • Throws: HTTP_Request2_Exception
  • Access: public

[ Top ]

setAdapter   [line 684]

HTTP_Request2 setAdapter( string|HTTP_Request2_Adapter $adapter)

Sets the adapter used to actually perform the request

You can pass either an instance of a class implementing HTTP_Request2_Adapter or a class name. The method will only try to include a file if the class name starts with HTTP_Request2_Adapter_, it will also try to prepend this prefix to the class name if it doesn't contain any underscores, so that

  1.  $request->setAdapter('curl');
will work.

  • Throws: HTTP_Request2_Exception
  • Access: public

Parameters:

string|HTTP_Request2_Adapter   $adapter   — 

[ Top ]

setAuth   [line 331]

HTTP_Request2 setAuth( string $user, [string $password = ''], [string $scheme = self::AUTH_BASIC])

Sets the autentification data
  • Access: public

Parameters:

string   $user   —  user name
string   $password   —  password
string   $scheme   —  authentication scheme

[ Top ]

setBody   [line 455]

HTTP_Request2 setBody( string $body, [bool $isFilename = false])

Sets the request body
  • Throws: HTTP_Request2_Exception
  • Access: public

Parameters:

string   $body   —  Either a string with the body or filename containing body
bool   $isFilename   —  Whether first parameter is a filename

[ Top ]

setConfig   [line 297]

HTTP_Request2 setConfig( [array $config = array()])

Sets the configuration parameters

$config array can have the following keys:

  • 'adapter' - adapter to use (string)
  • 'connect_timeout' - Connection timeout in seconds (float)
  • 'use_brackets' - Whether to append [] to array variable names (bool)
  • 'protocol_version' - HTTP Version to use, '1.0' or '1.1' (string)
  • 'buffer_size' - Buffer size to use for reading and writing (int)
  • 'proxy_host' - Proxy server host (string)
  • 'proxy_port' - Proxy server port (integer)
  • 'proxy_user' - Proxy auth username (string)
  • 'proxy_password' - Proxy auth password (string)
  • 'proxy_auth_scheme' - Proxy auth scheme, one of HTTP_Request2::AUTH_* constants (string)

  • Throws: HTTP_Request2_Exception If the parameter is unknown
  • Access: public

Parameters:

array   $config   —  array of the form ('param name' => 'param value')

[ Top ]

setHeader   [line 383]

HTTP_Request2 setHeader( string|array $name, [string|null $value = null])

Sets request header(s)

The first parameter may be either a full header string 'header: value' or header name. In the former case $value parameter is ignored, in the latter the header's value will either be set to $value or the header will be removed if $value is null. The first parameter can also be an array of headers, in that case method will be called recursively.

Note that headers are treated case insensitively as per RFC 2616.

  1.  $req->setHeader('Foo: Bar')// sets the value of 'Foo' header to 'Bar'
  2.  $req->setHeader('FoO''Baz')// sets the value of 'Foo' header to 'Baz'
  3.  $req->setHeader(array('foo' => 'Quux'))// sets the value of 'Foo' header to 'Quux'
  4.  $req->setHeader('FOO')// removes 'Foo' header from request

  • Throws: HTTP_Request2_Exception
  • Access: public

Parameters:

string|array   $name   —  header name, header string ('Header: value') or an array of headers
string|null   $value   —  header value, header will be removed if null

[ Top ]

setLastEvent   [line 627]

void setLastEvent( string $name, [mixed $data = null])

Sets the last event

Adapters should use this method to set the current state of the request and notify the observers.

  • Access: public

Parameters:

string   $name   —  event name
mixed   $data   —  event data

[ Top ]

setMethod   [line 255]

HTTP_Request2 setMethod( string $method)

Sets the request method
  • Throws: HTTP_Request2_Exception if the method name is invalid
  • Access: public

Parameters:

string   $method   — 

[ Top ]

setUrl   [line 215]

HTTP_Request2 setUrl( string|Net_URL2 $url)

Sets the URL for this request

If the URL has userinfo part (username & password) these will be removed and converted to auth data. If the URL does not have a path component, that will be set to '/'.

  • Throws: HTTP_Request2_Exception
  • Access: public

Parameters:

string|Net_URL2   $url   —  Request URL

[ Top ]


Documentation generated on Mon, 11 Mar 2019 15:26:15 -0400 by phpDocumentor 1.4.4. PEAR Logo Copyright © PHP Group 2004.