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,
);
}