]> git.mxchange.org Git - friendica.git/blobdiff - src/Model/Nodeinfo.php
Merge pull request #9806 from Extarys/actionfade
[friendica.git] / src / Model / Nodeinfo.php
index d39641553114acc8fa527b36f40457a5b6504e80..ef22c0dddfa06f2af02206332b5a74f21e57c93d 100644 (file)
@@ -24,6 +24,7 @@ namespace Friendica\Model;
 use Friendica\Core\Addon;
 use Friendica\Database\DBA;
 use Friendica\DI;
+use stdClass;
 
 /**
  * Model interaction for the nodeinfo
@@ -43,20 +44,7 @@ class 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'))) {
@@ -68,10 +56,11 @@ class 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->debug('user statistics', $userStats);
 
-               $items = DBA::p("SELECT COUNT(*) AS `total`, `gravity` FROM `item` WHERE `origin` AND NOT `deleted` AND `uid` != 0 AND `gravity` IN (?, ?) GROUP BY `gravity`",
+               $items = DBA::p("SELECT COUNT(*) AS `total`, `gravity` FROM `post-view` 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) {
@@ -82,4 +71,109 @@ class Nodeinfo
                }
                DBA::close($items);
        }
+
+       /**
+        * 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';
+
+               if (Addon::isEnabled('tumblr')) {
+                       $services['outbound'][] = 'tumblr';
+               }
+               if (Addon::isEnabled('twitter') || Addon::isEnabled('buffer')) {
+                       $services['outbound'][] = 'twitter';
+               }
+               if (Addon::isEnabled('wppost')) {
+                       $services['outbound'][] = 'wordpress';
+               }
+
+               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'];
+                       }
+               }
+
+               return $organization;
+       }
 }