2 * BioJava development code
4 * This code may be freely distributed and modified under the
5 * terms of the GNU Lesser General Public Licence. This should
6 * be distributed with the code. If you do not have a copy,
9 * http://www.gnu.org/copyleft/lesser.html
11 * Copyright for this code is held jointly by the individual
12 * authors. These should be listed in @author doc comments.
14 * For more information on the BioJava project and its aims,
15 * or to join the biojava-l mailing list, visit the home page
18 * http://www.biojava.org/
20 * Created on Nov 20, 2005
23 package org.biojava.dasobert.das;
25 import java.io.InputStream;
26 import java.net.HttpURLConnection;
28 import java.util.Iterator;
29 import java.util.logging.Level;
30 import java.util.logging.Logger;
31 import javax.xml.parsers.ParserConfigurationException;
32 import javax.xml.parsers.SAXParser;
33 import javax.xml.parsers.SAXParserFactory;
35 import org.biojava.dasobert.dasregistry.Das1Source;
36 import org.biojava.dasobert.eventmodel.SequenceEvent;
37 import org.biojava.dasobert.eventmodel.SequenceListener;
38 import org.xml.sax.InputSource;
39 import org.xml.sax.SAXException;
40 import org.xml.sax.SAXNotRecognizedException;
41 import org.xml.sax.XMLReader;
45 * a thread that gets the sequence from a DAS server
47 * @author Andreas Prlic
50 public class SequenceThread extends Thread
53 Das1Source[] sequenceServers;
61 static Logger logger = Logger.getLogger("org.biojava.spice");
63 public SequenceThread(String sp_accession, Das1Source ds)
66 Das1Source[] dss = new Das1Source[1];
68 this.sp_accession = sp_accession;
69 this.sequenceServers = dss;
70 clearSequenceListeners();
74 public SequenceThread(String sp_accession, Das1Source[] ds)
78 this.sp_accession = sp_accession;
79 this.sequenceServers = ds;
80 clearSequenceListeners();
83 public void clearSequenceListeners()
85 seqListeners = new ArrayList();
88 public void addSequenceListener(SequenceListener lis)
90 seqListeners.add(lis);
98 public void getSequence()
101 boolean gotSequence = false;
103 for (int i = 0; i < sequenceServers.length; i++)
109 Das1Source ds = sequenceServers[i];
110 String url = ds.getUrl();
111 char lastChar = url.charAt(url.length() - 1);
112 if (!(lastChar == '/'))
114 String dascmd = url + "sequence?segment=";
115 String connstr = dascmd + sp_accession;
121 String sequence = retrieveSequence(connstr);
122 // bug in aristotle das source?
123 sequence.replaceAll(" ", "");
125 // set the sequence ...
127 triggerNewSequence(sp_accession, sequence, ds, version);
130 } catch (Exception ex)
132 ex.printStackTrace();
133 logger.warning(ex.getMessage());
135 // triggerException(ex);
143 "could not retreive UniProt sequence from any available DAS sequence server");
145 triggerNoSequence(sp_accession);
149 // private void triggerException(Exception e){
150 // Iterator iter = seqListeners.iterator();
151 // while (iter.hasNext()){
152 // SequenceListener li = (SequenceListener)iter.next();
153 // li.exceptionOccured(e);
157 private void triggerNewSequence(String sp_accession, String sequence,
158 Das1Source source, String version)
161 Iterator iter = seqListeners.iterator();
162 while (iter.hasNext())
164 SequenceListener li = (SequenceListener) iter.next();
165 // SequenceEvent event = new SequenceEvent(sequence);
166 SequenceEvent event = new SequenceEvent(sp_accession, sequence,
168 event.setSource(source);
169 li.newSequence(event);
173 private void triggerNoSequence(String ac)
176 Iterator iter = seqListeners.iterator();
177 while (iter.hasNext())
179 SequenceListener li = (SequenceListener) iter.next();
180 li.noObjectFound(ac);
186 * retrieve the Sequence from a DAS server.
189 * the DAS - request string. e.g.
190 * http://www.ebi.ac.uk/das-srv/uniprot/das/aristotle/sequence?segment=P00280
191 * @return the requested Sequence
194 public String retrieveSequence(String connstr) throws Exception
197 // logger.finest("trying: " + connstr) ;
198 URL dasUrl = new URL(connstr);
199 // DAS_httpConnector dhtp = new DAS_httpConnector() ;
200 logger.info("requesting sequence from " + connstr);
201 InputStream dasInStream = open(dasUrl);
203 SAXParserFactory spfactory = SAXParserFactory.newInstance();
206 // String vali = System.getProperty("XMLVALIDATION");
207 String vali = "false";
208 boolean validate = false;
209 if ((vali != null) && (vali.equals("true")))
211 spfactory.setValidating(validate);
213 SAXParser saxParser = null;
217 saxParser = spfactory.newSAXParser();
218 } catch (ParserConfigurationException e)
220 // e.printStackTrace();
221 logger.log(Level.FINER, "Uncaught exception", e);
224 XMLReader xmlreader = saxParser.getXMLReader();
228 xmlreader.setFeature("http://xml.org/sax/features/validation",
230 } catch (SAXException e)
232 logger.finer("Cannot set validation to " + validate);
233 logger.log(Level.FINER, "Uncaught exception", e);
240 "http://apache.org/xml/features/nonvalidating/load-external-dtd",
242 } catch (SAXNotRecognizedException e)
244 // e.printStackTrace();
245 logger.finer("Cannot set load-external-dtd to" + validate);
246 logger.log(Level.FINER, "Uncaught exception", e);
247 // System.err.println("Cannot set load-external-dtd to" + validate);
250 // DAS_DNA_Handler cont_handle = new DAS_DNA_Handler() ;
251 DAS_Sequence_Handler cont_handle = new DAS_Sequence_Handler();
252 xmlreader.setContentHandler(cont_handle);
253 xmlreader.setErrorHandler(new org.xml.sax.helpers.DefaultHandler());
254 InputSource insource = new InputSource();
255 insource.setByteStream(dasInStream);
257 xmlreader.parse(insource);
258 String sequence = cont_handle.get_sequence();
259 version = cont_handle.getVersion();
260 // logger.finest("Got sequence from DAS: " +sequence);
262 logger.exiting(this.getClass().getName(), "retreiveSequence", sequence);
266 private InputStream open(URL url)
270 InputStream inStream = null;
274 HttpURLConnection huc = null;
276 huc = DAS_FeatureRetrieve.openHttpURLConnection(url);
278 logger.finest(huc.getResponseMessage());
280 inStream = huc.getInputStream();
282 } catch (Exception ex)
284 ex.printStackTrace();
285 logger.log(Level.WARNING, "exception occured", ex);