]> git.mxchange.org Git - friendica-addons.git/commitdiff
statistics: For performance reasons the calculations are done via cron. Additionally...
authorMichael Vogel <icarus@dabo.de>
Sun, 2 Feb 2014 09:05:23 +0000 (10:05 +0100)
committerMichael Vogel <icarus@dabo.de>
Sun, 2 Feb 2014 09:05:23 +0000 (10:05 +0100)
statistics_json/statistics_json.php

index fe48bac2457b8594f874549c56293d6d1687419a..5bc4902e13e43450f67459fae7264fc238580a17 100644 (file)
@@ -8,10 +8,12 @@
  */
 
 function statistics_json_install() {
+       register_hook('cron', 'addon/statistics_json/statistics_json.php', 'statistics_json_cron');
 }
 
 
 function statistics_json_uninstall() {
+       unregister_hook('cron', 'addon/statistics_json/statistics_json.php', 'statistics_json_cron');
 }
 
 function statistics_json_module() {}
@@ -23,8 +25,32 @@ function statistics_json_init() {
                        "name" => $a->config["sitename"],
                        "version" => FRIENDICA_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'),
+                       "active_users_monthly" => get_config('statistics_json','active_users_monthly'),
+                       "local_posts" => get_config('statistics_json','local_posts')
                        );
 
+       header("Content-Type: application/json");
+       echo json_encode($statistics);
+       logger("statistics_init: printed ".print_r($statistics, true));
+       killme();
+}
+
+function statistics_json_cron($a,$b) {
+       $last = get_config('statistics_json','last_calucation');
+
+       if($last) {
+               // Calculate all 3 hours
+               $next = $last + (180 * 60);
+               if($next > time()) {
+                       logger('statistics_json_cron: calculation intervall not reached');
+                       return;
+               }
+       }
+        logger('statistics_json_cron: cron_start');
+
+
        $users = q("SELECT profile.*, `user`.`login_date`, `lastitem`.`lastitem_date`
                        FROM (SELECT MAX(`item`.`changed`) as `lastitem_date`, `item`.`uid`
                                FROM `item`
@@ -39,14 +65,10 @@ function statistics_json_init() {
                                        AND NOT `user`.`account_removed`
                                        AND NOT `user`.`account_expired`");
 
-       if (!is_array($users)) {
-                       $statistics["total_users"] = -1;
-                       $statistics["active_users_halfyear"] = -1;
-                       $statistics["active_users_monthly"] = -1;
-       } else {
-                       $statistics["total_users"] = count($users);
-                       $statistics["active_users_halfyear"] = 0;
-                       $statistics["active_users_monthly"] = 0;
+       if (is_array($users)) {
+                       $total_users = count($users);
+                       $active_users_halfyear = 0;
+                       $active_users_monthly = 0;
 
                        $halfyear = time() - (180 * 24 * 60 * 60);
                        $month = time() - (30 * 24 * 60 * 60);
@@ -54,23 +76,31 @@ function statistics_json_init() {
                        foreach ($users AS $user) {
                                if ((strtotime($user['login_date']) > $halfyear) OR
                                        (strtotime($user['lastitem_date']) > $halfyear))
-                                       ++$statistics["active_users_halfyear"];
+                                       ++$active_users_halfyear;
 
                                if ((strtotime($user['login_date']) > $month) OR
                                        (strtotime($user['lastitem_date']) > $month))
-                                       ++$statistics["active_users_monthly"];
+                                       ++$active_users_monthly;
 
                        }
+                       set_config('statistics_json','total_users', $total_users);
+                       logger('statistics_json_cron: total_users: '.$total_users, LOGGER_DEBUG);
+
+                       set_config('statistics_json','active_users_halfyear', $active_users_halfyear);
+                       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 id=parent");
+
        if (!is_array($posts))
-               $statistics["local_posts"] = -1;
+               $local_posts = -1;
        else
-               $statistics["local_posts"] = $posts[0]["local_posts"];
+               $local_posts = $posts[0]["local_posts"];
 
-       header("Content-Type: application/json");
-       echo json_encode($statistics);
-       logger("statistics_init: printed ".print_r($statistics, true));
-       killme();
+       set_config('statistics_json','local_posts', $local_posts);
+
+        logger('statistics_json_cron: local_posts: '.$local_posts, LOGGER_DEBUG);
+
+        logger('statistics_json_cron: cron_end');
+       set_config('statistics_json','last_calucation', time());
 }