]> git.mxchange.org Git - friendica.git/commitdiff
Moving mod/statistics_json to src/Module/Statistics_json
authorPhilipp Holzer <admin@philipp.info>
Mon, 22 Apr 2019 08:38:34 +0000 (10:38 +0200)
committerPhilipp Holzer <admin@philipp.info>
Mon, 22 Apr 2019 08:38:34 +0000 (10:38 +0200)
mod/statistics_json.php [deleted file]
src/Module/Statistics_json.php [new file with mode: 0644]

diff --git a/mod/statistics_json.php b/mod/statistics_json.php
deleted file mode 100644 (file)
index a8d3c8a..0000000
+++ /dev/null
@@ -1,63 +0,0 @@
-<?php
-
-/**
- * @file mod/statistics_json.php
- */
-
-use Friendica\App;
-use Friendica\Core\Addon;
-use Friendica\Core\Config;
-use Friendica\Core\Logger;
-use Friendica\Core\System;
-
-function statistics_json_init(App $a) {
-
-       if (!Config::get("system", "nodeinfo")) {
-               System::httpExit(404);
-       }
-
-       $registration_open =
-               intval(Config::get('config', 'register_policy')) !== \Friendica\Module\Register::CLOSED
-               && ! Config::get('config', 'invitation_only');
-
-       $statistics = [
-               "name" => Config::get('config', 'sitename'),
-               "network" => FRIENDICA_PLATFORM,
-               "version" => FRIENDICA_VERSION . "-" . DB_UPDATE_VERSION,
-               "registrations_open" => $registration_open,
-               "total_users" => Config::get('nodeinfo', 'total_users'),
-               "active_users_halfyear" => Config::get('nodeinfo', 'active_users_halfyear'),
-               "active_users_monthly" => Config::get('nodeinfo', 'active_users_monthly'),
-               "local_posts" => Config::get('nodeinfo', 'local_posts')
-       ];
-
-       $statistics["services"] = [];
-       $statistics["services"]["appnet"] = Addon::isEnabled("appnet");
-       $statistics["services"]["blogger"] = Addon::isEnabled("blogger");
-       $statistics["services"]["buffer"] = Addon::isEnabled("buffer");
-       $statistics["services"]["dreamwidth"] = Addon::isEnabled("dwpost");
-       $statistics["services"]["gnusocial"] = Addon::isEnabled("statusnet");
-       $statistics["services"]["libertree"] = Addon::isEnabled("libertree");
-       $statistics["services"]["livejournal"] = Addon::isEnabled("ljpost");
-       $statistics["services"]["pumpio"] = Addon::isEnabled("pumpio");
-       $statistics["services"]["twitter"] = Addon::isEnabled("twitter");
-       $statistics["services"]["tumblr"] = Addon::isEnabled("tumblr");
-       $statistics["services"]["wordpress"] = Addon::isEnabled("wppost");
-
-       $statistics["appnet"] = $statistics["services"]["appnet"];
-       $statistics["blogger"] = $statistics["services"]["blogger"];
-       $statistics["buffer"] = $statistics["services"]["buffer"];
-       $statistics["dreamwidth"] = $statistics["services"]["dreamwidth"];
-       $statistics["gnusocial"] = $statistics["services"]["gnusocial"];
-       $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, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
-       Logger::log("statistics_init: printed " . print_r($statistics, true), Logger::DATA);
-       exit();
-}
diff --git a/src/Module/Statistics_json.php b/src/Module/Statistics_json.php
new file mode 100644 (file)
index 0000000..aca204b
--- /dev/null
@@ -0,0 +1,60 @@
+<?php
+
+namespace Friendica\Module;
+
+use Friendica\BaseModule;
+use Friendica\Core\Addon;
+use Friendica\Core\System;
+
+class Statistics_json extends BaseModule
+{
+       public static function init()
+       {
+               $config = self::getApp()->getConfig();
+
+               if (!$config->get("system", "nodeinfo")) {
+                       System::httpExit(404);
+               }
+       }
+
+       public static function rawContent()
+       {
+               $config = self::getApp()->getConfig();
+               $logger = self::getApp()->getLogger();
+
+               $registration_open =
+                       intval($config->get('config', 'register_policy')) !== Register::CLOSED
+                       && !$config->get('config', 'invitation_only');
+
+               /// @todo mark the "service" addons and load them dynamically here
+               $services = [
+                       'appnet'      => Addon::isEnabled('appnet'),
+                       'buffer'      => Addon::isEnabled('buffer'),
+                       'dreamwidth'  => Addon::isEnabled('dreamwidth'),
+                       'gnusocial'   => Addon::isEnabled('gnusocial'),
+                       'libertree'   => Addon::isEnabled('libertree'),
+                       'livejournal' => Addon::isEnabled('livejournal'),
+                       'pumpio'      => Addon::isEnabled('pumpio'),
+                       'twitter'     => Addon::isEnabled('twitter'),
+                       'tumblr'      => Addon::isEnabled('tumblr'),
+                       'wordpress'   => Addon::isEnabled('wordpress'),
+               ];
+
+               $statistics = array_merge([
+                       'name'                  => $config->get('config', 'sitename'),
+                       'network'               => FRIENDICA_PLATFORM,
+                       'version'               => FRIENDICA_VERSION . '-' . DB_UPDATE_VERSION,
+                       'registrations_open'    => $registration_open,
+                       'total_users'           => $config->get('nodeinfo', 'total_users'),
+                       'active_users_halfyear' => $config->get('nodeinfo', 'active_users_halfyear'),
+                       'active_users_monthly'  => $config->get('nodeinfo', 'active_users_monthly'),
+                       'local_posts'           => $config->get('nodeinfo', 'local_posts'),
+                       'services'              => $services,
+               ], $services);
+
+               header("Content-Type: application/json");
+               echo json_encode($statistics, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES);
+               $logger->debug("statistics.", ['statistics' => $statistics]);
+               exit();
+       }
+}