Валидация в Redbean PHP
Мне нравится идея использования моделей FUSE для проверки в RedbeanPHP.
Моим приложениям иногда требуется принимать данные из нескольких источников (форма, файл и т. Д.), Поэтому имеет смысл поставить проверку на фактическое обновление класса.
Глядя на примеры на сайте Redbean, кажется, что проверка основана на создании исключения.
Конечно, вы можете выдать только одно исключение, поэтому я предполагаю, что мне нужно создать дополнительное свойство типа "массив" в моем классе FUSE для хранения проверочных сообщений, связанных с отдельными полями.
У кого-нибудь есть идеи получше? Вот что я пытался до сих пор...
<form action="" method="post">
<p>your name: <input name="name" type="text"></p>
<p>your email: <input name="email" type="text"></p>
<p>your message:</p>
<textarea name="message" id="" cols="30" rows="10"></textarea>
<input name="send" value="send message" type="submit">
</form>
<?php
/**
* @property $name string
* @property $email string
* @property $message string
*/
class Model_Comment extends RedBean_SimpleModel{
public $invalid = array();
public function update(){
if(empty($this->name)) $this->invalid['name'] = "field is empty";
if(empty($this->email)) $this->invalid['email'] = "field is empty";
if(empty($this->message)) $this->invalid['message'] = "field is empty";
if(count($this->invalid) > 0) throw new Exception('Validation Failed!');
}
public function getInvalid(){
return $this->invalid;
}
}
if(isset($_POST['send'])){
$comment = R::dispense('comment');
/* @var $comment Model_Comment */
$comment->import($_POST,'name,email,message');
try{
R::store($comment);
}
catch(Exception $e){
echo $e->getMessage();
$invalid = $comment->getInvalid();
print_r($invalid);
exit;
}
echo '<p>thank you for leaving a message.</p>';
}
echo "<h2>What people said!</h2>";
$comments = R::find('comment');
/* @var $comments Model_Comment[] */
foreach($comments as $comment){
echo "<p>{$comment->name}: {$comment->message}</p>";
}
?>
1 ответ
Вы можете продлить RedBean_SimpleModel
класс, чтобы добавить свои собственные методы и поля к нему, так что он будет работать со всей вашей моделью. Затем вы можете использовать транзакции для управления проверками. Это может выглядеть так (код не проверен):
class RedBean_MyCustomModel extends RedBean_SimpleModel {
private $errors = array();
public function error($field, $text) {
$this->errors[$field] = $text;
}
public function getErrors() {
return $this->errors;
}
public function update() {
$this->errors = array(); // reset the errors array
R::begin(); // begin transaction before the update
}
public function after_update() {
if (count($this->errors) > 0) {
R::rollback();
throw new Exception('Validation failed');
}
}
}
Тогда ваша модель может выглядеть так:
class Model_Comment extends RedBean_MyCustomModel {
public function update(){
parent::update();
if(empty($this->name)) $this->error('name', 'field is empty');
if(empty($this->email)) $this->error('name', 'field is empty');
if(empty($this->message)) $this->error('name', 'field is empty');
}
public function getInvalid(){
return $this->invalid;
}
}