WP_Http_Cookie::__construct()publicWP 2.8.0

Sets up this cookie object.

The parameter $data should be either an associative array containing the indices names below or a header string detailing it.

Method of the class: WP_Http_Cookie{}

No Hooks.

Return

null. Nothing (null).

Usage

$WP_Http_Cookie = new WP_Http_Cookie();
$WP_Http_Cookie->__construct( $data, $requested_url );
$data(string|array) (required)

Raw cookie data as header string or data array.

  • name(string)
    Cookie name.

  • value(mixed)
    Value. Should NOT already be urlencoded.

  • expires(string|int|null)
    Optional. Unix timestamp or formatted date.
    Default: null

  • path(string)
    Optional. Path.
    Default: '/'

  • domain(string)
    Optional. Domain.
    Default: host of parsed $requested_url

  • port(int|string)
    Optional. Port or comma-separated list of ports.
    Default: null

  • host_only(true|false)
    Optional. host-only storage flag.
    Default: true
$requested_url(string)
The URL which the cookie was set on, used for default $domain and $port values.
Default: ''

Changelog

Since 2.8.0 Introduced.
Since 5.2.0 Added host_only to the $data parameter.

WP_Http_Cookie::__construct() code WP 6.5.2

public function __construct( $data, $requested_url = '' ) {
	if ( $requested_url ) {
		$parsed_url = parse_url( $requested_url );
	}
	if ( isset( $parsed_url['host'] ) ) {
		$this->domain = $parsed_url['host'];
	}
	$this->path = isset( $parsed_url['path'] ) ? $parsed_url['path'] : '/';
	if ( ! str_ends_with( $this->path, '/' ) ) {
		$this->path = dirname( $this->path ) . '/';
	}

	if ( is_string( $data ) ) {
		// Assume it's a header string direct from a previous request.
		$pairs = explode( ';', $data );

		// Special handling for first pair; name=value. Also be careful of "=" in value.
		$name        = trim( substr( $pairs[0], 0, strpos( $pairs[0], '=' ) ) );
		$value       = substr( $pairs[0], strpos( $pairs[0], '=' ) + 1 );
		$this->name  = $name;
		$this->value = urldecode( $value );

		// Removes name=value from items.
		array_shift( $pairs );

		// Set everything else as a property.
		foreach ( $pairs as $pair ) {
			$pair = rtrim( $pair );

			// Handle the cookie ending in ; which results in an empty final pair.
			if ( empty( $pair ) ) {
				continue;
			}

			list( $key, $val ) = strpos( $pair, '=' ) ? explode( '=', $pair ) : array( $pair, '' );
			$key               = strtolower( trim( $key ) );
			if ( 'expires' === $key ) {
				$val = strtotime( $val );
			}
			$this->$key = $val;
		}
	} else {
		if ( ! isset( $data['name'] ) ) {
			return;
		}

		// Set properties based directly on parameters.
		foreach ( array( 'name', 'value', 'path', 'domain', 'port', 'host_only' ) as $field ) {
			if ( isset( $data[ $field ] ) ) {
				$this->$field = $data[ $field ];
			}
		}

		if ( isset( $data['expires'] ) ) {
			$this->expires = is_int( $data['expires'] ) ? $data['expires'] : strtotime( $data['expires'] );
		} else {
			$this->expires = null;
		}
	}
}