- Add typing for most of the services, controllers and mappers - Add api doc for mappers - Use vendor-bin for psalm - Use attributes for controllers - Fix upload of attachments Signed-off-by: Carl Schwan <carl.schwan@nextcloud.com>
185 lines
4.8 KiB
PHP
185 lines
4.8 KiB
PHP
<?php
|
|
|
|
/**
|
|
* SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
namespace OCA\Deck\Controller;
|
|
|
|
use OCA\Deck\Model\OptionalNullableValue;
|
|
use OCA\Deck\Service\AssignmentService;
|
|
use OCA\Deck\Service\CardService;
|
|
use OCP\AppFramework\ApiController;
|
|
use OCP\AppFramework\Http;
|
|
use OCP\AppFramework\Http\Attribute\CORS;
|
|
use OCP\AppFramework\Http\Attribute\NoAdminRequired;
|
|
use OCP\AppFramework\Http\Attribute\NoCSRFRequired;
|
|
use OCP\AppFramework\Http\DataResponse;
|
|
use OCP\IRequest;
|
|
|
|
/**
|
|
* Class BoardApiController
|
|
*
|
|
* @package OCA\Deck\Controller
|
|
*/
|
|
class CardApiController extends ApiController {
|
|
|
|
/**
|
|
* @param string $appName
|
|
* @param IRequest $request
|
|
* @param CardService $cardService
|
|
* @param AssignmentService $assignmentService
|
|
* @param string $userId
|
|
*/
|
|
public function __construct(
|
|
string $appName,
|
|
IRequest $request,
|
|
private CardService $cardService,
|
|
private AssignmentService $assignmentService,
|
|
private $userId,
|
|
) {
|
|
parent::__construct($appName, $request);
|
|
}
|
|
|
|
/**
|
|
* @NoAdminRequired
|
|
* @CORS
|
|
* @NoCSRFRequired
|
|
*
|
|
* Get a specific card.
|
|
*/
|
|
public function get() {
|
|
$card = $this->cardService->find($this->request->getParam('cardId'));
|
|
$response = new DataResponse($card, HTTP::STATUS_OK);
|
|
$response->setETag($card->getEtag());
|
|
return $response;
|
|
}
|
|
|
|
/**
|
|
* @NoAdminRequired
|
|
* @CORS
|
|
* @NoCSRFRequired
|
|
*
|
|
* @params $title
|
|
* @params $type
|
|
* @params $order
|
|
* @params $description
|
|
*
|
|
* Get a specific card.
|
|
*/
|
|
public function create($title, $type = 'plain', $order = 999, $description = '', $duedate = null, $labels = [], $users = []) {
|
|
$card = $this->cardService->create($title, $this->request->getParam('stackId'), $type, $order, $this->userId, $description, $duedate);
|
|
|
|
foreach ($labels as $labelId) {
|
|
$this->cardService->assignLabel($card->id, $labelId);
|
|
}
|
|
|
|
foreach ($users as $user) {
|
|
$this->assignmentService->assignUser($card->id, $user['id'], $user['type']);
|
|
}
|
|
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Update a card
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function update(string $title, $type, string $owner, string $description = '', int $order = 0, $duedate = null, $archived = null): DataResponse {
|
|
$done = array_key_exists('done', $this->request->getParams()) ? new OptionalNullableValue($this->request->getParam('done', null)) : null;
|
|
$card = $this->cardService->update($this->request->getParam('cardId'), $title, $this->request->getParam('stackId'), $type, $owner, $description, $order, $duedate, 0, $archived, $done);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Delete a specific card.
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function delete(): DataResponse {
|
|
$card = $this->cardService->delete($this->request->getParam('cardId'));
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Assign a label to a card.
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function assignLabel(int $labelId): DataResponse {
|
|
$card = $this->cardService->assignLabel($this->request->getParam('cardId'), $labelId);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Assign a label to a card.
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function removeLabel(int $labelId): DataResponse {
|
|
$card = $this->cardService->removeLabel($this->request->getParam('cardId'), $labelId);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Assign a user to a card
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function assignUser(int $cardId, string $userId, int $type = 0): DataResponse {
|
|
$card = $this->assignmentService->assignUser($cardId, $userId, $type);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Unassign a user from a card
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function unassignUser(int $cardId, string $userId, int $type = 0): DataResponse {
|
|
$card = $this->assignmentService->unassignUser($cardId, $userId, $type);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Archive card
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function archive(int $cardId): DataResponse {
|
|
$card = $this->cardService->archive($cardId);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Unarchive card
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function unarchive(int $cardId): DataResponse {
|
|
$card = $this->cardService->unarchive($cardId);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
|
|
/**
|
|
* Reorder cards
|
|
*/
|
|
#[NoAdminRequired]
|
|
#[CORS]
|
|
#[NoCSRFRequired]
|
|
public function reorder(int $stackId, int $order): DataResponse {
|
|
$card = $this->cardService->reorder((int)$this->request->getParam('cardId'), $stackId, $order);
|
|
return new DataResponse($card, HTTP::STATUS_OK);
|
|
}
|
|
}
|