]> git.mxchange.org Git - friendica.git/blob - src/Api/Mastodon/Account.php
Add missing fields to Mastodon API Account entity
[friendica.git] / src / Api / Mastodon / Account.php
1 <?php
2
3 namespace Friendica\Api\Mastodon;
4
5 use Friendica\Content\Text\BBCode;
6 use Friendica\Database\DBA;
7 use Friendica\Model\Contact;
8 use Friendica\Util\DateTimeFormat;
9
10 /**
11  * Class Account
12  *
13  * @see https://docs.joinmastodon.org/entities/account
14  */
15 class Account
16 {
17         /** @var string */
18         var $id;
19         /** @var string */
20         var $username;
21         /** @var string */
22         var $acct;
23         /** @var string */
24         var $display_name;
25         /** @var bool */
26         var $locked;
27         /** @var string (Datetime) */
28         var $created_at;
29         /** @var int */
30         var $followers_count;
31         /** @var int */
32         var $following_count;
33         /** @var int */
34         var $statuses_count;
35         /** @var string */
36         var $note;
37         /** @var string (URL)*/
38         var $url;
39         /** @var string (URL) */
40         var $avatar;
41         /** @var string (URL) */
42         var $avatar_static;
43         /** @var string (URL) */
44         var $header;
45         /** @var string (URL) */
46         var $header_static;
47         /** @var Emoji[] */
48         var $emojis;
49         /** @var Account|null */
50         var $moved = null;
51         /** @var Field[]|null */
52         var $fields = null;
53         /** @var bool|null */
54         var $bot = null;
55         /** @var bool */
56         var $group;
57         /** @var bool */
58         var $discoverable;
59         /** @var string|null (Datetime) */
60         var $last_status_at = null;
61
62         /**
63          * Creates an account record from a public contact record. Expects all contact table fields to be set.
64          *
65          * @param array $publicContact Full contact table record with uid = 0
66          * @param array $apcontact     Optional full apcontact table record
67          * @return Account
68          * @throws \Friendica\Network\HTTPException\InternalServerErrorException
69          */
70         public static function create(array $publicContact, array $apcontact = [])
71         {
72                 $account = new Account();
73                 $account->id              = $publicContact['id'];
74                 $account->username        = $publicContact['nick'];
75                 $account->acct            = $publicContact['addr'];
76                 $account->display_name    = $publicContact['name'];
77                 $account->locked          = !empty($apcontact['manually-approve']);
78                 $account->created_at      = DateTimeFormat::utc($publicContact['created'], DateTimeFormat::ATOM);
79                 $account->followers_count = $apcontact['followers_count'] ?? 0;
80                 $account->following_count = $apcontact['following_count'] ?? 0;
81                 $account->statuses_count  = $apcontact['statuses_count'] ?? 0;
82                 $account->note            = BBCode::convert($publicContact['about'], false);
83                 $account->url             = $publicContact['url'];
84                 $account->avatar          = $publicContact['avatar'];
85                 $account->avatar_static   = $publicContact['avatar'];
86                 // No header picture in Friendica
87                 $account->header          = '';
88                 $account->header_static   = '';
89                 // No custom emojis per account in Friendica
90                 $account->emojis          = [];
91                 // No metadata fields in Friendica
92                 $account->fields          = [];
93                 $account->bot             = ($publicContact['contact-type'] == Contact::TYPE_NEWS);
94                 $account->group           = ($publicContact['contact-type'] == Contact::TYPE_COMMUNITY);
95                 $account->discoverable    = !$publicContact['unsearchable'];
96                 $account->last_status_at  = !empty($publicContact['last-item']) ? DateTimeFormat::utc($publicContact['last-item'], DateTimeFormat::ATOM) : null;
97
98                 return $account;
99         }
100 }