123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- <?php
- if (!defined('STATUSNET')) {
- exit(1);
- }
- class ApiLoggerPlugin extends Plugin
- {
-
-
- 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;
- }
- function onPluginVersion(&$versions)
- {
- $versions[] = array('name' => 'ApiLogger',
- 'version' => GNUSOCIAL_VERSION,
- 'author' => 'Brion Vibber',
- 'homepage' => 'http://status.net/wiki/Plugin:ApiLogger',
- 'rawdescription' =>
-
- _m('Allows random sampling of API requests.'));
- return true;
- }
- }
|