12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- <?php
- if (!defined('STATUSNET')) {
- exit(1);
- }
- class ApiLoggerPlugin extends Plugin
- {
- const PLUGIN_VERSION = '2.0.0';
-
-
- public $frequency = 1.0;
- function onArgsInitialize($args)
- {
- if (isset($args['action'])) {
- $action = strtolower($args['action']);
- if (substr($action, 0, 3) == 'api') {
- if ($this->frequency < 1.0 && $this->frequency > 0.0) {
- $max = mt_getrandmax();
- $n = mt_rand() / $max;
- if ($n > $this->frequency) {
- return true;
- }
- }
- $uri = $_SERVER['REQUEST_URI'];
- $method = $_SERVER['REQUEST_METHOD'];
- $ssl = empty($_SERVER['HTTPS']) ? 'no' : 'yes';
- $cookie = empty($_SERVER['HTTP_COOKIE']) ? 'no' : 'yes';
- $etag = empty($_SERVER['HTTP_IF_MATCH']) ? 'no' : 'yes';
- $last = empty($_SERVER['HTTP_IF_MODIFIED_SINCE']) ? 'no' : 'yes';
- $auth = empty($_SERVER['HTTP_AUTHORIZATION']) ? 'no' : 'yes';
- if ($auth == 'no' && function_exists('apache_request_headers')) {
-
-
- $headers = apache_request_headers();
- if (isset($headers['Authorization'])) {
- $auth = 'yes';
- }
- }
- $agent = empty($_SERVER['HTTP_USER_AGENT']) ? 'no' : $_SERVER['HTTP_USER_AGENT'];
- $query = (strpos($uri, '?') === false) ? 'no' : 'yes';
- if ($query == 'yes') {
- if (preg_match('/\?since_id=\d+$/', $uri)) {
- $query = 'since_id';
- }
- }
- common_log(LOG_INFO, "STATLOG action:$action method:$method ssl:$ssl query:$query cookie:$cookie auth:$auth ifmatch:$etag ifmod:$last agent:$agent");
- }
- }
- return true;
- }
- public function onPluginVersion(array &$versions): bool
- {
- $versions[] = array('name' => 'ApiLogger',
- 'version' => self::PLUGIN_VERSION,
- 'author' => 'Brion Vibber',
- 'homepage' => 'https://git.gnu.io/gnu/gnu-social/tree/master/plugins/ApiLogger',
- 'rawdescription' =>
-
- _m('Allows random sampling of API requests.'));
- return true;
- }
- }
|