3 * @copyright Copyright (C) 2010-2022, 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\Statuses;
24 use Friendica\Core\Logger;
25 use Friendica\Module\BaseApi;
27 use Friendica\Model\Contact;
28 use Friendica\Model\Item;
29 use Friendica\Network\HTTPException\BadRequestException;
32 * Destroys a specific status.
34 * @see https://developer.twitter.com/en/docs/tweets/post-and-engage/api-reference/post-statuses-destroy-id
36 class Destroy extends BaseApi
38 protected function post(array $request = [])
40 BaseApi::checkAllowedScope(BaseApi::SCOPE_READ);
41 $uid = BaseApi::getCurrentUserID();
43 if (!empty($this->parameters['id'])) {
44 $id = (int)$this->parameters['id'];
45 } elseif (!empty($request['id'])) {
46 $id = (int)$request['id'];
48 throw new BadRequestException('An id is missing.');
51 $this->logger->notice('API: api_statuses_destroy: ' . $id);
53 $include_entities = filter_var($request['include_entities'] ?? false, FILTER_VALIDATE_BOOLEAN);
55 $ret = DI::twitterStatus()->createFromItemId($id, $uid, $include_entities)->toArray();
57 Item::deleteForUser(['id' => $id], $uid);
59 $this->response->exit('status', ['status' => $ret], $this->parameters['extension'] ?? null, Contact::getPublicIdByUserId($uid));