diff src/main/java/de/intevation/lada/data/importer/LAFImporter.java @ 337:cb47c33b119d

Imporved error/warning handling and fixed some bugs in the importer module.
author Raimund Renkert <rrenkert@intevation.de>
date Wed, 28 Aug 2013 15:11:50 +0200
parents 5d11428e6a09
children e0bbb54f2f7c
line wrap: on
line diff
--- a/src/main/java/de/intevation/lada/data/importer/LAFImporter.java	Wed Aug 28 15:10:19 2013 +0200
+++ b/src/main/java/de/intevation/lada/data/importer/LAFImporter.java	Wed Aug 28 15:11:50 2013 +0200
@@ -16,6 +16,7 @@
 import javax.persistence.Query;
 
 import de.intevation.lada.auth.AuthenticationResponse;
+import de.intevation.lada.data.QueryBuilder;
 import de.intevation.lada.data.Repository;
 import de.intevation.lada.model.LKommentarM;
 import de.intevation.lada.model.LKommentarP;
@@ -23,6 +24,7 @@
 import de.intevation.lada.model.LMesswert;
 import de.intevation.lada.model.LOrt;
 import de.intevation.lada.model.LProbe;
+import de.intevation.lada.model.LProbeInfo;
 import de.intevation.lada.rest.Response;
 import de.intevation.lada.validation.ValidationException;
 import de.intevation.lada.validation.Validator;
@@ -99,301 +101,24 @@
         this.errors.clear();
         this.parser.reset();
         try {
-            boolean success = parser.parse(content);
-            if (success) {
-                List<LProbe> proben = parser.getProben();
-                List<LMessung> messungen = parser.getMessungen();
-                List<LOrt> orte = parser.getOrte();
-                List<LKommentarP> pKommentare = parser.getProbeKommentare();
-                List<LKommentarM> mKommentare = parser.getMessungKommentare();
-                List<LMesswert> messwerte = parser.getMesswerte();
-                writeProben(auth, proben);
-                writeMessungen(auth, messungen);
-                //writeOrte(auth, orte);
-                writePKommentare(auth, pKommentare);
-                writeMKommentare(auth, mKommentare);
-                writeMesswerte(auth, messwerte);
-            }
-            else {
+            boolean success = parser.parse(auth, content);
+            if (!success) {
                 List<ReportData> report = new ArrayList<ReportData>();
-                report.add( new ReportData("parser", "no success", 660));
+                report.add(new ReportData("parser", "no success", 660));
                 errors.put("parser", report);
+                warnings.put("parser", new ArrayList<ReportData>());
                 return false;
             }
         }
         catch (LAFParserException e) {
             List<ReportData> report = new ArrayList<ReportData>();
-            report.add(new ReportData("parser", e.getMessage(), 660));
+            report.add(new ReportData("parser", e.getMessage(), 670));
             errors.put("parser", report);
+            warnings.put("parser", new ArrayList<ReportData>());
             return false;
         }
-        Map<String, Map<String, List<ReportData>>> data =
-            new HashMap<String, Map<String, List<ReportData>>>();
         this.warnings.putAll(this.parser.getWarnings());
         this.errors.putAll(this.parser.getErrors());
-        data.put("warnings", warnings);
-        data.put("errors", errors);
         return true;
     }
