Revision 21689

View differences:

org.gvsig.raster.wms/tags/org.gvsig.raster.wms-2.2.240/org.gvsig.raster.wms.remoteclient/src/main/java/org/gvsig/remoteclient/wms/WMSServiceInformation.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24
 
25
package org.gvsig.remoteclient.wms;
26

  
27
import java.util.Vector;
28

  
29
import org.gvsig.remoteclient.ogc.OGCClientOperation;
30
import org.gvsig.remoteclient.ogc.OGCServiceInformation;
31
import org.gvsig.remoteclient.utils.CapabilitiesTags;
32

  
33
/**
34
 * Class that represents the description of the WMS metadata.
35
 * The first part of the capabilities will return the service information
36
 * from the WMS, this class will hold this information.
37
 * 
38
 * @author <a href="mailto:jpiera@gvsig.org">Jorge Piera</a>
39
 */
40
public class WMSServiceInformation extends OGCServiceInformation{
41
	/*public String map_online_resource = null;
42
    public String feature_online_resource = null;*/
43
    public String version;
44
    public String name;
45
    public String scope;
46
    public String title;
47
    public String abstr;
48
    public String keywords;
49
    public String fees;
50
    public String operationsInfo;
51
    public String personname;
52
    public String organization;
53
    public String function;
54
    public String addresstype;
55
    public String address;
56
    public String place;
57
    public String province;
58
    public String postcode;
59
    public String country;
60
    public String phone;
61
    public String fax;
62
    public String email;
63
    public Vector formats;
64
    public Vector infoformats;
65

  
66
    public WMSServiceInformation()
67
    {
68
        version = new String();
69
        name = new String();
70
        scope = new String();
71
        title = new String();
72
        abstr = new String();
73
        keywords = new String();
74
        fees = new String();
75
        operationsInfo = new String();
76
        personname = new String();
77
        organization = new String();
78
        function = new String();
79
        addresstype = new String();
80
        address = new String();
81
        place = new String();
82
        province = new String();
83
        postcode = new String();
84
        country = new String();
85
        phone = new String();
86
        fax = new String();
87
        email = new String();
88
        formats = new Vector(); 
89
        infoformats = new Vector();
90
    }
91
    
92
    public boolean isQueryable()
93
    {
94
    	if (getOnlineResource(CapabilitiesTags.GETFEATUREINFO) != null)    	
95
    		return true;
96
    	else
97
    		return false;
98
    }
99
    
100
    public boolean hasLegendGraphic()
101
    {
102
    	if (getOnlineResource(CapabilitiesTags.GETLEGENDGRAPHIC) != null) 
103
    		return true;
104
    	else
105
    		return false;
106
    }
107
    
108
    public void clear() {
109
    	version = new String();
110
        name = new String();
111
        scope = new String();
112
        title = new String();
113
        abstr = new String();
114
        keywords = new String();
115
        fees = new String();
116
        operationsInfo = new String();
117
        personname = new String();
118
        organization = new String();
119
        function = new String();
120
        addresstype = new String();
121
        address = new String();
122
        place = new String();
123
        province = new String();
124
        postcode = new String();
125
        country = new String();
126
        phone = new String();
127
        fax = new String();
128
        email = new String();
129
        formats = new Vector();  
130
        infoformats = new Vector();
131
    }      
132
    
133
	/* (non-Javadoc)
134
	 * @see org.gvsig.remoteClient.ogc.OGCServiceInformation#createOperation(java.lang.String)
135
	 */	
136
	public OGCClientOperation createOperation(String name) {
137
		return new WMSOperation(name); 
138
	}
139

  
140
	/* (non-Javadoc)
141
	 * @see org.gvsig.remoteClient.ogc.OGCServiceInformation#createOperation(java.lang.String, java.lang.String)
142
	 */	
143
	public OGCClientOperation createOperation(String name, String onlineResource) {
144
		return new WMSOperation(name, onlineResource);
145
	}	
146

  
147
 }
148

  
org.gvsig.raster.wms/tags/org.gvsig.raster.wms-2.2.240/org.gvsig.raster.wms.remoteclient/src/main/java/org/gvsig/remoteclient/wms/WMSEventListener.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24

  
25
package org.gvsig.remoteclient.wms;
26
/**
27
 * Interface for monitoring events from the WMSClient.
28
 * @author jaume dominguez faus - jaume.dominguez@iver.es
29
 *
30
 */
