/** * Delete an Ort entity */ public function deleteAction() { if ($this->request->hasArgument('uUID')) { $uuid = $this->request->getArgument('uUID'); } if (empty($uuid)) { $this->throwStatus(400, 'Required uUID not provided', null); } $klosterstandorte = count($this->klosterstandortRepository->findByOrt($uuid)); $orthasurls = count($this->ortHasUrlRepository->findByOrt($uuid)); $bistums = count($this->bistumRepository->findByOrt($uuid)); if ($klosterstandorte == 0 && $orthasurls == 0 && $bistums == 0) { $ortObj = $this->ortRepository->findByIdentifier($uuid); if (!is_object($ortObj)) { $this->throwStatus(400, 'Entity Ort not available', null); } $this->ortRepository->remove($ortObj); // Fetch Ort Urls $ortHasUrls = $ortObj->getOrtHasUrls(); if (is_array($ortHasUrls)) { foreach ($ortHasUrls as $ortHasUrl) { $this->ortHasUrlRepository->remove($ortHasUrl); } } $this->throwStatus(200, null, null); } else { $this->throwStatus(400, 'Due to dependencies Ort entity could not be deleted', null); } }
/** * Import Ort table into the FLOW domain_model tabel subugoe_germaniasacra_domain_model_ort * @return int */ public function importOrtAction() { if ($this->logger) { $start = microtime(true); } /** @var \Doctrine\DBAL\Connection $sqlConnection */ $sqlConnection = $this->entityManager->getConnection(); $tbl = 'subugoe_germaniasacra_domain_model_ort'; $sql = "ANALYZE LOCAL TABLE " . $tbl; $sqlConnection->executeUpdate($sql); $sqlConnection->close(); /** @var \Doctrine\DBAL\Connection $sqlConnection */ $sqlConnection = $this->entityManager->getConnection(); $tbl = 'subugoe_germaniasacra_domain_model_urltyp'; $sql = 'SELECT * FROM ' . $tbl . ' WHERE name = "Geonames"'; $urltyp = $sqlConnection->fetchAll($sql); if (count($urltyp) > 0) { $urltypUUID = $urltyp[0]['persistence_object_identifier']; } if (!isset($urltypUUID)) { $urlTypeName = "Geonames"; $urltypObject = new Urltyp(); $urltypObject->setName($urlTypeName); $this->urltypRepository->add($urltypObject); $this->persistenceManager->persistAll(); $urltypUUID = $urltypObject->getUUID(); } $sql = 'SELECT * FROM Ort ORDER BY ID ASC'; $orts = $sqlConnection->fetchAll($sql); if (isset($orts) and is_array($orts)) { $nOrt = 0; foreach ($orts as $ortvalue) { $uid = $ortvalue['ID']; $ort = $ortvalue['Ort']; $laenge = round($ortvalue['Laenge'], 5); $breite = round($ortvalue['Breite'], 5); $wuestung = $ortvalue['Wuestung']; $gemeinde = $ortvalue['Gemeinde']; $kreis = $ortvalue['Kreis']; $land = $ortvalue['Land']; $url = $ortvalue['GeoNameId']; $ortObject = new Ort(); $ortObject->setUid($uid); $ortObject->setOrt($ort); $ortObject->setLaenge($laenge); $ortObject->setBreite($breite); $ortObject->setWuestung($wuestung); $ortObject->setGemeinde($gemeinde); $ortObject->setKreis($kreis); $landObject = $this->landRepository->findOneByUid($land); if (is_object($landObject)) { $ortObject->setLand($landObject); } $this->ortRepository->add($ortObject); $this->persistenceManager->persistAll(); $ortUUID = $ortObject->getUUID(); if (isset($url) && !empty($url)) { $url = 'http://geonames.org/' . $url; $urlbemerkung = $ort . " " . $url; $urlObject = new Url(); $urlObject->setUrl($url); $urlObject->setBemerkung($urlbemerkung); $urltypObject = $this->urltypRepository->findByIdentifier($urltypUUID); $urlObject->setUrltyp($urltypObject); $this->urlRepository->add($urlObject); $this->persistenceManager->persistAll(); $urlUUID = $urlObject->getUUID(); $orthasurlObject = new Orthasurl(); $ortObject = $this->ortRepository->findByIdentifier($ortUUID); $orthasurlObject->setOrt($ortObject); $urlObject = $this->urlRepository->findByIdentifier($urlUUID); $orthasurlObject->setUrl($urlObject); $this->ortHasUrlRepository->add($orthasurlObject); $this->persistenceManager->persistAll(); } $nOrt++; } if ($this->logger) { $end = microtime(true); $time = number_format($end - $start, 2); $this->logger->log('Ort import completed in ' . round($time / 60, 2) . ' minutes.'); } return $nOrt; } }