CODE STYLE class.searchIndex.php

This commit is contained in:
Fernando Ontiveros
2012-10-09 13:21:57 -04:00
parent 5919afd930
commit d73f690e1d

View File

@@ -1,6 +1,6 @@
<?php <?php
/** /**
*
* ProcessMaker Open Source Edition * ProcessMaker Open Source Edition
* Copyright (C) 2004 - 2012 Colosa Inc.23 * Copyright (C) 2004 - 2012 Colosa Inc.23
* *
@@ -19,10 +19,8 @@
* *
* For more information, contact Colosa Inc, 5304 Ventura Drive, * For more information, contact Colosa Inc, 5304 Ventura Drive,
* Delray Beach, FL, 33484, USA, or email info@colosa.com. * Delray Beach, FL, 33484, USA, or email info@colosa.com.
*
*/ */
/** /**
* Class used as interface to have access to the search index services * Class used as interface to have access to the search index services
* *
@@ -34,7 +32,7 @@ class BpmnEngine_Services_SearchIndex
private $_solrIsEnabled = false; private $_solrIsEnabled = false;
private $_solrHost = ""; private $_solrHost = "";
function __construct($solrIsEnabled = false, $solrHost = "") public function __construct ($solrIsEnabled = false, $solrHost = "")
{ {
// check if Zend Library is available // check if Zend Library is available
// if(class_exists("Zend_Registry")){ // if(class_exists("Zend_Registry")){
@@ -51,6 +49,7 @@ class BpmnEngine_Services_SearchIndex
$this->_solrHost = $solrHost; $this->_solrHost = $solrHost;
// } // }
} }
/** /**
* Verify if the Solr service is available * Verify if the Solr service is available
* @gearman = false * @gearman = false
@@ -59,16 +58,15 @@ class BpmnEngine_Services_SearchIndex
* *
* no input parameters @param[in] * no input parameters @param[in]
* *
* @param * @param [out] bool true if index service is enabled false in other case
* [out] bool true if index service is enabled false in other case
*/ */
public function isEnabled() public function isEnabled ()
{ {
// require_once (ROOT_PATH . // require_once (ROOT_PATH .
// '/businessLogic/modules/SearchIndexAccess/Solr.php'); // '/businessLogic/modules/SearchIndexAccess/Solr.php');
require_once ('class.solr.php'); require_once ('class.solr.php');
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
return $solr->isEnabled (); return $solr->isEnabled();
} }
/** /**
@@ -77,12 +75,10 @@ class BpmnEngine_Services_SearchIndex
* @rest = false * @rest = false
* @background = false * @background = false
* *
* @param * @param [in] Entity_FacetRequest facetRequestEntity Facet request entity
* [in] Entity_FacetRequest facetRequestEntity Facet request entity * @param [out] array FacetGroup
* @param
* [out] array FacetGroup
*/ */
public function getFacetsList($facetRequestEntity) public function getFacetsList ($facetRequestEntity)
{ {
require_once ('class.solr.php'); require_once ('class.solr.php');
// require_once (ROOT_PATH . // require_once (ROOT_PATH .
@@ -96,34 +92,31 @@ class BpmnEngine_Services_SearchIndex
* *************************************************************** * ***************************************************************
*/ */
// get array of selected facet groups // get array of selected facet groups
$facetRequestEntity->selectedFacetsString = str_replace (',,', ',', $facetRequestEntity->selectedFacetsString); $facetRequestEntity->selectedFacetsString = str_replace( ',,', ',', $facetRequestEntity->selectedFacetsString );
// remove descriptions of selected facet groups // remove descriptions of selected facet groups
$aGroups = explode (',', $facetRequestEntity->selectedFacetsString);
$aGroups = array_filter ($aGroups); // remove empty items $aGroups = explode( ',', $facetRequestEntity->selectedFacetsString );
$aGroups = array_filter( $aGroups ); // remove empty items
$aSelectedFacetGroups = array (); $aSelectedFacetGroups = array ();
foreach ($aGroups as $i => $value) { foreach ($aGroups as $i => $value) {
$gi = explode (':::', $value); $gi = explode( ':::', $value );
$gr = explode ('::', $gi [0]); $gr = explode( '::', $gi[0] );
$it = explode ('::', $gi [1]); $it = explode( '::', $gi[1] );
// create string for remove condition // create string for remove condition
$count = 0; $count = 0;
$removeCondition = str_replace ($value . ',', '', $facetRequestEntity->selectedFacetsString, $count); $removeCondition = str_replace( $value . ',', '', $facetRequestEntity->selectedFacetsString, $count );
if ($count == 0) { if ($count == 0) {
$removeCondition = str_replace ($value, '', $facetRequestEntity->selectedFacetsString, $count); $removeCondition = str_replace( $value, '', $facetRequestEntity->selectedFacetsString, $count );
} }
$selectedFacetGroupData = array ( $selectedFacetGroupData = array ('selectedFacetGroupName' => $gr[0],'selectedFacetGroupPrintName' => $gr[1],'selectedFacetItemName' => $it[0],'selectedFacetItemPrintName' => $it[1],'selectedFacetRemoveCondition' => $removeCondition
'selectedFacetGroupName' => $gr [0],
'selectedFacetGroupPrintName' => $gr [1],
'selectedFacetItemName' => $it [0],
'selectedFacetItemPrintName' => $it [1],
'selectedFacetRemoveCondition' => $removeCondition
); );
$aSelectedFacetGroups [] = Entity_SelectedFacetGroupItem::createForRequest ($selectedFacetGroupData); $aSelectedFacetGroups[] = Entity_SelectedFacetGroupItem::createForRequest( $selectedFacetGroupData );
} }
/** /**
@@ -132,16 +125,14 @@ class BpmnEngine_Services_SearchIndex
// convert request to index request // convert request to index request
// create filters // create filters
$filters = array (); $filters = array ();
if (! empty ($aSelectedFacetGroups)) { if (! empty( $aSelectedFacetGroups )) {
// exclude facetFields and facetDates included in filter from the next // exclude facetFields and facetDates included in filter from the next
// list of facets // list of facets
foreach ($aSelectedFacetGroups as $value) { foreach ($aSelectedFacetGroups as $value) {
$facetRequestEntity->facetFields = array_diff ($facetRequestEntity->facetFields, array ( $facetRequestEntity->facetFields = array_diff( $facetRequestEntity->facetFields, array ($value->selectedFacetGroupName
$value->selectedFacetGroupName ) );
)); $facetRequestEntity->facetDates = array_diff( $facetRequestEntity->facetDates, array ($value->selectedFacetGroupName
$facetRequestEntity->facetDates = array_diff ($facetRequestEntity->facetDates, array ( ) );
$value->selectedFacetGroupName
));
} }
// $facetFields = array_diff($facetFields, // $facetFields = array_diff($facetFields,
@@ -149,15 +140,15 @@ class BpmnEngine_Services_SearchIndex
// $facetDates = array_diff($facetDates, // $facetDates = array_diff($facetDates,
// $facetInterfaceRequestEntity->selectedFacetGroups); // $facetInterfaceRequestEntity->selectedFacetGroups);
foreach ($aSelectedFacetGroups as $group) { foreach ($aSelectedFacetGroups as $group) {
$filters [] = $group->selectedFacetGroupName . ':' . urlencode ($group->selectedFacetItemName); $filters[] = $group->selectedFacetGroupName . ':' . urlencode( $group->selectedFacetItemName );
} }
} }
$facetRequestEntity->filters = $filters; $facetRequestEntity->filters = $filters;
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
// create list of facets // create list of facets
$facetsList = $solr->getFacetsList ($facetRequestEntity); $facetsList = $solr->getFacetsList( $facetRequestEntity );
$numFound = $facetsList->response->numFound; $numFound = $facetsList->response->numFound;
@@ -170,29 +161,28 @@ class BpmnEngine_Services_SearchIndex
*/ */
// include facet field results // include facet field results
$facetFieldsResult = $facetsList->facet_counts->facet_fields; $facetFieldsResult = $facetsList->facet_counts->facet_fields;
if (! empty ($facetFieldsResult)) { if (! empty( $facetFieldsResult )) {
foreach ($facetFieldsResult as $facetGroup => $facetvalues) { foreach ($facetFieldsResult as $facetGroup => $facetvalues) {
if (count ($facetvalues) > 0) // if the group have facets included if (count( $facetvalues ) > 0) // if the group have facets included
{ {
$data = array ( $data = array ('facetGroupName' => $facetGroup
'facetGroupName' => $facetGroup
); );
$data ['facetGroupPrintName'] = $facetGroup; $data['facetGroupPrintName'] = $facetGroup;
$data ['facetGroupType'] = 'field'; $data['facetGroupType'] = 'field';
$facetItems = array (); $facetItems = array ();
for ($i = 0; $i < count ($facetvalues); $i += 2) { for ($i = 0; $i < count( $facetvalues ); $i += 2) {
$dataItem = array (); $dataItem = array ();
$dataItem ['facetName'] = $facetvalues [$i]; $dataItem['facetName'] = $facetvalues[$i];
$dataItem ['facetPrintName'] = $facetvalues [$i]; $dataItem['facetPrintName'] = $facetvalues[$i];
$dataItem ['facetCount'] = $facetvalues [$i + 1]; $dataItem['facetCount'] = $facetvalues[$i + 1];
$dataItem ['facetSelectCondition'] = $facetRequestEntity->selectedFacetsString . (empty ($facetRequestEntity->selectedFacetsString) ? '' : ',') . $data ['facetGroupName'] . '::' . $data ['facetGroupPrintName'] . ':::' . $dataItem ['facetName'] . '::' . $dataItem ['facetPrintName']; $dataItem['facetSelectCondition'] = $facetRequestEntity->selectedFacetsString . (empty( $facetRequestEntity->selectedFacetsString ) ? '' : ',') . $data['facetGroupName'] . '::' . $data['facetGroupPrintName'] . ':::' . $dataItem['facetName'] . '::' . $dataItem['facetPrintName'];
$newFacetItem = Entity_FacetItem::createForInsert ($dataItem); $newFacetItem = Entity_FacetItem::createForInsert( $dataItem );
$facetItems [] = $newFacetItem; $facetItems[] = $newFacetItem;
} }
$data ['facetItems'] = $facetItems; $data['facetItems'] = $facetItems;
$newFacetGroup = Entity_FacetGroup::createForInsert ($data); $newFacetGroup = Entity_FacetGroup::createForInsert( $data );
$facetGroups [] = $newFacetGroup; $facetGroups[] = $newFacetGroup;
} }
} }
} }
@@ -201,43 +191,41 @@ class BpmnEngine_Services_SearchIndex
*/ */
// include facet date ranges results // include facet date ranges results
$facetDatesResult = $facetsList->facet_counts->facet_dates; $facetDatesResult = $facetsList->facet_counts->facet_dates;
if (! empty ($facetDatesResult)) { if (! empty( $facetDatesResult )) {
foreach ($facetDatesResult as $facetGroup => $facetvalues) { foreach ($facetDatesResult as $facetGroup => $facetvalues) {
if (count ((array)$facetvalues) > 3) // if the group have any facets included if (count( (array) $facetvalues ) > 3) // if the group have any facets included
// besides start, end and gap // besides start, end and gap
{ {
$data = array ( $data = array ('facetGroupName' => $facetGroup
'facetGroupName' => $facetGroup
); );
$data ['facetGroupPrintName'] = $facetGroup; $data['facetGroupPrintName'] = $facetGroup;
$data ['facetGroupType'] = 'daterange'; $data['facetGroupType'] = 'daterange';
$facetItems = array (); $facetItems = array ();
$facetvalueskeys = array_keys ((array)$facetvalues); $facetvalueskeys = array_keys( (array) $facetvalues );
foreach ($facetvalueskeys as $i => $k) { foreach ($facetvalueskeys as $i => $k) {
if ($k != 'gap' && $k != 'start' && $k != 'end') { if ($k != 'gap' && $k != 'start' && $k != 'end') {
$dataItem = array (); $dataItem = array ();
if ($i < count ($facetvalueskeys) - 4) { if ($i < count( $facetvalueskeys ) - 4) {
$dataItem ['facetName'] = '[' . $k . '%20TO%20' . $facetvalueskeys [$i + 1] . ']'; $dataItem['facetName'] = '[' . $k . '%20TO%20' . $facetvalueskeys[$i + 1] . ']';
$dataItem ['facetPrintName'] = '[' . $k . '%20TO%20' . $facetvalueskeys [$i + 1] . ']'; $dataItem['facetPrintName'] = '[' . $k . '%20TO%20' . $facetvalueskeys[$i + 1] . ']';
} } else {
else {
// the last group // the last group
$dataItem ['facetName'] = '[' . $k . '%20TO%20' . $facetvalues->end . ']'; $dataItem['facetName'] = '[' . $k . '%20TO%20' . $facetvalues->end . ']';
$dataItem ['facetPrintName'] = '[' . $k . '%20TO%20' . $facetvalues->end . ']'; $dataItem['facetPrintName'] = '[' . $k . '%20TO%20' . $facetvalues->end . ']';
} }
$dataItem ['facetCount'] = $facetvalues->$k; $dataItem['facetCount'] = $facetvalues->$k;
$dataItem ['facetSelectCondition'] = $facetRequestEntity->selectedFacetsString . (empty ($facetRequestEntity->selectedFacetsString) ? '' : ',') . $data ['facetGroupName'] . '::' . $data ['facetGroupPrintName'] . ':::' . $dataItem ['facetName'] . '::' . $dataItem ['facetPrintName']; $dataItem['facetSelectCondition'] = $facetRequestEntity->selectedFacetsString . (empty( $facetRequestEntity->selectedFacetsString ) ? '' : ',') . $data['facetGroupName'] . '::' . $data['facetGroupPrintName'] . ':::' . $dataItem['facetName'] . '::' . $dataItem['facetPrintName'];
$newFacetItem = Entity_FacetItem::createForInsert ($dataItem); $newFacetItem = Entity_FacetItem::createForInsert( $dataItem );
$facetItems [] = $newFacetItem; $facetItems[] = $newFacetItem;
} }
} }
$data ['facetItems'] = $facetItems; $data['facetItems'] = $facetItems;
$newFacetGroup = Entity_FacetGroup::createForInsert ($data); $newFacetGroup = Entity_FacetGroup::createForInsert( $data );
$facetGroups [] = $newFacetGroup; $facetGroups[] = $newFacetGroup;
} }
} }
} }
@@ -250,107 +238,111 @@ class BpmnEngine_Services_SearchIndex
$filterText = ''; // the list of selected filters used for filtering result, $filterText = ''; // the list of selected filters used for filtering result,
// send in ajax // send in ajax
foreach ($aSelectedFacetGroups as $selectedFacetGroup) { foreach ($aSelectedFacetGroups as $selectedFacetGroup) {
$filterText .= $selectedFacetGroup->selectedFacetGroupName . ':' . urlencode ($selectedFacetGroup->selectedFacetItemName) . ','; $filterText .= $selectedFacetGroup->selectedFacetGroupName . ':' . urlencode( $selectedFacetGroup->selectedFacetItemName ) . ',';
} }
$filterText = substr_replace ($filterText, '', - 1); $filterText = substr_replace( $filterText, '', - 1 );
// $filterText = ($filterText == '')?'':'&filterText='.$filterText; // $filterText = ($filterText == '')?'':'&filterText='.$filterText;
/** /**
* *************************************************************** * ***************************************************************
*/ */
// Create result // Create result
$dataFacetResult = array ( $dataFacetResult = array ('aFacetGroups' => $facetGroups,'aSelectedFacetGroups' => $aSelectedFacetGroups,'sFilterText' => $filterText
'aFacetGroups' => $facetGroups,
'aSelectedFacetGroups' => $aSelectedFacetGroups,
'sFilterText' => $filterText
); );
$facetResult = Entity_FacetResult::createForRequest ($dataFacetResult); $facetResult = Entity_FacetResult::createForRequest( $dataFacetResult );
return $facetResult; return $facetResult;
} }
/** /**
* Get the total number of documents in search server * Get the total number of documents in search server
*
* @param string $workspace * @param string $workspace
* @return integer number of documents * @return integer number of documents
* *
*/ */
public function getNumberDocuments($workspace) public function getNumberDocuments ($workspace)
{ {
require_once ('class.solr.php'); require_once ('class.solr.php');
// require_once (ROOT_PATH . // require_once (ROOT_PATH .
// '/businessLogic/modules/SearchIndexAccess/Solr.php'); // '/businessLogic/modules/SearchIndexAccess/Solr.php');
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
// create list of facets // create list of facets
$numberDocuments = $solr->getNumberDocuments ($workspace); $numberDocuments = $solr->getNumberDocuments( $workspace );
return $numberDocuments; return $numberDocuments;
} }
/** /**
* Update document Index * Update document Index
*
* @param SolrUpdateDocumentEntity $solrUpdateDocumentEntity * @param SolrUpdateDocumentEntity $solrUpdateDocumentEntity
*/ */
public function updateIndexDocument($solrUpdateDocumentEntity) public function updateIndexDocument ($solrUpdateDocumentEntity)
{ {
G::LoadClass ('solr'); G::LoadClass( 'solr' );
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
// create list of facets // create list of facets
$solr->updateDocument ($solrUpdateDocumentEntity); $solr->updateDocument( $solrUpdateDocumentEntity );
} }
/** /**
* Delete document from index * Delete document from index
*
* @param string $workspace * @param string $workspace
* @param string $idQuery * @param string $idQuery
*/ */
public function deleteDocumentFromIndex($workspace, $idQuery) public function deleteDocumentFromIndex ($workspace, $idQuery)
{ {
G::LoadClass ('solr'); G::LoadClass( 'solr' );
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
// create list of facets // create list of facets
$solr->deleteDocument ($workspace, $idQuery); $solr->deleteDocument( $workspace, $idQuery );
} }
/** /**
* Commit index changes * Commit index changes
*
* @param string $workspace * @param string $workspace
*/ */
public function commitIndexChanges($workspace) public function commitIndexChanges ($workspace)
{ {
G::LoadClass ('solr'); G::LoadClass( 'solr' );
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
// commit // commit
$solr->commitChanges ($workspace); $solr->commitChanges( $workspace );
} }
/** /**
* Optimize index changes * Optimize index changes
*
* @param string $workspace * @param string $workspace
*/ */
public function optimizeIndexChanges($workspace) public function optimizeIndexChanges ($workspace)
{ {
G::LoadClass ('solr'); G::LoadClass( 'solr' );
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
// commit // commit
$solr->optimizeChanges ($workspace); $solr->optimizeChanges( $workspace );
} }
/** /**
* Call Solr server to return the list of paginated pages. * Call Solr server to return the list of paginated pages.
*
* @param FacetRequest $solrRequestData * @param FacetRequest $solrRequestData
* @return Entity_SolrQueryResult * @return Entity_SolrQueryResult
*/ */
public function getDataTablePaginatedList($solrRequestData) public function getDataTablePaginatedList ($solrRequestData)
{ {
require_once ('class.solr.php'); require_once ('class.solr.php');
require_once ('entities/SolrRequestData.php'); require_once ('entities/SolrRequestData.php');
@@ -358,14 +350,14 @@ class BpmnEngine_Services_SearchIndex
// prepare the list of sorted columns // prepare the list of sorted columns
// verify if the data of sorting is available // verify if the data of sorting is available
if (isset ($solrRequestData->sortCols [0])) { if (isset( $solrRequestData->sortCols[0] )) {
for ($i = 0; $i < $solrRequestData->numSortingCols; $i ++) { for ($i = 0; $i < $solrRequestData->numSortingCols; $i ++) {
// verify if column is sortable // verify if column is sortable
if ($solrRequestData->includeCols [$solrRequestData->sortCols [$i]] != '' && $solrRequestData->sortableCols [$i] == "true") { if ($solrRequestData->includeCols[$solrRequestData->sortCols[$i]] != '' && $solrRequestData->sortableCols[$i] == "true") {
// change sorting column index to column names // change sorting column index to column names
$solrRequestData->sortCols [$i] = $solrRequestData->includeCols [$solrRequestData->sortCols [$i]]; $solrRequestData->sortCols[$i] = $solrRequestData->includeCols[$solrRequestData->sortCols[$i]];
// define the direction of the sorting columns // define the direction of the sorting columns
$solrRequestData->sortDir [$i] = $solrRequestData->sortDir [$i]; $solrRequestData->sortDir[$i] = $solrRequestData->sortDir[$i];
} }
} }
} }
@@ -374,12 +366,13 @@ class BpmnEngine_Services_SearchIndex
// $solrRequestData->includeCols = array_diff($solrRequestData->includeCols, // $solrRequestData->includeCols = array_diff($solrRequestData->includeCols,
// array('')); // array(''));
// execute query // execute query
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
$solrPaginatedResult = $solr->executeQuery ($solrRequestData); $solrPaginatedResult = $solr->executeQuery( $solrRequestData );
// get total number of documents in index // get total number of documents in index
$numTotalDocs = $solr->getNumberDocuments ($solrRequestData->workspace); $numTotalDocs = $solr->getNumberDocuments( $solrRequestData->workspace );
// create the Datatable response of the query // create the Datatable response of the query
$numFound = $solrPaginatedResult->response->numFound; $numFound = $solrPaginatedResult->response->numFound;
@@ -387,65 +380,62 @@ class BpmnEngine_Services_SearchIndex
$docs = $solrPaginatedResult->response->docs; $docs = $solrPaginatedResult->response->docs;
// print_r($docs); // print_r($docs);
// insert list of names in docs result // insert list of names in docs result
$data = array ( $data = array ("sEcho" => '', // must be completed in response
"sEcho" => '', // must be completed in response "iTotalRecords" => intval( $numTotalDocs ), // we must get the
"iTotalRecords" => intval ($numTotalDocs), // we must get the
// total number of // total number of
// documents // documents
"iTotalDisplayRecords" => $numFound, "iTotalDisplayRecords" => $numFound,"aaData" => array ()
"aaData" => array ()
); );
// copy result document or add placeholders to result // copy result document or add placeholders to result
foreach ($docs as $i => $doc) { foreach ($docs as $i => $doc) {
$data ['aaData'] [$i] = array (); $data['aaData'][$i] = array ();
foreach ($solrRequestData->includeCols as $columnName) { foreach ($solrRequestData->includeCols as $columnName) {
if ($columnName == '') { if ($columnName == '') {
$data ['aaData'] [$i] [] = ''; // placeholder $data['aaData'][$i][] = ''; // placeholder
} } else {
else { if (isset( $doc->$columnName )) {
if (isset ($doc->$columnName)) { $data['aaData'][$i][] = $doc->$columnName;
$data ['aaData'] [$i] [] = $doc->$columnName; } else {
} $data['aaData'][$i][] = '';
else {
$data ['aaData'] [$i] [] = '';
} }
} }
} }
} }
$solrQueryResponse = Entity_SolrQueryResult::createForRequest ($data); $solrQueryResponse = Entity_SolrQueryResult::createForRequest( $data );
// //
return $solrQueryResponse; return $solrQueryResponse;
} }
/** /**
* Return the list of stored fields in the index. * Return the list of stored fields in the index.
*
* @param string $workspace * @param string $workspace
* @return array of index fields * @return array of index fields
*/ */
public function getIndexFields($workspace) public function getIndexFields ($workspace)
{ {
require_once ('class.solr.php'); require_once ('class.solr.php');
$solr = new BpmnEngine_SearchIndexAccess_Solr ($this->_solrIsEnabled, $this->_solrHost); $solr = new BpmnEngine_SearchIndexAccess_Solr( $this->_solrIsEnabled, $this->_solrHost );
// print "SearchIndex!!!!"; // print "SearchIndex!!!!";
// create list of facets // create list of facets
$solrFieldsData = $solr->getListIndexedStoredFields ($workspace); $solrFieldsData = $solr->getListIndexedStoredFields( $workspace );
// copy list of arrays // copy list of arrays
$listFields = array (); $listFields = array ();
foreach ($solrFieldsData->fields as $key => $fieldData) { foreach ($solrFieldsData->fields as $key => $fieldData) {
if (array_key_exists ('dynamicBase', $fieldData)) { if (array_key_exists( 'dynamicBase', $fieldData )) {
$originalFieldName = substr ($key, 0, - strlen ($fieldData->dynamicBase) + 1); $originalFieldName = substr( $key, 0, - strlen( $fieldData->dynamicBase ) + 1 );
// $listFields[strtolower($originalFieldName)] = $key; //in case of case insentive strings // $listFields[strtolower($originalFieldName)] = $key; //in case of case insentive strings
// Maintain case sensitive variable names // Maintain case sensitive variable names
$listFields [$originalFieldName] = $key; $listFields[$originalFieldName] = $key;
} } else {
else {
// $listFields[strtolower($key)] = $key; // $listFields[strtolower($key)] = $key;
// Maintain case sensitive variable names // Maintain case sensitive variable names
$listFields [$key] = $key; $listFields[$key] = $key;
} }
} }