31
public interface WMSEventListener {
32
	public static final int CAPABILITIES = 1;
33
	public static final int MAP = 2;
34
	public static final int FEATURE_INFO = 2;
35
	public static final int FINISHED = -1;
36
	public static final int STARTED = -2;
37
	public static final int TRANSFERRING = -3;
38
	public static final int FAILED = -4;
39
	public static final int CANCELLED = -5;
40
	
41
	public abstract void newEvent(int idRequest, int eventType);
42
}
org.gvsig.raster.wms/tags/org.gvsig.raster.wms-2.2.240/org.gvsig.raster.wms.remoteclient/src/main/java/org/gvsig/remoteclient/wms/WMSExtent.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24
package org.gvsig.remoteclient.wms;
25

  
26
import java.io.IOException;
27

  
28
import org.kxml2.io.KXmlParser;
29
import org.xmlpull.v1.XmlPullParserException;
30

  
31
import org.gvsig.remoteclient.utils.CapabilitiesTags;
32

  
33
public class WMSExtent {
34
	    
35
    private String name; 
36
    /**
37
     * Indicates that the server will round off inexact dimension values
38
     * to the nearest valid value, or (if it is null or zero) it will not.
39
     */
40
    private String nearestValue; 
41
    /**
42
     * Indicates that temporal data are normally kept current and that the
43
     * request parameter TIME <b>may</b> include the keyword 'current' 
44
     * instead of an ending value. 
45
     */
46
    private String current;
47
    
48
    /**
49
     * cotains the expression for this dimension's extent.
50
     */
51
    private String extentExpression;
52
    private String extDefaultValue;
53

  
54
    public String getName() {        
55
        return name;
56
    } 
57
    
58
    /**
59
     * Tells that the temporal data are normally kept current and that
60
     * the request parameter TIME may include the keyword 'current'
61
     * instead of an ending value.
62
     *
63
     * @return <b>true</b> if the server does keep the data, <b>false</b> else.
64
     */
65
    public boolean allowsCurrentTime() {
66
        return (current!=null && !current.equals("0"));
67
    }
68
    
69
    /**
70
     * Gets the value that would be used along this dimension if a Web
71
     * request omits a value for the dimension.
72
     * 
73
     * @return Returns the defaultValue.
74
     */
75
    public String getDefaultValue() {
76
        return extDefaultValue;
77
    }
78
    
79
    /**
80
     * Returns the extent expression as it was written in the Capabilities 
81
     * document.
82
     * @return String
83
     */
84
    public String getExtentExpression() {
85
        return extentExpression;
86
    }
87
       
88

  
89
    /**
90
     * @return Returns the nearestValues.
91
     */
92
    public boolean allowsNearestValue() {
93
        return (nearestValue!=null && !nearestValue.equals("0"));
94
    }	 
95

  
96
	   /**
97
	 * Parses the EXTENT tag in the WMS capabilities, filling the Extend fills of the
98
	 * WMSDimension object and loading the data into memory to be easily accesed.
99
	 */
100
	public void parse(KXmlParser parser) throws IOException, XmlPullParserException{
101
	    parser.require(KXmlParser.START_TAG, null, CapabilitiesTags.EXTENT);
102
	    name			 = parser.getAttributeValue("", CapabilitiesTags.DIMENSION_NAME);
103
	    extDefaultValue  = parser.getAttributeValue("", CapabilitiesTags.DEFAULT);
104
	    nearestValue    = parser.getAttributeValue("", CapabilitiesTags.EXTENT_NEAREST_VALUE);
105
	    current          = parser.getAttributeValue("", CapabilitiesTags.EXTENT_CURRENT);
106
	    extentExpression = parser.nextText();
107
	}	
108
}
org.gvsig.raster.wms/tags/org.gvsig.raster.wms-2.2.240/org.gvsig.raster.wms.remoteclient/src/main/java/org/gvsig/remoteclient/wms/WMSProtocolHandlerFactory.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24

  
25
package org.gvsig.remoteclient.wms;
26

  
27
import java.io.File;
28
import java.io.IOException;
29
import java.io.StringReader;
30
import java.net.ConnectException;
31
import java.net.URL;
32
import java.util.ArrayList;
33
import java.util.Iterator;
34
import org.apache.commons.io.FileUtils;
35

  
36
import org.gvsig.remoteclient.utils.CapabilitiesTags;
37
import org.gvsig.remoteclient.utils.Utilities;
38
import org.kxml2.io.KXmlParser;
39
import org.slf4j.Logger;
40
import org.slf4j.LoggerFactory;
41
import org.xmlpull.v1.XmlPullParserException;
42

  
43
public class WMSProtocolHandlerFactory {
44
    
45
    private static final Logger logger = LoggerFactory.getLogger(WMSProtocolHandlerFactory.class);
46
    public org.gvsig.remoteclient.wms.WMSProtocolHandler wMSProtocolHandler;
47

  
48
    private static ArrayList supportedVersions = new ArrayList();
49

  
50
    static {
51
        /*
52
         * Se meten en el array versions las distintas versiones
53
         * del protocolo en orden descendente
54
         */
55
    	//versions.add(WMSProtocolHandler1_3_0.class);
56
        //versions.add(WMSProtocolHandler1_1_1.class);
57
    	supportedVersions.add("1.3.0");
58
    	supportedVersions.add("1.1.1");
59
    	supportedVersions.add("1.1.0");
60
     }
61

  
62
    /**
63
     * M?todo que dada una respuesta de getCapabilities y un iterador sobre una
64
     * coleccion de WMSClient's ordenada descendentemente devuelve el cliente
65
     * cuya version es igual o inmediatamente inferior
66
     *
67
     * @param caps Capabilities con la respuesta del servidor
68
     * @param clients Iterador de conjunto ordenado descendientemente
69
     *
70
     * @return cliente cuya version es igual o inmediatamente inferior
71
     * @throws IllegalAccessException
72
     * @throws InstantiationException
73
     *
74
     */
75
    private static String getDriverVersion(String version, Iterator clients) throws InstantiationException, IllegalAccessException {
76
        while (clients.hasNext()) {
77
            String clientVersion = (String)clients.next();
78
            int ret = version.compareTo(clientVersion);
79

  
80
            if (ret >= 0) {
81
                return clientVersion;
82
            }
83
        }
84
        return null;
85
    }
86

  
87
    /**
88
     * Establece la versi?n con la que se comunicar? con el servidor y devuelve
89
     * el objeto Capabilities obtenido con dicha versi?n
90
     *
91
     * @param host maquina con la que se negocia
92
     *
93
     * @return instancia de un cliente capaz de negociar con el host que se
94
     *         pasa como par?metro
95
     */
96
     public static WMSProtocolHandler negotiate(String host) throws ConnectException, IOException {
97

  
98
        if (supportedVersions.size() == 0)
99
        {
100
        	return null;
101
        }
102

  
103
        try
104
        {
105
        	String highestVersionSupportedByServer  = getSuitableWMSVersion(host,"");
106
        	if (supportedVersions.contains(highestVersionSupportedByServer))
107
        	{
108
        		//we support the highest version supported by the server
109
        		// this is the best case
110
        		return createVersionDriver(highestVersionSupportedByServer);
111
        	}
112

  
113

  
114
        else
115
        	{
116
        		// in case we dont support the highest version from the server
117
        		// we start the negotiation process in which we have to get the higest version
118
        		// the WMS supports and we are able to read.
119
        		Iterator iVersion = supportedVersions.iterator();
120
        		String wmsVersion;
121
        		String gvSIGVersion;
122

  
123
        		while (iVersion.hasNext()) {
124
		                gvSIGVersion = (String)iVersion.next();
125
		                wmsVersion = getSuitableWMSVersion(host,gvSIGVersion);
126
		                //TODO:
127
		                //compare with the version returned by the WMS!!!!!
128
		                // send GetCapabilities and read the version to compare.
129
		                int res = wmsVersion.compareTo(gvSIGVersion);
130

  
131
		                if (res == 0) { //Si es la misma que nuestra version
132
		                    return createVersionDriver(gvSIGVersion);
133
		                } else if (res > 0) { //Si es mayor que nuestra version
134
		                    throw new Exception("Server Version too high: " + wmsVersion);
135
		                } else { //Si es menor que nuestra version
136
		                         //Obtenemos la primera version menor o igual que tengamos
137
		                    String lowerVersion = WMSProtocolHandlerFactory.getDriverVersion(wmsVersion, iVersion);
138

  
139
		                    if (lowerVersion == null) { //Si no hay ninguna
140
		                        throw new Exception("Lowest server version is " + wmsVersion);
141
		                    } else {
142
		                        if (lowerVersion.equals(wmsVersion)) {
143
		                            return createVersionDriver(lowerVersion);
144
		                        } else { //Si hay una version menor que la que retorno el servidor
145
		                            //iV = lower;
146
		                        }
147
		                    }
148
		                }
149
        		}
150
        	}//case we had to start the negotiation process.
151
	        return null; // if it did not find any suitable version.
152
        }
153
        catch(ConnectException conEx)
154
        {
155
        	throw conEx;
156
        }
157
        catch(IOException ioEx)
158
        {
159
        	throw ioEx;
160
        }
161
        catch(Exception e)
162
        {
163
                logger.warn("Can't determine server version",e);
164
          	return null;
165
        }
166
    }
167

  
168
     /**
169
      * Sends a GetCapabilities to the WMS server to get the version
170
      * if the version parameter is null, the WMS will return the highest version supported
171
      * if not it will return the lower highest version than the one requested.
172
      * @param host
173
      * @param version
174
      * @return suitable version supported by the server
175
      */
176
     private static String getSuitableWMSVersion(String host, String _version) throws ConnectException, IOException
177
     {
178
         int sizes[] = new int[] { 1024, 1024*10, 1024*50, 1024*100 };
179
         XmlPullParserException  xmlEx = null;
180
         for( int i=0; i<sizes.length; i++ ) {
181
             String version;
182
             try {
183
                 version = getSuitableWMSVersion(host, _version, sizes[i]);
184
                 return version;
185
             } catch (XmlPullParserException ex) {
186
                 xmlEx = ex;
187
                 // Try with other size
188
             }
189
         }
190
         logger.warn("Can't determine server version",xmlEx);
191
         return "";
192
     }
193
     
194
    private static String readFromUrl(String url_s, int size) throws IOException {
195
            URL url = new URL(url_s);
196
            Utilities.removeURL(url);
197
            File f = Utilities.downloadFile(url, "wms_capabilities.xml", null);
198
            return FileUtils.readFileToString(f);
199
    }
200
    
201
    private static String getSuitableWMSVersion(String host, String _version, int size) throws ConnectException, IOException, XmlPullParserException {
202
        String request = WMSProtocolHandler.buildCapabilitiesSuitableVersionRequest(host, _version);
203
        String version = new String();
204
        StringReader reader = null;
205
        try {
206
            String string = readFromUrl(request, size);
207
            
208
            // patch for ArcIMS + WMS connector > 9.0 bug
209
            int a = string.toLowerCase().indexOf("<?xml");
210
            if ( a != -1 ) {
211
                string = string.substring(a, string.length());
212
            }
213
            // end patch
214

  
215
            reader = new StringReader(string);
216
            KXmlParser kxmlParser = null;
217
            kxmlParser = new KXmlParser();
218
            kxmlParser.setInput(reader);
219
            kxmlParser.nextTag();
220
            if ( kxmlParser.getEventType() != KXmlParser.END_DOCUMENT ) {
221
                if ( (kxmlParser.getName().compareTo(CapabilitiesTags.CAPABILITIES_ROOT1_1_0) == 0)
222
                        || (kxmlParser.getName().compareTo(CapabilitiesTags.CAPABILITIES_ROOT1_1_1) == 0)
223
                        || (kxmlParser.getName().compareTo(CapabilitiesTags.CAPABILITIES_ROOT1_3_0) == 0) ) {
224
                    version = kxmlParser.getAttributeValue("", CapabilitiesTags.VERSION);
225
                }
226
            }
227
            // do not forget to close the Stream.
228
            reader.close();
229
            reader = null;
230
            return version;
231
        } catch (ConnectException conEx) {
232
            throw new ConnectException(conEx.getMessage());
233
        } catch (IOException ioEx) {
234
            throw new IOException(ioEx.getMessage());
235
        } catch (XmlPullParserException xmlEx) {
236
            throw xmlEx;
237
//                    logger.warn("Can't determine server version",xmlEx);
238
//                    return "";
239
        } finally {
240
            if ( reader != null ) {
241
                try {
242
                    reader.close();
243
                } catch (Exception ex) {
244
                    logger.warn("Can't close reader", ex);
245
                }
246
            }
247
        }
248
    }
249

  
250
     /**
251
      * It creates an instance of a WMSDriver class.
252
      *
253
      * @param String, with the version of the driver to be created
254
      * @return WMSDriver.
255
      */
256
       private static WMSProtocolHandler createVersionDriver(String version)
257
       {
258
         try
259
         {
260
           Class driver;
261
           version = version.replace('.', '_');
262
           driver = Class.forName("org.gvsig.remoteclient.wms.wms_"+version+".WMSProtocolHandler" + version);
263
           return (WMSProtocolHandler)driver.newInstance();
264
         }
265
         catch (Exception e)
266
         {
267
                logger.warn("Can't create WMS protocol handler for version '"+version+"'.",e);
268
           //throw new Exception("WMSDriverFactory. Unknown driver version " + e);
269
        	 return null;
270
         }
271
       }
272

  
273
 }
