ILIAS  release_5-2 Revision v5.2.25-18-g3f80b828510
CAS_CookieJar Class Reference

This class provides access to service cookies and handles parsing of response headers to pull out cookie values. More...

+ Collaboration diagram for CAS_CookieJar:

Public Member Functions

 __construct (array &$storageArray)
 Create a new cookie jar by passing it a reference to an array in which it should store cookies. More...
 
 storeCookies ($request_url, $response_headers)
 Store cookies for a web service request. More...
 
 getCookies ($request_url)
 Retrieve cookies applicable for a web service request. More...
 

Protected Member Functions

 parseCookieHeaders ( $header, $defaultDomain)
 Parse Cookies without PECL From the comments in http://php.net/manual/en/function.http-parse-cookie.php. More...
 
 parseCookieHeader ($line, $defaultDomain)
 Parse a single cookie header line. More...
 
 storeCookie ($cookie)
 Add, update, or remove a cookie. More...
 
 discardCookie ($cookie)
 Discard an existing cookie. More...
 
 expireCookies ()
 Go through our stored cookies and remove any that are expired. More...
 
 cookieMatchesTarget ($cookie, $target)
 Answer true if cookie is applicable to a target. More...
 

Private Attributes

 $_cookies
 

Detailed Description

This class provides access to service cookies and handles parsing of response headers to pull out cookie values.

Definition at line 41 of file CookieJar.php.

Constructor & Destructor Documentation

◆ __construct()

CAS_CookieJar::__construct ( array $storageArray)

Create a new cookie jar by passing it a reference to an array in which it should store cookies.

Parameters
array&$storageArrayArray to store cookies
Returns
void

Definition at line 54 of file CookieJar.php.

55  {
56  $this->_cookies =& $storageArray;
57  }

Member Function Documentation

◆ cookieMatchesTarget()

CAS_CookieJar::cookieMatchesTarget (   $cookie,
  $target 
)
protected

Answer true if cookie is applicable to a target.

Parameters
array$cookieAn array of cookie attributes.
array$targetAn array of URL attributes as generated by parse_url().
Returns
bool

private

Definition at line 317 of file CookieJar.php.

References $target.

Referenced by getCookies(), and storeCookies().

318  {
319  if (!is_array($target)) {
321  '$target must be an array of URL attributes as generated by parse_url().'
322  );
323  }
324  if (!isset($target['host'])) {
326  '$target must be an array of URL attributes as generated by parse_url().'
327  );
328  }
329 
330  // Verify that the scheme matches
331  if ($cookie['secure'] && $target['scheme'] != 'https') {
332  return false;
333  }
334 
335  // Verify that the host matches
336  // Match domain and mulit-host cookies
337  if (strpos($cookie['domain'], '.') === 0) {
338  // .host.domain.edu cookies are valid for host.domain.edu
339  if (substr($cookie['domain'], 1) == $target['host']) {
340  // continue with other checks
341  } else {
342  // non-exact host-name matches.
343  // check that the target host a.b.c.edu is within .b.c.edu
344  $pos = strripos($target['host'], $cookie['domain']);
345  if (!$pos) {
346  return false;
347  }
348  // verify that the cookie domain is the last part of the host.
349  if ($pos + strlen($cookie['domain']) != strlen($target['host'])) {
350  return false;
351  }
352  // verify that the host name does not contain interior dots as per
353  // RFC 2965 section 3.3.2 Rejecting Cookies
354  // http://www.ietf.org/rfc/rfc2965.txt
355  $hostname = substr($target['host'], 0, $pos);
356  if (strpos($hostname, '.') !== false) {
357  return false;
358  }
359  }
360  } else {
361  // If the cookie host doesn't begin with '.',
362  // the host must case-insensitive match exactly
363  if (strcasecmp($target['host'], $cookie['domain']) !== 0) {
364  return false;
365  }
366  }
367 
368  // Verify that the port matches
369  if (isset($cookie['ports'])
370  && !in_array($target['port'], $cookie['ports'])
371  ) {
372  return false;
373  }
374 
375  // Verify that the path matches
376  if (strpos($target['path'], $cookie['path']) !== 0) {
377  return false;
378  }
379 
380  return true;
381  }
Exception that denotes invalid arguments were passed.
+ Here is the caller graph for this function:

◆ discardCookie()

CAS_CookieJar::discardCookie (   $cookie)
protected

Discard an existing cookie.

Parameters
array$cookieAn cookie
Returns
void

protected

Definition at line 272 of file CookieJar.php.

Referenced by storeCookie().

