當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Tx_Solr_Util::isAllowedPageType方法代碼示例

本文整理匯總了PHP中Tx_Solr_Util::isAllowedPageType方法的典型用法代碼示例。如果您正苦於以下問題:PHP Tx_Solr_Util::isAllowedPageType方法的具體用法?PHP Tx_Solr_Util::isAllowedPageType怎麽用?PHP Tx_Solr_Util::isAllowedPageType使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Tx_Solr_Util的用法示例。


在下文中一共展示了Tx_Solr_Util::isAllowedPageType方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: addItem

 /**
  * Adds an item to the index queue.
  *
  * Not meant for public use.
  *
  * @param string $itemType The item's type, usually a table name.
  * @param string $itemUid The item's uid, usually an integer uid, could be a
  *      different value for non-database-record types.
  * @param string $indexingConfiguration The item's indexing configuration to use.
  *      Optional, overwrites existing / determined configuration.
  * @return void
  */
 private function addItem($itemType, $itemUid, $indexingConfiguration)
 {
     $additionalRecordFields = '';
     if ($itemType == 'pages') {
         $additionalRecordFields = ', doktype, uid';
     }
     $record = BackendUtility::getRecord($itemType, $itemUid, 'pid' . $additionalRecordFields);
     if (empty($record) || $itemType == 'pages' && !Tx_Solr_Util::isAllowedPageType($record)) {
         return;
     }
     if ($itemType == 'pages') {
         $rootPageId = Tx_Solr_Util::getRootPageId($itemUid);
     } else {
         $rootPageId = Tx_Solr_Util::getRootPageId($record['pid']);
     }
     if (Tx_Solr_Util::isRootPage($rootPageId)) {
         $item = array('root' => $rootPageId, 'item_type' => $itemType, 'item_uid' => $itemUid, 'changed' => $this->getItemChangedTime($itemType, $itemUid));
         if (!empty($indexingConfiguration)) {
             $indexingConfigurationList = array($indexingConfiguration);
         } else {
             $indexingConfigurationList = $this->getIndexingConfigurationsByItem($itemType, $itemUid, $rootPageId);
         }
         $solrConfiguration = tx_solr_Util::getSolrConfigurationFromPageId($rootPageId);
         // make a backup of the current item
         $baseItem = $item;
         foreach ($indexingConfigurationList as $indexingConfigurationCurrent) {
             $item = $baseItem;
             $item['indexing_configuration'] = $indexingConfigurationCurrent;
             $addItemToQueue = TRUE;
             // Ensure additionalWhereClause is applied.
             if (!empty($solrConfiguration['index.']['queue.'][$item['indexing_configuration'] . '.']['additionalWhereClause'])) {
                 $indexingConfigurationCheckRecord = BackendUtility::getRecord($itemType, $itemUid, 'pid' . $additionalRecordFields, ' AND ' . $solrConfiguration['index.']['queue.'][$item['indexing_configuration'] . '.']['additionalWhereClause']);
                 if (empty($indexingConfigurationCheckRecord)) {
                     // item does not match the indexing configuration's additionalWhereClause
                     $addItemToQueue = FALSE;
                 }
             }
             if ($addItemToQueue) {
                 $GLOBALS['TYPO3_DB']->exec_INSERTquery('tx_solr_indexqueue_item', $item);
             }
         }
     }
 }
開發者ID:romaincanon,項目名稱:ext-solr,代碼行數:55,代碼來源:Queue.php

示例2: addItem

 /**
  * Adds an item to the index queue.
  *
  * Not meant for public use.
  *
  * @param string $itemType The item's type, usually a table name.
  * @param string $itemUid The item's uid, usually an integer uid, could be a
  *      different value for non-database-record types.
  * @param string $indexingConfiguration The item's indexing configuration to use.
  *      Optional, overwrites existing / determined configuration.
  * @return void
  */
 private function addItem($itemType, $itemUid, $indexingConfiguration)
 {
     // FIXME must respect the indexer's additionalWhereClause option:
     // must not add items to the index queue which are excluded through
     // additionalWhereClause. Requires construction of additionalWhereClause
     // through multiple options instead of just one
     // FIXME temporary until we have a query builder to take care of this
     $additionalRecordFields = '';
     if ($itemType == 'pages') {
         $additionalRecordFields = ', doktype, uid';
     }
     $record = t3lib_BEfunc::getRecord($itemType, $itemUid, 'pid' . $additionalRecordFields);
     // FIXME temporary until we have a query builder to take care of this
     if (empty($record) || $itemType == 'pages' && !Tx_Solr_Util::isAllowedPageType($record)) {
         return;
     }
     if ($itemType == 'pages') {
         $rootPageId = Tx_Solr_Util::getRootPageId($itemUid);
     } else {
         $rootPageId = Tx_Solr_Util::getRootPageId($record['pid']);
     }
     if (Tx_Solr_Util::isRootPage($rootPageId)) {
         $item = array('root' => $rootPageId, 'item_type' => $itemType, 'item_uid' => $itemUid, 'changed' => $this->getItemChangedTime($itemType, $itemUid));
         if (!empty($indexingConfiguration)) {
             $indexingConfigurationList = array($indexingConfiguration);
         } else {
             $indexingConfigurationList = $this->getIndexingConfigurationsByItem($itemType, $itemUid, $rootPageId);
         }
         // make a backup of the current item
         $baseItem = $item;
         foreach ($indexingConfigurationList as $indexingConfigurationCurrent) {
             $item = $baseItem;
             $item['indexing_configuration'] = $indexingConfigurationCurrent;
             $writeToIndex = TRUE;
             // Ensure additionalWhereClause is applied.
             $solrConfiguration = tx_solr_Util::getSolrConfigurationFromPageId($record['pid']);
             if (!empty($solrConfiguration['index.']['queue.'][$item['indexing_configuration'] . '.']['additionalWhereClause'])) {
                 $record = t3lib_BEfunc::getRecord($itemType, $itemUid, 'pid' . $additionalRecordFields, ' AND ' . $solrConfiguration['index.']['queue.'][$item['indexing_configuration'] . '.']['additionalWhereClause']);
                 if (empty($record)) {
                     $writeToIndex = FALSE;
                 }
             }
             if ($writeToIndex) {
                 $GLOBALS['TYPO3_DB']->exec_INSERTquery('tx_solr_indexqueue_item', $item);
             }
         }
     }
 }
開發者ID:sfsmfc,項目名稱:solr,代碼行數:60,代碼來源:Queue.php

示例3: isIndexablePageType

 /**
  * Checks whether a page has a page type that can be indexed.
  * Currently standard pages and mount pages can be indexed.
  *
  * @param array $record A page record
  * @return boolean TRUE if the page can be indexed according to its page type, FALSE otherwise
  */
 protected function isIndexablePageType(array $record)
 {
     return Tx_Solr_Util::isAllowedPageType($record);
 }
開發者ID:romaincanon,項目名稱:ext-solr,代碼行數:11,代碼來源:GarbageCollector.php


注:本文中的Tx_Solr_Util::isAllowedPageType方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。