annotate sites/all/modules/custom/solrsearch/Drupal_Apache_Solr_Service.php @ 0:015d06b10d37 default tip

initial
author dwinter
date Wed, 31 Jul 2013 13:49:13 +0200
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
015d06b10d37 initial
dwinter
parents:
diff changeset
1 <?php
015d06b10d37 initial
dwinter
parents:
diff changeset
2
015d06b10d37 initial
dwinter
parents:
diff changeset
3 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
4 * Copyright (c) 2007-2009, Conduit Internet Technologies, Inc.
015d06b10d37 initial
dwinter
parents:
diff changeset
5 * All rights reserved.
015d06b10d37 initial
dwinter
parents:
diff changeset
6 *
015d06b10d37 initial
dwinter
parents:
diff changeset
7 * Redistribution and use in source and binary forms, with or without
015d06b10d37 initial
dwinter
parents:
diff changeset
8 * modification, are permitted provided that the following conditions are met:
015d06b10d37 initial
dwinter
parents:
diff changeset
9 *
015d06b10d37 initial
dwinter
parents:
diff changeset
10 * - Redistributions of source code must retain the above copyright notice,
015d06b10d37 initial
dwinter
parents:
diff changeset
11 * this list of conditions and the following disclaimer.
015d06b10d37 initial
dwinter
parents:
diff changeset
12 * - Redistributions in binary form must reproduce the above copyright
015d06b10d37 initial
dwinter
parents:
diff changeset
13 * notice, this list of conditions and the following disclaimer in the
015d06b10d37 initial
dwinter
parents:
diff changeset
14 * documentation and/or other materials provided with the distribution.
015d06b10d37 initial
dwinter
parents:
diff changeset
15 * - Neither the name of Conduit Internet Technologies, Inc. nor the names of
015d06b10d37 initial
dwinter
parents:
diff changeset
16 * its contributors may be used to endorse or promote products derived from
015d06b10d37 initial
dwinter
parents:
diff changeset
17 * this software without specific prior written permission.
015d06b10d37 initial
dwinter
parents:
diff changeset
18 *
015d06b10d37 initial
dwinter
parents:
diff changeset
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
015d06b10d37 initial
dwinter
parents:
diff changeset
20 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
015d06b10d37 initial
dwinter
parents:
diff changeset
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
015d06b10d37 initial
dwinter
parents:
diff changeset
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
015d06b10d37 initial
dwinter
parents:
diff changeset
23 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
015d06b10d37 initial
dwinter
parents:
diff changeset
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
015d06b10d37 initial
dwinter
parents:
diff changeset
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
015d06b10d37 initial
dwinter
parents:
diff changeset
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
015d06b10d37 initial
dwinter
parents:
diff changeset
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
015d06b10d37 initial
dwinter
parents:
diff changeset
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
015d06b10d37 initial
dwinter
parents:
diff changeset
29 * POSSIBILITY OF SUCH DAMAGE.
015d06b10d37 initial
dwinter
parents:
diff changeset
30 *
015d06b10d37 initial
dwinter
parents:
diff changeset
31 * @copyright Copyright 2007-2009 Conduit Internet Technologies, Inc. (http://conduit-it.com)
015d06b10d37 initial
dwinter
parents:
diff changeset
32 * @license New BSD (http://solr-php-client.googlecode.com/svn/trunk/COPYING)
015d06b10d37 initial
dwinter
parents:
diff changeset
33 * @version $Id: Service.php 22 2009-11-09 22:46:54Z donovan.jimenez $
015d06b10d37 initial
dwinter
parents:
diff changeset
34 *
015d06b10d37 initial
dwinter
parents:
diff changeset
35 * @package Apache
015d06b10d37 initial
dwinter
parents:
diff changeset
36 * @subpackage Solr
015d06b10d37 initial
dwinter
parents:
diff changeset
37 * @author Donovan Jimenez <djimenez@conduit-it.com>
015d06b10d37 initial
dwinter
parents:
diff changeset
38 */
015d06b10d37 initial
dwinter
parents:
diff changeset
39
015d06b10d37 initial
dwinter
parents:
diff changeset
40 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
41 * Additional code Copyright (c) 2008-2011 by Robert Douglass, James McKinney,
015d06b10d37 initial
dwinter
parents:
diff changeset
42 * Jacob Singh, Alejandro Garza, Peter Wolanin, and additional contributors.
015d06b10d37 initial
dwinter
parents:
diff changeset
43 *
015d06b10d37 initial
dwinter
parents:
diff changeset
44 * This program is free software; you can redistribute it and/or modify
015d06b10d37 initial
dwinter
parents:
diff changeset
45 * it under the terms of the GNU General Public License as published by
015d06b10d37 initial
dwinter
parents:
diff changeset
46 * the Free Software Foundation; either version 2 of the License, or (at
015d06b10d37 initial
dwinter
parents:
diff changeset
47 * your option) any later version.
015d06b10d37 initial
dwinter
parents:
diff changeset
48
015d06b10d37 initial
dwinter
parents:
diff changeset
49 *
015d06b10d37 initial
dwinter
parents:
diff changeset
50 * This program is distributed in the hope that it will be useful, but
015d06b10d37 initial
dwinter
parents:
diff changeset
51 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
015d06b10d37 initial
dwinter
parents:
diff changeset
52 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
015d06b10d37 initial
dwinter
parents:
diff changeset
53 * for more details.
015d06b10d37 initial
dwinter
parents:
diff changeset
54 *
015d06b10d37 initial
dwinter
parents:
diff changeset
55 * You should have received a copy of the GNU General Public License
015d06b10d37 initial
dwinter
parents:
diff changeset
56 * along with this program as the file LICENSE.txt; if not, please see
015d06b10d37 initial
dwinter
parents:
diff changeset
57 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt.
015d06b10d37 initial
dwinter
parents:
diff changeset
58 */
015d06b10d37 initial
dwinter
parents:
diff changeset
59
015d06b10d37 initial
dwinter
parents:
diff changeset
60 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
61 * Starting point for the Solr API. Represents a Solr server resource and has
015d06b10d37 initial
dwinter
parents:
diff changeset
62 * methods for pinging, adding, deleting, committing, optimizing and searching.
015d06b10d37 initial
dwinter
parents:
diff changeset
63 */
015d06b10d37 initial
dwinter
parents:
diff changeset
64
015d06b10d37 initial
dwinter
parents:
diff changeset
65 class DrupalsolrsearchService implements DrupalApacheSolrServiceInterface {
015d06b10d37 initial
dwinter
parents:
diff changeset
66 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
67 * How NamedLists should be formatted in the output. This specifically effects facet counts. Valid values
015d06b10d37 initial
dwinter
parents:
diff changeset
68 * are 'map' (default) or 'flat'.
015d06b10d37 initial
dwinter
parents:
diff changeset
69 *
015d06b10d37 initial
dwinter
parents:
diff changeset
70 */
015d06b10d37 initial
dwinter
parents:
diff changeset
71 const NAMED_LIST_FORMAT = 'map';
015d06b10d37 initial
dwinter
parents:
diff changeset
72
015d06b10d37 initial
dwinter
parents:
diff changeset
73 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
74 * Servlet mappings
015d06b10d37 initial
dwinter
parents:
diff changeset
75 */
015d06b10d37 initial
dwinter
parents:
diff changeset
76 const PING_SERVLET = 'admin/ping';
015d06b10d37 initial
dwinter
parents:
diff changeset
77 const UPDATE_SERVLET = 'update';
015d06b10d37 initial
dwinter
parents:
diff changeset
78 const SEARCH_SERVLET = 'select';
015d06b10d37 initial
dwinter
parents:
diff changeset
79 const LUKE_SERVLET = 'admin/luke';
015d06b10d37 initial
dwinter
parents:
diff changeset
80 const SYSTEM_SERVLET = 'admin/system';
015d06b10d37 initial
dwinter
parents:
diff changeset
81 const STATS_SERVLET = 'admin/stats.jsp';
015d06b10d37 initial
dwinter
parents:
diff changeset
82 const STATS_SERVLET_4 = 'admin/mbeans?wt=xml&stats=true';
015d06b10d37 initial
dwinter
parents:
diff changeset
83
015d06b10d37 initial
dwinter
parents:
diff changeset
84 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
85 * Server url
015d06b10d37 initial
dwinter
parents:
diff changeset
86 *
015d06b10d37 initial
dwinter
parents:
diff changeset
87 * @var array
015d06b10d37 initial
dwinter
parents:
diff changeset
88 */
015d06b10d37 initial
dwinter
parents:
diff changeset
89 protected $parsed_url;
015d06b10d37 initial
dwinter
parents:
diff changeset
90
015d06b10d37 initial
dwinter
parents:
diff changeset
91 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
92 * Constructed servlet full path URLs
015d06b10d37 initial
dwinter
parents:
diff changeset
93 *
015d06b10d37 initial
dwinter
parents:
diff changeset
94 * @var string
015d06b10d37 initial
dwinter
parents:
diff changeset
95 */
015d06b10d37 initial
dwinter
parents:
diff changeset
96 protected $update_url;
015d06b10d37 initial
dwinter
parents:
diff changeset
97
015d06b10d37 initial
dwinter
parents:
diff changeset
98 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
99 * Default HTTP timeout when one is not specified (initialized to default_socket_timeout ini setting)
015d06b10d37 initial
dwinter
parents:
diff changeset
100 *
015d06b10d37 initial
dwinter
parents:
diff changeset
101 * var float
015d06b10d37 initial
dwinter
parents:
diff changeset
102 */
015d06b10d37 initial
dwinter
parents:
diff changeset
103 protected $_defaultTimeout;
015d06b10d37 initial
dwinter
parents:
diff changeset
104 protected $env_id;
015d06b10d37 initial
dwinter
parents:
diff changeset
105 protected $luke;
015d06b10d37 initial
dwinter
parents:
diff changeset
106 protected $stats;
015d06b10d37 initial
dwinter
parents:
diff changeset
107 protected $system_info;
015d06b10d37 initial
dwinter
parents:
diff changeset
108
015d06b10d37 initial
dwinter
parents:
diff changeset
109 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
110 * Flag that denotes whether to use soft commits for Solr 4.x, defaults to FALSE.
015d06b10d37 initial
dwinter
parents:
diff changeset
111 *
015d06b10d37 initial
dwinter
parents:
diff changeset
112 * @var bool
015d06b10d37 initial
dwinter
parents:
diff changeset
113 */
015d06b10d37 initial
dwinter
parents:
diff changeset
114 protected $soft_commit = FALSE;
015d06b10d37 initial
dwinter
parents:
diff changeset
115
015d06b10d37 initial
dwinter
parents:
diff changeset
116 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
117 * Call the /admin/ping servlet, to test the connection to the server.
015d06b10d37 initial
dwinter
parents:
diff changeset
118 *
015d06b10d37 initial
dwinter
parents:
diff changeset
119 * @param $timeout
015d06b10d37 initial
dwinter
parents:
diff changeset
120 * maximum time to wait for ping in seconds, -1 for unlimited (default 2).
015d06b10d37 initial
dwinter
parents:
diff changeset
121 * @return
015d06b10d37 initial
dwinter
parents:
diff changeset
122 * (float) seconds taken to ping the server, FALSE if timeout occurs.
015d06b10d37 initial
dwinter
parents:
diff changeset
123 */
015d06b10d37 initial
dwinter
parents:
diff changeset
124 public function ping($timeout = 2) {
015d06b10d37 initial
dwinter
parents:
diff changeset
125 $start = microtime(TRUE);
015d06b10d37 initial
dwinter
parents:
diff changeset
126
015d06b10d37 initial
dwinter
parents:
diff changeset
127 if ($timeout <= 0.0) {
015d06b10d37 initial
dwinter
parents:
diff changeset
128 $timeout = -1;
015d06b10d37 initial
dwinter
parents:
diff changeset
129 }
015d06b10d37 initial
dwinter
parents:
diff changeset
130 $pingUrl = $this->_constructUrl(self::PING_SERVLET);
015d06b10d37 initial
dwinter
parents:
diff changeset
131 // Attempt a HEAD request to the solr ping url.
015d06b10d37 initial
dwinter
parents:
diff changeset
132 $options = array(
015d06b10d37 initial
dwinter
parents:
diff changeset
133 'method' => 'HEAD',
015d06b10d37 initial
dwinter
parents:
diff changeset
134 'timeout' => $timeout,
015d06b10d37 initial
dwinter
parents:
diff changeset
135 );
015d06b10d37 initial
dwinter
parents:
diff changeset
136 $response = $this->_makeHttpRequest($pingUrl, $options);
015d06b10d37 initial
dwinter
parents:
diff changeset
137
015d06b10d37 initial
dwinter
parents:
diff changeset
138 if ($response->code == 200) {
015d06b10d37 initial
dwinter
parents:
diff changeset
139 // Add 0.1 ms to the ping time so we never return 0.0.
015d06b10d37 initial
dwinter
parents:
diff changeset
140 return microtime(TRUE) - $start + 0.0001;
015d06b10d37 initial
dwinter
parents:
diff changeset
141 }
015d06b10d37 initial
dwinter
parents:
diff changeset
142 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
143 return FALSE;
015d06b10d37 initial
dwinter
parents:
diff changeset
144 }
015d06b10d37 initial
dwinter
parents:
diff changeset
145 }
015d06b10d37 initial
dwinter
parents:
diff changeset
146
015d06b10d37 initial
dwinter
parents:
diff changeset
147 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
148 * Flags whether to use soft commits for Solr 4.x.
015d06b10d37 initial
dwinter
parents:
diff changeset
149 *
015d06b10d37 initial
dwinter
parents:
diff changeset
150 * @param bool $soft_commit
015d06b10d37 initial
dwinter
parents:
diff changeset
151 * Whether or not to use soft commits for Solr 4.x.
015d06b10d37 initial
dwinter
parents:
diff changeset
152 */
015d06b10d37 initial
dwinter
parents:
diff changeset
153 public function setSoftCommit($soft_commit) {
015d06b10d37 initial
dwinter
parents:
diff changeset
154 $this->soft_commit = (bool) $soft_commit;
015d06b10d37 initial
dwinter
parents:
diff changeset
155 }
015d06b10d37 initial
dwinter
parents:
diff changeset
156
015d06b10d37 initial
dwinter
parents:
diff changeset
157 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
158 * Returns the flag that denotes whether to use soft commits for Solr 4.x.
015d06b10d37 initial
dwinter
parents:
diff changeset
159 *
015d06b10d37 initial
dwinter
parents:
diff changeset
160 * @return bool
015d06b10d37 initial
dwinter
parents:
diff changeset
161 * Whether to use soft commits for Solr 4.x.
015d06b10d37 initial
dwinter
parents:
diff changeset
162 */
015d06b10d37 initial
dwinter
parents:
diff changeset
163 public function getSoftCommit() {
015d06b10d37 initial
dwinter
parents:
diff changeset
164 return $this->soft_commit;
015d06b10d37 initial
dwinter
parents:
diff changeset
165 }
015d06b10d37 initial
dwinter
parents:
diff changeset
166
015d06b10d37 initial
dwinter
parents:
diff changeset
167 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
168 * Call the /admin/system servlet
015d06b10d37 initial
dwinter
parents:
diff changeset
169 *
015d06b10d37 initial
dwinter
parents:
diff changeset
170 * @return
015d06b10d37 initial
dwinter
parents:
diff changeset
171 * (array) With all the system info
015d06b10d37 initial
dwinter
parents:
diff changeset
172 */
015d06b10d37 initial
dwinter
parents:
diff changeset
173 protected function setSystemInfo() {
015d06b10d37 initial
dwinter
parents:
diff changeset
174 $url = $this->_constructUrl(self::SYSTEM_SERVLET, array('wt' => 'json'));
015d06b10d37 initial
dwinter
parents:
diff changeset
175 if ($this->env_id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
176 $this->system_info_cid = $this->env_id . ":system:" . drupal_hash_base64($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
177 $cache = cache_get($this->system_info_cid, 'cache_solrsearch');
015d06b10d37 initial
dwinter
parents:
diff changeset
178 if (isset($cache->data)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
179 $this->system_info = json_decode($cache->data);
015d06b10d37 initial
dwinter
parents:
diff changeset
180 }
015d06b10d37 initial
dwinter
parents:
diff changeset
181 }
015d06b10d37 initial
dwinter
parents:
diff changeset
182 // Second pass to populate the cache if necessary.
015d06b10d37 initial
dwinter
parents:
diff changeset
183 if (empty($this->system_info)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
184 $response = $this->_sendRawGet($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
185 $this->system_info = json_decode($response->data);
015d06b10d37 initial
dwinter
parents:
diff changeset
186 if ($this->env_id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
187 cache_set($this->system_info_cid, $response->data, 'cache_solrsearch');
015d06b10d37 initial
dwinter
parents:
diff changeset
188 }
015d06b10d37 initial
dwinter
parents:
diff changeset
189 }
015d06b10d37 initial
dwinter
parents:
diff changeset
190 }
015d06b10d37 initial
dwinter
parents:
diff changeset
191
015d06b10d37 initial
dwinter
parents:
diff changeset
192 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
193 * Get information about the Solr Core.
015d06b10d37 initial
dwinter
parents:
diff changeset
194 *
015d06b10d37 initial
dwinter
parents:
diff changeset
195 * @return
015d06b10d37 initial
dwinter
parents:
diff changeset
196 * (string) system info encoded in json
015d06b10d37 initial
dwinter
parents:
diff changeset
197 */
015d06b10d37 initial
dwinter
parents:
diff changeset
198 public function getSystemInfo() {
015d06b10d37 initial
dwinter
parents:
diff changeset
199 if (!isset($this->system_info)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
200 $this->setSystemInfo();
015d06b10d37 initial
dwinter
parents:
diff changeset
201 }
015d06b10d37 initial
dwinter
parents:
diff changeset
202 return $this->system_info;
015d06b10d37 initial
dwinter
parents:
diff changeset
203 }
015d06b10d37 initial
dwinter
parents:
diff changeset
204
015d06b10d37 initial
dwinter
parents:
diff changeset
205 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
206 * Sets $this->luke with the meta-data about the index from admin/luke.
015d06b10d37 initial
dwinter
parents:
diff changeset
207 */
015d06b10d37 initial
dwinter
parents:
diff changeset
208 protected function setLuke($num_terms = 0) {
015d06b10d37 initial
dwinter
parents:
diff changeset
209 if (empty($this->luke[$num_terms])) {
015d06b10d37 initial
dwinter
parents:
diff changeset
210 $params = array(
015d06b10d37 initial
dwinter
parents:
diff changeset
211 'numTerms' => "$num_terms",
015d06b10d37 initial
dwinter
parents:
diff changeset
212 'wt' => 'json',
015d06b10d37 initial
dwinter
parents:
diff changeset
213 'json.nl' => self::NAMED_LIST_FORMAT,
015d06b10d37 initial
dwinter
parents:
diff changeset
214 );
015d06b10d37 initial
dwinter
parents:
diff changeset
215 $url = $this->_constructUrl(self::LUKE_SERVLET, $params);
015d06b10d37 initial
dwinter
parents:
diff changeset
216 if ($this->env_id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
217 $cid = $this->env_id . ":luke:" . drupal_hash_base64($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
218 $cache = cache_get($cid, 'cache_solrsearch');
015d06b10d37 initial
dwinter
parents:
diff changeset
219 if (isset($cache->data)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
220 $this->luke = $cache->data;
015d06b10d37 initial
dwinter
parents:
diff changeset
221 }
015d06b10d37 initial
dwinter
parents:
diff changeset
222 }
015d06b10d37 initial
dwinter
parents:
diff changeset
223 }
015d06b10d37 initial
dwinter
parents:
diff changeset
224 // Second pass to populate the cache if necessary.
015d06b10d37 initial
dwinter
parents:
diff changeset
225 if (empty($this->luke[$num_terms])) {
015d06b10d37 initial
dwinter
parents:
diff changeset
226 $this->luke[$num_terms] = $this->_sendRawGet($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
227 if ($this->env_id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
228 cache_set($cid, $this->luke, 'cache_solrsearch');
015d06b10d37 initial
dwinter
parents:
diff changeset
229 }
015d06b10d37 initial
dwinter
parents:
diff changeset
230 }
015d06b10d37 initial
dwinter
parents:
diff changeset
231 }
015d06b10d37 initial
dwinter
parents:
diff changeset
232
015d06b10d37 initial
dwinter
parents:
diff changeset
233 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
234 * Get just the field meta-data about the index.
015d06b10d37 initial
dwinter
parents:
diff changeset
235 */
015d06b10d37 initial
dwinter
parents:
diff changeset
236 public function getFields($num_terms = 0) {
015d06b10d37 initial
dwinter
parents:
diff changeset
237 return $this->getLuke($num_terms)->fields;
015d06b10d37 initial
dwinter
parents:
diff changeset
238 }
015d06b10d37 initial
dwinter
parents:
diff changeset
239
015d06b10d37 initial
dwinter
parents:
diff changeset
240 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
241 * Get meta-data about the index.
015d06b10d37 initial
dwinter
parents:
diff changeset
242 */
015d06b10d37 initial
dwinter
parents:
diff changeset
243 public function getLuke($num_terms = 0) {
015d06b10d37 initial
dwinter
parents:
diff changeset
244 if (!isset($this->luke[$num_terms])) {
015d06b10d37 initial
dwinter
parents:
diff changeset
245 $this->setLuke($num_terms);
015d06b10d37 initial
dwinter
parents:
diff changeset
246 }
015d06b10d37 initial
dwinter
parents:
diff changeset
247 return $this->luke[$num_terms];
015d06b10d37 initial
dwinter
parents:
diff changeset
248 }
015d06b10d37 initial
dwinter
parents:
diff changeset
249
015d06b10d37 initial
dwinter
parents:
diff changeset
250 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
251 * Get the current solr version. This could be 1, 3 or 4
015d06b10d37 initial
dwinter
parents:
diff changeset
252 *
015d06b10d37 initial
dwinter
parents:
diff changeset
253 * @return int
015d06b10d37 initial
dwinter
parents:
diff changeset
254 * 1, 3 or 4. Does not give a more details version, for that you need
015d06b10d37 initial
dwinter
parents:
diff changeset
255 * to get the system info.
015d06b10d37 initial
dwinter
parents:
diff changeset
256 */
015d06b10d37 initial
dwinter
parents:
diff changeset
257 public function getSolrVersion() {
015d06b10d37 initial
dwinter
parents:
diff changeset
258 $system_info = $this->getSystemInfo();
015d06b10d37 initial
dwinter
parents:
diff changeset
259 // Get our solr version number
015d06b10d37 initial
dwinter
parents:
diff changeset
260 if (isset($system_info->lucene->{'solr-spec-version'})) {
015d06b10d37 initial
dwinter
parents:
diff changeset
261 return $system_info->lucene->{'solr-spec-version'}[0];
015d06b10d37 initial
dwinter
parents:
diff changeset
262 }
015d06b10d37 initial
dwinter
parents:
diff changeset
263 return 0;
015d06b10d37 initial
dwinter
parents:
diff changeset
264 }
015d06b10d37 initial
dwinter
parents:
diff changeset
265
015d06b10d37 initial
dwinter
parents:
diff changeset
266 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
267 * Sets $this->stats with the information about the Solr Core form
015d06b10d37 initial
dwinter
parents:
diff changeset
268 */
015d06b10d37 initial
dwinter
parents:
diff changeset
269 protected function setStats() {
015d06b10d37 initial
dwinter
parents:
diff changeset
270 $data = $this->getLuke();
015d06b10d37 initial
dwinter
parents:
diff changeset
271 $solr_version = $this->getSolrVersion();
015d06b10d37 initial
dwinter
parents:
diff changeset
272 // Only try to get stats if we have connected to the index.
015d06b10d37 initial
dwinter
parents:
diff changeset
273 if (empty($this->stats) && isset($data->index->numDocs)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
274 if ($solr_version >= 4) {
015d06b10d37 initial
dwinter
parents:
diff changeset
275 $url = $this->_constructUrl(self::STATS_SERVLET_4);
015d06b10d37 initial
dwinter
parents:
diff changeset
276 }
015d06b10d37 initial
dwinter
parents:
diff changeset
277 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
278 $url = $this->_constructUrl(self::STATS_SERVLET);
015d06b10d37 initial
dwinter
parents:
diff changeset
279 }
015d06b10d37 initial
dwinter
parents:
diff changeset
280 if ($this->env_id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
281 $this->stats_cid = $this->env_id . ":stats:" . drupal_hash_base64($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
282 $cache = cache_get($this->stats_cid, 'cache_solrsearch');
015d06b10d37 initial
dwinter
parents:
diff changeset
283 if (isset($cache->data)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
284 $this->stats = simplexml_load_string($cache->data);
015d06b10d37 initial
dwinter
parents:
diff changeset
285 }
015d06b10d37 initial
dwinter
parents:
diff changeset
286 }
015d06b10d37 initial
dwinter
parents:
diff changeset
287 // Second pass to populate the cache if necessary.
015d06b10d37 initial
dwinter
parents:
diff changeset
288 if (empty($this->stats)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
289 $response = $this->_sendRawGet($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
290 $this->stats = simplexml_load_string($response->data);
015d06b10d37 initial
dwinter
parents:
diff changeset
291 if ($this->env_id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
292 cache_set($this->stats_cid, $response->data, 'cache_solrsearch');
015d06b10d37 initial
dwinter
parents:
diff changeset
293 }
015d06b10d37 initial
dwinter
parents:
diff changeset
294 }
015d06b10d37 initial
dwinter
parents:
diff changeset
295 }
015d06b10d37 initial
dwinter
parents:
diff changeset
296 }
015d06b10d37 initial
dwinter
parents:
diff changeset
297
015d06b10d37 initial
dwinter
parents:
diff changeset
298 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
299 * Get information about the Solr Core.
015d06b10d37 initial
dwinter
parents:
diff changeset
300 *
015d06b10d37 initial
dwinter
parents:
diff changeset
301 * Returns a Simple XMl document
015d06b10d37 initial
dwinter
parents:
diff changeset
302 */
015d06b10d37 initial
dwinter
parents:
diff changeset
303 public function getStats() {
015d06b10d37 initial
dwinter
parents:
diff changeset
304 if (!isset($this->stats)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
305 $this->setStats();
015d06b10d37 initial
dwinter
parents:
diff changeset
306 }
015d06b10d37 initial
dwinter
parents:
diff changeset
307 return $this->stats;
015d06b10d37 initial
dwinter
parents:
diff changeset
308 }
015d06b10d37 initial
dwinter
parents:
diff changeset
309
015d06b10d37 initial
dwinter
parents:
diff changeset
310 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
311 * Get summary information about the Solr Core.
015d06b10d37 initial
dwinter
parents:
diff changeset
312 */
015d06b10d37 initial
dwinter
parents:
diff changeset
313 public function getStatsSummary() {
015d06b10d37 initial
dwinter
parents:
diff changeset
314 $stats = $this->getStats();
015d06b10d37 initial
dwinter
parents:
diff changeset
315 $solr_version = $this->getSolrVersion();
015d06b10d37 initial
dwinter
parents:
diff changeset
316
015d06b10d37 initial
dwinter
parents:
diff changeset
317 $summary = array(
015d06b10d37 initial
dwinter
parents:
diff changeset
318 '@pending_docs' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
319 '@autocommit_time_seconds' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
320 '@autocommit_time' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
321 '@deletes_by_id' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
322 '@deletes_by_query' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
323 '@deletes_total' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
324 '@schema_version' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
325 '@core_name' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
326 '@index_size' => '',
015d06b10d37 initial
dwinter
parents:
diff changeset
327 );
015d06b10d37 initial
dwinter
parents:
diff changeset
328
015d06b10d37 initial
dwinter
parents:
diff changeset
329 if (!empty($stats)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
330 if ($solr_version <= 3) {
015d06b10d37 initial
dwinter
parents:
diff changeset
331 $docs_pending_xpath = $stats->xpath('//stat[@name="docsPending"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
332 $summary['@pending_docs'] = (int) trim(current($docs_pending_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
333 $max_time_xpath = $stats->xpath('//stat[@name="autocommit maxTime"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
334 $max_time = (int) trim(current($max_time_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
335 // Convert to seconds.
015d06b10d37 initial
dwinter
parents:
diff changeset
336 $summary['@autocommit_time_seconds'] = $max_time / 1000;
015d06b10d37 initial
dwinter
parents:
diff changeset
337 $summary['@autocommit_time'] = format_interval($max_time / 1000);
015d06b10d37 initial
dwinter
parents:
diff changeset
338 $deletes_id_xpath = $stats->xpath('//stat[@name="deletesById"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
339 $summary['@deletes_by_id'] = (int) trim(current($deletes_id_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
340 $deletes_query_xpath = $stats->xpath('//stat[@name="deletesByQuery"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
341 $summary['@deletes_by_query'] = (int) trim(current($deletes_query_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
342 $summary['@deletes_total'] = $summary['@deletes_by_id'] + $summary['@deletes_by_query'];
015d06b10d37 initial
dwinter
parents:
diff changeset
343 $schema = $stats->xpath('/solr/schema[1]');
015d06b10d37 initial
dwinter
parents:
diff changeset
344 $summary['@schema_version'] = trim($schema[0]);
015d06b10d37 initial
dwinter
parents:
diff changeset
345 $core = $stats->xpath('/solr/core[1]');
015d06b10d37 initial
dwinter
parents:
diff changeset
346 $summary['@core_name'] = trim($core[0]);
015d06b10d37 initial
dwinter
parents:
diff changeset
347 $size_xpath = $stats->xpath('//stat[@name="indexSize"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
348 $summary['@index_size'] = trim(current($size_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
349 }
015d06b10d37 initial
dwinter
parents:
diff changeset
350 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
351 $system_info = $this->getSystemInfo();
015d06b10d37 initial
dwinter
parents:
diff changeset
352 $docs_pending_xpath = $stats->xpath('//lst["stats"]/long[@name="docsPending"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
353 $summary['@pending_docs'] = (int) trim(current($docs_pending_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
354 $max_time_xpath = $stats->xpath('//lst["stats"]/str[@name="autocommit maxTime"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
355 $max_time = (int) trim(current($max_time_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
356 // Convert to seconds.
015d06b10d37 initial
dwinter
parents:
diff changeset
357 $summary['@autocommit_time_seconds'] = $max_time / 1000;
015d06b10d37 initial
dwinter
parents:
diff changeset
358 $summary['@autocommit_time'] = format_interval($max_time / 1000);
015d06b10d37 initial
dwinter
parents:
diff changeset
359 $deletes_id_xpath = $stats->xpath('//lst["stats"]/long[@name="deletesById"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
360 $summary['@deletes_by_id'] = (int) trim(current($deletes_id_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
361 $deletes_query_xpath = $stats->xpath('//lst["stats"]/long[@name="deletesByQuery"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
362 $summary['@deletes_by_query'] = (int) trim(current($deletes_query_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
363 $summary['@deletes_total'] = $summary['@deletes_by_id'] + $summary['@deletes_by_query'];
015d06b10d37 initial
dwinter
parents:
diff changeset
364 $schema = $system_info->core->schema;
015d06b10d37 initial
dwinter
parents:
diff changeset
365 $summary['@schema_version'] = $schema;
015d06b10d37 initial
dwinter
parents:
diff changeset
366 $core = $stats->xpath('//lst["core"]/str[@name="coreName"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
367 $summary['@core_name'] = trim(current($core));
015d06b10d37 initial
dwinter
parents:
diff changeset
368 $size_xpath = $stats->xpath('//lst["core"]/str[@name="indexSize"]');
015d06b10d37 initial
dwinter
parents:
diff changeset
369 $summary['@index_size'] = trim(current($size_xpath));
015d06b10d37 initial
dwinter
parents:
diff changeset
370 }
015d06b10d37 initial
dwinter
parents:
diff changeset
371 }
015d06b10d37 initial
dwinter
parents:
diff changeset
372
015d06b10d37 initial
dwinter
parents:
diff changeset
373 return $summary;
015d06b10d37 initial
dwinter
parents:
diff changeset
374 }
015d06b10d37 initial
dwinter
parents:
diff changeset
375
015d06b10d37 initial
dwinter
parents:
diff changeset
376 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
377 * Clear cached Solr data.
015d06b10d37 initial
dwinter
parents:
diff changeset
378 */
015d06b10d37 initial
dwinter
parents:
diff changeset
379 public function clearCache() {
015d06b10d37 initial
dwinter
parents:
diff changeset
380 // Don't clear cached data if the server is unavailable.
015d06b10d37 initial
dwinter
parents:
diff changeset
381 if (@$this->ping()) {
015d06b10d37 initial
dwinter
parents:
diff changeset
382 $this->_clearCache();
015d06b10d37 initial
dwinter
parents:
diff changeset
383 }
015d06b10d37 initial
dwinter
parents:
diff changeset
384 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
385 throw new Exception('No Solr instance available when trying to clear the cache.');
015d06b10d37 initial
dwinter
parents:
diff changeset
386 }
015d06b10d37 initial
dwinter
parents:
diff changeset
387 }
015d06b10d37 initial
dwinter
parents:
diff changeset
388
015d06b10d37 initial
dwinter
parents:
diff changeset
389 protected function _clearCache() {
015d06b10d37 initial
dwinter
parents:
diff changeset
390 if ($this->env_id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
391 cache_clear_all($this->env_id . ":stats:", 'cache_solrsearch', TRUE);
015d06b10d37 initial
dwinter
parents:
diff changeset
392 cache_clear_all($this->env_id . ":luke:", 'cache_solrsearch', TRUE);
015d06b10d37 initial
dwinter
parents:
diff changeset
393 }
015d06b10d37 initial
dwinter
parents:
diff changeset
394 $this->luke = array();
015d06b10d37 initial
dwinter
parents:
diff changeset
395 $this->stats = NULL;
015d06b10d37 initial
dwinter
parents:
diff changeset
396 }
015d06b10d37 initial
dwinter
parents:
diff changeset
397
015d06b10d37 initial
dwinter
parents:
diff changeset
398 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
399 * Constructor
015d06b10d37 initial
dwinter
parents:
diff changeset
400 *
015d06b10d37 initial
dwinter
parents:
diff changeset
401 * @param $url
015d06b10d37 initial
dwinter
parents:
diff changeset
402 * The URL to the Solr server, possibly including a core name. E.g. http://localhost:8983/solr/
015d06b10d37 initial
dwinter
parents:
diff changeset
403 * or https://search.example.com/solr/core99/
015d06b10d37 initial
dwinter
parents:
diff changeset
404 * @param $env_id
015d06b10d37 initial
dwinter
parents:
diff changeset
405 * The machine name of a corresponding saved configuration used for loading
015d06b10d37 initial
dwinter
parents:
diff changeset
406 * data like which facets are enabled.
015d06b10d37 initial
dwinter
parents:
diff changeset
407 */
015d06b10d37 initial
dwinter
parents:
diff changeset
408 public function __construct($url, $env_id = NULL) {
015d06b10d37 initial
dwinter
parents:
diff changeset
409 $this->env_id = $env_id;
015d06b10d37 initial
dwinter
parents:
diff changeset
410 $this->setUrl($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
411
015d06b10d37 initial
dwinter
parents:
diff changeset
412 // determine our default http timeout from ini settings
015d06b10d37 initial
dwinter
parents:
diff changeset
413 $this->_defaultTimeout = (int) ini_get('default_socket_timeout');
015d06b10d37 initial
dwinter
parents:
diff changeset
414
015d06b10d37 initial
dwinter
parents:
diff changeset
415 // double check we didn't get 0 for a timeout
015d06b10d37 initial
dwinter
parents:
diff changeset
416 if ($this->_defaultTimeout <= 0) {
015d06b10d37 initial
dwinter
parents:
diff changeset
417 $this->_defaultTimeout = 60;
015d06b10d37 initial
dwinter
parents:
diff changeset
418 }
015d06b10d37 initial
dwinter
parents:
diff changeset
419 }
015d06b10d37 initial
dwinter
parents:
diff changeset
420
015d06b10d37 initial
dwinter
parents:
diff changeset
421 function getId() {
015d06b10d37 initial
dwinter
parents:
diff changeset
422 return $this->env_id;
015d06b10d37 initial
dwinter
parents:
diff changeset
423 }
015d06b10d37 initial
dwinter
parents:
diff changeset
424
015d06b10d37 initial
dwinter
parents:
diff changeset
425 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
426 * Check the reponse code and thow an exception if it's not 200.
015d06b10d37 initial
dwinter
parents:
diff changeset
427 *
015d06b10d37 initial
dwinter
parents:
diff changeset
428 * @param stdClass $response
015d06b10d37 initial
dwinter
parents:
diff changeset
429 * response object.
015d06b10d37 initial
dwinter
parents:
diff changeset
430 *
015d06b10d37 initial
dwinter
parents:
diff changeset
431 * @return
015d06b10d37 initial
dwinter
parents:
diff changeset
432 * response object
015d06b10d37 initial
dwinter
parents:
diff changeset
433 * @thows Exception
015d06b10d37 initial
dwinter
parents:
diff changeset
434 */
015d06b10d37 initial
dwinter
parents:
diff changeset
435 protected function checkResponse($response) {
015d06b10d37 initial
dwinter
parents:
diff changeset
436 $code = (int) $response->code;
015d06b10d37 initial
dwinter
parents:
diff changeset
437 if ($code != 200) {
015d06b10d37 initial
dwinter
parents:
diff changeset
438 if ($code >= 400 && $code != 403 && $code != 404) {
015d06b10d37 initial
dwinter
parents:
diff changeset
439 // Add details, like Solr's exception message.
015d06b10d37 initial
dwinter
parents:
diff changeset
440 $response->status_message .= $response->data;
015d06b10d37 initial
dwinter
parents:
diff changeset
441 }
015d06b10d37 initial
dwinter
parents:
diff changeset
442 throw new Exception('"' . $code . '" Status: ' . $response->status_message);
015d06b10d37 initial
dwinter
parents:
diff changeset
443 }
015d06b10d37 initial
dwinter
parents:
diff changeset
444 return $response;
015d06b10d37 initial
dwinter
parents:
diff changeset
445 }
015d06b10d37 initial
dwinter
parents:
diff changeset
446
015d06b10d37 initial
dwinter
parents:
diff changeset
447 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
448 * Make a request to a servlet (a path) that's not a standard path.
015d06b10d37 initial
dwinter
parents:
diff changeset
449 *
015d06b10d37 initial
dwinter
parents:
diff changeset
450 * @param string $servlet
015d06b10d37 initial
dwinter
parents:
diff changeset
451 * A path to be added to the base Solr path. e.g. 'extract/tika'
015d06b10d37 initial
dwinter
parents:
diff changeset
452 *
015d06b10d37 initial
dwinter
parents:
diff changeset
453 * @param array $params
015d06b10d37 initial
dwinter
parents:
diff changeset
454 * Any request parameters when constructing the URL.
015d06b10d37 initial
dwinter
parents:
diff changeset
455 *
015d06b10d37 initial
dwinter
parents:
diff changeset
456 * @param array $options
015d06b10d37 initial
dwinter
parents:
diff changeset
457 * @see drupal_http_request() $options.
015d06b10d37 initial
dwinter
parents:
diff changeset
458 *
015d06b10d37 initial
dwinter
parents:
diff changeset
459 * @return
015d06b10d37 initial
dwinter
parents:
diff changeset
460 * response object
015d06b10d37 initial
dwinter
parents:
diff changeset
461 *
015d06b10d37 initial
dwinter
parents:
diff changeset
462 * @thows Exception
015d06b10d37 initial
dwinter
parents:
diff changeset
463 */
015d06b10d37 initial
dwinter
parents:
diff changeset
464 public function makeServletRequest($servlet, $params = array(), $options = array()) {
015d06b10d37 initial
dwinter
parents:
diff changeset
465 // Add default params.
015d06b10d37 initial
dwinter
parents:
diff changeset
466 $params += array(
015d06b10d37 initial
dwinter
parents:
diff changeset
467 'wt' => 'json',
015d06b10d37 initial
dwinter
parents:
diff changeset
468 'json.nl' => self::NAMED_LIST_FORMAT,
015d06b10d37 initial
dwinter
parents:
diff changeset
469 );
015d06b10d37 initial
dwinter
parents:
diff changeset
470
015d06b10d37 initial
dwinter
parents:
diff changeset
471 $url = $this->_constructUrl($servlet, $params);
015d06b10d37 initial
dwinter
parents:
diff changeset
472 $response = $this->_makeHttpRequest($url, $options);
015d06b10d37 initial
dwinter
parents:
diff changeset
473 return $this->checkResponse($response);
015d06b10d37 initial
dwinter
parents:
diff changeset
474 }
015d06b10d37 initial
dwinter
parents:
diff changeset
475
015d06b10d37 initial
dwinter
parents:
diff changeset
476 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
477 * Central method for making a GET operation against this Solr Server
015d06b10d37 initial
dwinter
parents:
diff changeset
478 */
015d06b10d37 initial
dwinter
parents:
diff changeset
479 protected function _sendRawGet($url, $options = array()) {
015d06b10d37 initial
dwinter
parents:
diff changeset
480 $response = $this->_makeHttpRequest($url, $options);
015d06b10d37 initial
dwinter
parents:
diff changeset
481 return $this->checkResponse($response);
015d06b10d37 initial
dwinter
parents:
diff changeset
482 }
015d06b10d37 initial
dwinter
parents:
diff changeset
483
015d06b10d37 initial
dwinter
parents:
diff changeset
484 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
485 * Central method for making a POST operation against this Solr Server
015d06b10d37 initial
dwinter
parents:
diff changeset
486 */
015d06b10d37 initial
dwinter
parents:
diff changeset
487 protected function _sendRawPost($url, $options = array()) {
015d06b10d37 initial
dwinter
parents:
diff changeset
488 $options['method'] = 'POST';
015d06b10d37 initial
dwinter
parents:
diff changeset
489 // Normally we use POST to send XML documents.
015d06b10d37 initial
dwinter
parents:
diff changeset
490 if (!isset($options['headers']['Content-Type'])) {
015d06b10d37 initial
dwinter
parents:
diff changeset
491 $options['headers']['Content-Type'] = 'text/xml; charset=UTF-8';
015d06b10d37 initial
dwinter
parents:
diff changeset
492 }
015d06b10d37 initial
dwinter
parents:
diff changeset
493 $response = $this->_makeHttpRequest($url, $options);
015d06b10d37 initial
dwinter
parents:
diff changeset
494 return $this->checkResponse($response);
015d06b10d37 initial
dwinter
parents:
diff changeset
495 }
015d06b10d37 initial
dwinter
parents:
diff changeset
496
015d06b10d37 initial
dwinter
parents:
diff changeset
497 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
498 * Central method for making the actual http request to the Solr Server
015d06b10d37 initial
dwinter
parents:
diff changeset
499 *
015d06b10d37 initial
dwinter
parents:
diff changeset
500 * This is just a wrapper around drupal_http_request().
015d06b10d37 initial
dwinter
parents:
diff changeset
501 */
015d06b10d37 initial
dwinter
parents:
diff changeset
502 protected function _makeHttpRequest($url, array $options = array()) {
015d06b10d37 initial
dwinter
parents:
diff changeset
503 if (!isset($options['method']) || $options['method'] == 'GET' || $options['method'] == 'HEAD') {
015d06b10d37 initial
dwinter
parents:
diff changeset
504 // Make sure we are not sending a request body.
015d06b10d37 initial
dwinter
parents:
diff changeset
505 $options['data'] = NULL;
015d06b10d37 initial
dwinter
parents:
diff changeset
506 }
015d06b10d37 initial
dwinter
parents:
diff changeset
507
015d06b10d37 initial
dwinter
parents:
diff changeset
508 $result = drupal_http_request($url, $options);
015d06b10d37 initial
dwinter
parents:
diff changeset
509
015d06b10d37 initial
dwinter
parents:
diff changeset
510 if (!isset($result->code) || $result->code < 0) {
015d06b10d37 initial
dwinter
parents:
diff changeset
511 $result->code = 0;
015d06b10d37 initial
dwinter
parents:
diff changeset
512 $result->status_message = 'Request failed';
015d06b10d37 initial
dwinter
parents:
diff changeset
513 $result->protocol = 'HTTP/1.0';
015d06b10d37 initial
dwinter
parents:
diff changeset
514 }
015d06b10d37 initial
dwinter
parents:
diff changeset
515 // Additional information may be in the error property.
015d06b10d37 initial
dwinter
parents:
diff changeset
516 if (isset($result->error)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
517 $result->status_message .= ': ' . check_plain($result->error);
015d06b10d37 initial
dwinter
parents:
diff changeset
518 }
015d06b10d37 initial
dwinter
parents:
diff changeset
519
015d06b10d37 initial
dwinter
parents:
diff changeset
520 if (!isset($result->data)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
521 $result->data = '';
015d06b10d37 initial
dwinter
parents:
diff changeset
522 $result->response = NULL;
015d06b10d37 initial
dwinter
parents:
diff changeset
523 }
015d06b10d37 initial
dwinter
parents:
diff changeset
524 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
525 $response = json_decode($result->data);
015d06b10d37 initial
dwinter
parents:
diff changeset
526 if (is_object($response)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
527 foreach ($response as $key => $value) {
015d06b10d37 initial
dwinter
parents:
diff changeset
528 $result->$key = $value;
015d06b10d37 initial
dwinter
parents:
diff changeset
529 }
015d06b10d37 initial
dwinter
parents:
diff changeset
530 }
015d06b10d37 initial
dwinter
parents:
diff changeset
531 }
015d06b10d37 initial
dwinter
parents:
diff changeset
532 return $result;
015d06b10d37 initial
dwinter
parents:
diff changeset
533 }
015d06b10d37 initial
dwinter
parents:
diff changeset
534
015d06b10d37 initial
dwinter
parents:
diff changeset
535
015d06b10d37 initial
dwinter
parents:
diff changeset
536 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
537 * Escape a value for special query characters such as ':', '(', ')', '*', '?', etc.
015d06b10d37 initial
dwinter
parents:
diff changeset
538 *
015d06b10d37 initial
dwinter
parents:
diff changeset
539 * NOTE: inside a phrase fewer characters need escaped, use {@link DrupalsolrsearchService::escapePhrase()} instead
015d06b10d37 initial
dwinter
parents:
diff changeset
540 *
015d06b10d37 initial
dwinter
parents:
diff changeset
541 * @param string $value
015d06b10d37 initial
dwinter
parents:
diff changeset
542 * @return string
015d06b10d37 initial
dwinter
parents:
diff changeset
543 */
015d06b10d37 initial
dwinter
parents:
diff changeset
544 static public function escape($value)
015d06b10d37 initial
dwinter
parents:
diff changeset
545 {
015d06b10d37 initial
dwinter
parents:
diff changeset
546 //list taken from http://lucene.apache.org/java/docs/queryparsersyntax.html#Escaping%20Special%20Characters
015d06b10d37 initial
dwinter
parents:
diff changeset
547 $pattern = '/(\+|-|&&|\|\||!|\(|\)|\{|}|\[|]|\^|"|~|\*|\?|:|\\\)/';
015d06b10d37 initial
dwinter
parents:
diff changeset
548 $replace = '\\\$1';
015d06b10d37 initial
dwinter
parents:
diff changeset
549
015d06b10d37 initial
dwinter
parents:
diff changeset
550 return preg_replace($pattern, $replace, $value);
015d06b10d37 initial
dwinter
parents:
diff changeset
551 }
015d06b10d37 initial
dwinter
parents:
diff changeset
552
015d06b10d37 initial
dwinter
parents:
diff changeset
553 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
554 * Escape a value meant to be contained in a phrase for special query characters
015d06b10d37 initial
dwinter
parents:
diff changeset
555 *
015d06b10d37 initial
dwinter
parents:
diff changeset
556 * @param string $value
015d06b10d37 initial
dwinter
parents:
diff changeset
557 * @return string
015d06b10d37 initial
dwinter
parents:
diff changeset
558 */
015d06b10d37 initial
dwinter
parents:
diff changeset
559 static public function escapePhrase($value)
015d06b10d37 initial
dwinter
parents:
diff changeset
560 {
015d06b10d37 initial
dwinter
parents:
diff changeset
561 $pattern = '/("|\\\)/';
015d06b10d37 initial
dwinter
parents:
diff changeset
562 $replace = '\\\$1';
015d06b10d37 initial
dwinter
parents:
diff changeset
563
015d06b10d37 initial
dwinter
parents:
diff changeset
564 return preg_replace($pattern, $replace, $value);
015d06b10d37 initial
dwinter
parents:
diff changeset
565 }
015d06b10d37 initial
dwinter
parents:
diff changeset
566
015d06b10d37 initial
dwinter
parents:
diff changeset
567 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
568 * Convenience function for creating phrase syntax from a value
015d06b10d37 initial
dwinter
parents:
diff changeset
569 *
015d06b10d37 initial
dwinter
parents:
diff changeset
570 * @param string $value
015d06b10d37 initial
dwinter
parents:
diff changeset
571 * @return string
015d06b10d37 initial
dwinter
parents:
diff changeset
572 */
015d06b10d37 initial
dwinter
parents:
diff changeset
573 static public function phrase($value)
015d06b10d37 initial
dwinter
parents:
diff changeset
574 {
015d06b10d37 initial
dwinter
parents:
diff changeset
575 return '"' . self::escapePhrase($value) . '"';
015d06b10d37 initial
dwinter
parents:
diff changeset
576 }
015d06b10d37 initial
dwinter
parents:
diff changeset
577
015d06b10d37 initial
dwinter
parents:
diff changeset
578 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
579 * Return a valid http URL given this server's host, port and path and a provided servlet name
015d06b10d37 initial
dwinter
parents:
diff changeset
580 *
015d06b10d37 initial
dwinter
parents:
diff changeset
581 * @param $servlet
015d06b10d37 initial
dwinter
parents:
diff changeset
582 * A string path to a Solr request handler.
015d06b10d37 initial
dwinter
parents:
diff changeset
583 * @param $params
015d06b10d37 initial
dwinter
parents:
diff changeset
584 * @param $parsed_url
015d06b10d37 initial
dwinter
parents:
diff changeset
585 * A url to use instead of the stored one.
015d06b10d37 initial
dwinter
parents:
diff changeset
586 *
015d06b10d37 initial
dwinter
parents:
diff changeset
587 * @return string
015d06b10d37 initial
dwinter
parents:
diff changeset
588 */
015d06b10d37 initial
dwinter
parents:
diff changeset
589 protected function _constructUrl($servlet, $params = array(), $added_query_string = NULL) {
015d06b10d37 initial
dwinter
parents:
diff changeset
590 // PHP's built in http_build_query() doesn't give us the format Solr wants.
015d06b10d37 initial
dwinter
parents:
diff changeset
591 $query_string = $this->httpBuildQuery($params);
015d06b10d37 initial
dwinter
parents:
diff changeset
592
015d06b10d37 initial
dwinter
parents:
diff changeset
593 if ($query_string) {
015d06b10d37 initial
dwinter
parents:
diff changeset
594 $query_string = '?' . $query_string;
015d06b10d37 initial
dwinter
parents:
diff changeset
595 if ($added_query_string) {
015d06b10d37 initial
dwinter
parents:
diff changeset
596 $query_string = $query_string . '&' . $added_query_string;
015d06b10d37 initial
dwinter
parents:
diff changeset
597 }
015d06b10d37 initial
dwinter
parents:
diff changeset
598 }
015d06b10d37 initial
dwinter
parents:
diff changeset
599 elseif ($added_query_string) {
015d06b10d37 initial
dwinter
parents:
diff changeset
600 $query_string = '?' . $added_query_string;
015d06b10d37 initial
dwinter
parents:
diff changeset
601 }
015d06b10d37 initial
dwinter
parents:
diff changeset
602
015d06b10d37 initial
dwinter
parents:
diff changeset
603 $url = $this->parsed_url;
015d06b10d37 initial
dwinter
parents:
diff changeset
604 return $url['scheme'] . $url['user'] . $url['pass'] . $url['host'] . $url['port'] . $url['path'] . $servlet . $query_string;
015d06b10d37 initial
dwinter
parents:
diff changeset
605 }
015d06b10d37 initial
dwinter
parents:
diff changeset
606
015d06b10d37 initial
dwinter
parents:
diff changeset
607 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
608 * Get the Solr url
015d06b10d37 initial
dwinter
parents:
diff changeset
609 *
015d06b10d37 initial
dwinter
parents:
diff changeset
610 * @return string
015d06b10d37 initial
dwinter
parents:
diff changeset
611 */
015d06b10d37 initial
dwinter
parents:
diff changeset
612 public function getUrl() {
015d06b10d37 initial
dwinter
parents:
diff changeset
613 return $this->_constructUrl('');
015d06b10d37 initial
dwinter
parents:
diff changeset
614 }
015d06b10d37 initial
dwinter
parents:
diff changeset
615
015d06b10d37 initial
dwinter
parents:
diff changeset
616 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
617 * Set the Solr url.
015d06b10d37 initial
dwinter
parents:
diff changeset
618 *
015d06b10d37 initial
dwinter
parents:
diff changeset
619 * @param $url
015d06b10d37 initial
dwinter
parents:
diff changeset
620 *
015d06b10d37 initial
dwinter
parents:
diff changeset
621 * @return $this
015d06b10d37 initial
dwinter
parents:
diff changeset
622 */
015d06b10d37 initial
dwinter
parents:
diff changeset
623 public function setUrl($url) {
015d06b10d37 initial
dwinter
parents:
diff changeset
624 $parsed_url = parse_url($url);
015d06b10d37 initial
dwinter
parents:
diff changeset
625
015d06b10d37 initial
dwinter
parents:
diff changeset
626 if (!isset($parsed_url['scheme'])) {
015d06b10d37 initial
dwinter
parents:
diff changeset
627 $parsed_url['scheme'] = 'http';
015d06b10d37 initial
dwinter
parents:
diff changeset
628 }
015d06b10d37 initial
dwinter
parents:
diff changeset
629 $parsed_url['scheme'] .= '://';
015d06b10d37 initial
dwinter
parents:
diff changeset
630
015d06b10d37 initial
dwinter
parents:
diff changeset
631 if (!isset($parsed_url['user'])) {
015d06b10d37 initial
dwinter
parents:
diff changeset
632 $parsed_url['user'] = '';
015d06b10d37 initial
dwinter
parents:
diff changeset
633 }
015d06b10d37 initial
dwinter
parents:
diff changeset
634 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
635 $parsed_url['host'] = '@' . $parsed_url['host'];
015d06b10d37 initial
dwinter
parents:
diff changeset
636 }
015d06b10d37 initial
dwinter
parents:
diff changeset
637 $parsed_url['pass'] = isset($parsed_url['pass']) ? ':' . $parsed_url['pass'] : '';
015d06b10d37 initial
dwinter
parents:
diff changeset
638 $parsed_url['port'] = isset($parsed_url['port']) ? ':' . $parsed_url['port'] : '';
015d06b10d37 initial
dwinter
parents:
diff changeset
639
015d06b10d37 initial
dwinter
parents:
diff changeset
640 if (isset($parsed_url['path'])) {
015d06b10d37 initial
dwinter
parents:
diff changeset
641 // Make sure the path has a single leading/trailing slash.
015d06b10d37 initial
dwinter
parents:
diff changeset
642 $parsed_url['path'] = '/' . ltrim($parsed_url['path'], '/');
015d06b10d37 initial
dwinter
parents:
diff changeset
643 $parsed_url['path'] = rtrim($parsed_url['path'], '/') . '/';
015d06b10d37 initial
dwinter
parents:
diff changeset
644 }
015d06b10d37 initial
dwinter
parents:
diff changeset
645 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
646 $parsed_url['path'] = '/';
015d06b10d37 initial
dwinter
parents:
diff changeset
647 }
015d06b10d37 initial
dwinter
parents:
diff changeset
648 // For now we ignore query and fragment.
015d06b10d37 initial
dwinter
parents:
diff changeset
649 $this->parsed_url = $parsed_url;
015d06b10d37 initial
dwinter
parents:
diff changeset
650 // Force the update url to be rebuilt.
015d06b10d37 initial
dwinter
parents:
diff changeset
651 unset($this->update_url);
015d06b10d37 initial
dwinter
parents:
diff changeset
652 return $this;
015d06b10d37 initial
dwinter
parents:
diff changeset
653 }
015d06b10d37 initial
dwinter
parents:
diff changeset
654
015d06b10d37 initial
dwinter
parents:
diff changeset
655 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
656 * Raw update Method. Takes a raw post body and sends it to the update service. Post body
015d06b10d37 initial
dwinter
parents:
diff changeset
657 * should be a complete and well formed xml document.
015d06b10d37 initial
dwinter
parents:
diff changeset
658 *
015d06b10d37 initial
dwinter
parents:
diff changeset
659 * @param string $rawPost
015d06b10d37 initial
dwinter
parents:
diff changeset
660 * @param float $timeout Maximum expected duration (in seconds)
015d06b10d37 initial
dwinter
parents:
diff changeset
661 *
015d06b10d37 initial
dwinter
parents:
diff changeset
662 * @return response object
015d06b10d37 initial
dwinter
parents:
diff changeset
663 *
015d06b10d37 initial
dwinter
parents:
diff changeset
664 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
665 */
015d06b10d37 initial
dwinter
parents:
diff changeset
666 public function update($rawPost, $timeout = FALSE) {
015d06b10d37 initial
dwinter
parents:
diff changeset
667 // @todo: throw exception if updates are disabled.
015d06b10d37 initial
dwinter
parents:
diff changeset
668 if (empty($this->update_url)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
669 // Store the URL in an instance variable since many updates may be sent
015d06b10d37 initial
dwinter
parents:
diff changeset
670 // via a single instance of this class.
015d06b10d37 initial
dwinter
parents:
diff changeset
671 $this->update_url = $this->_constructUrl(self::UPDATE_SERVLET, array('wt' => 'json'));
015d06b10d37 initial
dwinter
parents:
diff changeset
672 }
015d06b10d37 initial
dwinter
parents:
diff changeset
673 $options['data'] = $rawPost;
015d06b10d37 initial
dwinter
parents:
diff changeset
674 if ($timeout) {
015d06b10d37 initial
dwinter
parents:
diff changeset
675 $options['timeout'] = $timeout;
015d06b10d37 initial
dwinter
parents:
diff changeset
676 }
015d06b10d37 initial
dwinter
parents:
diff changeset
677 return $this->_sendRawPost($this->update_url, $options);
015d06b10d37 initial
dwinter
parents:
diff changeset
678 }
015d06b10d37 initial
dwinter
parents:
diff changeset
679
015d06b10d37 initial
dwinter
parents:
diff changeset
680 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
681 * Add an array of Solr Documents to the index all at once
015d06b10d37 initial
dwinter
parents:
diff changeset
682 *
015d06b10d37 initial
dwinter
parents:
diff changeset
683 * @param array $documents Should be an array of solrsearchDocument instances
015d06b10d37 initial
dwinter
parents:
diff changeset
684 * @param boolean $allowDups
015d06b10d37 initial
dwinter
parents:
diff changeset
685 * @param boolean $overwritePending
015d06b10d37 initial
dwinter
parents:
diff changeset
686 * @param boolean $overwriteCommitted
015d06b10d37 initial
dwinter
parents:
diff changeset
687 *
015d06b10d37 initial
dwinter
parents:
diff changeset
688 * @return response objecte
015d06b10d37 initial
dwinter
parents:
diff changeset
689 *
015d06b10d37 initial
dwinter
parents:
diff changeset
690 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
691 */
015d06b10d37 initial
dwinter
parents:
diff changeset
692 public function addDocuments($documents, $overwrite = NULL, $commitWithin = NULL) {
015d06b10d37 initial
dwinter
parents:
diff changeset
693 $attr = '';
015d06b10d37 initial
dwinter
parents:
diff changeset
694
015d06b10d37 initial
dwinter
parents:
diff changeset
695 if (isset($overwrite)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
696 $attr .= ' overwrite="' . empty($overwrite) ? 'false"' : 'true"';
015d06b10d37 initial
dwinter
parents:
diff changeset
697 }
015d06b10d37 initial
dwinter
parents:
diff changeset
698 if (isset($commitWithin)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
699 $attr .= ' commitWithin="' . intval($commitWithin) . '"';
015d06b10d37 initial
dwinter
parents:
diff changeset
700 }
015d06b10d37 initial
dwinter
parents:
diff changeset
701
015d06b10d37 initial
dwinter
parents:
diff changeset
702 $rawPost = "<add{$attr}>";
015d06b10d37 initial
dwinter
parents:
diff changeset
703 foreach ($documents as $document) {
015d06b10d37 initial
dwinter
parents:
diff changeset
704 if (is_object($document) && ($document instanceof solrsearchDocument)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
705 $rawPost .= solrsearchDocument::documentToXml($document);
015d06b10d37 initial
dwinter
parents:
diff changeset
706 }
015d06b10d37 initial
dwinter
parents:
diff changeset
707 }
015d06b10d37 initial
dwinter
parents:
diff changeset
708 $rawPost .= '</add>';
015d06b10d37 initial
dwinter
parents:
diff changeset
709
015d06b10d37 initial
dwinter
parents:
diff changeset
710 return $this->update($rawPost);
015d06b10d37 initial
dwinter
parents:
diff changeset
711 }
015d06b10d37 initial
dwinter
parents:
diff changeset
712
015d06b10d37 initial
dwinter
parents:
diff changeset
713 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
714 * Send a commit command. Will be synchronous unless both wait parameters are set to false.
015d06b10d37 initial
dwinter
parents:
diff changeset
715 *
015d06b10d37 initial
dwinter
parents:
diff changeset
716 * @param boolean $optimize Defaults to true
015d06b10d37 initial
dwinter
parents:
diff changeset
717 * optimizes the index files. Only valid for solr versions <= 3
015d06b10d37 initial
dwinter
parents:
diff changeset
718 * @param boolean $waitFlush
015d06b10d37 initial
dwinter
parents:
diff changeset
719 * block until index changes are flushed to disk. Only valid for solr versions <= 3
015d06b10d37 initial
dwinter
parents:
diff changeset
720 * @param boolean $waitSearcher
015d06b10d37 initial
dwinter
parents:
diff changeset
721 * block until a new searcher is opened and registered as the main query searcher, making the changes visible.
015d06b10d37 initial
dwinter
parents:
diff changeset
722 * @param float $timeout
015d06b10d37 initial
dwinter
parents:
diff changeset
723 * Maximum expected duration of the commit operation on the server (otherwise, will throw a communication exception)
015d06b10d37 initial
dwinter
parents:
diff changeset
724 *
015d06b10d37 initial
dwinter
parents:
diff changeset
725 * @return response object
015d06b10d37 initial
dwinter
parents:
diff changeset
726 *
015d06b10d37 initial
dwinter
parents:
diff changeset
727 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
728 */
015d06b10d37 initial
dwinter
parents:
diff changeset
729 public function commit($optimize = TRUE, $waitFlush = TRUE, $waitSearcher = TRUE, $timeout = 3600) {
015d06b10d37 initial
dwinter
parents:
diff changeset
730 $optimizeValue = $optimize ? 'true' : 'false';
015d06b10d37 initial
dwinter
parents:
diff changeset
731 $flushValue = $waitFlush ? 'true' : 'false';
015d06b10d37 initial
dwinter
parents:
diff changeset
732 $searcherValue = $waitSearcher ? 'true' : 'false';
015d06b10d37 initial
dwinter
parents:
diff changeset
733 $softCommit = $this->soft_commit ? 'true' : 'false';
015d06b10d37 initial
dwinter
parents:
diff changeset
734
015d06b10d37 initial
dwinter
parents:
diff changeset
735 $solr_version = $this->getSolrVersion();
015d06b10d37 initial
dwinter
parents:
diff changeset
736 if ($solr_version <= 3) {
015d06b10d37 initial
dwinter
parents:
diff changeset
737 $rawPost = '<commit waitSearcher="' . $searcherValue . '" waitFlush="' . $flushValue . '" optimize="' . $optimizeValue . '" />';
015d06b10d37 initial
dwinter
parents:
diff changeset
738 }
015d06b10d37 initial
dwinter
parents:
diff changeset
739 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
740 $rawPost = '<commit waitSearcher="' . $searcherValue . '" softCommit="' . $softCommit . '" />';
015d06b10d37 initial
dwinter
parents:
diff changeset
741 }
015d06b10d37 initial
dwinter
parents:
diff changeset
742
015d06b10d37 initial
dwinter
parents:
diff changeset
743 $response = $this->update($rawPost, $timeout);
015d06b10d37 initial
dwinter
parents:
diff changeset
744 $this->_clearCache();
015d06b10d37 initial
dwinter
parents:
diff changeset
745 return $response;
015d06b10d37 initial
dwinter
parents:
diff changeset
746 }
015d06b10d37 initial
dwinter
parents:
diff changeset
747
015d06b10d37 initial
dwinter
parents:
diff changeset
748 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
749 * Create a delete document based on document ID
015d06b10d37 initial
dwinter
parents:
diff changeset
750 *
015d06b10d37 initial
dwinter
parents:
diff changeset
751 * @param string $id Expected to be utf-8 encoded
015d06b10d37 initial
dwinter
parents:
diff changeset
752 * @param float $timeout Maximum expected duration of the delete operation on the server (otherwise, will throw a communication exception)
015d06b10d37 initial
dwinter
parents:
diff changeset
753 *
015d06b10d37 initial
dwinter
parents:
diff changeset
754 * @return response object
015d06b10d37 initial
dwinter
parents:
diff changeset
755 *
015d06b10d37 initial
dwinter
parents:
diff changeset
756 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
757 */
015d06b10d37 initial
dwinter
parents:
diff changeset
758 public function deleteById($id, $timeout = 3600) {
015d06b10d37 initial
dwinter
parents:
diff changeset
759 return $this->deleteByMultipleIds(array($id), $timeout);
015d06b10d37 initial
dwinter
parents:
diff changeset
760 }
015d06b10d37 initial
dwinter
parents:
diff changeset
761
015d06b10d37 initial
dwinter
parents:
diff changeset
762 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
763 * Create and post a delete document based on multiple document IDs.
015d06b10d37 initial
dwinter
parents:
diff changeset
764 *
015d06b10d37 initial
dwinter
parents:
diff changeset
765 * @param array $ids Expected to be utf-8 encoded strings
015d06b10d37 initial
dwinter
parents:
diff changeset
766 * @param float $timeout Maximum expected duration of the delete operation on the server (otherwise, will throw a communication exception)
015d06b10d37 initial
dwinter
parents:
diff changeset
767 *
015d06b10d37 initial
dwinter
parents:
diff changeset
768 * @return response object
015d06b10d37 initial
dwinter
parents:
diff changeset
769 *
015d06b10d37 initial
dwinter
parents:
diff changeset
770 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
771 */
015d06b10d37 initial
dwinter
parents:
diff changeset
772 public function deleteByMultipleIds($ids, $timeout = 3600) {
015d06b10d37 initial
dwinter
parents:
diff changeset
773 $rawPost = '<delete>';
015d06b10d37 initial
dwinter
parents:
diff changeset
774
015d06b10d37 initial
dwinter
parents:
diff changeset
775 foreach ($ids as $id) {
015d06b10d37 initial
dwinter
parents:
diff changeset
776 $rawPost .= '<id>' . htmlspecialchars($id, ENT_NOQUOTES, 'UTF-8') . '</id>';
015d06b10d37 initial
dwinter
parents:
diff changeset
777 }
015d06b10d37 initial
dwinter
parents:
diff changeset
778 $rawPost .= '</delete>';
015d06b10d37 initial
dwinter
parents:
diff changeset
779
015d06b10d37 initial
dwinter
parents:
diff changeset
780 return $this->update($rawPost, $timeout);
015d06b10d37 initial
dwinter
parents:
diff changeset
781 }
015d06b10d37 initial
dwinter
parents:
diff changeset
782
015d06b10d37 initial
dwinter
parents:
diff changeset
783 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
784 * Create a delete document based on a query and submit it
015d06b10d37 initial
dwinter
parents:
diff changeset
785 *
015d06b10d37 initial
dwinter
parents:
diff changeset
786 * @param string $rawQuery Expected to be utf-8 encoded
015d06b10d37 initial
dwinter
parents:
diff changeset
787 * @param float $timeout Maximum expected duration of the delete operation on the server (otherwise, will throw a communication exception)
015d06b10d37 initial
dwinter
parents:
diff changeset
788 * @return stdClass response object
015d06b10d37 initial
dwinter
parents:
diff changeset
789 *
015d06b10d37 initial
dwinter
parents:
diff changeset
790 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
791 */
015d06b10d37 initial
dwinter
parents:
diff changeset
792 public function deleteByQuery($rawQuery, $timeout = 3600) {
015d06b10d37 initial
dwinter
parents:
diff changeset
793 $rawPost = '<delete><query>' . htmlspecialchars($rawQuery, ENT_NOQUOTES, 'UTF-8') . '</query></delete>';
015d06b10d37 initial
dwinter
parents:
diff changeset
794
015d06b10d37 initial
dwinter
parents:
diff changeset
795 return $this->update($rawPost, $timeout);
015d06b10d37 initial
dwinter
parents:
diff changeset
796 }
015d06b10d37 initial
dwinter
parents:
diff changeset
797
015d06b10d37 initial
dwinter
parents:
diff changeset
798 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
799 * Send an optimize command. Will be synchronous unless both wait parameters are set
015d06b10d37 initial
dwinter
parents:
diff changeset
800 * to false.
015d06b10d37 initial
dwinter
parents:
diff changeset
801 *
015d06b10d37 initial
dwinter
parents:
diff changeset
802 * @param boolean $waitFlush
015d06b10d37 initial
dwinter
parents:
diff changeset
803 * block until index changes are flushed to disk Removed in Solr 4.0
015d06b10d37 initial
dwinter
parents:
diff changeset
804 * @param boolean $waitSearcher
015d06b10d37 initial
dwinter
parents:
diff changeset
805 * block until a new searcher is opened and registered as the main query searcher, making the changes visible.
015d06b10d37 initial
dwinter
parents:
diff changeset
806 * @param float $timeout
015d06b10d37 initial
dwinter
parents:
diff changeset
807 * Maximum expected duration of the commit operation on the server (otherwise, will throw a communication exception)
015d06b10d37 initial
dwinter
parents:
diff changeset
808 *
015d06b10d37 initial
dwinter
parents:
diff changeset
809 * @return response object
015d06b10d37 initial
dwinter
parents:
diff changeset
810 *
015d06b10d37 initial
dwinter
parents:
diff changeset
811 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
812 */
015d06b10d37 initial
dwinter
parents:
diff changeset
813 public function optimize($waitFlush = TRUE, $waitSearcher = TRUE, $timeout = 3600) {
015d06b10d37 initial
dwinter
parents:
diff changeset
814 $flushValue = $waitFlush ? 'true' : 'false';
015d06b10d37 initial
dwinter
parents:
diff changeset
815 $searcherValue = $waitSearcher ? 'true' : 'false';
015d06b10d37 initial
dwinter
parents:
diff changeset
816 $softCommit = $this->soft_commit ? 'true' : 'false';
015d06b10d37 initial
dwinter
parents:
diff changeset
817
015d06b10d37 initial
dwinter
parents:
diff changeset
818 $solr_version = $this->getSolrVersion();
015d06b10d37 initial
dwinter
parents:
diff changeset
819 if ($solr_version <= 3) {
015d06b10d37 initial
dwinter
parents:
diff changeset
820 $rawPost = '<optimize waitSearcher="' . $searcherValue . '" waitFlush="' . $flushValue . '" />';
015d06b10d37 initial
dwinter
parents:
diff changeset
821 }
015d06b10d37 initial
dwinter
parents:
diff changeset
822 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
823 $rawPost = '<optimize waitSearcher="' . $searcherValue . '" softCommit="' . $softCommit . '" />';
015d06b10d37 initial
dwinter
parents:
diff changeset
824 }
015d06b10d37 initial
dwinter
parents:
diff changeset
825
015d06b10d37 initial
dwinter
parents:
diff changeset
826 return $this->update($rawPost, $timeout);
015d06b10d37 initial
dwinter
parents:
diff changeset
827 }
015d06b10d37 initial
dwinter
parents:
diff changeset
828
015d06b10d37 initial
dwinter
parents:
diff changeset
829 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
830 * Like PHP's built in http_build_query(), but uses rawurlencode() and no [] for repeated params.
015d06b10d37 initial
dwinter
parents:
diff changeset
831 */
015d06b10d37 initial
dwinter
parents:
diff changeset
832 protected function httpBuildQuery(array $query, $parent = '') {
015d06b10d37 initial
dwinter
parents:
diff changeset
833 $params = array();
015d06b10d37 initial
dwinter
parents:
diff changeset
834
015d06b10d37 initial
dwinter
parents:
diff changeset
835 foreach ($query as $key => $value) {
015d06b10d37 initial
dwinter
parents:
diff changeset
836 $key = ($parent ? $parent : rawurlencode($key));
015d06b10d37 initial
dwinter
parents:
diff changeset
837
015d06b10d37 initial
dwinter
parents:
diff changeset
838 // Recurse into children.
015d06b10d37 initial
dwinter
parents:
diff changeset
839 if (is_array($value)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
840 $params[] = $this->httpBuildQuery($value, $key);
015d06b10d37 initial
dwinter
parents:
diff changeset
841 }
015d06b10d37 initial
dwinter
parents:
diff changeset
842 // If a query parameter value is NULL, only append its key.
015d06b10d37 initial
dwinter
parents:
diff changeset
843 elseif (!isset($value)) {
015d06b10d37 initial
dwinter
parents:
diff changeset
844 $params[] = $key;
015d06b10d37 initial
dwinter
parents:
diff changeset
845 }
015d06b10d37 initial
dwinter
parents:
diff changeset
846 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
847 $params[] = $key . '=' . rawurlencode($value);
015d06b10d37 initial
dwinter
parents:
diff changeset
848 }
015d06b10d37 initial
dwinter
parents:
diff changeset
849 }
015d06b10d37 initial
dwinter
parents:
diff changeset
850
015d06b10d37 initial
dwinter
parents:
diff changeset
851 return implode('&', $params);
015d06b10d37 initial
dwinter
parents:
diff changeset
852 }
015d06b10d37 initial
dwinter
parents:
diff changeset
853
015d06b10d37 initial
dwinter
parents:
diff changeset
854 /**
015d06b10d37 initial
dwinter
parents:
diff changeset
855 * Simple Search interface
015d06b10d37 initial
dwinter
parents:
diff changeset
856 *
015d06b10d37 initial
dwinter
parents:
diff changeset
857 * @param string $query The raw query string
015d06b10d37 initial
dwinter
parents:
diff changeset
858 * @param array $params key / value pairs for other query parameters (see Solr documentation), use arrays for parameter keys used more than once (e.g. facet.field)
015d06b10d37 initial
dwinter
parents:
diff changeset
859 *
015d06b10d37 initial
dwinter
parents:
diff changeset
860 * @return response object
015d06b10d37 initial
dwinter
parents:
diff changeset
861 *
015d06b10d37 initial
dwinter
parents:
diff changeset
862 * @throws Exception If an error occurs during the service call
015d06b10d37 initial
dwinter
parents:
diff changeset
863 */
015d06b10d37 initial
dwinter
parents:
diff changeset
864 public function search($query = '', array $params = array(), $method = 'GET') {
015d06b10d37 initial
dwinter
parents:
diff changeset
865 // Always use JSON. See http://code.google.com/p/solr-php-client/issues/detail?id=6#c1 for reasoning
015d06b10d37 initial
dwinter
parents:
diff changeset
866
015d06b10d37 initial
dwinter
parents:
diff changeset
867
015d06b10d37 initial
dwinter
parents:
diff changeset
868
015d06b10d37 initial
dwinter
parents:
diff changeset
869 if (!user_access("view restricted content")){
015d06b10d37 initial
dwinter
parents:
diff changeset
870 $params['fq'][]='access-type:free';
015d06b10d37 initial
dwinter
parents:
diff changeset
871
015d06b10d37 initial
dwinter
parents:
diff changeset
872
015d06b10d37 initial
dwinter
parents:
diff changeset
873 }
015d06b10d37 initial
dwinter
parents:
diff changeset
874
015d06b10d37 initial
dwinter
parents:
diff changeset
875 $params['wt'] = 'json';
015d06b10d37 initial
dwinter
parents:
diff changeset
876 // Additional default params.
015d06b10d37 initial
dwinter
parents:
diff changeset
877 $params += array(
015d06b10d37 initial
dwinter
parents:
diff changeset
878 'json.nl' => self::NAMED_LIST_FORMAT,
015d06b10d37 initial
dwinter
parents:
diff changeset
879 );
015d06b10d37 initial
dwinter
parents:
diff changeset
880 if ($query) {
015d06b10d37 initial
dwinter
parents:
diff changeset
881 $params['q'] = $query;
015d06b10d37 initial
dwinter
parents:
diff changeset
882 }
015d06b10d37 initial
dwinter
parents:
diff changeset
883 // PHP's built in http_build_query() doesn't give us the format Solr wants.
015d06b10d37 initial
dwinter
parents:
diff changeset
884 $queryString = $this->httpBuildQuery($params);
015d06b10d37 initial
dwinter
parents:
diff changeset
885 // Check string length of the query string, change method to POST
015d06b10d37 initial
dwinter
parents:
diff changeset
886 $len = strlen($queryString);
015d06b10d37 initial
dwinter
parents:
diff changeset
887 // Fetch our threshold to find out when to flip to POST
015d06b10d37 initial
dwinter
parents:
diff changeset
888 $max_len = solrsearch_environment_variable_get($this->env_id, 'solrsearch_search_post_threshold', 3600);
015d06b10d37 initial
dwinter
parents:
diff changeset
889
015d06b10d37 initial
dwinter
parents:
diff changeset
890 // if longer than $max_len (default 3600) characters
015d06b10d37 initial
dwinter
parents:
diff changeset
891 // we should switch to POST (a typical server handles 4096 max).
015d06b10d37 initial
dwinter
parents:
diff changeset
892 // If this class is used independently (without environments), we switch automatically to POST at an
015d06b10d37 initial
dwinter
parents:
diff changeset
893 // limit of 1800 chars.
015d06b10d37 initial
dwinter
parents:
diff changeset
894 if (($len > 1800) && (empty($this->env_id) || ($len > $max_len))) {
015d06b10d37 initial
dwinter
parents:
diff changeset
895 $method = 'POST';
015d06b10d37 initial
dwinter
parents:
diff changeset
896 }
015d06b10d37 initial
dwinter
parents:
diff changeset
897
015d06b10d37 initial
dwinter
parents:
diff changeset
898 if ($method == 'GET') {
015d06b10d37 initial
dwinter
parents:
diff changeset
899 $searchUrl = $this->_constructUrl(self::SEARCH_SERVLET, array(), $queryString);
015d06b10d37 initial
dwinter
parents:
diff changeset
900
015d06b10d37 initial
dwinter
parents:
diff changeset
901 return $this->_sendRawGet($searchUrl);
015d06b10d37 initial
dwinter
parents:
diff changeset
902 }
015d06b10d37 initial
dwinter
parents:
diff changeset
903 else if ($method == 'POST') {
015d06b10d37 initial
dwinter
parents:
diff changeset
904 $searchUrl = $this->_constructUrl(self::SEARCH_SERVLET);
015d06b10d37 initial
dwinter
parents:
diff changeset
905 $options['data'] = $queryString;
015d06b10d37 initial
dwinter
parents:
diff changeset
906 $options['headers']['Content-Type'] = 'application/x-www-form-urlencoded; charset=UTF-8';
015d06b10d37 initial
dwinter
parents:
diff changeset
907 return $this->_sendRawPost($searchUrl, $options);
015d06b10d37 initial
dwinter
parents:
diff changeset
908 }
015d06b10d37 initial
dwinter
parents:
diff changeset
909 else {
015d06b10d37 initial
dwinter
parents:
diff changeset
910 throw new Exception("Unsupported method '$method' for search(), use GET or POST");
015d06b10d37 initial
dwinter
parents:
diff changeset
911 }
015d06b10d37 initial
dwinter
parents:
diff changeset
912 }
015d06b10d37 initial
dwinter
parents:
diff changeset
913 }