2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
2015-04-27 11:33:13 +12:00
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
namespace SilverStripe\Forms;
|
|
|
|
|
|
|
|
use SilverStripe\Core\Object;
|
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
2016-04-20 14:27:50 +12:00
|
|
|
* This validation class handles all form and custom form validation through the use of Required
|
|
|
|
* fields. It relies on javascript for client-side validation, and marking fields after server-side
|
|
|
|
* validation. It acts as a visitor to individual form fields.
|
2014-08-15 18:53:05 +12:00
|
|
|
*/
|
2007-07-19 10:40:28 +00:00
|
|
|
abstract class Validator extends Object {
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-03-03 02:24:29 +00:00
|
|
|
/**
|
|
|
|
* @var Form $form
|
|
|
|
*/
|
2007-07-19 10:40:28 +00:00
|
|
|
protected $form;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-03-03 02:24:29 +00:00
|
|
|
/**
|
|
|
|
* @var array $errors
|
|
|
|
*/
|
2007-07-19 10:40:28 +00:00
|
|
|
protected $errors;
|
2012-03-09 12:12:33 +13:00
|
|
|
|
2009-03-03 02:24:29 +00:00
|
|
|
/**
|
|
|
|
* @param Form $form
|
2015-04-27 11:33:13 +12:00
|
|
|
*
|
2016-04-20 14:27:50 +12:00
|
|
|
* @return $this
|
2009-03-03 02:24:29 +00:00
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function setForm($form) {
|
2007-07-19 10:40:28 +00:00
|
|
|
$this->form = $form;
|
2015-04-27 11:33:13 +12:00
|
|
|
|
2012-02-17 13:35:26 +01:00
|
|
|
return $this;
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-03-03 02:24:29 +00:00
|
|
|
/**
|
2015-04-27 11:33:13 +12:00
|
|
|
* Returns any errors there may be.
|
|
|
|
*
|
|
|
|
* @return null|array
|
2009-03-03 02:24:29 +00:00
|
|
|
*/
|
2015-04-27 11:33:13 +12:00
|
|
|
public function validate() {
|
2007-07-19 10:40:28 +00:00
|
|
|
$this->errors = null;
|
2015-04-27 11:33:13 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
$this->php($this->form->getData());
|
2015-04-27 11:33:13 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
return $this->errors;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2008-03-06 02:06:47 +00:00
|
|
|
/**
|
2016-04-20 14:27:50 +12:00
|
|
|
* Callback to register an error on a field (Called from implementations of
|
|
|
|
* {@link FormField::validate}). The optional error message type parameter is loaded into the
|
|
|
|
* HTML class attribute.
|
2015-04-27 11:33:13 +12:00
|
|
|
*
|
2014-11-12 15:19:12 +13:00
|
|
|
* See {@link getErrors()} for details.
|
2016-04-20 14:27:50 +12:00
|
|
|
*
|
|
|
|
* @param string $fieldName
|
|
|
|
* @param string $errorMessage
|
|
|
|
* @param string $errorMessageType
|
2008-03-06 02:06:47 +00:00
|
|
|
*/
|
2016-04-20 14:27:50 +12:00
|
|
|
public function validationError($fieldName, $errorMessage, $errorMessageType = '') {
|
2007-07-19 10:40:28 +00:00
|
|
|
$this->errors[] = array(
|
|
|
|
'fieldName' => $fieldName,
|
2016-04-20 14:27:50 +12:00
|
|
|
'message' => $errorMessage,
|
|
|
|
'messageType' => $errorMessageType,
|
2007-07-19 10:40:28 +00:00
|
|
|
);
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2009-03-12 16:47:29 +00:00
|
|
|
/**
|
2016-04-20 14:27:50 +12:00
|
|
|
* Returns all errors found by a previous call to {@link validate()}. The returned array has a
|
|
|
|
* structure resembling:
|
2015-04-27 11:33:13 +12:00
|
|
|
*
|
2016-04-20 14:27:50 +12:00
|
|
|
* <code>
|
|
|
|
* array(
|
|
|
|
* 'fieldName' => '[form field name]',
|
|
|
|
* 'message' => '[validation error message]',
|
|
|
|
* 'messageType' => '[bad|message|validation|required]',
|
|
|
|
* )
|
|
|
|
* </code>
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2016-04-20 14:27:50 +12:00
|
|
|
* @return null|array
|
2009-03-12 16:47:29 +00:00
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function getErrors() {
|
2007-08-23 05:47:54 +00:00
|
|
|
return $this->errors;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-04-27 11:33:13 +12:00
|
|
|
/**
|
|
|
|
* @param string $fieldName
|
|
|
|
* @param array $data
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function requireField($fieldName, $data) {
|
2010-10-19 01:20:38 +00:00
|
|
|
if(is_array($data[$fieldName]) && count($data[$fieldName])) {
|
2015-04-27 11:33:13 +12:00
|
|
|
foreach($data[$fieldName] as $componentKey => $componentValue) {
|
|
|
|
if(!strlen($componentValue)) {
|
|
|
|
$this->validationError(
|
|
|
|
$fieldName,
|
|
|
|
sprintf('%s %s is required', $fieldName, $componentKey),
|
|
|
|
'required'
|
|
|
|
);
|
2012-09-27 09:34:00 +12:00
|
|
|
}
|
2010-10-19 01:20:38 +00:00
|
|
|
}
|
2012-09-27 09:34:00 +12:00
|
|
|
} else if(!strlen($data[$fieldName])) {
|
2015-04-27 11:33:13 +12:00
|
|
|
$this->validationError(
|
|
|
|
$fieldName,
|
|
|
|
sprintf('%s is required', $fieldName),
|
|
|
|
'required'
|
|
|
|
);
|
2012-09-27 09:34:00 +12:00
|
|
|
}
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2007-07-19 10:40:28 +00:00
|
|
|
/**
|
2016-04-20 14:27:50 +12:00
|
|
|
* Returns whether the field in question is required. This will usually display '*' next to the
|
|
|
|
* field. The base implementation always returns false.
|
2015-04-27 11:33:13 +12:00
|
|
|
*
|
2016-04-20 14:27:50 +12:00
|
|
|
* @param string $fieldName
|
2015-04-27 11:33:13 +12:00
|
|
|
*
|
2016-04-20 14:27:50 +12:00
|
|
|
* @return bool
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
public function fieldIsRequired($fieldName) {
|
2007-07-19 10:40:28 +00:00
|
|
|
return false;
|
|
|
|
}
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2015-04-27 11:33:13 +12:00
|
|
|
/**
|
|
|
|
* @param array $data
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
2012-09-19 12:07:39 +02:00
|
|
|
abstract public function php($data);
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|