273  {
274  if (!isset($cookie['domain'])
275  || !isset($cookie['path'])
276  || !isset($cookie['path'])
277  ) {
278  throw new CAS_InvalidArgumentException('Invalid Cookie array passed.');
279  }
280 
281  foreach ($this->_cookies as $key => $old_cookie) {
282  if ( $cookie['domain'] == $old_cookie['domain']
283  && $cookie['path'] == $old_cookie['path']
284  && $cookie['name'] == $old_cookie['name']
285  ) {
286  unset($this->_cookies[$key]);
287  }
288  }
289  }
Exception that denotes invalid arguments were passed.
+ Here is the caller graph for this function:

◆ expireCookies()

CAS_CookieJar::expireCookies ( )
protected

Go through our stored cookies and remove any that are expired.

Returns
void

protected

Definition at line 298 of file CookieJar.php.

References time.

Referenced by getCookies().

299  {
300  foreach ($this->_cookies as $key => $cookie) {
301  if (isset($cookie['expires']) && $cookie['expires'] < time()) {
302  unset($this->_cookies[$key]);
303  }
304  }
305  }
Add data(end) time
Method that wraps PHPs time in order to allow simulations with the workflow.
+ Here is the caller graph for this function:

◆ getCookies()

CAS_CookieJar::getCookies (   $request_url)

Retrieve cookies applicable for a web service request.

Cookie applicability is based on RFC 2965: http://www.ietf.org/rfc/rfc2965.txt

Parameters
string$request_urlThe url that the cookies will be for.
Returns
array An array containing cookies. E.g. array('name' => 'val');

private

Definition at line 102 of file CookieJar.php.

References $target, array, cookieMatchesTarget(), and expireCookies().

103  {
104  if (!count($this->_cookies)) {
105  return array();
106  }
107 
108  // If our request URL can't be parsed, no cookies apply.
109  $target = parse_url($request_url);
110  if ($target === false) {
111  return array();
112  }
113 
114  $this->expireCookies();
115 
116  $matching_cookies = array();
117  foreach ($this->_cookies as $key => $cookie) {
118  if ($this->cookieMatchesTarget($cookie, $target)) {
119  $matching_cookies[$cookie['name']] = $cookie['value'];
120  }
121  }
122  return $matching_cookies;
123  }
cookieMatchesTarget($cookie, $target)
Answer true if cookie is applicable to a target.
Definition: CookieJar.php:317
expireCookies()
Go through our stored cookies and remove any that are expired.
Definition: CookieJar.php:298
Create styles array
The data for the language used.
+ Here is the call graph for this function:

◆ parseCookieHeader()

CAS_CookieJar::parseCookieHeader (   $line,
  $defaultDomain 
)
protected

Parse a single cookie header line.

Based on RFC2965 http://www.ietf.org/rfc/rfc2965.txt

Parameters
string$lineThe header line.
string$defaultDomainThe domain to use if none is specified in the cookie.
Returns
array

Definition at line 161 of file CookieJar.php.

References array, time, and phpCAS\trace().

Referenced by parseCookieHeaders().

162  {
163  if (!$defaultDomain) {
165  '$defaultDomain was not provided.'
166  );
167  }
168 
169  // Set our default values
170  $cookie = array(
171  'domain' => $defaultDomain,
172  'path' => '/',
173  'secure' => false,
174  );
175 
176  $line = preg_replace('/^Set-Cookie2?: /i', '', trim($line));
177 
178  // trim any trailing semicolons.
179  $line = trim($line, ';');
180 
181  phpCAS::trace("Cookie Line: $line");
182 
183  // This implementation makes the assumption that semicolons will not
184  // be present in quoted attribute values. While attribute values that
185  // contain semicolons are allowed by RFC2965, they are hopefully rare
186  // enough to ignore for our purposes. Most browsers make the same
187  // assumption.
188  $attributeStrings = explode(';', $line);
189 
190  foreach ( $attributeStrings as $attributeString ) {
191  // split on the first equals sign and use the rest as value
192  $attributeParts = explode('=', $attributeString, 2);
193 
194  $attributeName = trim($attributeParts[0]);
195  $attributeNameLC = strtolower($attributeName);
196 
197  if (isset($attributeParts[1])) {
198  $attributeValue = trim($attributeParts[1]);
199  // Values may be quoted strings.
200  if (strpos($attributeValue, '"') === 0) {
201  $attributeValue = trim($attributeValue, '"');
202  // unescape any escaped quotes:
203  $attributeValue = str_replace('\"', '"', $attributeValue);
204  }
205  } else {
206  $attributeValue = null;
207  }
208 
209  switch ($attributeNameLC) {
210  case 'expires':
211  $cookie['expires'] = strtotime($attributeValue);
212  break;
213  case 'max-age':
214  $cookie['max-age'] = (int)$attributeValue;
215  // Set an expiry time based on the max-age
216  if ($cookie['max-age']) {
217  $cookie['expires'] = time() + $cookie['max-age'];
218  } else {
219  // If max-age is zero, then the cookie should be removed
220  // imediately so set an expiry before now.
221  $cookie['expires'] = time() - 1;
222  }
223  break;
224  case 'secure':
225  $cookie['secure'] = true;
226  break;
227  case 'domain':
228  case 'path':
229  case 'port':
230  case 'version':
231  case 'comment':
232  case 'commenturl':
233  case 'discard':
234  case 'httponly':
235  $cookie[$attributeNameLC] = $attributeValue;
236  break;
237  default:
238  $cookie['name'] = $attributeName;
239  $cookie['value'] = $attributeValue;
240  }
241  }
242 
243  return $cookie;
244  }
static trace($str)
This method is used to log something in debug mode.
Definition: CAS.php:579
Exception that denotes invalid arguments were passed.
Create styles array
The data for the language used.
Add data(end) time
Method that wraps PHPs time in order to allow simulations with the workflow.
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ parseCookieHeaders()

