NullSpi.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. /**
  3. * This program is free software; you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License as published by
  5. * the Free Software Foundation; either version 2 of the License, or
  6. * (at your option) any later version.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License along
  14. * with this program; if not, write to the Free Software Foundation, Inc.,
  15. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  16. * http://www.gnu.org/copyleft/gpl.html
  17. *
  18. * @file
  19. */
  20. namespace MediaWiki\Logger;
  21. use Psr\Log\NullLogger;
  22. /**
  23. * LoggerFactory service provider that creates \Psr\Log\NullLogger
  24. * instances. A NullLogger silently discards all log events sent to it.
  25. *
  26. * Usage:
  27. *
  28. * $wgMWLoggerDefaultSpi = [
  29. * 'class' => \MediaWiki\Logger\NullSpi::class,
  30. * ];
  31. *
  32. * @see \MediaWiki\Logger\LoggerFactory
  33. * @since 1.25
  34. * @copyright © 2014 Wikimedia Foundation and contributors
  35. */
  36. class NullSpi implements Spi {
  37. /**
  38. * @var \Psr\Log\NullLogger $singleton
  39. */
  40. protected $singleton;
  41. public function __construct() {
  42. $this->singleton = new NullLogger();
  43. }
  44. /**
  45. * Get a logger instance.
  46. *
  47. * @param string $channel Logging channel
  48. * @return \Psr\Log\NullLogger Logger instance
  49. */
  50. public function getLogger( $channel ) {
  51. return $this->singleton;
  52. }
  53. }