X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=statistics_json%2Fstatistics_json.php;h=87ffdb00399e2d1af439713d6e509858586ebcfa;hb=9f18d7e6ded53ce9338c624ed4228315581fb217;hp=65d3985dc01cef783bd2783bc09ce5db9184244c;hpb=9ae0f9a65d139df27450bc8350c68d570aad966c;p=friendica-addons.git diff --git a/statistics_json/statistics_json.php b/statistics_json/statistics_json.php index 65d3985d..87ffdb00 100644 --- a/statistics_json/statistics_json.php +++ b/statistics_json/statistics_json.php @@ -2,9 +2,10 @@ /** * Name: Statistics - * Description: Generates some statistics for http://pods.jasonrobinson.me/ - * Version: 0.1 + * Description: Generates some statistics for http://the-federation.info/ + * Version: 0.2 * Author: Michael Vogel + * Status: Unsupported */ function statistics_json_install() { @@ -18,13 +19,18 @@ function statistics_json_uninstall() { function statistics_json_module() {} +function statistics_json_plugin_enabled($plugin) { + $r = q("SELECT * FROM `addon` WHERE `installed` = 1 AND `name` = '%s'", $plugin); + return((bool)(count($r) > 0)); +} + function statistics_json_init() { global $a; $statistics = array( "name" => $a->config["sitename"], "network" => FRIENDICA_PLATFORM, - "version" => FRIENDICA_VERSION, + "version" => FRIENDICA_VERSION."-".DB_UPDATE_VERSION, "registrations_open" => ($a->config['register_policy'] != 0), "total_users" => get_config('statistics_json','total_users'), "active_users_halfyear" => get_config('statistics_json','active_users_halfyear'), @@ -32,6 +38,35 @@ function statistics_json_init() { "local_posts" => get_config('statistics_json','local_posts') ); + $statistics["services"] = array(); + $statistics["services"]["appnet"] = statistics_json_plugin_enabled("appnet"); + $statistics["services"]["blogger"] = statistics_json_plugin_enabled("blogger"); + $statistics["services"]["buffer"] = statistics_json_plugin_enabled("buffer"); + $statistics["services"]["dreamwidth"] = statistics_json_plugin_enabled("dwpost"); + $statistics["services"]["facebook"] = statistics_json_plugin_enabled("fbpost"); + $statistics["services"]["gnusocial"] = statistics_json_plugin_enabled("statusnet"); + $statistics["services"]["googleplus"] = statistics_json_plugin_enabled("gpluspost"); + $statistics["services"]["libertree"] = statistics_json_plugin_enabled("libertree"); + $statistics["services"]["livejournal"] = statistics_json_plugin_enabled("ljpost"); + $statistics["services"]["pumpio"] = statistics_json_plugin_enabled("pumpio"); + $statistics["services"]["twitter"] = statistics_json_plugin_enabled("twitter"); + $statistics["services"]["tumblr"] = statistics_json_plugin_enabled("tumblr"); + $statistics["services"]["wordpress"] = statistics_json_plugin_enabled("wppost"); + + $statistics["appnet"] = $statistics["services"]["appnet"]; + $statistics["blogger"] = $statistics["services"]["blogger"]; + $statistics["buffer"] = $statistics["services"]["buffer"]; + $statistics["dreamwidth"] = $statistics["services"]["dreamwidth"]; + $statistics["facebook"] = $statistics["services"]["facebook"]; + $statistics["gnusocial"] = $statistics["services"]["gnusocial"]; + $statistics["googleplus"] = $statistics["services"]["googleplus"]; + $statistics["libertree"] = $statistics["services"]["libertree"]; + $statistics["livejournal"] = $statistics["services"]["livejournal"]; + $statistics["pumpio"] = $statistics["services"]["pumpio"]; + $statistics["twitter"] = $statistics["services"]["twitter"]; + $statistics["tumblr"] = $statistics["services"]["tumblr"]; + $statistics["wordpress"] = $statistics["services"]["wordpress"]; + header("Content-Type: application/json"); echo json_encode($statistics); logger("statistics_init: printed ".print_r($statistics, true)); @@ -42,8 +77,8 @@ function statistics_json_cron($a,$b) { $last = get_config('statistics_json','last_calucation'); if($last) { - // Calculate all 3 hours - $next = $last + (180 * 60); + // Calculate every 24 hours + $next = $last + (24 * 60 * 60); if($next > time()) { logger('statistics_json_cron: calculation intervall not reached'); return; @@ -91,7 +126,7 @@ function statistics_json_cron($a,$b) { set_config('statistics_json','active_users_monthly', $active_users_monthly); } - $posts = q("SELECT COUNT(*) AS local_posts FROM `item` WHERE `wall`"); + $posts = q("SELECT COUNT(*) AS local_posts FROM `item` WHERE `wall` AND `uid` != 0 AND `id` = `parent` AND left(body, 6) != '[share'"); if (!is_array($posts)) $local_posts = -1; @@ -102,6 +137,12 @@ function statistics_json_cron($a,$b) { logger('statistics_json_cron: local_posts: '.$local_posts, LOGGER_DEBUG); + // Now trying to register + $url = "http://the-federation.info/register/".$a->get_hostname(); + logger('statistics_json_cron: registering url: '.$url, LOGGER_DEBUG); + $ret = fetch_url($url); + logger('statistics_json_cron: registering answer: '.$ret, LOGGER_DEBUG); + logger('statistics_json_cron: cron_end'); set_config('statistics_json','last_calucation', time()); }