-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplugin.php
82 lines (62 loc) · 1.84 KB
/
plugin.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
<?php
/**
* @package Silverback Log Services
* @version 1.1
*/
/**
Plugin Name: Wordpress Log
Plugin URI: https://github.com/silverbackstudio/wp-log
Description: Setup Wordpress log actions and record core events
Author: Silverback Studio
Version: 1.1
Author URI: http://www.silverbackstudio.it/
Text Domain: svbk-wp-log
*/
use Svbk\WP\Log as WP_Log;
function svbk_logger_init() {
load_plugin_textdomain( 'svbk-wp-log', false, dirname( plugin_basename( __FILE__ ) ) . '/languages' );
if ( ! defined( 'WP_LOGGER_NAME' ) ) {
define( 'WP_LOGGER_NAME', 'wordpress' );
}
if ( Monolog\Registry::hasLogger( WP_LOGGER_NAME ) ) {
$wp_logger = Monolog\Registry::getInstance( WP_LOGGER_NAME );
} else {
$wp_logger = new Monolog\Logger( WP_LOGGER_NAME );
Monolog\Registry::addLogger( $wp_logger, WP_LOGGER_NAME );
}
$wp_logger->pushProcessor( new WP_Log\Processor\PlaceholderProcessor() );
$wp_logger->pushProcessor(
new Monolog\Processor\WebProcessor(
null,
array(
'url' => 'REQUEST_URI',
'ip' => 'REMOTE_ADDR',
'http_method' => 'REQUEST_METHOD',
)
)
);
$wp_logger->pushProcessor( new Monolog\Processor\MemoryUsageProcessor() );
$wp_logger->pushProcessor( new WP_Log\Processor\WordpressProcessor() );
add_action( 'log', array( $wp_logger, 'log' ), 10, 3 );
do_action( 'svbk_logger_init', $wp_logger );
return $wp_logger;
}
add_action( 'plugins_loaded', 'svbk_logger_init', 5 );
function svbk_logger_register_hooks() {
$channels = apply_filters(
'svbk_log_classes',
array(
'core' => WP_Log\Hook\Core::class,
'user' => WP_Log\Hook\User::class,
'post' => WP_Log\Hook\Post::class,
'http' => WP_Log\Hook\Http::class,
)
);
foreach ( $channels as $channel => $className ) {
if ( false === $className ) {
continue;
}
$className::setup();
}
}
add_action( 'init', 'svbk_logger_register_hooks', 5 );