php - 使用自定义验证约束检查数据库中是否存在条目

标签 php symfony validation symfony-forms

所以在我的 Symfony 应用程序中,我有一个名为 Post 的实体。

我的帖子实体具有以下属性: post_startpost_end 等等。

实体:

/**
 * @ORM\Entity
 * @ORM\Table(name="post")
 */
class Post
{

    /**
     * @var int
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     * @ORM\Column(type="integer")
     */
    private $id;

    /**
     * @var DateType
     * @ORM\Column(type="date")
     */
    private $post_start;

    /**
     * @var DateType
     * @ORM\Column(type="date")
     * @Assert\GreaterThanOrEqual(propertyPath="post_start")
     */
    private $post_end;

.....
}

格式类型:

public function buildForm(FormBuilderInterface $builder, array $options)
    {
        $builder->add(
            'post_start',
            DateType::class,
            [
                'widget' => 'single_text',
                'format' => 'dd.MM.yyyy',
                'required' => true,
                'attr' => [
                    'class' => 'form-control input-inline datepicker',
                    'data-provide' => 'datepicker',
                    'data-date-format' => 'dd.mm.yyyy',
                ]
            ]
        );

        $builder->add(
            'post_end',
            DateType::class,
            [
                'widget' => 'single_text',
                'format' => 'dd.MM.yyyy',
                'required' => true,
                'attr' => [
                    'class' => 'form-control input-inline datepicker',
                    'data-provide' => 'datepicker',
                    'data-date-format' => 'dd.mm.yyyy'
                ]
            ]
        );

        $builder->add('submit', SubmitType::class, [
            'label' => 'save post',
            'attr' => array('class' => 'btn btn-success')
        ]);
    }

    public function configureOptions(OptionsResolver $resolver)
    {
        $resolver->setDefaults([
            'data_class' => Post::class
        ]);
    }

当我提交表单时,我想检查数据库是否已有具有相同开始日期和结束日期且来自同一用户的条目。

1. If YES -> Show error message 
2. If NO -> Create post request.

当条目已经存在,但它来自不同的用户时,继续创建帖子。

我想用自定义验证器约束来做到这一点。但是接下来会发生什么,我必须以某种方式将数据相互比较

包含相等日期:

/**
 * @Annotation
 */
class ContainsEqualDate extends Constraint
{
    public $message = 'Post request is already exists.';

    public function getTargets()
    {
        return self::CLASS_CONSTRAINT;
    }
}

ContainsEqualDateValidator:

class ContainsEqualDateValidator extends ConstraintValidator
{
    /**
     * @var ORMUserRepository
     */
    private $userRepository;

    /**
     * @var ORMPostRepository
     */
    private $postRepository;

    /**
     * @param ORMUserRepository $userRepository
     * @param ORMPostRepository $postRepository
     */
    public function __construct(ORMUserRepository $userRepository, ORMPostRepository $postRepository)
    {
        $this->userRepository = $userRepository;
        $this->postRepository = $postRepository;
    }

    /**
     * Checks if the passed value is valid.
     *
     * @param mixed $value The value that should be validated
     * @param Constraint $constraint The constraint for the validation
     */
    public function validate($value, Constraint $constraint)
    {

 $userId = $this->getUser();

    $postExists = $this->postRepository->findBy(array(
        'post_start' => $value,
        'app_user_id' => $userId
    ));
}

/**
 * @return User
 */
private function getUser(): User
{
    return $this->storage->getToken()->getUser();
}
    }
     }

最佳答案

@Max Trui,您没有提到 User 和 Post 实体在您的数据库中是如何相关的。

如果您在 Post 实体中有 UserId,则可以执行以下操作。

$userId = $this->userRepository->getUser()->getId();
$entryExists = ($this->postRepository->findBy(array('post_start' => $value, 'user_id' => $userId)) == null) ? true : false;

您可以将“post_start”替换为动态字段名称值(post_start 或 post_end),您可以从调用验证器的位置提供该值。

如果您想同时检查两个日期,请在验证器中提供两个值。

关于php - 使用自定义验证约束检查数据库中是否存在条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48283797/

相关文章:

php - WordPress wp_get_current_user() 不显示结果

symfony - 无法启动 Symfony Panther

php - Symfony 5 - 基于浏览器语言的网站翻译后重定向

正则表达式匹配两个单词之一

php - 优化此 SQL 查询的最佳方法是什么?

PHP 'exec' 命令不能与 'awk' 命令一起正常工作

php - php 的复选框问题

symfony - 如何访问 Controller 中的防火墙配置?

spring-boot - Spring Boot : Custom Validation in Request Params

ajax - 在 Razor View 上调用 ajax 后显示模型状态错误