Проблема с добавлением ошибок в библиотеку проверки в Kohana 3 - PullRequest
2 голосов
/ 24 февраля 2010

Мне нужно добавить несколько ошибок в помощник проверки в Kohana 3.

Вот с чего я начну:

            // validate form
             $post = Validate::factory($_POST)
            // Trim all fields
            ->filter(TRUE, 'trim')
            // Rules for name
            ->rule('first-name', 'not_empty')
            ->rule('last-name', 'not_empty')

            // Rules for email address
            ->rule('email', 'not_empty')
            ->rule('email', 'email')

            // Rules for address stuff
            ->rule('address', 'not_empty')
            ->rule('suburb', 'not_empty')
            ->rule('state', 'not_empty')
            ->rule('postcode', 'not_empty')

            // Rules for misc
            ->rule('phone', 'not_empty')
            ->rule('company', 'not_empty')
            ->rule('abn', 'not_empty');

Теперь я также проверяю некоторые вещи и добавляю ошибок, если возникла проблема

         if ( ! in_array($post['state'], array_keys($states))) {
                $post->error('state', 'not_found');
            }


            if ( $this->userModel->doesEmailExist($post['email'])) {
                $post->error('email', 'already_exists');
        }

Я сделал несколько var_dump() для них, и они являются возвращающими значениями, которые должны добавить ошибку!

Однако, когда я звоню $post->check(), кажется, что он только подтверждает правила, которые я добавил в первом блоке кода выше.

У меня совпадающие значения также в моем /application/messages/join.php

<?php defined('SYSPATH') or die('No direct script access.');

return array(
    'not_empty'    => ':field must not be empty.',
    'matches'      => ':field must be the same as :param1',
    'regex'        => ':field does not match the required format',
    'exact_length' => ':field must be exactly :param1 characters long',
    'min_length'   => ':field must be at least :param1 characters long',
    'max_length'   => ':field must be less than :param1 characters long',
    'in_array'     => ':field must be one of the available options',
    'digit'        => ':field must be a digit',
    'email'        => array(
        'email' => 'You must enter a valid email.',
        'already_exists' => 'This email is already associated with an account'
    ),

    'name'         => 'You must enter your name.',
);

Я что-то здесь не так делаю? Спасибо

Обновление

Я только что выполнил несколько быстрых действий по отладке в библиотеке валидации, а именно вывел свойство _errors после каждого вызова метода error.

Что я вижу, так это то, что мои ошибки добавляются, но затем перезаписываются (возможно, это противоречит правилам, которые я добавил выше). Это нормально?

Ответы [ 3 ]

4 голосов
/ 24 февраля 2010

В качестве альтернативы (если вы не хотите взламывать ядро), вы можете вместо этого использовать валидаторы обратного вызова. Тогда ваш код будет выглядеть так:

    $post->callback('state', array($this, 'doesStateExist'));
    $post->callback('email', array($this->userModel, 'doesEmailExist'));
0 голосов
/ 17 июля 2013

Я нашел другой способ добавить сообщения об ошибках:

$errors = array();

if (!$post->check()) {
   $errors += $post->errors();
}

if (!isset($_POST['something'])) {
   $errors['something'] = 'Please enter something';
}

if (empty($errors)) {
  $orm->save();
  return;
}

$tpl->error_fields($errors);
0 голосов
/ 01 марта 2010

Вы должны всегда запускать $validate->check() перед выполнением собственных проверок и добавлением ошибок. ответ мезе будет лучше.

...