org.gvsig.raster.wms/tags/org.gvsig.raster.wms-2.2.240/org.gvsig.raster.wms.remoteclient/src/main/java/org/gvsig/remoteclient/wms/WMSLayer.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24
package org.gvsig.remoteclient.wms;
25

  
26
import java.io.IOException;
27
import java.util.ArrayList;
28
import java.util.Hashtable;
29
import java.util.TreeMap;
30
import java.util.Vector;
31

  
32
import org.kxml2.io.KXmlParser;
33
import org.xmlpull.v1.XmlPullParserException;
34

  
35
import org.gvsig.remoteclient.utils.BoundaryBox;
36
import org.gvsig.remoteclient.utils.CapabilitiesTags;
37

  
38
/**
39
 * <p>Abstract class that defines an WMSLayer.</p>
40
 *
41
 */
42
public abstract class WMSLayer implements org.gvsig.remoteclient.ILayer {
43

  
44
    protected ArrayList children;
45
    protected WMSLayer parent;
46

  
47
    /**
48
     * <p>Layer Abstract field in the capabilities document </p>
49
     */
50
    private String layerAbstract;
51

  
52
    /**
53
     * <p>Themes provided by the WMS for the layer</p>
54
     */
55
    public ArrayList styles = new ArrayList();
56

  
57
    /**
58
     * <p>Layer name</p>
59
     */
60
    private String name;
61

  
62
    /**
63
     * <p>Layer title</p>
64
     */
65
    private String title;
66

  
67
    private ArrayList keywordList = new ArrayList();
68
    /**
69
     * <p>CRS list of this layer (Tag CRS)</p>
70
     */
71
    protected Vector srs = new Vector();
72

  
73
    /**
74
     * <p>Bounding box por CRS (Tag BoundingBox)</p>
75
     */
76
    private Hashtable bBoxes  = new Hashtable();
77

  
78
    /**
79
     * <p>extents that defines the bbox for the LatLon projection
80
     * It can be included in the bBoxes vector as well, because it is the most used, we keep it separeted too, according
81
     *  with the OGC WMSCapabilities specifications...
82
     */
83
    private org.gvsig.remoteclient.utils.BoundaryBox latLonBbox;
84

  
85
    /**
86
     * <p>min scale for the layer to be visible</p>
87
     */
88
    private double scaleMin;
89

  
90
    /**
91
     * <p>max scale for the layer to be visible</p>
92
     */
93
    private double scaleMax;
94

  
95
    /**
96
     * <p>Dimensions defined for the layer in the capabilities doc</p>
97
     */
98
    protected java.util.ArrayList dimensions = new ArrayList();
99

  
100
    /**
101
     * Tells if this layer accepts getFeatureInfo requests.
102
     */
103
    private boolean queryable = false;
104

  
105
    /**
106
     * Tells if this layer is opaque.
107
     */
108
    private boolean opaque = false;
109
    /**
110
     * when set to true, noSubsets indicates that the server is not able to make a map
111
     * of a geographic area other than the layer's bounding box.
112
     */
113
    private boolean m_noSubSets = false;
114

  
115
    /**
116
     * when present and non-zero fixedWidth and fixedHeight indicate that the server is not
117
     * able to produce a map of the layer at a width and height different from the fixed sizes indicated.
118
     */
119
    private int fixedWidth = 0;
120
    private int fixedHeight = 0;
121

  
122
    /**
123
     * Tells if this layer can be served with transparency.
124
     */
125
    private boolean transparency;
126

  
127
    /**
128
     * <p>Parses the LAYER tag in the WMS capabilities, filling the WMSLayer object
129
     * loading the data in memory to be easily accesed</p>
130
     *
131
     */
132
    public abstract void parse(KXmlParser parser, TreeMap layerTreeMap)
133
    throws IOException, XmlPullParserException;
134

  
135
    //public abstract ArrayList getAllDimensions();
136

  
137
    /**
138
     * add a new keyword to the keywordList.
139
     * @param key
140
     */
141
    protected void addkeyword(String key) {
142
    	keywordList.add(key);
143
    }
144
    
145
    public ArrayList getKeywords() {
146
    	return keywordList;
147
    }
148
    
149
    /**
150
     * <p>Adds a style to the styles vector</p>
151
     * @param _style
152
     */
153
    public void addStyle(org.gvsig.remoteclient.wms.WMSStyle _style) {
154
        styles.add( _style );    
155
    }
156

  
157
    /**
158
     * <p>Gets the style vector</p>
159
     * @return
160
     */
161
    public ArrayList getStyles() {
162
    	ArrayList list = new ArrayList();
163
    	if (styles != null)
164
    		list.addAll(styles);
165
    	if (this.getParent()!= null) {
166
    		//return getAllStyles(this);
167
    		if(this.getParent().getStyles() != null)
168
    			list.addAll(this.getParent().getStyles());
169
    	}
170
        return list;
171
    }
172

  
173
    public ArrayList getAllStyles(WMSLayer layer) {
174
    	if (layer.getParent()!= null) {
175
    		ArrayList list = getAllStyles(layer.getParent());
176
    		for(int i = 0; i < this.styles.size(); i++) {
177
    			list.add(styles.get(i));
178
    		}
179
    		return list;
180
    	} else {
181
    		return styles;
182
    	}
183
    }
184
    
185
    /**
186
     * <p>Adds a bbox to the Bboxes vector</p>
187
     * @param bbox
188
     */
189
    public void addBBox(BoundaryBox bbox) {
190
        bBoxes.put(bbox.getSrs(), bbox);
191
    }
192

  
193
    /**
194
     * <p>returns the bbox with that id in the Bboxes vector</p>
195
     * @param id
196
     */
197
    public BoundaryBox getBbox(String id) {
198
    	//Si hay una bounding box definida para esa capa y ese crs, se usa esa
199
    	BoundaryBox b = (BoundaryBox) bBoxes.get(id);
200
    	if(b != null)
201
    		return b;
202
    	
203
    	if ((id.compareToIgnoreCase( CapabilitiesTags.EPSG_4326 )==0)
204
    		||(id.compareToIgnoreCase( CapabilitiesTags.CRS_84)==0)) {
205
    		if (latLonBbox != null)
206
    		return (BoundaryBox)latLonBbox;
207
    	}
208
        
209
        if (parent!=null)
210
            return parent.getBbox(id);
211
        return null;
212
    }
213

  
214
    /**
215
     * <p>Gets the bBoxes vector</p>
216
     * @return
217
     */
218
    public Hashtable getBboxes() {
219
        return bBoxes;
220
    }
221

  
222

  
223
    //Methods to manipulate the box that defines the layer extent in LatLon SRS.
224
    public BoundaryBox getLatLonBox() {
225
        return latLonBbox;
226
    }
227
    
228
    public void setLatLonBox(BoundaryBox box) {
229
        latLonBbox = box;
230
    }
231
    
232
    /**
233
     * <p>adds a new srs to the srs vector</p>
234
     */
235
    public void addSrs(String srs) {
236
    	if (!this.srs.contains(srs))
237
    		this.srs.add(srs);
238
    }
239
    
240
    public void removeSrs(String srs) {
241
   		this.srs.remove(srs);
242
    }
243

  
244
    public Vector getAllSrs() {
245
        Vector mySRSs = (Vector) this.srs.clone();
246
        if (parent!=null)
247
            mySRSs.addAll(parent.getAllSrs());
248
        return mySRSs;
249
    }
250

  
251
    /**
252
     * <p>gets the maximum scale for this layer</p>
253
     * @return
254
     */
255
    public double getScaleMax() {
256
        return scaleMax;
257
    }
258

  
259
    /**
260
     * <p>gets the minimum scale for this layer</p>
261
     * @return
262
     */
263
    public double getScaleMin() {
264
        return scaleMin;
265
    }
266

  
267
    /**
268
     * <p>sets the minimum scale for this layer to be visible.</p>
269
     *
270
     * @param scale
271
     */
272
    public void setScaleMin(double scale) {
273
        scaleMin = scale;
274
    }
275

  
276
    /**
277
     * <p>sets the maximum scale for this layer to be visible</p>
278
     * @param scale
279
     */
280
    public void setScaleMax(double scale) {
281
        scaleMax = scale;
282
    }
283

  
284
    /**
285
     * <p> gets the dimension vector defined in this layer</p>
286
     * @return
287
     */
288
    public abstract ArrayList getDimensions();
289

  
290
    public WMSDimension getDimension(String name) {
291
    	for(int i = 0; i < dimensions.size(); i++ ) {
292
    		if(((WMSDimension)dimensions.get(i)).getName().compareTo(name) == 0) {
293
    			return (WMSDimension)dimensions.get(i);
294
    		}
295
    	}
296
    	return null;
297
    }
298

  
299
    /**
300
     * <p>Adds a dimension to the dimension vector </p>
301
     * @param dimension
302
     */
303
    public void addDimension(org.gvsig.remoteclient.wms.WMSDimension dimension) {
304
        dimensions.add(dimension);
305
    }
306

  
307
    /**
308
     * <p>Gets layer name</p>
309
     * @return
310
     */
311
    public String getName() {
312
        return this.name;
313
    }
314

  
315
    /**
316
     * <p>Sets layer name</p>
317
     * @param _name
318
     */
319
    public void setName(String name) {
320
        this.name = name;
321
    }
322

  
323
    /**
324
     * <p>Gets layer title</p>
325
     * @return
326
     */
327
    public String getTitle() {
328
        return title;
329
    }
330

  
331
    /**
332
     * <p>Sets the layer title</p>
333
     * @param _title
334
     */
335
    public void setTitle(String title) {
336
        this.title = title;
337
    }
338

  
339
    /**
340
     * <p>Gets the layer abstract</p>
341
     * @return
342
     */
343
    public String getAbstract() {
344
        return layerAbstract;
345
    }
346

  
347
    /**
348
     * <p>Sets the layer abstract</p>
349
     * @param m_abstract
350
     */
351
    public void setAbstract(String _abstract) {
352
        layerAbstract = _abstract;
353
    }
354

  
355

  
356
    public ArrayList getChildren() {
357
        return children;
358
    }
359

  
360

  
361
    public void setChildren(ArrayList children) {
362
        this.children = children;
363
    }
364

  
365

  
366
    public WMSLayer getParent() {
367
        return parent;
368
    }
369

  
370

  
371
    public void setParent(WMSLayer parent) {
372
        this.parent = parent;
373
    }
374

  
375
    public String toString(){
376
        return this.getTitle();
377
    }
378

  
379

  
380
    /**
381
     * Tells if this layer accepts getFeatureInfo requests.
382
     */
383
    public boolean isQueryable() {
384
        return queryable;
385
    }
386

  
387

  
388
    /**
389
     * @param queryable The queryable to set.
390
     */
391
    public void setQueryable(boolean queryable) {
392
        this.queryable = queryable;
393
    }
394

  
395
    /**
396
     * Tells if this layer is opaque.
397
     */
398
    public boolean isOpaque() {
399
        return opaque;
400
    }
401
    /**
402
     * @param opaque.
403
     */
404
    public void setOpaque(boolean opaque) {
405
        this.opaque = opaque;
406
    }
407

  
408
    /**
409
     * Tells if this layer is subsettable
410
     */
411
    public boolean noSubSets() {
412
        return this.m_noSubSets;
413
    }
414
    /**
415
     * @param set layer nosubsets attribute.
416
     */
417
    public void setNoSubSets(boolean _noSubSets) {
418
        m_noSubSets = _noSubSets;
419
    }
420

  
421
    public void setfixedWidth(int w) {
422
        fixedWidth = w;
423
    }
424

  
425
    public int getfixedWidth() {
426
        return fixedWidth;
427
    }
428

  
429
    public void setfixedHeight(int h) {
430
        fixedHeight = h;
431
    }
432

  
433
    public int getfixedHeight() {
434
        return fixedHeight;
435
    }
436

  
437
    /**
438
     * @return <b>true</b> if this layer can be served with transparency, otherwise <b>false</b>
439
     */
440
    public boolean hasTransparency() {
441
        return transparency;
442
    }
443

  
444
    //Methods to parse tags that are common to several versions of WMS.
445
    //In case there is a version which has different implemantation of one of this tags
446
    // the subclass can overwrite this method
447

  
448
    /**
449
     * Parses the keywordlist from the capabilities and fills this list in the WMSLayer.
450
     * @param parser
451
     */
452
    protected void parseKeywordList(KXmlParser parser)  throws IOException, XmlPullParserException {
453
    	int currentTag;
454
    	boolean end = false;
455
    	String value;
456

  
457
    	parser.require(KXmlParser.START_TAG, null, CapabilitiesTags.KEYWORDLIST);
458
    	currentTag = parser.nextTag();
459

  
460
        while (!end) {
461
			 switch(currentTag) {
462
				case KXmlParser.START_TAG:
463
					if (parser.getName().compareTo(CapabilitiesTags.KEYWORD) == 0) {
464
						value = parser.nextText();
465
						if ((value != null) && (value.length() > 0 ))
466
							addkeyword(value);
467
					}
468
					break;
469
				case KXmlParser.END_TAG:
470
					if (parser.getName().compareTo(CapabilitiesTags.KEYWORDLIST) == 0)
471
						end = true;
472
					break;
473
				case KXmlParser.TEXT:
474
					break;
475
			 }
476
			 if (!end) {
477
				 currentTag = parser.next();
478
			 }
479
    	}
480
    	parser.require(KXmlParser.END_TAG, null, CapabilitiesTags.KEYWORDLIST);
481
    }
482

  
483
    /**
484
     * Reads and parses the layer attributes
485
     * Maybe this method should be moved to the WMSLayer. Until now the attributes are teh same for all versions.
486
     * @param parser
487
     */
488
    protected void readLayerAttributes(KXmlParser parser) {
489
    	String value = new String();
490

  
491
        //First of all set whether the layer is Queryable reading the attribute.
492
        value = parser.getAttributeValue("", CapabilitiesTags.QUERYABLE);
493
        if (value != null) {
494
            if (value.compareTo("0") == 0)
495
                setQueryable(false);
496
            else
497
                setQueryable(true);
498
        }
499
        value = parser.getAttributeValue("", CapabilitiesTags.OPAQUE);
500
        if (value != null) {
501
            if (value.compareTo("0") == 0)
502
                setOpaque(false);
503
            else
504
                setOpaque(true);
505
        }
506
        value = parser.getAttributeValue("", CapabilitiesTags.NOSUBSETS);
507
        if (value != null) {
508
            if (value.compareTo("0") == 0)
509
                setNoSubSets(false);
510
            else
511
            	setNoSubSets(true);
512
        }
513
        value = parser.getAttributeValue("", CapabilitiesTags.FIXEDWIDTH);
514
        if (value != null) {
515
        	setfixedWidth(Integer.parseInt(value));
516
        }
517
        value = parser.getAttributeValue("", CapabilitiesTags.FIXEDHEIGHT);
518
        if (value != null) {
519
        	setfixedHeight(Integer.parseInt(value));
520
        }
521
    }
522

  
523

  
524
    /**
525
     * <p>Inner class describing the MetadataURL tag in OGC specifications in WMS</p>
526
     *
527
     */
528
    protected class MetadataURL {
529
    	public MetadataURL() {
530
    		type = new String();
531
    		format = new String();
532
    		onlineResource_xlink = new String();
533
    		onlineResource_type = new String();
534
    		onlineResource_href = new String();
535
    	}
536
        public String type;
537
        public String format;
538
        public String onlineResource_xlink;
539
        public String onlineResource_type;
540
        public String onlineResource_href;
541
     }
542

  
543
    /**
544
     * <p>Inner class describing the DataURL tag in OGC specifications in WMS</p>
545
     *
546
     */
547
    protected class DataURL {
548
    	public DataURL() {
549
    		type = new String();
550
    		format = new String();
551
    		onlineResource_xlink = new String();
552
    		onlineResource_type = new String();
553
    		onlineResource_href = new String();
554
    	}
555
        public String type;
556
        public String format;
557
        public String onlineResource_xlink;
558
        public String onlineResource_type;
559
        public String onlineResource_href;
560
     }
561
}
org.gvsig.raster.wms/tags/org.gvsig.raster.wms-2.2.240/org.gvsig.raster.wms.remoteclient/src/main/java/org/gvsig/remoteclient/wms/WMSClient.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24

  
25
package org.gvsig.remoteclient.wms;
26

  
27
import java.awt.geom.Rectangle2D;
28
import java.io.File;
29
import java.io.IOException;
30
import java.net.ConnectException;
31
import java.net.URL;
32
import java.util.TreeMap;
33
import java.util.Vector;
34
import org.apache.commons.lang3.StringUtils;
35

  
36
import org.gvsig.compat.net.ICancellable;
37
import org.gvsig.remoteclient.exceptions.ServerErrorException;
38
import org.gvsig.remoteclient.exceptions.WMSException;
39
import org.gvsig.remoteclient.utils.BoundaryBox;
40
import org.slf4j.Logger;
41
import org.slf4j.LoggerFactory;
42

  
43

  
44
/**
45
 * <p>Represents the class the with the necessary logic to connect to a OGCWMS and interpretate the data </p>
46
 * 
47
 */
