Merge pull request #7027 from nupplaphil/task/mod_statistics_json
Moving mod/statistics_json to src/Module/Statistics_json
This commit is contained in:
commit
0aa0ec2710
|
@ -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();
|
|
||||||
}
|
|
60
src/Module/Statistics_json.php
Normal file
60
src/Module/Statistics_json.php
Normal file
|
@ -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();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue