]> git.mxchange.org Git - friendica.git/commitdiff
Added entities
authorMichael <heluecht@pirati.ca>
Wed, 11 Dec 2019 06:51:59 +0000 (06:51 +0000)
committerMichael <heluecht@pirati.ca>
Wed, 11 Dec 2019 06:51:59 +0000 (06:51 +0000)
src/Api/Mastodon/Instance.php [new file with mode: 0644]
src/Api/Mastodon/Stats.php [new file with mode: 0644]
src/Module/Api/Mastodon/Instance.php

diff --git a/src/Api/Mastodon/Instance.php b/src/Api/Mastodon/Instance.php
new file mode 100644 (file)
index 0000000..fef7394
--- /dev/null
@@ -0,0 +1,83 @@
+<?php
+
+namespace Friendica\Api\Mastodon;
+
+use Friendica\Core\Protocol;
+
+use Friendica\Api\Mastodon\Account;
+use Friendica\Api\Mastodon\Stats;
+use Friendica\Core\Config;
+use Friendica\Database\DBA;
+use Friendica\Model\User;
+use Friendica\Module\Register;
+
+/**
+ * Class Account
+ *
+ * @see https://docs.joinmastodon.org/api/entities/#instance
+ */
+class Instance
+{
+       /** @var string (URL) */
+       var $uri;
+       /** @var string */
+       var $title;
+       /** @var string */
+       var $description;
+       /** @var string */
+       var $email;
+       /** @var string */
+       var $version;
+       /** @var array */
+       var $urls;
+       /** @var Stats */
+       var $stats;
+       /** @var string */
+       var $thumbnail;
+       /** @var array */
+       var $languages;
+       /** @var int */
+       var $max_toot_chars;
+       /** @var bool */
+       var $registrations;
+       /** @var bool */
+       var $approval_required;
+       /** @var Account|null */
+       var $contact_account;
+
+       /**
+        * Creates an instance record
+        *
+        * @return Instance
+        * @throws \Friendica\Network\HTTPException\InternalServerErrorException
+        */
+       public static function get($app) {
+               $register_policy = intval(Config::get('config', 'register_policy'));
+
+               $instance = new Instance();
+               $instance->uri = $app->getBaseURL();
+               $instance->title = Config::get('config', 'sitename');
+               $instance->description = Config::get('config', 'info');
+               $instance->email = Config::get('config', 'admin_email');
+               $instance->version = FRIENDICA_VERSION;
+               $instance->urls = []; // Not supported
+               $instance->stats = Stats::get();
+               $instance->thumbnail = $app->getBaseURL() . (Config::get('system', 'shortcut_icon') ?? 'images/friendica-32.png');
+               $instance->languages = [Config::get('system', 'language')];
+               $instance->max_toot_chars = (int)Config::get('config', 'api_import_size', Config::get('config', 'max_import_size'));
+               $instance->registrations = ($register_policy != Register::CLOSED);
+               $instance->approval_required = ($register_policy == Register::APPROVE);
+               $instance->contact_account = [];
+
+               if (!empty(Config::get('config', 'admin_email'))) {
+                       $adminList = explode(',', str_replace(' ', '', Config::get('config', 'admin_email')));
+                       $administrator = User::getByEmail($adminList[0], ['nickname']);
+                       if (!empty($administrator)) {
+                               $adminContact = DBA::selectFirst('contact', [], ['nick' => $administrator['nickname'], 'self' => true]);
+                               $instance->contact_account = Account::createFromContact($adminContact);
+                       }
+               }
+
+               return $instance;
+       }
+}
diff --git a/src/Api/Mastodon/Stats.php b/src/Api/Mastodon/Stats.php
new file mode 100644 (file)
index 0000000..895a58e
--- /dev/null
@@ -0,0 +1,38 @@
+<?php
+
+namespace Friendica\Api\Mastodon;
+
+use Friendica\Core\Config;
+use Friendica\Core\Protocol;
+use Friendica\Database\DBA;
+
+/**
+ * Class Stats
+ *
+ * @see https://docs.joinmastodon.org/api/entities/#stats
+ */
+class Stats
+{
+       /** @var int */
+       var $user_count;
+       /** @var int */
+       var $status_count;
+       /** @var int */
+       var $domain_count;
+
+       /**
+        * Creates a stats record
+        *
+        * @return Stats
+        * @throws \Friendica\Network\HTTPException\InternalServerErrorException
+        */
+       public static function get() {
+               $stats = new Stats();
+               if (!empty(Config::get('system', 'nodeinfo'))) {
+                       $stats->user_count = intval(Config::get('nodeinfo', 'total_users'));
+                       $stats->status_count = Config::get('nodeinfo', 'local_posts') + Config::get('nodeinfo', 'local_comments');
+                       $stats->domain_count = DBA::count('gserver', ["`network` in (?, ?) AND `last_contact` >= `last_failure`", Protocol::DFRN, Protocol::ACTIVITYPUB]);
+               }
+               return $stats;
+       }
+}
index 321dbf7caf2c0251142099143205f620e55460f8..6a2b3abb636c42d128b047d5c65082d82c61d095 100644 (file)
@@ -2,75 +2,21 @@
 
 namespace Friendica\Module\Api\Mastodon;
 
-use Friendica\Api\Mastodon\Account;
-use Friendica\Core\Config;
-use Friendica\Core\Protocol;
+use Friendica\Api\Mastodon\Instance as InstanceEntity;
 use Friendica\Core\System;
-use Friendica\Database\DBA;
-use Friendica\Model\User;
 use Friendica\Module\Base\Api;
-use Friendica\Module\Register;
-use Friendica\Network\HTTPException;
-use Friendica\Util\Network;
 
 /**
  * @see https://docs.joinmastodon.org/api/rest/instances/
  */
 class Instance extends Api
 {
-       public static function init(array $parameters = [])
-       {
-               parent::init($parameters);
-       }
-
        /**
         * @param array $parameters
         * @throws HTTPException\InternalServerErrorException
         */
        public static function rawContent(array $parameters = [])
        {
-               $app = self::getApp();
-
-                $register_policy = intval(Config::get('config', 'register_policy'));
-
-               $return = [
-                       'uri' => $app->getBaseURL(),
-                       'title' => Config::get('config', 'sitename'),
-                       'description' => Config::get('config', 'info'),
-                       'email' => Config::get('config', 'admin_email'),
-                       'version' => FRIENDICA_VERSION,
-                       'urls' => [], // Not supported
-                       'stats' => [],
-                       'thumbnail' => $app->getBaseURL() . (Config::get('system', 'shortcut_icon') ?? 'images/friendica-32.png'),
-                       'languages' => [Config::get('system', 'language')],
-                       'max_toot_chars' => (int)Config::get('config', 'api_import_size', Config::get('config', 'max_import_size')),
-                       'registrations' => ($register_policy != Register::CLOSED),
-                       'approval_required' => ($register_policy == Register::APPROVE),
-                       'contact_account' => []
-               ];
-
-               if (!$return['registrations']) {
-                       unset($return['approval_required']);
-               }
-
-               if (!empty(Config::get('system', 'nodeinfo'))) {
-                       $count = DBA::count('gserver', ["`network` in (?, ?) AND `last_contact` >= `last_failure`", Protocol::DFRN, Protocol::ACTIVITYPUB]);
-                       $return['stats'] = [
-                               'user_count' => intval(Config::get('nodeinfo', 'total_users')),
-                               'status_count' => Config::get('nodeinfo', 'local_posts') + Config::get('nodeinfo', 'local_comments'),
-                               'domain_count' => $count
-                       ];
-               }
-
-               if (!empty(Config::get('config', 'admin_email'))) {
-                       $adminList = explode(',', str_replace(' ', '', Config::get('config', 'admin_email')));
-                       $administrator = User::getByEmail($adminList[0], ['nickname']);
-                       if (!empty($administrator)) {
-                               $adminContact = DBA::selectFirst('contact', [], ['nick' => $administrator['nickname'], 'self' => true]);
-                               $return['contact_account'] = Account::createFromContact($adminContact);
-                       }
-               }
-
-               System::jsonExit($return);
+               System::jsonExit(InstanceEntity::get(self::getApp()));
        }
 }