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();
|
||||
}
|
|
@ -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 New Issue
Block a user