View source
<?php
module_load_include('php', 'apachesolr', 'Drupal_Apache_Solr_Service');
class AcquiaSearchService extends DrupalApacheSolrService {
public function optimize($waitFlush = true, $waitSearcher = true, $timeout = 3600) {
return TRUE;
}
protected function prepareRequest(&$url, &$options, $use_data = TRUE) {
module_load_include('inc', 'acquia_agent', 'acquia_agent_streams');
$id = uniqid();
if (!stristr($url, '?')) {
$url .= "?";
}
else {
$url .= "&";
}
$url .= 'request_id=' . $id;
if ($use_data && isset($options['data'])) {
list($cookie, $nonce) = acquia_search_auth_cookie($url, $options['data'], NULL, $this->env_id);
}
else {
list($cookie, $nonce) = acquia_search_auth_cookie($url, NULL, NULL, $this->env_id);
}
if (empty($cookie)) {
throw new Exception('Invalid authentication string - subscription keys expired or missing.');
}
$options['headers']['Cookie'] = $cookie;
$options['headers'] += array(
'User-Agent' => 'acquia_search/' . variable_get('acquia_search_version', '6.x-3.x'),
);
$options['context'] = acquia_agent_stream_context_create($url, 'acquia_search');
if (!$options['context']) {
throw new Exception(t("Could not create stream context"));
}
return $nonce;
}
protected function authenticateResponse($response, $nonce, $url) {
$hmac = acquia_search_extract_hmac($response->headers);
if (!acquia_search_valid_response($hmac, $nonce, $response->data, NULL, $this->env_id)) {
throw new Exception('Authentication of search content failed url: ' . $url);
}
return $response;
}
public function makeServletRequest($servlet, $params = array(), $options = array()) {
$params += array(
'wt' => 'json',
);
$url = $this
->_constructUrl($servlet, $params);
$nonce = $this
->prepareRequest($url, $options, FALSE);
$response = $this
->_makeHttpRequest($url, $options);
$response = $this
->checkResponse($response);
return $this
->authenticateResponse($response, $nonce, $url);
}
protected function _sendRawGet($url, $options = array()) {
$nonce = $this
->prepareRequest($url, $options);
$response = $this
->_makeHttpRequest($url, $options);
$response = $this
->checkResponse($response);
return $this
->authenticateResponse($response, $nonce, $url);
}
protected function _sendRawPost($url, $options = array()) {
$options['method'] = 'POST';
if (!isset($options['headers']['Content-Type'])) {
$options['headers']['Content-Type'] = 'text/xml; charset=UTF-8';
}
$nonce = $this
->prepareRequest($url, $options);
$response = $this
->_makeHttpRequest($url, $options);
$response = $this
->checkResponse($response);
return $this
->authenticateResponse($response, $nonce, $url);
}
}