BUG 0000 herbert> SOLR implementation in PMOS2
Solr support in PMOS2 includes:
Functionality:
- Implementation of Home views (Inbox, Draft, Participated, Unassigned). The views return fast results.
- Include read, unread, all, and process filter in inbox View.
- Include process filter in draft view.
- Include started by me, completed by me, all, process, and status filter in participated view.
- Include process filter in unassigned view.
- Improved search functionality (search in user defined variables): Use the following syntax to search in process (user defined) variables. {variable_name}:{search_word} ex1:"causal:20*" where causal is the variable defined by the user.
+ Use of wildcards in search: Use * as wildcard at the begin or end of word
+ Multiple conditions in search: Separate multiple conditions by space ex2:"Materiales causal:20*" means that we are searching for the word Materiales and the causal that begin with 20.
+ Search in dates (interval ): Format=> {variable_date}:[yyyy-mm-dd TO yyyy-mm-dd]
Local date not UTC date required
ex: FechaRegistro:[2011-04-15 TO 2011-04-30] //registros con fecha entre el 2011-04-15 y el 2011-04-30.
+ we can use the wildcard *:
ex: FechaRegistro:[* TO 2011-04-30] //registros con fecha menor o igual a 2011-04-30.
FechaRegistro:[2011-04-15 TO *] //registros con fecha mayor o igual a 2011-04-15.
+ Search of exact phrases. format: {variable}:"frase a buscar"
ex: Cliente:"Jesus Marin"
- Application update function.
+ The function is called every time a change is detected in the application's data including the related delegations.
- Use of cache to improve performance
Not included:
- Order of task, sent by, and due date columns.
Pending:
- Advanced search view using faceted lists.
2012-05-15 10:56:48 -04:00
|
|
|
<?php
|
2013-03-14 14:50:58 -04:00
|
|
|
|
2012-05-30 17:47:28 -04:00
|
|
|
/**
|
|
|
|
|
* ProcessMaker Open Source Edition
|
|
|
|
|
* Copyright (C) 2004 - 2012 Colosa Inc.23
|
|
|
|
|
*
|
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*
|
|
|
|
|
* For more information, contact Colosa Inc, 5304 Ventura Drive,
|
|
|
|
|
* Delray Beach, FL, 33484, USA, or email info@colosa.com.
|
|
|
|
|
*/
|
|
|
|
|
|
2012-05-29 17:07:53 -04:00
|
|
|
/**
|
2012-09-19 14:48:38 -04:00
|
|
|
* Interface to the Solr Search server
|
2012-10-09 13:23:16 -04:00
|
|
|
*
|
2012-05-29 17:07:53 -04:00
|
|
|
* @author Herbert Saal Gutierrez
|
|
|
|
|
*
|
|
|
|
|
*/
|
2012-05-30 17:47:28 -04:00
|
|
|
class BpmnEngine_SearchIndexAccess_Solr
|
|
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
const SOLR_VERSION = '&version=2.2';
|
2013-03-14 14:50:58 -04:00
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
private $_solrIsEnabled = false;
|
|
|
|
|
private $_solrHost = "";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
public function __construct($solrIsEnabled = false, $solrHost = "")
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
|
|
|
|
// use the parameters to initialize class
|
|
|
|
|
$this->_solrIsEnabled = $solrIsEnabled;
|
|
|
|
|
$this->_solrHost = $solrHost;
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Verify if the Solr service is available
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2013-01-25 17:13:52 -04:00
|
|
|
public function isEnabled($workspace)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-01-25 17:13:52 -04:00
|
|
|
$resultServerStatus = false;
|
2012-09-19 14:48:38 -04:00
|
|
|
|
2013-01-25 17:13:52 -04:00
|
|
|
if ($this->_solrIsEnabled != true) {
|
|
|
|
|
return $resultServerStatus;
|
|
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
|
2013-01-25 17:13:52 -04:00
|
|
|
//Verify solr server response
|
2013-03-14 14:50:58 -04:00
|
|
|
try {
|
2013-01-25 17:13:52 -04:00
|
|
|
$resultServerStatus = $this->ping($workspace);
|
|
|
|
|
} catch (Exception $e) {
|
|
|
|
|
$resultServerStatus = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $resultServerStatus;
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Returns the total number of indexed documents
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @param workspace: workspace name
|
|
|
|
|
* @return total
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function getNumberDocuments($workspace)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2012-10-09 13:23:16 -04:00
|
|
|
// get total number of documents in registry
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/select/?q=*:*";
|
|
|
|
|
$solrIntruct .= self::SOLR_VERSION;
|
|
|
|
|
$solrIntruct .= "&start=0&rows=0&echoParams=none&wt=json";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handlerTotal = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handlerTotal, CURLOPT_RETURNTRANSFER, true);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handlerTotal, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handlerTotal, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handlerTotal, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handlerTotal, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$responseTotal = curl_exec($handlerTotal);
|
|
|
|
|
curl_close($handlerTotal);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
// verify the result of solr
|
2013-03-14 14:50:58 -04:00
|
|
|
$responseSolrTotal = G::json_decode($responseTotal);
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($responseSolrTotal->responseHeader->status != 0) {
|
2013-03-14 14:50:58 -04:00
|
|
|
throw new Exception("Error returning the total number of documents in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
$numTotalDocs = $responseSolrTotal->response->numFound;
|
|
|
|
|
return $numTotalDocs;
|
BUG 0000 herbert> SOLR implementation in PMOS2
Solr support in PMOS2 includes:
Functionality:
- Implementation of Home views (Inbox, Draft, Participated, Unassigned). The views return fast results.
- Include read, unread, all, and process filter in inbox View.
- Include process filter in draft view.
- Include started by me, completed by me, all, process, and status filter in participated view.
- Include process filter in unassigned view.
- Improved search functionality (search in user defined variables): Use the following syntax to search in process (user defined) variables. {variable_name}:{search_word} ex1:"causal:20*" where causal is the variable defined by the user.
+ Use of wildcards in search: Use * as wildcard at the begin or end of word
+ Multiple conditions in search: Separate multiple conditions by space ex2:"Materiales causal:20*" means that we are searching for the word Materiales and the causal that begin with 20.
+ Search in dates (interval ): Format=> {variable_date}:[yyyy-mm-dd TO yyyy-mm-dd]
Local date not UTC date required
ex: FechaRegistro:[2011-04-15 TO 2011-04-30] //registros con fecha entre el 2011-04-15 y el 2011-04-30.
+ we can use the wildcard *:
ex: FechaRegistro:[* TO 2011-04-30] //registros con fecha menor o igual a 2011-04-30.
FechaRegistro:[2011-04-15 TO *] //registros con fecha mayor o igual a 2011-04-15.
+ Search of exact phrases. format: {variable}:"frase a buscar"
ex: Cliente:"Jesus Marin"
- Application update function.
+ The function is called every time a change is detected in the application's data including the related delegations.
- Use of cache to improve performance
Not included:
- Order of task, sent by, and due date columns.
Pending:
- Advanced search view using faceted lists.
2012-05-15 10:56:48 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Execute a query in base to Requested data
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return solr response
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function executeQuery($solrRequestData)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
|
|
|
|
$workspace = $solrRequestData->workspace;
|
|
|
|
|
|
|
|
|
|
// format request
|
2013-03-14 14:50:58 -04:00
|
|
|
$query = empty($solrRequestData->searchText) ? '*:*' : $solrRequestData->searchText;
|
|
|
|
|
$query = rawurlencode($query);
|
2012-10-09 13:23:16 -04:00
|
|
|
$start = '&start=' . $solrRequestData->startAfter;
|
|
|
|
|
$rows = '&rows=' . $solrRequestData->pageSize;
|
|
|
|
|
$fieldList = '';
|
|
|
|
|
$cols = $solrRequestData->includeCols;
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!empty($cols)) {
|
|
|
|
|
$fieldList = "&fl=" . implode(",", $cols);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
$sort = '';
|
|
|
|
|
if ($solrRequestData->numSortingCols > 0) {
|
|
|
|
|
$sort = '&sort=';
|
2013-03-14 14:50:58 -04:00
|
|
|
for ($i = 0; $i < $solrRequestData->numSortingCols; $i++) {
|
2012-10-09 13:23:16 -04:00
|
|
|
$sort .= $solrRequestData->sortCols[$i] . "%20" . $solrRequestData->sortDir[$i] . ",";
|
|
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$sort = substr_replace($sort, "", - 1);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
$resultFormat = empty($solrRequestData->resultFormat) ? '' : '&wt=' . $solrRequestData->resultFormat;
|
2012-10-09 13:23:16 -04:00
|
|
|
$filters = '';
|
2013-03-14 14:50:58 -04:00
|
|
|
$aFilters = explode(',', $solrRequestData->filterText);
|
2012-10-09 13:23:16 -04:00
|
|
|
foreach ($aFilters as $value) {
|
2013-03-14 14:50:58 -04:00
|
|
|
$filters .= '&fq=' . urlencode($value);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/select/?q=$query";
|
|
|
|
|
$solrIntruct .= "&echoParams=none";
|
|
|
|
|
$solrIntruct .= self::SOLR_VERSION;
|
|
|
|
|
$solrIntruct .= $start;
|
|
|
|
|
$solrIntruct .= $rows;
|
|
|
|
|
$solrIntruct .= $fieldList;
|
|
|
|
|
$solrIntruct .= $sort;
|
|
|
|
|
$solrIntruct .= $filters;
|
|
|
|
|
$solrIntruct .= $resultFormat;
|
|
|
|
|
// send query
|
|
|
|
|
// search the cases in base to datatable parameters
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
// decode
|
2013-03-14 14:50:58 -04:00
|
|
|
$responseSolr = G::json_decode($response);
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($responseSolr->responseHeader->status != 0) {
|
2013-03-14 14:50:58 -04:00
|
|
|
throw new Exception("Error executing query to Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $responseSolr;
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Insert or Update document index
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return solr response
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function updateDocument($solrUpdateDocument)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $solrUpdateDocument->workspace;
|
|
|
|
|
$solrIntruct .= "/update";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Content-type:application/xml'
|
|
|
|
|
)); // -H
|
|
|
|
|
curl_setopt($handler, CURLOPT_BINARYTRANSFER, true); // --data-binary
|
|
|
|
|
curl_setopt($handler, CURLOPT_POSTFIELDS, $solrUpdateDocument->document); // data
|
2012-10-09 13:23:16 -04:00
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$swOk = strpos($response, '<int name="status">0</int>');
|
|
|
|
|
if (!$swOk) {
|
|
|
|
|
throw new Exception("Error updating document in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Commit the changes since the last commit
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return solr response
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function commitChanges($workspace)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/update";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Content-type:application/xml')); // -H
|
|
|
|
|
curl_setopt($handler, CURLOPT_BINARYTRANSFER, true); // --data-binary
|
|
|
|
|
curl_setopt($handler, CURLOPT_POSTFIELDS, "<commit/>"); // data
|
2012-10-09 13:23:16 -04:00
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$swOk = strpos($response, '<int name="status">0</int>');
|
|
|
|
|
if (!$swOk) {
|
|
|
|
|
throw new Exception("Error commiting changes in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Rollback the changes since the last commit
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return solr response
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function rollbackChanges($workspace)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/update";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Content-type:application/xml')); // -H
|
|
|
|
|
curl_setopt($handler, CURLOPT_BINARYTRANSFER, true); // --data-binary
|
|
|
|
|
curl_setopt($handler, CURLOPT_POSTFIELDS, "<rollback/>"); // data
|
2012-10-09 13:23:16 -04:00
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$swOk = strpos($response, '<int name="status">0</int>');
|
|
|
|
|
if (!$swOk) {
|
|
|
|
|
throw new Exception("Error rolling back changes in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Optimize Solr index
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return solr response
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function optimizeChanges($workspace)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/update";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Content-type:application/xml')); // -H
|
|
|
|
|
curl_setopt($handler, CURLOPT_BINARYTRANSFER, true); // --data-binary
|
|
|
|
|
curl_setopt($handler, CURLOPT_POSTFIELDS, "<optimize/>"); // data
|
2012-10-09 13:23:16 -04:00
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$swOk = strpos($response, '<int name="status">0</int>');
|
|
|
|
|
if (!$swOk) {
|
|
|
|
|
throw new Exception("Error optimizing changes in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Return the list of the stored fields in Solr
|
|
|
|
|
*
|
|
|
|
|
* @param string $workspace Solr instance name
|
|
|
|
|
* @throws Exception
|
|
|
|
|
* @return void mixed of field names
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function getListIndexedStoredFields($workspace)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/admin/luke?numTerms=0&wt=json";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
// decode
|
2013-03-14 14:50:58 -04:00
|
|
|
$responseSolr = G::json_decode($response);
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($responseSolr->responseHeader->status != 0) {
|
2013-03-14 14:50:58 -04:00
|
|
|
throw new Exception("Error getting index fields in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
return $responseSolr;
|
BUG 0000 herbert> SOLR implementation in PMOS2
Solr support in PMOS2 includes:
Functionality:
- Implementation of Home views (Inbox, Draft, Participated, Unassigned). The views return fast results.
- Include read, unread, all, and process filter in inbox View.
- Include process filter in draft view.
- Include started by me, completed by me, all, process, and status filter in participated view.
- Include process filter in unassigned view.
- Improved search functionality (search in user defined variables): Use the following syntax to search in process (user defined) variables. {variable_name}:{search_word} ex1:"causal:20*" where causal is the variable defined by the user.
+ Use of wildcards in search: Use * as wildcard at the begin or end of word
+ Multiple conditions in search: Separate multiple conditions by space ex2:"Materiales causal:20*" means that we are searching for the word Materiales and the causal that begin with 20.
+ Search in dates (interval ): Format=> {variable_date}:[yyyy-mm-dd TO yyyy-mm-dd]
Local date not UTC date required
ex: FechaRegistro:[2011-04-15 TO 2011-04-30] //registros con fecha entre el 2011-04-15 y el 2011-04-30.
+ we can use the wildcard *:
ex: FechaRegistro:[* TO 2011-04-30] //registros con fecha menor o igual a 2011-04-30.
FechaRegistro:[2011-04-15 TO *] //registros con fecha mayor o igual a 2011-04-15.
+ Search of exact phrases. format: {variable}:"frase a buscar"
ex: Cliente:"Jesus Marin"
- Application update function.
+ The function is called every time a change is detected in the application's data including the related delegations.
- Use of cache to improve performance
Not included:
- Order of task, sent by, and due date columns.
Pending:
- Advanced search view using faceted lists.
2012-05-15 10:56:48 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
|
2013-01-25 17:13:52 -04:00
|
|
|
/**
|
|
|
|
|
* Ping the Solr Server to check his health
|
|
|
|
|
*
|
|
|
|
|
* @param string $workspace
|
|
|
|
|
* Solr instance name
|
|
|
|
|
* @throws Exception
|
|
|
|
|
* @return void mixed of field names
|
|
|
|
|
*/
|
|
|
|
|
public function ping($workspace)
|
|
|
|
|
{
|
|
|
|
|
if (!$this->_solrIsEnabled) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$solrIntruct = "";
|
|
|
|
|
|
|
|
|
|
//Get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, -1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2013-01-25 17:13:52 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/admin/ping?wt=json";
|
|
|
|
|
|
|
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
|
|
|
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
|
|
|
|
|
if ($sysConf["proxy_host"] != "") {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf["proxy_host"] . (($sysConf["proxy_port"] != "") ? ":" . $sysConf["proxy_port"] : ""));
|
2013-01-25 17:13:52 -04:00
|
|
|
|
|
|
|
|
if ($sysConf["proxy_port"] != "") {
|
|
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf["proxy_port"]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($sysConf["proxy_user"] != "") {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf["proxy_user"] . (($sysConf["proxy_pass"] != "") ? ":" . $sysConf["proxy_pass"] : ""));
|
2013-01-25 17:13:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array("Expect:"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
|
|
|
|
|
|
|
|
|
//There's no response
|
|
|
|
|
if (!$response) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//Decode
|
2013-03-14 14:50:58 -04:00
|
|
|
$responseSolr = G::json_decode($response);
|
2013-01-25 17:13:52 -04:00
|
|
|
|
|
|
|
|
if ($responseSolr->responseHeader->status != "OK") {
|
|
|
|
|
throw new Exception("Error pinging Solr server." . $solrIntruct . " response error: " . $response . "\n");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Delete all documents from index
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return solr response
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function deleteAllDocuments($workspace)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
|
|
|
|
// $registry = Zend_Registry::getInstance();
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/update";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Content-type:application/xml')); // -H
|
|
|
|
|
curl_setopt($handler, CURLOPT_BINARYTRANSFER, true); // --data-binary
|
|
|
|
|
curl_setopt($handler, CURLOPT_POSTFIELDS, "<delete><query>*:*</query></delete>"); // data
|
2012-10-09 13:23:16 -04:00
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$swOk = strpos($response, '<int name="status">0</int>');
|
|
|
|
|
if (!$swOk) {
|
|
|
|
|
throw new Exception("Error deleting all documents in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
}
|
|
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Delete specified documents from index
|
|
|
|
|
* @gearman = false
|
|
|
|
|
* @rest = false
|
|
|
|
|
* @background = false
|
|
|
|
|
*
|
|
|
|
|
* @return solr response
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function deleteDocument($workspace, $idQuery)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
|
|
|
|
// $registry = Zend_Registry::getInstance();
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/update";
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
|
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Content-type:application/xml')); // -H
|
|
|
|
|
curl_setopt($handler, CURLOPT_BINARYTRANSFER, true); // --data-binary
|
|
|
|
|
curl_setopt($handler, CURLOPT_POSTFIELDS, "<delete><query>" . $idQuery . "</query></delete>"); // data
|
2012-10-09 13:23:16 -04:00
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$swOk = strpos($response, '<int name="status">0</int>');
|
|
|
|
|
if (!$swOk) {
|
|
|
|
|
throw new Exception("Error deleting document in Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
BUG 0000 herbert> SOLR implementation in PMOS2
Solr support in PMOS2 includes:
Functionality:
- Implementation of Home views (Inbox, Draft, Participated, Unassigned). The views return fast results.
- Include read, unread, all, and process filter in inbox View.
- Include process filter in draft view.
- Include started by me, completed by me, all, process, and status filter in participated view.
- Include process filter in unassigned view.
- Improved search functionality (search in user defined variables): Use the following syntax to search in process (user defined) variables. {variable_name}:{search_word} ex1:"causal:20*" where causal is the variable defined by the user.
+ Use of wildcards in search: Use * as wildcard at the begin or end of word
+ Multiple conditions in search: Separate multiple conditions by space ex2:"Materiales causal:20*" means that we are searching for the word Materiales and the causal that begin with 20.
+ Search in dates (interval ): Format=> {variable_date}:[yyyy-mm-dd TO yyyy-mm-dd]
Local date not UTC date required
ex: FechaRegistro:[2011-04-15 TO 2011-04-30] //registros con fecha entre el 2011-04-15 y el 2011-04-30.
+ we can use the wildcard *:
ex: FechaRegistro:[* TO 2011-04-30] //registros con fecha menor o igual a 2011-04-30.
FechaRegistro:[2011-04-15 TO *] //registros con fecha mayor o igual a 2011-04-15.
+ Search of exact phrases. format: {variable}:"frase a buscar"
ex: Cliente:"Jesus Marin"
- Application update function.
+ The function is called every time a change is detected in the application's data including the related delegations.
- Use of cache to improve performance
Not included:
- Order of task, sent by, and due date columns.
Pending:
- Advanced search view using faceted lists.
2012-05-15 10:56:48 -04:00
|
|
|
}
|
2012-09-19 14:48:38 -04:00
|
|
|
|
2012-10-09 13:23:16 -04:00
|
|
|
/**
|
|
|
|
|
* Execute a query in base to Request data
|
|
|
|
|
*
|
|
|
|
|
* @param Entity_FacetRequest $facetRequestEntity
|
|
|
|
|
* @return solr response: list of facets array
|
|
|
|
|
*/
|
2013-03-14 14:50:58 -04:00
|
|
|
public function getFacetsList($facetRequest)
|
2012-10-09 13:23:16 -04:00
|
|
|
{
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!$this->_solrIsEnabled) {
|
2012-10-09 13:23:16 -04:00
|
|
|
return;
|
2013-03-14 14:50:58 -04:00
|
|
|
}
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
$solrIntruct = '';
|
|
|
|
|
// get configuration information in base to workspace parameter
|
|
|
|
|
$workspace = $facetRequest->workspace;
|
|
|
|
|
|
|
|
|
|
// format request
|
2013-03-14 14:50:58 -04:00
|
|
|
$query = empty($facetRequest->searchText) ? '*:*' : $facetRequest->searchText;
|
|
|
|
|
$query = rawurlencode($query);
|
2012-10-09 13:23:16 -04:00
|
|
|
$start = '&start=0';
|
|
|
|
|
$rows = '&rows=0';
|
|
|
|
|
$facets = '&facet=on&facet.mincount=1&facet.limit=20'; // enable facet and
|
|
|
|
|
// only return facets
|
|
|
|
|
// with minimun one
|
|
|
|
|
// instance
|
|
|
|
|
foreach ($facetRequest->facetFields as $value) {
|
|
|
|
|
$facets .= '&facet.field=' . $value;
|
|
|
|
|
}
|
|
|
|
|
foreach ($facetRequest->facetQueries as $value) {
|
|
|
|
|
$facets .= '&facet.query=' . $value;
|
|
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
if (!empty($facetRequest->facetDates)) {
|
2012-10-09 13:23:16 -04:00
|
|
|
foreach ($facetRequest->facetDates as $value) {
|
|
|
|
|
$facets .= '&facet.date=' . $value;
|
|
|
|
|
}
|
|
|
|
|
$facets .= '&facet.date.start=' . $facetRequest->facetDatesStart;
|
|
|
|
|
$facets .= '&facet.date.end=' . $facetRequest->facetDatesEnd;
|
|
|
|
|
$facets .= '&facet.date.gap=' . $facetRequest->facetDateGap;
|
|
|
|
|
}
|
|
|
|
|
$filters = '';
|
|
|
|
|
foreach ($facetRequest->filters as $value) {
|
|
|
|
|
$filters .= '&fq=' . $value;
|
|
|
|
|
}
|
|
|
|
|
// echo "<pre>";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$resultFormat = '&wt=json';
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$solrIntruct = (substr($this->_solrHost, - 1) == "/") ? $this->_solrHost : $this->_solrHost . "/";
|
2012-10-09 13:23:16 -04:00
|
|
|
$solrIntruct .= $workspace;
|
|
|
|
|
$solrIntruct .= "/select/?q=$query";
|
|
|
|
|
$solrIntruct .= "&echoParams=none";
|
|
|
|
|
$solrIntruct .= self::SOLR_VERSION;
|
|
|
|
|
$solrIntruct .= $start;
|
|
|
|
|
$solrIntruct .= $rows;
|
|
|
|
|
$solrIntruct .= $facets;
|
|
|
|
|
$solrIntruct .= $filters;
|
|
|
|
|
$solrIntruct .= $resultFormat;
|
|
|
|
|
|
|
|
|
|
// send query
|
|
|
|
|
// search the cases in base to datatable parameters
|
2013-03-14 14:50:58 -04:00
|
|
|
$handler = curl_init($solrIntruct);
|
|
|
|
|
curl_setopt($handler, CURLOPT_RETURNTRANSFER, true);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
//Apply proxy settings
|
|
|
|
|
$sysConf = System::getSystemConfiguration();
|
|
|
|
|
if ($sysConf['proxy_host'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXY, $sysConf['proxy_host'] . ($sysConf['proxy_port'] != '' ? ':' . $sysConf['proxy_port'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($sysConf['proxy_port'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYPORT, $sysConf['proxy_port']);
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
if ($sysConf['proxy_user'] != '') {
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_PROXYUSERPWD, $sysConf['proxy_user'] . ($sysConf['proxy_pass'] != '' ? ':' . $sysConf['proxy_pass'] : ''));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
2013-03-14 14:50:58 -04:00
|
|
|
curl_setopt($handler, CURLOPT_HTTPHEADER, array('Expect:'));
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
2013-03-14 14:50:58 -04:00
|
|
|
$response = curl_exec($handler);
|
|
|
|
|
curl_close($handler);
|
2012-10-09 13:23:16 -04:00
|
|
|
|
|
|
|
|
// decode
|
2013-03-14 14:50:58 -04:00
|
|
|
$responseSolr = G::json_decode($response);
|
2012-10-09 13:23:16 -04:00
|
|
|
if ($responseSolr->responseHeader->status != 0) {
|
2013-03-14 14:50:58 -04:00
|
|
|
throw new Exception("Error getting faceted list from Solr." . $solrIntruct . " response error: " . $response . "\n");
|
2012-10-09 13:23:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $responseSolr;
|
BUG 0000 herbert> SOLR implementation in PMOS2
Solr support in PMOS2 includes:
Functionality:
- Implementation of Home views (Inbox, Draft, Participated, Unassigned). The views return fast results.
- Include read, unread, all, and process filter in inbox View.
- Include process filter in draft view.
- Include started by me, completed by me, all, process, and status filter in participated view.
- Include process filter in unassigned view.
- Improved search functionality (search in user defined variables): Use the following syntax to search in process (user defined) variables. {variable_name}:{search_word} ex1:"causal:20*" where causal is the variable defined by the user.
+ Use of wildcards in search: Use * as wildcard at the begin or end of word
+ Multiple conditions in search: Separate multiple conditions by space ex2:"Materiales causal:20*" means that we are searching for the word Materiales and the causal that begin with 20.
+ Search in dates (interval ): Format=> {variable_date}:[yyyy-mm-dd TO yyyy-mm-dd]
Local date not UTC date required
ex: FechaRegistro:[2011-04-15 TO 2011-04-30] //registros con fecha entre el 2011-04-15 y el 2011-04-30.
+ we can use the wildcard *:
ex: FechaRegistro:[* TO 2011-04-30] //registros con fecha menor o igual a 2011-04-30.
FechaRegistro:[2011-04-15 TO *] //registros con fecha mayor o igual a 2011-04-15.
+ Search of exact phrases. format: {variable}:"frase a buscar"
ex: Cliente:"Jesus Marin"
- Application update function.
+ The function is called every time a change is detected in the application's data including the related delegations.
- Use of cache to improve performance
Not included:
- Order of task, sent by, and due date columns.
Pending:
- Advanced search view using faceted lists.
2012-05-15 10:56:48 -04:00
|
|
|
}
|
2012-07-19 19:59:26 -04:00
|
|
|
}
|
2013-01-25 17:13:52 -04:00
|
|
|
|