-
-    private void writeMessungen(
-        AuthenticationResponse auth,
-        List<LMessung> messungen
-    ) {
-        for(LMessung messung: messungen) {
-            try {
-
-                Map<String, Integer> warn =
-                    messungValidator.validate(messung, false);
-                messungRepository.create(messung);
-                if (warn != null) {
-                    for (String key : warn.keySet()) {
-                       // warnings.put(messung.getProbeId(),
-                       // new ReportData(key, "", warn.get(key)));
-                    }
-                }
-            }
-            catch (ValidationException e) {
-                //errors.put(messung.getProbeId(), e.getErrors());
-                //warnings.put(
-                //    messung.getProbeId(),
-                //    e.getWarnings());
-            }
-        }
-    }
-
-    @TransactionAttribute(TransactionAttributeType.REQUIRED)
-    private void writeMesswerte(
-        AuthenticationResponse auth,
-        List<LMesswert> messwerte
-    ) {
-        for(LMesswert messwert: messwerte) {
-            try {
-                Map<String, Integer> warn =
-                    messwertValidator.validate(messwert, false);
-                Response r = messwertRepository.create(messwert);
-                if (warn != null) {
-                //    warnings.put(
-                //        messwert.getProbeId(),
-                //        warn);
-                }
-            }
-            catch (ValidationException e) {
-                //errors.put(messwert.getProbeId(), e.getErrors());
-                //warnings.put(
-                //    messwert.getProbeId(),
-                //    e.getWarnings());
-            }
-        }
-    }
-
-    @TransactionAttribute(TransactionAttributeType.REQUIRED)
-    private void writePKommentare(
-        AuthenticationResponse auth,
-        List<LKommentarP> kommentare
-    ) {
-        for(LKommentarP kommentar: kommentare) {
-            try {
-                pKommentarRepository.create(kommentar);
-            }
-            catch(Exception e) {
-                Map<String, Integer> err = new HashMap<String, Integer>();
-                err.put(
-                    kommentar.getProbeId() + " - " +
-                    kommentar.getkId(), 661);
-                //errors.put("lkommentarp", err);
-            }
-        }
-    }
-
-    @TransactionAttribute(TransactionAttributeType.REQUIRED)
-    private void writeMKommentare(
-        AuthenticationResponse auth,
-        List<LKommentarM> kommentare
-    ) {
-        for(LKommentarM kommentar: kommentare) {
-            Query q =
-            em.createNativeQuery(
-                "select nextval('kommentar_m_id_seq')");
-            BigInteger seqId = (BigInteger)q.getSingleResult();
-            kommentar.getId().setKId(seqId.intValue());
-            mKommentarRepository.create(kommentar);
-        }
-    }
-
-    @TransactionAttribute(TransactionAttributeType.REQUIRED)
-    private void writeOrte(
-        AuthenticationResponse auth,
-        List<LOrt> orte
-    ) {
-        for(LOrt ort: orte) {
-            try {
-                Map<String, Integer> warn =
-                    ortValidator.validate(ort, false);
-                ortRepository.create(ort);
-                if (warn != null) {
-                  //  warnings.put(String.valueOf(ort.getOrtId()), warn);
-                }
-            }
-            catch (ValidationException e) {
-                //errors.put(String.valueOf(ort.getOrtId()), e.getErrors());
-                //warnings.put(
-                //    String.valueOf(ort.getOrtId()),
-                //    e.getWarnings());
-            }
-        }
-    }
-
-    @TransactionAttribute(TransactionAttributeType.REQUIRED)
-    private void writeProben(AuthenticationResponse auth, List<LProbe> proben) {
-        for (LProbe probe: proben) {
-            if (!authorized(probe, auth)) {
-                Map<String, Integer> err = new HashMap<String, Integer>();
-                err.put("not authorized", 699);
-                //errors.put(probe.getProbeId(), err);
-                continue;
-            }
-            try {
-                Map<String, Integer> warn =
-                    probeValidator.validate(probe, false);
-                if (warn != null) {
-                  //  warnings.put(probe.getProbeId(), warn);
-                }
-            }
-            catch (ValidationException e) {
-                //errors.put(probe.getProbeId(), e.getErrors());
-                //warnings.put(probe.getProbeId(), e.getWarnings());
-                continue;
-            }
-            persist(probe);
-        }
-    }
-
-    private boolean authorized(LProbe probe, AuthenticationResponse auth) {
-        if (auth.getNetzbetreiber().contains(probe.getNetzbetreiberId()) &&
-            auth.getMst().contains(probe.getMstId())) {
-            return true;
-        }
-        return false;
-    }
-
-    @TransactionAttribute(TransactionAttributeType.REQUIRED)
-    private void persist(LProbe probe) {
-        String queryColumns = "insert into l_probe (probe_id, ba_id, test," +
-            " datenbasis_id, netzbetreiber_id, mst_id, probenart_id, umw_id";
-        String queryParameter = " values (:probe_id, :ba_id, :test," +
-            " :datenbasis_id, :netzbetreiber_id, :mst_id, :probenart_id," +
-            " :umw_id";
-        if (probe.getErzeugerId() != null) {
-            queryColumns += ", erzeuger_id";
-            queryParameter += ", :erzeuger_id";
-        }
-        if (probe.getHauptprobenNr() != null) {
-            queryColumns += ", hauptproben_nr";
-            queryParameter += ", :hauptproben_nr";
-        }
-        if (probe.getLetzteAenderung() != null) {
-            queryColumns += ", letzte_aenderung";
-            queryParameter += ", :letzte_aenderung";
-        }
-        if (probe.getMedia() != null) {
-            queryColumns += ", media";
-            queryParameter += ", :media";
-        }
-        if (probe.getMediaDesk() != null) {
-            queryColumns += ", media_desk";
-            queryParameter += ", :media_desk";
-        }
-        if (probe.getMittelungsdauer() != null) {
-            queryColumns += ", mittelungsdauer";
-            queryParameter += ", :mittelungsdauer";
-        }
-        if (probe.getMpKat() != null) {
-            queryColumns += ", mp_kat";
-            queryParameter += ", mp_kat";
-        }
-        if (probe.getMplId() != null) {
-            queryColumns += ", mpl_id";
-            queryParameter += ", :mpl_id";
-        }
-        if (probe.getMprId() != null) {
-            queryColumns += ", mpr_id";
-            queryParameter += ", :mpr_id";
-        }
-        if (probe.getProbeNehmerId() != null) {
-            queryColumns += ", probe_nehmer_id";
-            queryParameter += ", :probe_nehmer_id";
-        }
-        if (probe.getProbeentnahmeBeginn() != null) {
-            queryColumns += ", probeentnahme_beginn";
-            queryParameter += ", :probeentnahme_beginn";
-        }
-        if (probe.getProbeentnahmeEnde() != null) {
-            queryColumns += ", probeentnahme_ende";
-            queryParameter += ", :probeentnahme_ende";
-        }
-        if (probe.getSolldatumBeginn() != null) {
-            queryColumns += ", solldatum_beginn";
-            queryParameter += ", :solldatum_beginn";
-        }
-        if (probe.getSolldatumEnde() != null) {
-            queryColumns += ", solldatum_ende";
-            queryParameter += ", :solldatum_ende";
-        }
-        queryColumns += ") " + queryParameter + ")";
-        
-        Query insert = em.createNativeQuery(queryColumns);
-        insert.setParameter("probe_id", probe.getProbeId());
-        insert.setParameter("ba_id", probe.getBaId());
-        insert.setParameter("datenbasis_id", probe.getDatenbasisId());
-        insert.setParameter("mst_id", probe.getMstId());
-        insert.setParameter("netzbetreiber_id", probe.getNetzbetreiberId());
-        insert.setParameter("probenart_id", probe.getProbenartId());
-        insert.setParameter("test", probe.isTest());
-        insert.setParameter("umw_id", probe.getUmwId());
-        if (probe.getErzeugerId() != null) {
-            insert.setParameter("erzeuger_id", probe.getErzeugerId());
-        }
-        if (probe.getHauptprobenNr() != null) {
-            insert.setParameter("hauptproben_nr", probe.getHauptprobenNr());
-        }
-        if (probe.getLetzteAenderung() != null) {
-            insert.setParameter("letzte_aenderung", probe.getLetzteAenderung());
-        }
-        if (probe.getMedia() != null) {
-            insert.setParameter("media", probe.getMedia());
-        }
-        if (probe.getMediaDesk() != null) {
-            insert.setParameter("media_desk", probe.getMediaDesk());
-        }
-        if (probe.getMittelungsdauer() != null) {
-            insert.setParameter("mittelungsdauer", probe.getMittelungsdauer());
-        }
-        if (probe.getMpKat() != null) {
-            insert.setParameter("mp_kat", probe.getMpKat());
-        }
-        if (probe.getMplId() != null) {
-            insert.setParameter("mpl_id", probe.getMplId());
-        }
-        if (probe.getMprId() != null) {
-            insert.setParameter("mpr_id", probe.getMprId());
-        }
-        if (probe.getProbeNehmerId() != null) {
-            insert.setParameter("probe_nehmer_id", probe.getProbeNehmerId());
-        }
-        if (probe.getProbeentnahmeBeginn() != null) {
-            insert.setParameter("probeentnahme_beginn", probe.getProbeentnahmeBeginn());
-        }
-        if (probe.getProbeentnahmeEnde() != null) {
-            insert.setParameter("probeentnahme_ende", probe.getProbeentnahmeEnde());
-        }
-        if (probe.getSolldatumBeginn() != null) {
-            insert.setParameter("solldatum_beginn", probe.getSolldatumBeginn());
-        }
-        if (probe.getSolldatumEnde() != null) {
-            insert.setParameter("solldatum_ende", probe.getSolldatumEnde());
-        }
-        int res = insert.executeUpdate();
-        int i = res;
-    }
 }
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)