entity_manager = $entity_manager; $this->class_metadata = $entity_manager->getClassMetadata($this->getEntityClassName()); $this->doctrine_repository = new DoctrineEntityRepository($this->entity_manager, $this->class_metadata); } /** * @param array $criteria * @param array|null $order_by * @param int|null $limit * @param int|null $offset * @return array */ function findBy(array $criteria, array $order_by = null, $limit = null, $offset = null) { return $this->doctrine_repository->findBy($criteria, $order_by, $limit, $offset); } /** * @param array $criteria * @param array|null $order_by * @return object|null */ function findOneBy(array $criteria, array $order_by = null) { return $this->doctrine_repository->findOneBy($criteria, $order_by); } /** * @param mixed $id * @return object|null */ function findOneById($id) { return $this->doctrine_repository->find($id); } /** * @return array */ function findAll() { return $this->doctrine_repository->findAll(); } /** * @param object $entity */ function persist($entity) { $this->entity_manager->persist($entity); } function truncate() { $cmd = $this->entity_manager->getClassMetadata($this->getEntityClassName()); $table_name = $cmd->getTableName(); $connection = $this->entity_manager->getConnection(); $connection->transactional(function(Connection $connection) use ($table_name) { $connection->query('SET FOREIGN_KEY_CHECKS=0'); $q = "TRUNCATE $table_name"; $connection->executeUpdate($q); $connection->query('SET FOREIGN_KEY_CHECKS=1'); }); } /** * @param object $entity */ function remove($entity) { $this->entity_manager->remove($entity); } function flush() { $this->entity_manager->flush(); } /** * @return string */ abstract protected function getEntityClassName(); }