You are here

function SearchApiAcquiaSearchHttpTransport::authCookie in Acquia Search for Search API 7

Modify a solr base url and construct a hmac authenticator cookie.

Parameters

$url: The solr url beng requested - passed by reference and may be altered.

$string: A string - the data to be authenticated, or empty to just use the path and query from the url to build the authenticator.

$derived_key: Optional string to supply the derived key.

Return value

An array containing the string to be added as the content of the Cookie header to the request and the nonce.

See also

acquia_search_auth_cookie

1 call to SearchApiAcquiaSearchHttpTransport::authCookie()
SearchApiAcquiaSearchHttpTransport::prepareRequest in includes/SearchApiAcquiaSearchHttpTransport.php
Modify the url and add headers appropriate to authenticate to Acquia Search.

File

includes/SearchApiAcquiaSearchHttpTransport.php, line 96
Contains SearchApiAcquiaSearchHttpTransport.

Class

SearchApiAcquiaSearchHttpTransport
HTTP transport for connections to the Acquia Search Service.

Code

function authCookie(&$url, $string = '', $derived_key = NULL) {
  $uri = parse_url($url);

  // Add a scheme - should always be https if available.
  if (in_array('ssl', stream_get_transports(), TRUE) && !defined('ACQUIA_DEVELOPMENT_NOSSL')) {
    $scheme = 'https://';
    $port = '';
  }
  else {
    $scheme = 'http://';
    $port = isset($uri['port']) && $uri['port'] != 80 ? ':' . $uri['port'] : '';
  }
  $path = isset($uri['path']) ? $uri['path'] : '/';
  $query = isset($uri['query']) ? '?' . $uri['query'] : '';
  $url = $scheme . $uri['host'] . $port . $path . $query;

  // 32 character nonce.
  $nonce = base64_encode(drupal_random_bytes(24));
  if ($string) {
    $auth_header = $this
      ->authenticator($string, $nonce, $derived_key);
  }
  else {
    $auth_header = $this
      ->authenticator($path . $query, $nonce, $derived_key);
  }
  return array(
    $auth_header,
    $nonce,
  );
}