<?php
/**
- * @copyright Copyright (C) 2010-2022, the Friendica project
+ * @copyright Copyright (C) 2010-2023, the Friendica project
*
* @license GNU AGPL version 3 or any later version
*
use Friendica\Core\System;
use Friendica\DI;
use Friendica\Model\Item;
-use Friendica\Core\Session;
use Friendica\Model\Post;
use Friendica\Network\HTTPException;
use Friendica\Protocol\Diaspora;
{
protected function rawContent(array $request = [])
{
- if (!Session::isAuthenticated()) {
+ if (!DI::userSession()->isAuthenticated()) {
throw new HTTPException\ForbiddenException();
}
throw new HTTPException\BadRequestException();
}
- $verb = $this->parameters['verb'];
- $itemId = $this->parameters['id'];
+ $verb = $this->parameters['verb'];
+ $itemId = $this->parameters['id'];
+ $handled = false;
if (in_array($verb, ['announce', 'unannounce'])) {
- $item = Post::selectFirst(['network', 'uri-id', 'uid'], ['id' => $itemId]);
+ $item = Post::selectFirst(['network', 'uri-id'], ['id' => $itemId, 'uid' => [DI::userSession()->getLocalUserId(), 0]]);
if ($item['network'] == Protocol::DIASPORA) {
- Diaspora::performReshare($item['uri-id'], $item['uid']);
+ $quote = Post::selectFirst(['id'], ['quote-uri-id' => $item['uri-id'], 'body' => '', 'origin' => true, 'uid' => DI::userSession()->getLocalUserId()]);
+ if (!empty($quote['id'])) {
+ if (!Item::markForDeletionById($quote['id'])) {
+ throw new HTTPException\BadRequestException();
+ }
+ } else {
+ Diaspora::performReshare($item['uri-id'], DI::userSession()->getLocalUserId());
+ }
+ $handled = true;
}
}
- if (!Item::performActivity($itemId, $verb, local_user())) {
+ if (!$handled && !Item::performActivity($itemId, $verb, DI::userSession()->getLocalUserId())) {
throw new HTTPException\BadRequestException();
}