3 * @copyright Copyright (C) 2010-2021, 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 public function rawContent()
37 BaseApi::checkAllowedScope(BaseApi::SCOPE_WRITE);
38 $uid = BaseApi::getCurrentUserID();
40 $api_user = DI::twitterUser()->createFromUserId($uid, true)->toArray();
42 if (!empty($_POST['name'])) {
43 DBA::update('profile', ['name' => $_POST['name']], ['uid' => $uid]);
44 DBA::update('user', ['username' => $_POST['name']], ['uid' => $uid]);
45 Contact::update(['name' => $_POST['name']], ['uid' => $uid, 'self' => 1]);
46 Contact::update(['name' => $_POST['name']], ['id' => $api_user['id']]);
49 if (isset($_POST['description'])) {
50 DBA::update('profile', ['about' => $_POST['description']], ['uid' => $uid]);
51 Contact::update(['about' => $_POST['description']], ['uid' => $uid, 'self' => 1]);
52 Contact::update(['about' => $_POST['description']], ['id' => $api_user['id']]);
55 Profile::publishUpdate($uid);
57 $skip_status = $_REQUEST['skip_status'] ?? false;
59 $user_info = DI::twitterUser()->createFromUserId($uid, $skip_status)->toArray();
61 // "verified" isn't used here in the standard
62 unset($user_info["verified"]);
64 // "uid" is only needed for some internal stuff, so remove it from here
65 unset($user_info['uid']);
67 DI::apiResponse()->exit('user', ['user' => $user_info], $this->parameters['extension'] ?? null);