[Lada-commits] [PATCH 2 of 2] Adapt definition to LAF and validate uniqueness of idAlt
Wald Commits
scm-commit at wald.intevation.org
Tue Nov 1 12:48:46 CET 2016
# HG changeset patch
# User Tom Gottfried <tom at intevation.de>
# Date 1478000845 -3600
# Node ID 48c0132dbc85c9af7d6f429fa29dc170b11e2d21
# Parent 830a47aeb15d6bcbcd3fd30779aa8e594db0e7c8
Adapt definition to LAF and validate uniqueness of idAlt.
diff -r 830a47aeb15d -r 48c0132dbc85 db_schema/lada_schema.sql
--- a/db_schema/lada_schema.sql Tue Nov 01 12:11:06 2016 +0100
+++ b/db_schema/lada_schema.sql Tue Nov 01 12:47:25 2016 +0100
@@ -192,7 +192,7 @@
CREATE TABLE probe (
id serial PRIMARY KEY,
- id_alt character varying(20) UNIQUE NOT NULL
+ id_alt character varying(16) UNIQUE NOT NULL
DEFAULT 'sss'
|| lpad(nextval('land.probe_probe_id_seq')::varchar, 12, '0')
|| 'Y',
diff -r 830a47aeb15d -r 48c0132dbc85 src/main/java/de/intevation/lada/validation/rules/probe/UniqueIdAlt.java
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/src/main/java/de/intevation/lada/validation/rules/probe/UniqueIdAlt.java Tue Nov 01 12:47:25 2016 +0100
@@ -0,0 +1,56 @@
+/* Copyright (C) 2013 by Bundesamt fuer Strahlenschutz
+ * Software engineering by Intevation GmbH
+ *
+ * This file is Free Software under the GNU GPL (v>=3)
+ * and comes with ABSOLUTELY NO WARRANTY! Check out
+ * the documentation coming with IMIS-Labordaten-Application for details.
+ */
+package de.intevation.lada.validation.rules.probe;
+
+import java.util.List;
+
+import javax.inject.Inject;
+
+import de.intevation.lada.model.land.Probe;
+import de.intevation.lada.util.annotation.RepositoryConfig;
+import de.intevation.lada.util.data.QueryBuilder;
+import de.intevation.lada.util.data.Repository;
+import de.intevation.lada.util.data.RepositoryType;
+import de.intevation.lada.validation.Violation;
+import de.intevation.lada.validation.annotation.ValidationRule;
+import de.intevation.lada.validation.rules.Rule;
+
+/**
+ * Validation rule for probe.
+ * Validates if the probe has a unique "id_alt".
+ *
+ */
+ at ValidationRule("Probe")
+public class UniqueIdAlt implements Rule {
+
+ @Inject
+ @RepositoryConfig(type=RepositoryType.RO)
+ private Repository repo;
+
+ @Override
+ public Violation execute(Object object) {
+ Probe probe = (Probe)object;
+ QueryBuilder<Probe> builder = new QueryBuilder<Probe>(
+ repo.entityManager("land"),
+ Probe.class);
+ builder.and("idAlt", probe.getIdAlt());
+ List<Probe> existing = repo.filterPlain(builder.getQuery(), "land");
+ if (!existing.isEmpty()) {
+ Probe found = existing.get(0);
+ // The probe found in the db equals the new probe. (Update)
+ if (probe.getId() != null && probe.getId().equals(found.getId())) {
+ return null;
+ }
+ Violation violation = new Violation();
+ violation.addError("idAlt", 611);
+ return violation;
+ }
+ return null;
+ }
+
+}
More information about the Lada-commits
mailing list