Я работаю над каким-то простым скриптом, но не могу понять эту проблему. Итак, вот оно.
/**
* Booking
* @ORM\Table()
* @ORM\Entity(repositoryClass="Tons\BookingBundle\Entity\BookingRepository")
* @UniqueEntity(fields={"room", "since", "till"}, repositoryMethod="getInterferingRoomBookings")
* @Assert\Callback(methods={"isSinceLessThanTill"}, groups={"search","default"})
*/
class Booking
и метод репозитория
/**
* Get room state for a certain time period
*
* @param array $criteria
* @return array
*/
public function getInterferingRoomBookings(array $criteria)
{
/** @var $room Room */
$room = $criteria['room'];
$builder = $this->getQueryForRoomsBooked($criteria);
$builder->andWhere("ira.room = :room")->setParameter("room", $room);
return $builder->getQuery()->getArrayResult();
}
Проблема в том, что это работает с методами создания, как и должно быть, но при обновлении существующей сущности нарушает это ограничение.
Я пытался добавить ограничение по идентификатору, но при создании сущностей идентификатор равен нулю, поэтому метод репозитория даже не запускается. Также я попытался удалить Entity, а затем воссоздать его. как
$em->remove($entity);
$em->flush();
//-----------
$em->persist($entity);
$em->flush();
но это тоже не работает.
Создать действие
/**
* Creates a new Booking entity.
*
* @Route("/create", name="booking_create")
* @Method("POST")
* @Template("TonsBookingBundle:Booking:new.html.twig")
*/
public function createAction(Request $request)
{
$entity = new Booking();
$form = $this->createForm(new BookingType(), $entity);
$form->bind($request);
if ($form->isValid())
{
$em = $this->getDoctrine()->getManager();
$room = $entity->getRoom();
if($room->getLocked() && $room->getLockedBy()->getId() === $this->getUser()->getId())
{
$entity->setCreatedAt(new \DateTime());
$entity->setUpdatedAt(new \DateTime());
$entity->setManager($this->getUser());
$em->persist($entity);
$room->setLocked(false);
$room->setLockedBy(null);
$room->setLockedAt(null);
$em->persist($room);
$em->flush();
return $this->redirect($this->generateUrl('booking_show', array('id' => $entity->getId())));
}
else
{
$form->addError(new FormError("Номер в текущий момент не заблокирован или заблокирован другим менеджером"));
return array(
'entity' => $entity,
'form' => $form->createView(),
);
}
}
return array(
'entity' => $entity,
'form' => $form->createView(),
);
}
Обновить действие
/**
* Edits an existing Booking entity.
*
* @Route("/edit/{id}/save", name="booking_update")
* @Method("PUT")
* @Template("TonsBookingBundle:Booking:edit.html.twig")
*/
public function updateAction(Request $request, $id)
{
/** @var $em EntityManager */
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository('TonsBookingBundle:Booking')->find($id);
if (!$entity) {
throw $this->createNotFoundException('Unable to find Booking entity.');
}
$editForm = $this->createForm(new BookingType(), $entity);
$editForm->bind($request);
if ($editForm->isValid()) {
$em->persist($entity);
$em->flush();
return $this->redirect($this->generateUrl('booking_edit', array('id' => $id)));
}
return array(
'entity' => $entity,
'form' => $editForm->createView(),
);
}
$room->setLockedAt(null);
не хочет у меня работать, не знаю почему. Мое поле имеет значение DateTime, но допускает значение null, ввод' '
илиnull
дает мне ошибку: аргумент 1, переданный в AppBundle\Entity\User::setLockedAt(), должен быть экземпляром DateTime, заданным null,... - person nclsvh   schedule 09.12.2015