48
public class WMSClient extends org.gvsig.remoteclient.RasterClient {
49
    
50
    private static final Logger logger = LoggerFactory.getLogger(WMSClient.class);
51
    private org.gvsig.remoteclient.wms.WMSProtocolHandler handler;
52
//    private TreeMap layers = new TreeMap();
53
//    private WMSLayer rootLayer;
54
    
55
    /**
56
     * @return Returns the rootLayer.
57
     */
58
    public WMSLayer getRootLayer() {
59
        return handler.rootLayer;
60
    }
61

  
62
    /**
63
     * Constructor.
64
     * the parameter host, indicates the WMS host to connect.
65
     * */
66
    public WMSClient(String host) throws ConnectException, IOException 
67
    {
68
    	setHost(host);
69
        try {        	
70
        	handler = WMSProtocolHandlerFactory.negotiate(host);
71
        	handler.setHost(host);        
72
        } catch(ConnectException conE) {
73
                logger.warn("Can't create WMS protocol handler for host '"+host+"'.",conE);
74
        	throw conE; 
75
        } catch(IOException ioE) {
76
                logger.warn("Can't create WMS protocol handler for host '"+host+"'.",ioE);
77
        	throw ioE; 
78
        } catch(Exception e) {
79
                logger.warn("Can't create WMS protocol handler for host '"+host+"'.",e);
80
        }
81
    }
82
    
83
    public String getVersion()
84
    {
85
        return handler.getVersion();
86
    }
87
    /**
88
     * <p>One of the three interfaces that OGC WMS defines. Request a map.</p> 
89
     * @throws ServerErrorException 
90
     */
91
    public File getMap(WMSStatus status, ICancellable cancel) throws WMSException, ServerErrorException{   
92
        return handler.getMap(status, cancel);
93
    } 
94
    
95
    /**
96
     * <p>Gets the GetMap URL. The final client should download the file</p> 
97
     * @throws ServerErrorException 
98
     */
99
    public URL getGetMapURL(WMSStatus status, ICancellable cancel) throws WMSException, ServerErrorException{   
100
       return handler.getMapURL(status, cancel);
101
    } 
102
    
103
    /**
104
     * Returns the exception message if the file is a XML instead of a image.
105
     * @param file
106
     * @return
107
     * @throws IOException 
108
     */
109
    public String getExceptionMessage(File file) throws IOException {
110
    	return handler.getExceptionMessage(file);
111
    }
112
    
113
    /**
114
     * <p>One of the three interfaces defined by OGC WMS, it gets the service capabilities</p>
115
     * @param override, if true the previous downloaded data will be overridden
116
     */
117
    public void getCapabilities(WMSStatus status, boolean override, ICancellable cancel) {        
118
        handler.getCapabilities(status, override, cancel);
119
    } 
120
    
121
    /**
122
     * <p>One of the three interfaces defined by the OGC WMS, it gets the information about a feature requested</p>
123
     * @return 
124
     */
125
    public String getFeatureInfo(WMSStatus status, int x, int y, int featureCount, ICancellable cancel) throws WMSException{        
126
        return handler.getFeatureInfo(status, x, y, featureCount, cancel);
127
    } 
128
    
129
    /**
130
     * <p>One of the three interfaces defined by the OGC WMS, it gets legend of a layer</p>
131
     * @return 
132
     */
133
    public File getLegendGraphic(WMSStatus status, String layerName, ICancellable cancel) throws WMSException, ServerErrorException{        
134
        return handler.getLegendGraphic(status, layerName, cancel);
135
    } 
136
    
137
    /**
138
     * <p> Reads from the WMS Capabilities, the layers available in the service</p>
139
     * @return a TreeMap with the available layers in the WMS 
140
     */
141
    public TreeMap getLayers() {        
142
        return handler.layers;
143
    } 
144
    
145
    /**
146
     * <p>Reads from the WMS Capabilities the number if layers available in the service</p>
147
     * @return, number of layers available
148
     */
149
    public int getNumberOfLayers() {        
150
        if (handler.layers != null)
151
        {
152
            return handler.layers.size();
153
        }
154
        return 0;
155
    } 
156
    
157
    /**
158
     * <p>Gets the WMSLayer with this name</p>
159
     * 
160
     * @param _name, layer name
161
     * @return the layer with this name
162
     */
163
    public WMSLayer getLayer(String _name) {        
164
        if (handler.layers.get(_name) != null)
165
        {
166
            return (WMSLayer)handler.layers.get(_name);
167
        }
168
        
169
        return null;
170
    } 
171
    
172
    public String[] getLayerNames()
173
    {    	
174
        WMSLayer[] lyrs;
175
        
176
        lyrs = (WMSLayer[])handler.layers.values().toArray(new WMSLayer[0]);
177
        
178
        String[] names = new String[lyrs.length];
179
        
180
        for(int i = 0; i<lyrs.length; i++)
181
        {
182
            names[i] = ((WMSLayer)lyrs[i]).getName();
183
        }
184
        return names;
185
    }
186
    
187
    public String[] getLayerTitles()
188
    {    	
189
        WMSLayer[] lyrs;
190
        
191
        lyrs = (WMSLayer[])handler.layers.values().toArray(new WMSLayer[0]);
192
        
193
        String[] titles = new String[lyrs.length];
194
        
195
        for(int i = 0; i<lyrs.length; i++)
196
        {
197
            titles[i] = ((WMSLayer)lyrs[i]).getTitle();
198
        }
199
        return titles;
200
    }
201
    /**
202
     * <p>Gets the image formats available in the Service to retrieve the maps</p>
203
     * @return a vector with all the available formats
204
     */
205
    public Vector getFormats() {        
206
        return ((WMSServiceInformation)handler.getServiceInformation()).formats;         
207
    } 
208
    
209
    /**
210
     * <p>Gets the information by point formats available in the Service</p>
211
     * @return a vector with all the available formats
212
     */
213
    public Vector getInfoFormats() {        
214
        return ((WMSServiceInformation)handler.getServiceInformation()).infoformats;
215
    } 
216
    
217
    public boolean isQueryable()
218
    {
219
    	return ((WMSServiceInformation)handler.getServiceInformation()).isQueryable();  
220
    }
221
    public boolean hasLegendGraphic()
222
    {
223
    	return ((WMSServiceInformation)handler.getServiceInformation()).hasLegendGraphic();  
224
    }
225
    
226
    public void close() {        
227
        // your code here
228
    } 
229
    
230
    
231
    /**
232
     * Returns the max extent that envolves the requested layers
233
     * */
234
    public Rectangle2D getLayersExtent(String[]layerNames, String srs) {
235
        try {
236
        	if (layerNames == null) {
237
        		return null;
238
        	}
239
        	
240
            BoundaryBox bbox = null;
241
            WMSLayer layer = getLayer(layerNames[0]);
242
            
243
            bbox = layer.getBbox(srs);
244
            if (bbox == null) {
245
            	return null;
246
            }
247
            double xmin = bbox.getXmin();
248
            double xmax = bbox.getXmax();
249
            double ymin = bbox.getYmin();
250
            double ymax = bbox.getYmax();
251
            
252
            for(int i = 1; i < layerNames.length; i++) {
253
                layer = getLayer(layerNames[i]);
254
                bbox = layer.getBbox(srs);
255
                if (bbox == null) return null;
256
                if (bbox.getXmin() < xmin) {
257
                    xmin = bbox.getXmin();
258
                }
259
                if (bbox.getYmin() < ymin) {
260
                    ymin = bbox.getYmin();
261
                }
262
                if (bbox.getXmax() > xmax) {
263
                    xmax = bbox.getXmax();
264
                }
265
                if (bbox.getYmax() > ymax) {
266
                    ymax = bbox.getYmax();
267
                }
268
            }	
269
            
270
            Rectangle2D extent = new Rectangle2D.Double(xmin, ymin, Math.abs(xmax-xmin), Math.abs(ymax-ymin));
271
            return extent;
272
        } catch(Exception e) {
273
            String msg = null;
274
            try {
275
                msg = "Can't get layers extent, layers='"+StringUtils.join(layerNames, ",")+"', srs='"+srs+"'.";
276
            } catch(Exception ex) {
277
                msg = "Can't get layers extent.";
278
            }
279
            logger.warn(msg,e);
280
            return null;
281
        }
282
    }
283
    
284
    
285
    /**
286
     * Gets the Service information included in the Capabilities
287
     * */    
288
    public WMSServiceInformation getServiceInformation()
289
    {
290
        return ((WMSServiceInformation)handler.getServiceInformation());
291
    }
292
    
293
    
294
    /**
295
     * <p>Checks the connection to the remote WMS and requests its capabilities.</p>
296
     * @param override, if true the previous downloaded data will be overridden
297
     * 
298
     * @deprecated Use {@link #connect(WMSStatus, boolean, ICancellable)} instead,
299
     * as the WMSStatus is necessary when connecting in order to correct
300
     * call the getCapabilities method.
301
     */
302
    public boolean connect(boolean override, ICancellable cancel) 
303
    {
304
    	return connect(null, override, cancel);
305
    }
306
    
307
    /**
308
     * <p>Checks the connection to the remote WMS and requests its capabilities.</p>
309
     * <p>This method should probably be moved to RemoteClient interface, as the
310
     * same problem will probably happen for other protocols</p>
311
     * 
312
     * @param override, if true the previous downloaded data will be overridden
313
     */
314
    public boolean connect(WMSStatus status, boolean override, ICancellable cancel) 
315
    {
316
        String host = getHost();
317
        try {            
318
            if (handler == null)
319
            {
320
                if (host.trim().length() > 0)
321
                {					
322
                    //TODO: Implement correctly the negotiate algorithm
323
                    handler = WMSProtocolHandlerFactory.negotiate(host);
324
                    //handler = new WMSProtocolHandler1_1_1();
325
                    handler.setHost(host);
326
                }
327
                else
328
                {
329
                    //must to specify host first!!!!
330
                    return false;
331
                }                
332
            }
333
            getCapabilities(status, override, cancel);
334
            return true;
335
            
336
        } catch (Exception e) {
337
            logger.warn("Can't connect to host '"+host+"'.",e);
338
            return false;
339
        }
... This diff was truncated because it exceeds the maximum size that can be displayed.

Also available in: Unified diff