WikiProcessor.php 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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\Monolog;
  21. use WikiMap;
  22. /**
  23. * Annotate log records with request-global metadata, such as the hostname,
  24. * wiki / request ID, and MediaWiki version.
  25. *
  26. * @since 1.25
  27. * @copyright © 2013 Wikimedia Foundation and contributors
  28. */
  29. class WikiProcessor {
  30. /**
  31. * @param array $record
  32. * @return array
  33. */
  34. public function __invoke( array $record ) {
  35. global $wgVersion;
  36. $record['extra']['host'] = wfHostname();
  37. $record['extra']['wiki'] = WikiMap::getWikiIdFromDbDomain( WikiMap::getCurrentWikiDbDomain() );
  38. $record['extra']['mwversion'] = $wgVersion;
  39. $record['extra']['reqId'] = \WebRequest::getRequestId();
  40. if ( wfIsCLI() && isset( $_SERVER['argv'] ) ) {
  41. $record['extra']['cli_argv'] = implode( ' ', $_SERVER['argv'] );
  42. }
  43. return $record;
  44. }
  45. }