]> git.mxchange.org Git - friendica-addons.git/blobdiff - statistics_json/statistics_json.php
Additional work for PR 3778
[friendica-addons.git] / statistics_json / statistics_json.php
index 6861b130ba6c23526a4135134d88f009531386be..2bd2f41f60ff320017353e88329fa70485e4b75c 100644 (file)
@@ -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 <https://pirati.ca/profile/heluecht>
+ * 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,11 +77,11 @@ function statistics_json_cron($a,$b) {
        $last = get_config('statistics_json','last_calucation');
 
        if($last) {
-               // Calculate all 6 hours
-               $next = $last + (360 * 60);
+               // Calculate every 24 hours
+               $next = $last + (24 * 60 * 60);
                if($next > time()) {
                        logger('statistics_json_cron: calculation intervall not reached');
-//                     return;
+                       return;
                }
        }
         logger('statistics_json_cron: cron_start');
@@ -75,11 +110,11 @@ function statistics_json_cron($a,$b) {
                        $month = time() - (30 * 24 * 60 * 60);
 
                        foreach ($users AS $user) {
-                               if ((strtotime($user['login_date']) > $halfyear) OR
+                               if ((strtotime($user['login_date']) > $halfyear) ||
                                        (strtotime($user['lastitem_date']) > $halfyear))
                                        ++$active_users_halfyear;
 
-                               if ((strtotime($user['login_date']) > $month) OR
+                               if ((strtotime($user['login_date']) > $month) ||
                                        (strtotime($user['lastitem_date']) > $month))
                                        ++$active_users_monthly;
 
@@ -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` AND left(body, 6) != '[share'");
+       $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;
@@ -103,7 +138,7 @@ function statistics_json_cron($a,$b) {
         logger('statistics_json_cron: local_posts: '.$local_posts, LOGGER_DEBUG);
 
        // Now trying to register
-       $url = "http://pods.jasonrobinson.me/register/".$a->get_hostname();
+       $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);