Mercurial > lada > lada-server
changeset 260:0de24f5e7c01
Added boolean parameter to validate method to test if update or create was triggered.
author | Raimund Renkert <rrenkert@intevation.de> |
---|---|
date | Tue, 16 Jul 2013 08:24:34 +0200 (2013-07-16) |
parents | 9da1ee33b1fa |
children | 07c4186cbfab |
files | src/main/java/de/intevation/lada/data/LMessungRepository.java src/main/java/de/intevation/lada/data/LMesswertRepository.java src/main/java/de/intevation/lada/data/LOrtRepository.java src/main/java/de/intevation/lada/data/LProbeRepository.java src/main/java/de/intevation/lada/validation/LMessungValidator.java src/main/java/de/intevation/lada/validation/LMesswertValidator.java src/main/java/de/intevation/lada/validation/LOrtValidator.java src/main/java/de/intevation/lada/validation/LProbeValidator.java src/main/java/de/intevation/lada/validation/Validator.java |
diffstat | 9 files changed, 24 insertions(+), 14 deletions(-) [+] |
line wrap: on
line diff
--- a/src/main/java/de/intevation/lada/data/LMessungRepository.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/data/LMessungRepository.java Tue Jul 16 08:24:34 2013 +0200 @@ -108,7 +108,7 @@ LMessung messung = (LMessung)object; Response response = new Response(true, 200, messung); try { - Map<String, Integer> warnings = validator.validate(messung); + Map<String, Integer> warnings = validator.validate(messung, false); manager.create(messung); response.setWarnings(warnings); return response; @@ -152,7 +152,7 @@ Response response = new Response(true, 200, messung); // Try to save the new LProbe. try { - Map<String, Integer> warnings = validator.validate(messung); + Map<String, Integer> warnings = validator.validate(messung, true); manager.update(messung); response.setWarnings(warnings); return response;
--- a/src/main/java/de/intevation/lada/data/LMesswertRepository.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/data/LMesswertRepository.java Tue Jul 16 08:24:34 2013 +0200 @@ -107,7 +107,7 @@ LMesswert messwert = (LMesswert)object; Response response = new Response(true, 200, messwert); try { - Map<String, Integer> warnings = validator.validate(messwert); + Map<String, Integer> warnings = validator.validate(messwert, false); manager.create(messwert); response.setWarnings(warnings); return response;
--- a/src/main/java/de/intevation/lada/data/LOrtRepository.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/data/LOrtRepository.java Tue Jul 16 08:24:34 2013 +0200 @@ -109,7 +109,7 @@ Response response = new Response(true, 200, ort); // Try to save the new LOrt. try { - Map<String, Integer> warnings = validator.validate(ort); + Map<String, Integer> warnings = validator.validate(ort, false); manager.create(ort); response.setWarnings(warnings); return response; @@ -153,7 +153,7 @@ Response response = new Response(true, 200, ort); // Try to update a LOrt object. try { - Map<String, Integer> warnings = validator.validate(ort); + Map<String, Integer> warnings = validator.validate(ort, true); manager.update(ort); response.setWarnings(warnings); return response;
--- a/src/main/java/de/intevation/lada/data/LProbeRepository.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/data/LProbeRepository.java Tue Jul 16 08:24:34 2013 +0200 @@ -104,7 +104,7 @@ Response response = new Response(true, 200, probe); // Try to save the new LProbe. try { - Map<String, Integer> warnings = validator.validate(probe); + Map<String, Integer> warnings = validator.validate(probe, false); manager.create(probe); response.setWarnings(warnings); return response; @@ -147,7 +147,7 @@ LProbe probe = (LProbe)object; Response response = new Response(true, 200, probe); try { - Map<String, Integer> warnings = validator.validate(probe); + Map<String, Integer> warnings = validator.validate(probe, true); manager.update(probe); response.setWarnings(warnings); return response;
--- a/src/main/java/de/intevation/lada/validation/LMessungValidator.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/validation/LMessungValidator.java Tue Jul 16 08:24:34 2013 +0200 @@ -34,7 +34,7 @@ private Repository messungRepository; @Override - public Map<String, Integer> validate(Object object) + public Map<String, Integer> validate(Object object, boolean update) throws ValidationException { Map<String, Integer> warnings = new HashMap<String, Integer>(); if (!(object instanceof LMessung)) { @@ -44,12 +44,15 @@ } LMessung messung = (LMessung)object; - validateNebenprobenNr(messung, warnings); + validateHasNebenprobenNr(messung, warnings); validateDatum(messung, warnings); + if (!update) { + validateUniqueNebenprobenNr(messung, warnings); + } return warnings; } - private void validateNebenprobenNr( + private void validateHasNebenprobenNr( LMessung messung, Map<String, Integer> warnings) throws ValidationException { @@ -57,6 +60,12 @@ messung.getNebenprobenNr().equals("")) { warnings.put("nebenprobenNr", 631); } + } + + private void validateUniqueNebenprobenNr( + LMessung messung, + Map<String, Integer> warnings) + throws ValidationException { QueryBuilder<LMessung> builder = new QueryBuilder<LMessung>( messungRepository.getEntityManager(),
--- a/src/main/java/de/intevation/lada/validation/LMesswertValidator.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/validation/LMesswertValidator.java Tue Jul 16 08:24:34 2013 +0200 @@ -15,7 +15,7 @@ { @Override - public Map<String, Integer> validate(Object object) + public Map<String, Integer> validate(Object object, boolean update) throws ValidationException { Map<String, Integer> warnings = new HashMap<String, Integer>(); if (!(object instanceof LMesswert)) {
--- a/src/main/java/de/intevation/lada/validation/LOrtValidator.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/validation/LOrtValidator.java Tue Jul 16 08:24:34 2013 +0200 @@ -15,7 +15,7 @@ { @Override - public Map<String, Integer> validate(Object object) + public Map<String, Integer> validate(Object object, boolean update) throws ValidationException { Map<String, Integer> warnings = new HashMap<String, Integer>(); if (!(object instanceof LOrt)) {
--- a/src/main/java/de/intevation/lada/validation/LProbeValidator.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/validation/LProbeValidator.java Tue Jul 16 08:24:34 2013 +0200 @@ -40,7 +40,7 @@ * @param probe The LProbe object. */ @Override - public Map<String, Integer> validate(Object probe) + public Map<String, Integer> validate(Object probe, boolean update) throws ValidationException { Map<String, Integer>warnings = new HashMap<String, Integer>(); if (!(probe instanceof LProbe)) {
--- a/src/main/java/de/intevation/lada/validation/Validator.java Tue Jul 16 08:05:06 2013 +0200 +++ b/src/main/java/de/intevation/lada/validation/Validator.java Tue Jul 16 08:24:34 2013 +0200 @@ -9,5 +9,6 @@ */ public interface Validator { - public Map<String, Integer> validate(Object object) throws ValidationException; + public Map<String, Integer> validate(Object object, boolean update) + throws ValidationException; }