-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathclass-wpcomsh-log.php
139 lines (125 loc) · 3.19 KB
/
class-wpcomsh-log.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
<?php
/**
* WPCOMSH Log file.
*
* @package wpcomsh
*/
/**
* Class WPCOMSH_Log
*
* This is an interface for logging arbitrary data to wpcom logstash cluster.
* This auto-initializes and provides a hook to log data:
* ```
* do_action( 'wpcomsh_log', "test" );
* ```
*
* You can see logs in Kibana, log2logstash index, `feature:automated_transfer`.
*
* Note that logging must be enabled for the site for the logs to be sent,
* which involves enabling the `at_options_logging_on` site option on the
* Jetpack site.
*/
class WPCOMSH_Log {
/**
* Logging Endpoint URL.
*
* @var string
*/
protected static $log_endpoint = 'https://public-api.wordpress.com/rest/v1.1/automated-transfers/log';
/**
* Class instance.
*
* @var WPCOMSH_Log
*/
private static $instance;
/**
* Queue of log messages.
*
* @var array
*/
private $log_queue = array();
/**
* Whether it has a shutdown hook.
*
* @var bool
*/
private $has_shutdown_hook = false;
/**
* Site URL.
*
* @var string
*/
private $siteurl;
/**
* This instantiates the logging system. Because constructor is private, it can be only set up with `init` or `unsafe_direct_log`.
* `init` respects `at_options_logging_on` option. This essentially turns logging on/off so that we don't flood
* endpoint with too many requests.
* This is to be hooked into wp `init` hook.
*/
public static function init() {
if ( ! get_option( 'at_options_logging_on' ) ) {
return;
}
if ( self::$instance ) {
return;
}
self::$instance = new self();
self::$instance->add_hooks();
}
/**
* This method bypasses `at_options_logging_on` check.
* It is intended to be used when we are sure we want to send logs to logstash and
* we are sure that we don't fire it off frequently. Good example of when we want to use this
* is during the site setup process
*
* @param string $message Log message.
* @param array $extra Optional. Additional log data. Defaults to empty array.
*/
public static function unsafe_direct_log( $message, $extra = array() ) {
if ( ! self::$instance ) {
self::$instance = new self();
}
self::$instance->log( $message, $extra );
}
/**
* Constructor.
*/
private function __construct() {
$this->siteurl = get_site_url();
}
/**
* Adds the log action.
*/
private function add_hooks() {
add_action( 'wpcomsh_log', array( $this, 'log' ), 1 );
}
/**
* Logs a log message.
*
* @param string $message Log message.
* @param array $extra Optional. Additional log data. Defaults to empty array.
*/
public function log( $message, $extra = array() ) {
$this->log_queue[] = array(
'message' => $message,
'extra' => $extra,
);
if ( ! $this->has_shutdown_hook ) {
register_shutdown_function( array( $this, 'send_to_api' ) );
$this->has_shutdown_hook = true;
}
}
/**
* Sends log messages to the API endpoint.
*/
public function send_to_api() {
if ( count( $this->log_queue ) > 0 ) {
$payload = array(
'siteurl' => $this->siteurl,
'messages' => $this->log_queue,
);
wp_remote_post( self::$log_endpoint, array( 'body' => array( 'error' => wp_json_encode( $payload ) ) ) );
}
}
}
add_action( 'init', array( 'WPCOMSH_Log', 'init' ) );