2017-02-17 00:03:51 +01:00
|
|
|
<?php
|
|
|
|
namespace SilverStripe\FullTextSearch\Solr\Tasks;
|
2017-04-22 20:21:06 +02:00
|
|
|
use SilverStripe\Core\Injector\Injector;
|
2017-02-17 00:03:51 +01:00
|
|
|
use SilverStripe\Dev\BuildTask;
|
2017-04-22 20:21:06 +02:00
|
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
use SilverStripe\FullTextSearch\Utils\Logging\SearchLogFactory;
|
2017-02-17 00:03:51 +01:00
|
|
|
/**
|
|
|
|
* Abstract class for build tasks
|
|
|
|
*/
|
|
|
|
class Solr_BuildTask extends BuildTask
|
|
|
|
{
|
|
|
|
protected $enabled = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logger
|
|
|
|
*
|
|
|
|
* @var LoggerInterface
|
|
|
|
*/
|
|
|
|
protected $logger = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the current logger
|
|
|
|
*
|
|
|
|
* @return LoggerInterface
|
|
|
|
*/
|
|
|
|
public function getLogger()
|
|
|
|
{
|
2017-04-26 10:58:14 +02:00
|
|
|
//@todo left commented after a confusing merge conflict. Revisit if further testing is required
|
|
|
|
//return Injector::inst()->get('Logger');
|
2017-04-25 11:11:29 +02:00
|
|
|
return Injector::inst()->get(LoggerInterface::class);
|
2017-02-17 00:03:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Assign a new logger
|
|
|
|
*
|
|
|
|
* @param LoggerInterface $logger
|
|
|
|
*/
|
|
|
|
public function setLogger(LoggerInterface $logger)
|
|
|
|
{
|
|
|
|
$this->logger = $logger;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return SearchLogFactory
|
|
|
|
*/
|
|
|
|
protected function getLoggerFactory()
|
|
|
|
{
|
2017-04-26 10:58:14 +02:00
|
|
|
//@todo left commented after a confusing merge conflict. Revisit if further testing is required
|
|
|
|
//return Injector::inst()->get('SearchLogFactory');
|
2017-04-25 11:11:29 +02:00
|
|
|
return Injector::inst()->get(SearchLogFactory::class);
|
2017-02-17 00:03:51 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Setup task
|
|
|
|
*
|
|
|
|
* @param SS_HTTPReqest $request
|
|
|
|
*/
|
|
|
|
public function run($request)
|
|
|
|
{
|
|
|
|
$name = get_class($this);
|
|
|
|
$verbose = $request->getVar('verbose');
|
|
|
|
|
|
|
|
// Set new logger
|
|
|
|
$logger = $this
|
2017-04-22 20:21:06 +02:00
|
|
|
->getLoggerFactory()
|
|
|
|
->getOutputLogger($name, $verbose);
|
2017-02-17 00:03:51 +01:00
|
|
|
$this->setLogger($logger);
|
|
|
|
}
|
|
|
|
}
|