annotate artifacts/src/main/java/org/dive4elements/river/exports/injector/PNPInjector.java @ 8337:f5461750e5c7

Avoid NPE if river is not accessible.
author "Tom Gottfried <tom@intevation.de>"
date Fri, 26 Sep 2014 17:22:51 +0200
parents 10917ec29625
children 47199406994a
rev   line source
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
1 package org.dive4elements.river.exports.injector;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
2
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
3 import org.apache.log4j.Logger;
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
4 import org.dive4elements.artifacts.Artifact;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
5 import org.dive4elements.artifacts.CallContext;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
6 import org.dive4elements.artifacts.ContextInjector;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
7 import org.dive4elements.river.artifacts.D4EArtifact;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
8 import org.dive4elements.river.artifacts.access.RiverAccess;
8337
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
9 import org.dive4elements.river.model.River;
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
10 import org.dive4elements.river.model.Gauge;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
11 import org.w3c.dom.Document;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
12 import org.w3c.dom.Element;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
13
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
14 import static org.dive4elements.river.exports.injector.InjectorConstants.CURRENT_KM;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
15 import static org.dive4elements.river.exports.injector.InjectorConstants.PNP;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
16 import static org.dive4elements.river.exports.injector.InjectorConstants.GAUGE_EPSILON;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
17
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
18 public class PNPInjector
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
19 implements ContextInjector
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
20 {
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
21
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
22 private Logger log = Logger.getLogger(PNPInjector.class);
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
23 @Override
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
24 public void setup(Element cfg) {
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
25 // TODO Auto-generated method stub
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
26
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
27 }
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
28
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
29 @Override
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
30 public void injectContext(
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
31 CallContext ctx,
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
32 Artifact artifact,
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
33 Document request
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
34 ) {
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
35 Object currentKm = ctx.getContextValue(CURRENT_KM);
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
36 if (currentKm == null) {
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
37 log.debug("no current km. not injecting pnp");
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
38 return;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
39 }
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
40
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
41 Double km = Double.valueOf(currentKm.toString());
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
42 if (Double.isNaN(km) || Double.isInfinite(km)) {
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
43 log.debug("current km is NAN or infinte. not injecting pnp.");
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
44 return;
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
45 }
8337
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
46
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
47 River river = new RiverAccess((D4EArtifact)artifact).getRiver();
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
48 if (river == null) {
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
49 log.error("River not accessible from artifact. Not injecting PNP");
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
50 return;
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
51 }
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
52
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
53 Gauge gauge =
8337
f5461750e5c7 Avoid NPE if river is not accessible.
"Tom Gottfried <tom@intevation.de>"
parents: 8326
diff changeset
54 river.determineGaugeByStation(
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
55 km - GAUGE_EPSILON,
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
56 km + GAUGE_EPSILON);
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
57
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
58 if (gauge == null) {
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
59 log.debug("no gauge found at current km. not injecting pnp");
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
60 return;
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
61 }
8326
10917ec29625 Inject current km and pnp into the context used to calculate W in cm at gauge.
Raimund Renkert <rrenkert@intevation.de>
parents: 8304
diff changeset
62 log.debug("injecting pnp: " + gauge.getDatum());
8304
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
63 ctx.putContextValue(PNP, gauge.getDatum());
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
64 }
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
65
c4bd57172aa7 Added injector for PNP.
Raimund Renkert <rrenkert@intevation.de>
parents:
diff changeset
66 }

http://dive4elements.wald.intevation.org