-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathResourceController.php
More file actions
123 lines (110 loc) · 3.08 KB
/
ResourceController.php
File metadata and controls
123 lines (110 loc) · 3.08 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
<?php
/**
* This file is part of Blitz PHP framework.
*
* (c) 2022 Dimitri Sitchet Tomkeu <devcode.dst@gmail.com>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/
namespace BlitzPHP\Controllers;
use Psr\Http\Message\ResponseInterface;
/**
* Un contrôleur extensible pour fournir une API RESTful pour une ressource.
*/
class ResourceController extends RestController
{
protected string $returnFormat = '';
/**
* {@inheritDoc}
*/
public function __construct()
{
parent::__construct();
$this->setFormat($this->returnFormat);
}
/**
* Renvoie un tableau d'objets ressources, eux-mêmes au format tableau
*
* @return ResponseInterface|string|void
*/
public function index()
{
return $this->respondNotImplemented($this->_translate('notImplemented', [__METHOD__]));
}
/**
* Renvoyer les propriétés d'un objet ressource
*
* @param int|string|null $id
*
* @return ResponseInterface|string|void
*/
public function show($id = null)
{
return $this->respondNotImplemented($this->_translate('notImplemented', [__METHOD__]));
}
/**
* Renvoie un nouvel objet ressource, avec les propriétés par défaut
*
* @return ResponseInterface|string|void
*/
public function new()
{
return $this->respondNotImplemented($this->_translate('notImplemented', [__METHOD__]));
}
/**
* Créer un nouvel objet ressource, à partir des données envoyées
*
* @return ResponseInterface|string|void
*/
public function create()
{
return $this->respondNotImplemented($this->_translate('notImplemented', [__METHOD__]));
}
/**
* Renvoyer les propriétés modifiables d'un objet ressource
*
* @param int|string|null $id
*
* @return ResponseInterface|string|void
*/
public function edit($id = null)
{
return $this->respondNotImplemented($this->_translate('notImplemented', [__METHOD__]));
}
/**
* Ajouter ou mettre à jour une ressource de modèle, à partir de données envoyées
*
* @param int|string|null $id
*
* @return ResponseInterface|string|void
*/
public function update($id = null)
{
return $this->respondNotImplemented($this->_translate('notImplemented', [__METHOD__]));
}
/**
* Supprimer l'objet ressource désigné du modèle
*
* @param int|string|null $id
*
* @return ResponseInterface|string|void
*/
public function delete($id = null)
{
return $this->respondNotImplemented($this->_translate('notImplemented', [__METHOD__]));
}
/**
* Définir/modifier la représentation de réponse attendue pour les objets renvoyés
*
* @param string $format json/xml
*
* @return void
*/
public function setFormat(string $format = 'json')
{
if (in_array($format, ['json', 'xml'], true)) {
$this->returnFormat($format);
}
}
}