annotate artifacts/src/main/java/org/dive4elements/river/utils/ArtifactMapfileGenerator.java @ 6834:d4b9fe13c9b8

Add missing import in ArtifactMapfileGenerator
author Christian Lins <christian.lins@intevation.de>
date Thu, 15 Aug 2013 13:40:43 +0200
parents 20f98087664d
children fc2de41ebdb8
rev   line source
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
1 /* Copyright (C) 2011, 2012, 2013 by Bundesanstalt für Gewässerkunde
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
2 * Software engineering by Intevation GmbH
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
3 *
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5867
diff changeset
4 * This file is Free Software under the GNU AGPL (>=v3)
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
5 * and comes with ABSOLUTELY NO WARRANTY! Check out the
5994
af13ceeba52a Removed trailing whitespace.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5867
diff changeset
6 * documentation coming with Dive4Elements River for details.
5863
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
7 */
4897a58c8746 River artifacts: Added new copyright headers.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5838
diff changeset
8
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
9 package org.dive4elements.river.utils;
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
10
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
11 import org.dive4elements.artifacts.CallContext;
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
12 import org.dive4elements.river.artifacts.D4EArtifact;
5831
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
13 import org.dive4elements.river.artifacts.access.RiverAccess;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
14 import org.dive4elements.river.artifacts.model.LayerInfo;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
15 import org.dive4elements.river.artifacts.model.map.WMSDBLayerFacet;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
16 import org.dive4elements.river.artifacts.model.map.WMSLayerFacet;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
17 import org.dive4elements.river.artifacts.model.map.WSPLGENLayerFacet;
bd047b71ab37 Repaired internal references
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5309
diff changeset
18 import org.dive4elements.river.artifacts.resources.Resources;
6834
d4b9fe13c9b8 Add missing import in ArtifactMapfileGenerator
Christian Lins <christian.lins@intevation.de>
parents: 6833
diff changeset
19 import org.dive4elements.river.artifacts.states.FloodMapState;
6831
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
20
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
21 import java.io.File;
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
22 import java.io.FileNotFoundException;
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
23 import java.io.IOException;
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
24 import java.util.List;
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
25
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
26 import org.apache.log4j.Logger;
8c7433b8656d Backed out changeset 74a437805e2a
Sascha L. Teichmann <teichmann@intevation.de>
parents: 6826
diff changeset
27 import org.apache.velocity.Template;
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
28 import org.geotools.data.shapefile.ShpFiles;
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
29 import org.geotools.data.shapefile.shp.ShapefileHeader;
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
30 import org.geotools.data.shapefile.shp.ShapefileReader;
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
31
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
32 public class ArtifactMapfileGenerator extends MapfileGenerator {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
33
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
34 private static Logger logger = Logger.getLogger(ArtifactMapfileGenerator.class);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
35
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
36 @Override
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
37 protected String getVelocityLogfile() {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
38 return RiverUtils.getXPathString(RiverUtils.XPATH_FLOODMAP_VELOCITY_LOGFILE);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
39 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
40
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
41 @Override
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
42 protected String getMapserverTemplatePath() {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
43 return RiverUtils.getXPathString(RiverUtils.XPATH_FLOODMAP_MAPSERVER_TEMPLATE_PATH);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
44 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
45
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
46 @Override
5309
b55975761708 Changed visiblitiy of some methods. TODO: A lot of refactoring.
Raimund Renkert <rrenkert@intevation.de>
parents: 4994
diff changeset
47 public String getMapserverUrl() {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
48 return RiverUtils.getXPathString(RiverUtils.XPATH_FLOODMAP_MAPSERVER_URL);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
49 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
50
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
51 /**
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
52 * Method which starts searching for meta information file and mapfile
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
53 * generation.
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
54 */
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
55 @Override
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
56 public void generate() throws IOException
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
57 {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
58 File[] userDirs = getUserDirs();
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
59 List<String> layers = parseLayers(userDirs);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
60 logger.info("Found " + layers.size() + " layers for user mapfile.");
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
61
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
62 writeMapfile(layers);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
63 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
64
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
65 /**
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
66 * Creates a layer file used for Mapserver's mapfile which represents the
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
67 * floodmap.
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
68 *
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
69 * @param flys The D4EArtifact that owns <i>wms</i>.
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
70 * @param wms The WMSLayerFacet that contains information for the layer.
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
71 */
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
72 public void createUeskLayer(
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
73 D4EArtifact flys,
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
74 WSPLGENLayerFacet wms,
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
75 String style,
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
76 CallContext context
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
77 ) throws FileNotFoundException, IOException
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
78 {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
79 logger.debug("createUeskLayer");
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
80
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
81 LayerInfo layerinfo = new LayerInfo();
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
82 layerinfo.setName(MS_WSPLGEN_PREFIX + flys.identifier());
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
83 layerinfo.setType("POLYGON");
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
84 layerinfo.setDirectory(flys.identifier());
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
85 layerinfo.setData(WSPLGEN_RESULT_SHAPE);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
86 layerinfo.setTitle(Resources.getMsg(Resources.getLocale(context.getMeta()),
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
87 "floodmap.uesk",
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
88 "Floodmap"));
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
89 layerinfo.setStyle(style);
4994
63617e142dfe Quick-fix for floodmaps. Use the correct projection for DGM.
Raimund Renkert <rrenkert@intevation.de>
parents: 4702
diff changeset
90 RiverAccess access = new RiverAccess(flys);
63617e142dfe Quick-fix for floodmaps. Use the correct projection for DGM.
Raimund Renkert <rrenkert@intevation.de>
parents: 4702
diff changeset
91 String river = access.getRiver();
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
92 layerinfo.setSrid(RiverUtils.getRiverDGMSrid(river));
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
93
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
94 String name = MS_LAYER_PREFIX + wms.getName();
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
95
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
96 Template template = getTemplateByName(WSPLGEN_LAYER_TEMPLATE);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
97 if (template == null) {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
98 logger.warn("Template '" + WSPLGEN_LAYER_TEMPLATE + "' found.");
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
99 return;
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
100 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
101
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
102 try {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
103 File dir = new File(getShapefileBaseDir(), flys.identifier());
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
104 writeLayer(layerinfo, new File(dir, name), template);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
105 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
106 catch (FileNotFoundException fnfe) {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
107 logger.error(fnfe, fnfe);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
108 logger.warn("Unable to write layer: " + name);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
109 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
110 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
111
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
112
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
113 /**
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
114 * Creates a layer file used for Mapserver's mapfile which represents the
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
115 * shape files uploaded by the user.
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
116 *
5867
59ff03ff48f1 River artifacts: Renamed FLYSArtifact(Collection) to D4EArtifact(Collection).
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5865
diff changeset
117 * @param flys The D4EArtifact that owns <i>wms</i>.
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
118 * @param wms The WMSLayerFacet that contains information for the layer.
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
119 */
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
120 public void createUserShapeLayer(D4EArtifact flys, WMSLayerFacet wms)
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
121 throws FileNotFoundException, IOException
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
122 {
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
123 logger.debug("createUserShapeLayer");
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
124
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
125 String uuid = flys.identifier();
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
126 File dir = new File(getShapefileBaseDir(), uuid);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
127 File test = new File(dir, WSPLGEN_USER_SHAPE);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
128
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
129 if (!test.exists() || !test.canRead()) {
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
130 logger.debug("No user layer existing.");
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
131 return;
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
132 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
133
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
134 File userShape = new File(dir, WSPLGEN_USER_SHAPE);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
135 ShpFiles sf = new ShpFiles(userShape);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
136 ShapefileReader sfr = new ShapefileReader(sf, true, false, null);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
137 ShapefileHeader sfh = sfr.getHeader();
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
138
6833
20f98087664d (issue657) Prevent errornous recreation of usershape mapfile fragment.
Christian Lins <christian.lins@intevation.de>
parents: 6831
diff changeset
139 String group = MS_USERSHAPE_PREFIX + uuid;
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
140 String groupTitle = "I18N_USER_SHAPE_TITLE";
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
141
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
142 LayerInfo info = new LayerInfo();
6833
20f98087664d (issue657) Prevent errornous recreation of usershape mapfile fragment.
Christian Lins <christian.lins@intevation.de>
parents: 6831
diff changeset
143 info.setName(MS_LAYER_PREFIX + FloodMapState.WSPLGEN_USER_RGD + uuid);
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
144 if (sfh.getShapeType().isLineType()) {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
145 info.setType("LINE");
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
146 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
147 else if (sfh.getShapeType().isPolygonType()) {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
148 info.setType("POLYGON");
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
149 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
150 else {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
151 return;
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
152 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
153 info.setDirectory(uuid);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
154 info.setData(WSPLGEN_USER_SHAPE);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
155 info.setTitle("I18N_USER_SHAPE");
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
156 info.setGroup(group);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
157 info.setGroupTitle(groupTitle);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
158 info.setSrid(wms.getSrid());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
159
6833
20f98087664d (issue657) Prevent errornous recreation of usershape mapfile fragment.
Christian Lins <christian.lins@intevation.de>
parents: 6831
diff changeset
160 //String nameUser = MS_LAYER_PREFIX + wms.getName();
20f98087664d (issue657) Prevent errornous recreation of usershape mapfile fragment.
Christian Lins <christian.lins@intevation.de>
parents: 6831
diff changeset
161 // TODO: This rewrites the user-rgd mapfile fragment generated by
20f98087664d (issue657) Prevent errornous recreation of usershape mapfile fragment.
Christian Lins <christian.lins@intevation.de>
parents: 6831
diff changeset
162 // HWSBarrierState. Otherwise we would have to fragments with same
20f98087664d (issue657) Prevent errornous recreation of usershape mapfile fragment.
Christian Lins <christian.lins@intevation.de>
parents: 6831
diff changeset
163 // layer name. Should be refactored...
20f98087664d (issue657) Prevent errornous recreation of usershape mapfile fragment.
Christian Lins <christian.lins@intevation.de>
parents: 6831
diff changeset
164 String nameUser = MS_LAYER_PREFIX + "user-rgd";
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
165
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
166 Template tpl = getTemplateByName(SHP_LAYER_TEMPLATE);
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
167 if (tpl == null) {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
168 logger.warn("Template '" + SHP_LAYER_TEMPLATE + "' found.");
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
169 return;
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
170 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
171
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
172 try {
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
173 writeLayer(info, new File(dir, nameUser), tpl);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
174 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
175 catch (FileNotFoundException fnfe) {
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
176 logger.error(fnfe, fnfe);
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
177 logger.warn("Unable to write layer: " + nameUser);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
178 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
179
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
180 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
181
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
182
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
183 /**
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
184 * Creates a layer file used for Mapserver's mapfile which represents
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
185 * geometries from database.
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
186 *
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
187 * @param flys The D4EArtifact that owns <i>wms</i>.
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
188 * @param wms The WMSLayerFacet that contains information for the layer.
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
189 */
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
190 public void createDatabaseLayer(
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
191 D4EArtifact flys,
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
192 WMSDBLayerFacet wms,
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
193 String style
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
194 )
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
195 throws FileNotFoundException, IOException
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
196 {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
197 logger.debug("createDatabaseLayer");
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
198
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
199 LayerInfo layerinfo = new LayerInfo();
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
200 layerinfo.setName(wms.getName() + "-" + flys.identifier());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
201 layerinfo.setType(wms.getGeometryType());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
202 layerinfo.setFilter(wms.getFilter());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
203 layerinfo.setData(wms.getData());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
204 layerinfo.setTitle(wms.getDescription());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
205 layerinfo.setStyle(style);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
206 if(wms.getExtent() != null) {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
207 layerinfo.setExtent(GeometryUtils.jtsBoundsToOLBounds(wms.getExtent()));
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
208 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
209 layerinfo.setConnection(wms.getConnection());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
210 layerinfo.setConnectionType(wms.getConnectionType());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
211 layerinfo.setLabelItem(wms.getLabelItem());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
212 layerinfo.setSrid(wms.getSrid());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
213
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
214 String name = MS_LAYER_PREFIX + wms.getName();
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
215
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
216 Template template = getTemplateByName(DB_LAYER_TEMPLATE);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
217 if (template == null) {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
218 logger.warn("Template '" + DB_LAYER_TEMPLATE + "' found.");
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
219 return;
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
220 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
221
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
222 try {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
223 File dir = new File(getShapefileBaseDir(), flys.identifier());
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
224 writeLayer(layerinfo, new File(dir, name), template);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
225 }
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
226 catch (FileNotFoundException fnfe) {
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
227 logger.error(fnfe, fnfe);
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
228 logger.warn("Unable to write layer: " + name);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
229 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
230 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
231
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
232 @Override
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
233 protected String getMapfilePath() {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
234 return RiverUtils.getXPathString(RiverUtils.XPATH_FLOODMAP_MAPFILE_PATH);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
235 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
236
6332
f5bb53106ae8 Remove createBarriersLayer and createBarriers
Andre Heinecke <aheinecke@intevation.de>
parents: 5994
diff changeset
237 @Override
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
238 protected String getMapfileTemplate() {
5865
73da40528cf2 River artifacts: Renamed FLYSUtils to RiverUtils.
Sascha L. Teichmann <teichmann@intevation.de>
parents: 5863
diff changeset
239 return RiverUtils.getXPathString(RiverUtils.XPATH_FLOODMAP_MAPFILE_TEMPLATE);
4702
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
240 }
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
241
13abfb1bcb75 Fix typo in class names and correct file path in floodmap.xml.
Christian Lins <christian.lins@intevation.de>
parents:
diff changeset
242 }

http://dive4elements.wald.intevation.org