CAS_CookieJar::parseCookieHeaders (   $header,
  $defaultDomain 
)
protected

Parse Cookies without PECL From the comments in http://php.net/manual/en/function.http-parse-cookie.php.

Parameters
array$headerarray of header lines.
string$defaultDomainThe domain to use if none is specified in the cookie.
Returns
array of cookies

Definition at line 136 of file CookieJar.php.

References $header, array, parseCookieHeader(), phpCAS\traceBegin(), and phpCAS\traceEnd().

Referenced by storeCookies().

137  {
139  $cookies = array();
140  foreach ( $header as $line ) {
141  if ( preg_match('/^Set-Cookie2?: /i', $line)) {
142  $cookies[] = $this->parseCookieHeader($line, $defaultDomain);
143  }
144  }
145 
146  phpCAS::traceEnd($cookies);
147  return $cookies;
148  }
parseCookieHeader($line, $defaultDomain)
Parse a single cookie header line.
Definition: CookieJar.php:161
static traceEnd($res='')
This method is used to indicate the end of the execution of a function in debug mode.
Definition: CAS.php:638
$header
Create styles array
The data for the language used.
static traceBegin()
This method is used to indicate the start of the execution of a function in debug mode...
Definition: CAS.php:591
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ storeCookie()

CAS_CookieJar::storeCookie (   $cookie)
protected

Add, update, or remove a cookie.

Parameters
array$cookieA cookie array as created by parseCookieHeaders()
Returns
void

protected

Definition at line 255 of file CookieJar.php.

References discardCookie().

Referenced by storeCookies().

256  {
257  // Discard any old versions of this cookie.
258  $this->discardCookie($cookie);
259  $this->_cookies[] = $cookie;
260 
261  }
discardCookie($cookie)
Discard an existing cookie.
Definition: CookieJar.php:272
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ storeCookies()

CAS_CookieJar::storeCookies (   $request_url,
  $response_headers 
)

Store cookies for a web service request.

Cookie storage is based on RFC 2965: http://www.ietf.org/rfc/rfc2965.txt

Parameters
string$request_urlThe URL that generated the response headers.
array$response_headersAn array of the HTTP response header strings.
Returns
void

private

Definition at line 70 of file CookieJar.php.

References cookieMatchesTarget(), parseCookieHeaders(), storeCookie(), and phpCAS\trace().

71  {
72  $urlParts = parse_url($request_url);
73  $defaultDomain = $urlParts['host'];
74 
75  $cookies = $this->parseCookieHeaders($response_headers, $defaultDomain);
76 
77  // var_dump($cookies);
78  foreach ($cookies as $cookie) {
79  // Enforce the same-origin policy by verifying that the cookie
80  // would match the url that is setting it
81  if (!$this->cookieMatchesTarget($cookie, $urlParts)) {
82  continue;
83  }
84 
85  // store the cookie
86  $this->storeCookie($cookie);
87 
88  phpCAS::trace($cookie['name'].' -> '.$cookie['value']);
89  }
90  }
cookieMatchesTarget($cookie, $target)
Answer true if cookie is applicable to a target.
Definition: CookieJar.php:317
static trace($str)
This method is used to log something in debug mode.
Definition: CAS.php:579
storeCookie($cookie)
Add, update, or remove a cookie.
Definition: CookieJar.php:255
parseCookieHeaders( $header, $defaultDomain)
Parse Cookies without PECL From the comments in http://php.net/manual/en/function.http-parse-cookie.php.
Definition: CookieJar.php:136
+ Here is the call graph for this function:

Field Documentation

◆ $_cookies

CAS_CookieJar::$_cookies
private

Definition at line 44 of file CookieJar.php.


The documentation for this class was generated from the following file: