<?php
/**
- * @copyright Copyright (C) 2020, Friendica
+ * @copyright Copyright (C) 2010-2022, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
use Friendica\Core\Addon;
use Friendica\Database\DBA;
use Friendica\DI;
+use stdClass;
/**
* Model interaction for the nodeinfo
// If the addon 'statistics_json' is enabled then disable it and activate nodeinfo.
if (Addon::isEnabled('statistics_json')) {
$config->set('system', 'nodeinfo', true);
-
- $addon = 'statistics_json';
- $addons = $config->get('system', 'addon');
-
- if ($addons) {
- $addons_arr = explode(',', str_replace(' ', '', $addons));
-
- $idx = array_search($addon, $addons_arr);
- if ($idx !== false) {
- unset($addons_arr[$idx]);
- Addon::uninstall($addon);
- $config->set('system', 'addon', implode(', ', $addons_arr));
- }
- }
+ Addon::uninstall('statistics_json');
}
if (empty($config->get('system', 'nodeinfo'))) {
$config->set('nodeinfo', 'total_users', $userStats['total_users']);
$config->set('nodeinfo', 'active_users_halfyear', $userStats['active_users_halfyear']);
$config->set('nodeinfo', 'active_users_monthly', $userStats['active_users_monthly']);
+ $config->set('nodeinfo', 'active_users_weekly', $userStats['active_users_weekly']);
+
+ $logger->info('user statistics', $userStats);
+
+ $posts = DBA::count('post-thread', ["EXISTS(SELECT `uri-id` FROM `post-user` WHERE NOT `deleted` AND `origin` AND `uri-id` = `post-thread`.`uri-id`)"]);
+ $comments = DBA::count('post', ["NOT `deleted` AND `gravity` = ? AND EXISTS(SELECT `uri-id` FROM `post-user` WHERE `origin` AND `uri-id` = `post`.`uri-id`)", GRAVITY_COMMENT]);
+ $config->set('nodeinfo', 'local_posts', $posts);
+ $config->set('nodeinfo', 'local_comments', $comments);
+
+ $logger->info('User actitivy', ['posts' => $posts, 'comments' => $comments]);
+ }
+
+ /**
+ * Return the supported services
+ *
+ * @return Object with supported services
+ */
+ public static function getUsage(bool $version2 = false)
+ {
+ $config = DI::config();
+
+ $usage = new stdClass();
+
+ if (!empty($config->get('system', 'nodeinfo'))) {
+ $usage->users = [
+ 'total' => intval($config->get('nodeinfo', 'total_users')),
+ 'activeHalfyear' => intval($config->get('nodeinfo', 'active_users_halfyear')),
+ 'activeMonth' => intval($config->get('nodeinfo', 'active_users_monthly'))
+ ];
+ $usage->localPosts = intval($config->get('nodeinfo', 'local_posts'));
+ $usage->localComments = intval($config->get('nodeinfo', 'local_comments'));
+
+ if ($version2) {
+ $usage->users['activeWeek'] = intval($config->get('nodeinfo', 'active_users_weekly'));
+ }
+ }
+
+ return $usage;
+ }
+
+ /**
+ * Return the supported services
+ *
+ * @return array with supported services
+ */
+ public static function getServices()
+ {
+ $services = [
+ 'inbound' => [],
+ 'outbound' => [],
+ ];
+
+ if (Addon::isEnabled('blogger')) {
+ $services['outbound'][] = 'blogger';
+ }
+ if (Addon::isEnabled('dwpost')) {
+ $services['outbound'][] = 'dreamwidth';
+ }
+ if (Addon::isEnabled('statusnet')) {
+ $services['inbound'][] = 'gnusocial';
+ $services['outbound'][] = 'gnusocial';
+ }
+ if (Addon::isEnabled('ijpost')) {
+ $services['outbound'][] = 'insanejournal';
+ }
+ if (Addon::isEnabled('libertree')) {
+ $services['outbound'][] = 'libertree';
+ }
+ if (Addon::isEnabled('buffer')) {
+ $services['outbound'][] = 'linkedin';
+ }
+ if (Addon::isEnabled('ljpost')) {
+ $services['outbound'][] = 'livejournal';
+ }
+ if (Addon::isEnabled('buffer')) {
+ $services['outbound'][] = 'pinterest';
+ }
+ if (Addon::isEnabled('posterous')) {
+ $services['outbound'][] = 'posterous';
+ }
+ if (Addon::isEnabled('pumpio')) {
+ $services['inbound'][] = 'pumpio';
+ $services['outbound'][] = 'pumpio';
+ }
+
+ $services['outbound'][] = 'smtp';
- $logger->debug('user statistics', $userStats);
+ if (Addon::isEnabled('tumblr')) {
+ $services['outbound'][] = 'tumblr';
+ }
+ if (Addon::isEnabled('twitter') || Addon::isEnabled('buffer')) {
+ $services['outbound'][] = 'twitter';
+ }
+ if (Addon::isEnabled('wppost')) {
+ $services['outbound'][] = 'wordpress';
+ }
- $items = DBA::p("SELECT COUNT(*) AS `total`, `gravity` FROM `item` WHERE `origin` AND NOT `deleted` AND `uid` != 0 AND `gravity` IN (?, ?) GROUP BY `gravity`",
- GRAVITY_PARENT, GRAVITY_COMMENT);
- while ($item = DBA::fetch($items)) {
- if ($item['gravity'] == GRAVITY_PARENT) {
- $config->set('nodeinfo', 'local_posts', $item['total']);
- } elseif ($item['gravity'] == GRAVITY_COMMENT) {
- $config->set('nodeinfo', 'local_comments', $item['total']);
+ return $services;
+ }
+
+ public static function getOrganization($config)
+ {
+ $organization = ['name' => null, 'contact' => null, 'account' => null];
+
+ if (!empty($config->get('config', 'admin_email'))) {
+ $adminList = explode(',', str_replace(' ', '', $config->get('config', 'admin_email')));
+ $organization['contact'] = $adminList[0];
+ $administrator = User::getByEmail($adminList[0], ['username', 'nickname']);
+ if (!empty($administrator)) {
+ $organization['name'] = $administrator['username'];
+ $organization['account'] = DI::baseUrl()->get() . '/profile/' . $administrator['nickname'];
}
}
- DBA::close($items);
+
+ return $organization;
}
}