Abstract.php
7.52 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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
<?php
/**
* i-Educar - Sistema de gestão escolar
*
* Copyright (C) 2006 Prefeitura Municipal de Itajaí
* <ctima@itajai.sc.gov.br>
*
* Este programa é software livre; você pode redistribuí-lo e/ou modificá-lo
* sob os termos da Licença Pública Geral GNU conforme publicada pela Free
* Software Foundation; tanto a versão 2 da Licença, como (a seu critério)
* qualquer versão posterior.
*
* Este programa é distribuído na expectativa de que seja útil, porém, SEM
* NENHUMA GARANTIA; nem mesmo a garantia implícita de COMERCIABILIDADE OU
* ADEQUAÇÃO A UMA FINALIDADE ESPECÍFICA. Consulte a Licença Pública Geral
* do GNU para mais detalhes.
*
* Você deve ter recebido uma cópia da Licença Pública Geral do GNU junto
* com este programa; se não, escreva para a Free Software Foundation, Inc., no
* endereço 59 Temple Street, Suite 330, Boston, MA 02111-1307 USA.
*
* @author Eriksen Costa Paixão <eriksen.paixao_bs@cobra.com.br>
* @category i-Educar
* @license @@license@@
* @package CoreExt_Validate
* @since Arquivo disponível desde a versão 1.1.0
* @version $Id$
*/
require_once 'CoreExt/Validate/Interface.php';
/**
* CoreExt_Validate_Abstract abstract class.
*
* @author Eriksen Costa Paixão <eriksen.paixao_bs@cobra.com.br>
* @category i-Educar
* @license @@license@@
* @package CoreExt_Validate
* @since Classe disponível desde a versão 1.1.0
* @version @@package_version@@
*/
abstract class CoreExt_Validate_Abstract implements CoreExt_Validate_Interface
{
/**
* Opções de configuração geral da classe.
* @var array
*/
protected $_options = array(
'required' => TRUE,
'trim' => TRUE,
);
/**
* Valor não sanitizado que foi informado ao validador.
* @var mixed
*/
protected $_value = NULL;
/**
* Valor sanitizado.
* @var mixed
*/
protected $_sanitized = NULL;
/**
* Mensagem padrão para erros de valor obrigatório.
* @var string
*/
protected $_requiredMessage = 'Obrigatório.';
/**
* Mensagem padrão para erros de invalidez.
* @var string
*/
protected $_invalidMessage = 'Inválido.';
/**
* Construtor.
*
* Pode receber array com opções de configuração da classe.
*
* @param array $options
*/
public function __construct(array $options = array())
{
$this->_options = array_merge($this->getOptions(), $this->_getDefaultOptions());
$this->setOptions($options);
}
/**
* Configura as opções do validador.
*
* Método de checagem de opções inspirado na técnica empregada no
* {@link http://www.symfony-project.org symfony framework}.
*
* @param array $options
* @throws InvalidArgumentException Lança exceção não verificada caso alguma
* opção passada ao método não exista na definição da classe
*/
public function setOptions(array $options = array())
{
$defaultOptions = array_keys($this->getOptions());
$passedOptions = array_keys($options);
if (0 < count(array_diff($passedOptions, $defaultOptions))) {
throw new InvalidArgumentException(
sprintf('A classe %s não suporta as opções: %s.', get_class($this), implode(', ', $passedOptions))
);
}
$this->_options = array_merge($this->getOptions(), $options);
}
/**
* @see CoreExt_Validate_Interface#getOptions()
*/
public function getOptions()
{
return $this->_options;
}
/**
* Verifica se uma opção está setada.
*
* @param string $key
* @return bool
*/
protected function _hasOption($key)
{
return
isset($this->_options[$key]) &&
!$this->_isEmpty($this->_options[$key]);
}
/**
* Retorna um valor de opção de configuração ou NULL caso a opção não esteja
* setada.
*
* @param string $key
* @return mixed|NULL
*/
public function getOption($key)
{
return $this->_hasOption($key) ? $this->_options[$key] : NULL;
}
/**
* Permite que uma classe que estenda CoreExt_Validate_Abstract a definir
* valores de opções pré-definidos adequados ao caso específico.
*
* @return array
*/
protected abstract function _getDefaultOptions();
/**
* @see CoreExt_Validate_Interface#isValid($value)
*/
public function isValid($value)
{
$this->_value = $value;
$value = $this->_sanitize($value);
if (TRUE == $this->getOption('trim')) {
$value = trim($value);
}
$this->_sanitized = $value;
if (TRUE == $this->getOption('required') && $this->_isEmpty($value)) {
throw new Exception($this->_requiredMessage);
}
return $this->_validate($value);
}
/**
* Toda classe que estende CoreExt_Validate_Abstract deve implementar esse
* método com a lógica de validação adequada.
*
* @param string $value
* @return bool
*/
protected abstract function _validate($value);
/**
* Realiza uma sanitização
* @param mixed $value
* @return mixed
*/
protected function _sanitize($value)
{
return $value;
}
/**
* Verifica se um dado valor está vazio.
*
* Como vazio, entende-se string vazia (''), array sem itens (array()), o
* valor NULL e zero (0) numérico.
*
* @param mixed $value
* @return bool
*/
protected function _isEmpty($value)
{
return in_array(
$value, array('', array(), NULL), TRUE
);
}
/**
* Retorna uma mensagem de erro configurada em $_options.
*
* A mensagem de erro pode ser uma string ou um array. Se for uma string,
* ocorrerá a substituição dos placeholders. Se for um array, deverá ser
* especificado duas mensagens de erro, uma para a forma singular e outra
* para o plural. O placeholder @value será verificado para definir se a
* mensagem deve ser formatada no plural ou no singular.
*
* Exemplo de array de mensagem de erro que usa variante de número:
*
* <code>
* <?php
* $message = array(
* array(
* 'singular' => '@value problema encontrado.'
* 'plural' => '@value problemas encontrados.'
* )
* );
*
* // Iria imprimir:
* // singular (@value = 1): 1 problema encontrado
* // plural (@value = 4): 4 problemas encontrados
* </code>
*
* @param array|string $key O identificador da mensagem no array $_options
* @param array $options Array associativo para substituição de valores
* @return string
* @todo Implementar substituição com formatação padrão, semelhante ao
* a função Drupal {@link http://api.drupal.org/t t()}.
* @todo Implementar formatação singular/plural em uma classe diferente,
* como método público, permitindo realizar o teste.
*/
protected function _getErrorMessage($key, array $options = array())
{
$message = $this->getOption($key);
if (is_array($message)) {
// Verifica o tipo de @value para determinar a quantidade de $count
if (is_array($options['@value'])) {
$count = count($options['@value']);
}
elseif (is_numeric($options['@value'])) {
$count = count($options['@value']);
}
else {
$count = 1;
}
if (1 < $count) {
$message = $message['plural'];
$options['@value'] = implode(', ', $options['@value']);
}
else {
$message = $message['singular'];
$options['@value'] = array_shift($options['@value']);
}
}
return strtr($message, $options);
}
/**
* @see CoreExt_Validate_Interface#getValue()
*/
public function getValue()
{
return $this->_value;
}
/**
* @see CoreExt_Validate_Interface#getSanitizedValue()
*/
public function getSanitizedValue()
{
return $this->_sanitized;
}
}