Remove note app
This commit is contained in:
parent
099013ec89
commit
245eee7ba6
@ -20,7 +20,8 @@ You need to have [GPodderSync](You need to have GPodderSync installed to use thi
|
|||||||
<category>multimedia</category>
|
<category>multimedia</category>
|
||||||
<bugs>https://git.crystalyx.net/Xefir/RePod/issues</bugs>
|
<bugs>https://git.crystalyx.net/Xefir/RePod/issues</bugs>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<nextcloud min-version="22" max-version="25"/>
|
<php min-version="8.0"/>
|
||||||
|
<nextcloud min-version="25" max-version="27"/>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<navigations>
|
<navigations>
|
||||||
<navigation>
|
<navigation>
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
"platform": {
|
"platform": {
|
||||||
"php": "7.4"
|
"php": "8.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
4
composer.lock
generated
4
composer.lock
generated
@ -4,7 +4,7 @@
|
|||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "9de82c8d48d25264d6223d576d21996d",
|
"content-hash": "a1e3c2b1e55310ed136ba261a8932b08",
|
||||||
"packages": [],
|
"packages": [],
|
||||||
"packages-dev": [
|
"packages-dev": [
|
||||||
{
|
{
|
||||||
@ -389,7 +389,7 @@
|
|||||||
"platform": [],
|
"platform": [],
|
||||||
"platform-dev": [],
|
"platform-dev": [],
|
||||||
"platform-overrides": {
|
"platform-overrides": {
|
||||||
"php": "7.4"
|
"php": "8.0"
|
||||||
},
|
},
|
||||||
"plugin-api-version": "2.3.0"
|
"plugin-api-version": "2.3.0"
|
||||||
}
|
}
|
||||||
|
@ -1,23 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Controller;
|
|
||||||
|
|
||||||
use Closure;
|
|
||||||
|
|
||||||
use OCA\RePod\Service\NoteNotFound;
|
|
||||||
use OCP\AppFramework\Http;
|
|
||||||
|
|
||||||
use OCP\AppFramework\Http\DataResponse;
|
|
||||||
|
|
||||||
trait Errors {
|
|
||||||
protected function handleNotFound(Closure $callback): DataResponse {
|
|
||||||
try {
|
|
||||||
return new DataResponse($callback());
|
|
||||||
} catch (NoteNotFound $e) {
|
|
||||||
$message = ['message' => $e->getMessage()];
|
|
||||||
return new DataResponse($message, Http::STATUS_NOT_FOUND);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,79 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Controller;
|
|
||||||
|
|
||||||
use OCA\RePod\AppInfo\Application;
|
|
||||||
use OCA\RePod\Service\NoteService;
|
|
||||||
use OCP\AppFramework\ApiController;
|
|
||||||
use OCP\AppFramework\Http\DataResponse;
|
|
||||||
use OCP\IRequest;
|
|
||||||
|
|
||||||
class NoteApiController extends ApiController {
|
|
||||||
private NoteService $service;
|
|
||||||
private ?string $userId;
|
|
||||||
|
|
||||||
use Errors;
|
|
||||||
|
|
||||||
public function __construct(IRequest $request,
|
|
||||||
NoteService $service,
|
|
||||||
?string $userId) {
|
|
||||||
parent::__construct(Application::APP_ID, $request);
|
|
||||||
$this->service = $service;
|
|
||||||
$this->userId = $userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @CORS
|
|
||||||
* @NoCSRFRequired
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function index(): DataResponse {
|
|
||||||
return new DataResponse($this->service->findAll($this->userId));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @CORS
|
|
||||||
* @NoCSRFRequired
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function show(int $id): DataResponse {
|
|
||||||
return $this->handleNotFound(function () use ($id) {
|
|
||||||
return $this->service->find($id, $this->userId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @CORS
|
|
||||||
* @NoCSRFRequired
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function create(string $title, string $content): DataResponse {
|
|
||||||
return new DataResponse($this->service->create($title, $content,
|
|
||||||
$this->userId));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @CORS
|
|
||||||
* @NoCSRFRequired
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function update(int $id, string $title,
|
|
||||||
string $content): DataResponse {
|
|
||||||
return $this->handleNotFound(function () use ($id, $title, $content) {
|
|
||||||
return $this->service->update($id, $title, $content, $this->userId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @CORS
|
|
||||||
* @NoCSRFRequired
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function destroy(int $id): DataResponse {
|
|
||||||
return $this->handleNotFound(function () use ($id) {
|
|
||||||
return $this->service->delete($id, $this->userId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,69 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Controller;
|
|
||||||
|
|
||||||
use OCA\RePod\AppInfo\Application;
|
|
||||||
use OCA\RePod\Service\NoteService;
|
|
||||||
use OCP\AppFramework\Controller;
|
|
||||||
use OCP\AppFramework\Http\DataResponse;
|
|
||||||
use OCP\IRequest;
|
|
||||||
|
|
||||||
class NoteController extends Controller {
|
|
||||||
private NoteService $service;
|
|
||||||
private ?string $userId;
|
|
||||||
|
|
||||||
use Errors;
|
|
||||||
|
|
||||||
public function __construct(IRequest $request,
|
|
||||||
NoteService $service,
|
|
||||||
?string $userId) {
|
|
||||||
parent::__construct(Application::APP_ID, $request);
|
|
||||||
$this->service = $service;
|
|
||||||
$this->userId = $userId;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function index(): DataResponse {
|
|
||||||
return new DataResponse($this->service->findAll($this->userId));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function show(int $id): DataResponse {
|
|
||||||
return $this->handleNotFound(function () use ($id) {
|
|
||||||
return $this->service->find($id, $this->userId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function create(string $title, string $content): DataResponse {
|
|
||||||
return new DataResponse($this->service->create($title, $content,
|
|
||||||
$this->userId));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function update(int $id, string $title,
|
|
||||||
string $content): DataResponse {
|
|
||||||
return $this->handleNotFound(function () use ($id, $title, $content) {
|
|
||||||
return $this->service->update($id, $title, $content, $this->userId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @NoAdminRequired
|
|
||||||
*/
|
|
||||||
public function destroy(int $id): DataResponse {
|
|
||||||
return $this->handleNotFound(function () use ($id) {
|
|
||||||
return $this->service->delete($id, $this->userId);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,27 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Controller;
|
|
||||||
|
|
||||||
use OCA\RePod\AppInfo\Application;
|
|
||||||
use OCP\AppFramework\Controller;
|
|
||||||
use OCP\AppFramework\Http\TemplateResponse;
|
|
||||||
use OCP\IRequest;
|
|
||||||
use OCP\Util;
|
|
||||||
|
|
||||||
class PageController extends Controller {
|
|
||||||
public function __construct(IRequest $request) {
|
|
||||||
parent::__construct(Application::APP_ID, $request);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @NoAdminRequired
|
|
||||||
* @NoCSRFRequired
|
|
||||||
*/
|
|
||||||
public function index(): TemplateResponse {
|
|
||||||
Util::addScript(Application::APP_ID, 'repod-main');
|
|
||||||
|
|
||||||
return new TemplateResponse(Application::APP_ID, 'main');
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,32 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Db;
|
|
||||||
|
|
||||||
use JsonSerializable;
|
|
||||||
|
|
||||||
use OCP\AppFramework\Db\Entity;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @method getId(): int
|
|
||||||
* @method getTitle(): string
|
|
||||||
* @method setTitle(string $title): void
|
|
||||||
* @method getContent(): string
|
|
||||||
* @method setContent(string $content): void
|
|
||||||
* @method getUserId(): string
|
|
||||||
* @method setUserId(string $userId): void
|
|
||||||
*/
|
|
||||||
class Note extends Entity implements JsonSerializable {
|
|
||||||
protected string $title = '';
|
|
||||||
protected string $content = '';
|
|
||||||
protected string $userId = '';
|
|
||||||
|
|
||||||
public function jsonSerialize(): array {
|
|
||||||
return [
|
|
||||||
'id' => $this->id,
|
|
||||||
'title' => $this->title,
|
|
||||||
'content' => $this->content
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,46 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Db;
|
|
||||||
|
|
||||||
use OCP\AppFramework\Db\DoesNotExistException;
|
|
||||||
use OCP\AppFramework\Db\QBMapper;
|
|
||||||
use OCP\DB\QueryBuilder\IQueryBuilder;
|
|
||||||
use OCP\IDBConnection;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @template-extends QBMapper<Note>
|
|
||||||
*/
|
|
||||||
class NoteMapper extends QBMapper {
|
|
||||||
public function __construct(IDBConnection $db) {
|
|
||||||
parent::__construct($db, 'repod', Note::class);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @throws \OCP\AppFramework\Db\MultipleObjectsReturnedException
|
|
||||||
* @throws DoesNotExistException
|
|
||||||
*/
|
|
||||||
public function find(int $id, string $userId): Note {
|
|
||||||
/* @var $qb IQueryBuilder */
|
|
||||||
$qb = $this->db->getQueryBuilder();
|
|
||||||
$qb->select('*')
|
|
||||||
->from('repod')
|
|
||||||
->where($qb->expr()->eq('id', $qb->createNamedParameter($id, IQueryBuilder::PARAM_INT)))
|
|
||||||
->andWhere($qb->expr()->eq('user_id', $qb->createNamedParameter($userId)));
|
|
||||||
return $this->findEntity($qb);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $userId
|
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function findAll(string $userId): array {
|
|
||||||
/* @var $qb IQueryBuilder */
|
|
||||||
$qb = $this->db->getQueryBuilder();
|
|
||||||
$qb->select('*')
|
|
||||||
->from('repod')
|
|
||||||
->where($qb->expr()->eq('user_id', $qb->createNamedParameter($userId)));
|
|
||||||
return $this->findEntities($qb);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,48 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Migration;
|
|
||||||
|
|
||||||
use Closure;
|
|
||||||
use OCP\DB\ISchemaWrapper;
|
|
||||||
use OCP\Migration\IOutput;
|
|
||||||
use OCP\Migration\SimpleMigrationStep;
|
|
||||||
|
|
||||||
class Version000000Date20181013124731 extends SimpleMigrationStep {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param IOutput $output
|
|
||||||
* @param Closure $schemaClosure The `\Closure` returns a `ISchemaWrapper`
|
|
||||||
* @param array $options
|
|
||||||
* @return null|ISchemaWrapper
|
|
||||||
*/
|
|
||||||
public function changeSchema(IOutput $output, Closure $schemaClosure, array $options) {
|
|
||||||
/** @var ISchemaWrapper $schema */
|
|
||||||
$schema = $schemaClosure();
|
|
||||||
|
|
||||||
if (!$schema->hasTable('repod')) {
|
|
||||||
$table = $schema->createTable('repod');
|
|
||||||
$table->addColumn('id', 'integer', [
|
|
||||||
'autoincrement' => true,
|
|
||||||
'notnull' => true,
|
|
||||||
]);
|
|
||||||
$table->addColumn('title', 'string', [
|
|
||||||
'notnull' => true,
|
|
||||||
'length' => 200
|
|
||||||
]);
|
|
||||||
$table->addColumn('user_id', 'string', [
|
|
||||||
'notnull' => true,
|
|
||||||
'length' => 200,
|
|
||||||
]);
|
|
||||||
$table->addColumn('content', 'text', [
|
|
||||||
'notnull' => true,
|
|
||||||
'default' => ''
|
|
||||||
]);
|
|
||||||
|
|
||||||
$table->setPrimaryKey(['id']);
|
|
||||||
$table->addIndex(['user_id'], 'repod_user_id_index');
|
|
||||||
}
|
|
||||||
return $schema;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Service;
|
|
||||||
|
|
||||||
class NoteNotFound extends \Exception {
|
|
||||||
}
|
|
@ -1,82 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
declare(strict_types=1);
|
|
||||||
|
|
||||||
namespace OCA\RePod\Service;
|
|
||||||
|
|
||||||
use Exception;
|
|
||||||
|
|
||||||
use OCA\RePod\Db\Note;
|
|
||||||
use OCA\RePod\Db\NoteMapper;
|
|
||||||
|
|
||||||
use OCP\AppFramework\Db\DoesNotExistException;
|
|
||||||
use OCP\AppFramework\Db\MultipleObjectsReturnedException;
|
|
||||||
|
|
||||||
class NoteService {
|
|
||||||
private NoteMapper $mapper;
|
|
||||||
|
|
||||||
public function __construct(NoteMapper $mapper) {
|
|
||||||
$this->mapper = $mapper;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return list<Note>
|
|
||||||
*/
|
|
||||||
public function findAll(string $userId): array {
|
|
||||||
return $this->mapper->findAll($userId);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return never
|
|
||||||
*/
|
|
||||||
private function handleException(Exception $e) {
|
|
||||||
if ($e instanceof DoesNotExistException ||
|
|
||||||
$e instanceof MultipleObjectsReturnedException) {
|
|
||||||
throw new NoteNotFound($e->getMessage());
|
|
||||||
} else {
|
|
||||||
throw $e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function find(int $id, string $userId): Note {
|
|
||||||
try {
|
|
||||||
return $this->mapper->find($id, $userId);
|
|
||||||
|
|
||||||
// in order to be able to plug in different storage backends like files
|
|
||||||
// for instance it is a good idea to turn storage related exceptions
|
|
||||||
// into service related exceptions so controllers and service users
|
|
||||||
// have to deal with only one type of exception
|
|
||||||
} catch (Exception $e) {
|
|
||||||
$this->handleException($e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function create(string $title, string $content, string $userId): Note {
|
|
||||||
$note = new Note();
|
|
||||||
$note->setTitle($title);
|
|
||||||
$note->setContent($content);
|
|
||||||
$note->setUserId($userId);
|
|
||||||
return $this->mapper->insert($note);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function update(int $id, string $title, string $content, string $userId): Note {
|
|
||||||
try {
|
|
||||||
$note = $this->mapper->find($id, $userId);
|
|
||||||
$note->setTitle($title);
|
|
||||||
$note->setContent($content);
|
|
||||||
return $this->mapper->update($note);
|
|
||||||
} catch (Exception $e) {
|
|
||||||
$this->handleException($e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function delete(int $id, string $userId): Note {
|
|
||||||
try {
|
|
||||||
$note = $this->mapper->find($id, $userId);
|
|
||||||
$this->mapper->delete($note);
|
|
||||||
return $note;
|
|
||||||
} catch (Exception $e) {
|
|
||||||
$this->handleException($e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user