3 * @copyright Copyright (C) 2010-2023, the Friendica project
5 * @license GNU AGPL version 3 or any later version
7 * This program is free software: you can redistribute it and/or modify
8 * it under the terms of the GNU Affero General Public License as
9 * published by the Free Software Foundation, either version 3 of the
10 * License, or (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU Affero General Public License for more details.
17 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 namespace Friendica\Module\Api\Twitter\Account;
24 use Friendica\Database\DBA;
25 use Friendica\Module\BaseApi;
27 use Friendica\Model\Contact;
28 use Friendica\Model\Profile;
33 class UpdateProfile extends BaseApi
35 protected function post(array $request = [])
37 BaseApi::checkAllowedScope(BaseApi::SCOPE_WRITE);
38 $uid = BaseApi::getCurrentUserID();
40 $api_user = DI::twitterUser()->createFromUserId($uid, true)->toArray();
42 if (!empty($request['name'])) {
43 DBA::update('profile', ['name' => $request['name']], ['uid' => $uid]);
44 DBA::update('user', ['username' => $request['name']], ['uid' => $uid]);
45 Contact::update(['name' => $request['name']], ['uid' => $uid, 'self' => 1]);
46 Contact::update(['name' => $request['name']], ['id' => $api_user['id']]);
49 if (isset($request['description'])) {
50 DBA::update('profile', ['about' => $request['description']], ['uid' => $uid]);
51 Contact::update(['about' => $request['description']], ['uid' => $uid, 'self' => 1]);
52 Contact::update(['about' => $request['description']], ['id' => $api_user['id']]);
55 Contact::updateSelfFromUserID($uid, true);
57 Profile::publishUpdate($uid);
59 $skip_status = $this->getRequestValue($request, 'skip_status', false);
61 $user_info = DI::twitterUser()->createFromUserId($uid, $skip_status)->toArray();
63 // "verified" isn't used here in the standard
64 unset($user_info["verified"]);
66 // "uid" is only needed for some internal stuff, so remove it from here
67 unset($user_info['uid']);
69 $this->response->exit('user', ['user' => $user_info], $this->parameters['extension'] ?? null);