scriptName} [journal_path]\n"; } /** * Rebuild the search index for all articles in all journals. */ function execute() { // If we have an argument that this must be a journal path. $journal = null; if (count($this->argv)) { $journalPath = array_shift($this->argv); $journalDao =& DAORegistry::getDAO('JournalDAO'); $journal =& $journalDao->getJournalByPath($journalPath); if (!$journal) { die (__('search.cli.rebuildIndex.unknownJournal', array('journalPath' => $journalPath)). "\n"); } } // Register a router hook so that we can construct // useful URLs to journal content. HookRegistry::register('Request::getBaseUrl', array(&$this, 'callbackBaseUrl')); // Let the search implementation re-build the index. $articleSearchIndex = new ArticleSearchIndex(); $articleSearchIndex->rebuildIndex(true, $journal); } /** * Callback to patch the base URL which will be required * when constructing galley/supp file download URLs. * @see PKPRequest::getBaseUrl() */ function callbackBaseUrl($hookName, $params) { $baseUrl =& $params[0]; $baseUrl = Config::getVar('general', 'base_url'); return true; } } $tool = new rebuildSearchIndex(isset($argv) ? $argv : array()); $tool->execute(); ?>