Add second logging channel

This commit is contained in:
Romain Neutron
2013-07-01 14:38:17 +02:00
parent 24f6f19731
commit ce34bca408
8 changed files with 91 additions and 34 deletions

View File

@@ -136,3 +136,4 @@ xsendfile:
-
directory: ''
mount-point: ''
plugins: []

View File

@@ -37,7 +37,21 @@ abstract class Command extends SymfoCommand
{
if ($input->getOption('verbose')) {
$handler = new StreamHandler('php://stdout');
$this->container['monolog']->pushHandler($handler);
$this->container['monolog'] = $this->container->share(
$this->container->extend('monolog', function($logger, $app) use ($handler) {
$logger->pushHandler($handler);
return $logger;
})
);
$this->container['task-manager.logger'] = $this->container->share(
$this->container->extend('task-manager.logger', function($logger, $app) use ($handler) {
$logger->pushHandler($handler);
return $logger;
})
);
}
return $this->doExecute($input, $output);

View File

@@ -13,37 +13,22 @@ namespace Alchemy\Phrasea\Core\Provider;
use Silex\Application;
use Silex\ServiceProviderInterface;
use Monolog\Handler\SyslogHandler;
use Monolog\Handler\NativeMailerHandler;
use Alchemy\Phrasea\Exception\RuntimeException;
use Monolog\Logger;
use Monolog\Handler\NullHandler;
class TaskManagerServiceProvider implements ServiceProviderInterface
{
public function register(Application $app)
{
$app['task-manager.logger'] = $app->share(function(Application $app) {
$logger = new Logger('task-manager logger');
$logger->pushHandler(new NullHandler());
return $logger;
});
$app['task-manager'] = $app->share(function(Application $app) {
$logger = clone $app['monolog'];
$options = $app['phraseanet.configuration']['main']['task-manager']['options'];
if (isset($options['syslog_level']) && null !== $syslogLevel = constant($options['syslog_level'])) {
$handler = new SyslogHandler("Phraseanet-Task", "user", $syslogLevel);
$logger->pushHandler($handler);
}
if (isset($options['maillog_level']) && null !== $maillogLevel = constant($options['maillog_level'])) {
if ('' === $adminMail = trim($app['phraseanet.registry']->get('GV_adminMail'))) {
throw new RuntimeException("Admininstrator mail must be set to get log by mail.");
}
$senderMail = $app['phraseanet.registry']->get('GV_defaultmailsenderaddr');
$handler = new NativeMailerHandler($adminMail, "Phraseanet-Task", $senderMail, $maillogLevel);
$logger->pushHandler($handler);
}
return new \task_manager($app, $logger);
return new \task_manager($app, $app['task-manager.logger']);
});
}

View File

@@ -18,7 +18,7 @@ namespace Alchemy\Phrasea\Core;
*/
class Version
{
protected static $number = '3.8.0.a13';
protected static $number = '3.8.0.a14';
protected static $name = 'Carnosaurus';
public static function getNumber()

View File

@@ -96,8 +96,8 @@ class module_console_taskrun extends Command
}
$logfile = __DIR__ . '/../../../../logs/task_' . $task_id . '.log';
$this->container['monolog']->pushHandler(new RotatingFileHandler($logfile, 10));
$this->task = $task_manager->getTask($task_id, $this->container['monolog']);
$this->container['task-manager.logger']->pushHandler(new RotatingFileHandler($logfile, 10));
$this->task = $task_manager->getTask($task_id, $this->container['task-manager.logger']);
$lib2v = array(
'DEBUG' => \task_abstract::LOG_DEBUG,

View File

@@ -0,0 +1,57 @@
<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
use Alchemy\Phrasea\Application;
use Entities\Session;
use Entities\SessionModule;
class patch_3814 implements patchInterface
{
/** @var string */
private $release = '3.8.0.a14';
/** @var array */
private $concern = array(base::APPLICATION_BOX);
/**
* {@inheritdoc}
*/
public function get_release()
{
return $this->release;
}
/**
* {@inheritdoc}
*/
public function require_all_upgrades()
{
return false;
}
/**
* {@inheritdoc}
*/
public function concern()
{
return $this->concern;
}
/**
* {@inheritdoc}
*/
public function apply(base $appbox, Application $app)
{
$app['phraseanet.configuration']->setDefault('plugins');
return true;
}
}

View File

@@ -1627,7 +1627,7 @@ class record_adapter implements record_Interface, cache_cacheableInterface
$subdefs = $databox->get_subdef_structure()->getSubdefGroup($this->get_type());
if (!$subdefs) {
$app['monolog']->addInfo(sprintf('Nothing to do for %s', $this->get_type()));
$app['task-manager.logger']->addInfo(sprintf('Nothing to do for %s', $this->get_type()));
return;
}
@@ -1644,14 +1644,14 @@ class record_adapter implements record_Interface, cache_cacheableInterface
if ($this->has_subdef($subdefname) && $this->get_subdef($subdefname)->is_physically_present()) {
$pathdest = $this->get_subdef($subdefname)->get_pathfile();
$this->get_subdef($subdefname)->remove_file();
$app['monolog']->addInfo(sprintf('Removed old file for %s', $subdefname));
$app['task-manager.logger']->addInfo(sprintf('Removed old file for %s', $subdefname));
$this->clearSubdefCache($subdefname);
}
$pathdest = $this->generateSubdefPathname($subdef, $app['filesystem'], $pathdest);
$app['monolog']->addInfo(sprintf('Generating subdef %s to %s', $subdefname, $pathdest));
$this->generate_subdef($app['media-alchemyst'], $subdef, $pathdest, $app['monolog']);
$app['task-manager.logger']->addInfo(sprintf('Generating subdef %s to %s', $subdefname, $pathdest));
$this->generate_subdef($app['media-alchemyst'], $subdef, $pathdest, $app['task-manager.logger']);
if (file_exists($pathdest)) {
$media = $app['mediavorus']->guess($pathdest);

View File

@@ -865,7 +865,7 @@ abstract class task_abstract
$tid = $dependencyContainer['phraseanet.appbox']->get_connection()->lastInsertId();
$task = new $class_name($tid, $dependencyContainer, $dependencyContainer['monolog']);
$task = new $class_name($tid, $dependencyContainer, $dependencyContainer['task-manager.logger']);
$task->setTitle($task->getName());
return $task;