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;
44 /** a thread that gets the sequence from a DAS server
46 * @author Andreas Prlic
49 public class SequenceThread
52 Das1Source[] sequenceServers;
57 static Logger logger = Logger.getLogger("org.biojava.spice");
59 public SequenceThread(String sp_accession,Das1Source ds ) {
61 Das1Source[] dss =new Das1Source[1];
63 this.sp_accession = sp_accession;
64 this.sequenceServers =dss ;
65 clearSequenceListeners();
68 public SequenceThread(String sp_accession,Das1Source[] ds ) {
71 this.sp_accession = sp_accession;
72 this.sequenceServers =ds ;
73 clearSequenceListeners();
76 public void clearSequenceListeners(){
77 seqListeners = new ArrayList();
80 public void addSequenceListener(SequenceListener lis){
81 seqListeners.add(lis);
88 public void getSequence( ){
90 boolean gotSequence = false ;
92 for ( int i = 0 ; i< sequenceServers.length; i++){
94 if ( gotSequence ) break ;
96 Das1Source ds = sequenceServers[i];
97 String url = ds.getUrl() ;
98 char lastChar = url.charAt(url.length()-1);
99 if ( ! (lastChar == '/') )
101 String dascmd = url + "sequence?segment=";
102 String connstr = dascmd + sp_accession ;
107 String sequence = retrieveSequence(connstr);
108 // bug in aristotle das source?
109 sequence.replaceAll(" ","");
111 // set the sequence ...
113 triggerNewSequence(sp_accession,sequence,ds,version);
118 catch (Exception ex) {
119 ex.printStackTrace();
120 logger.warning(ex.getMessage());
122 //triggerException(ex);
127 logger.log(Level.WARNING,"could not retreive UniProt sequence from any available DAS sequence server");
129 triggerNoSequence(sp_accession);
135 // private void triggerException(Exception e){
136 // Iterator iter = seqListeners.iterator();
137 // while (iter.hasNext()){
138 // SequenceListener li = (SequenceListener)iter.next();
139 // li.exceptionOccured(e);
143 private void triggerNewSequence(String sp_accession,String sequence,Das1Source source,String version){
145 Iterator iter = seqListeners.iterator();
146 while (iter.hasNext()){
147 SequenceListener li = (SequenceListener)iter.next();
148 //SequenceEvent event = new SequenceEvent(sequence);
149 SequenceEvent event = new SequenceEvent(sp_accession,sequence,version);
150 event.setSource(source);
151 li.newSequence(event);
155 private void triggerNoSequence(String ac){
157 Iterator iter = seqListeners.iterator();
158 while (iter.hasNext()){
159 SequenceListener li = (SequenceListener)iter.next();
160 li.noObjectFound(ac);
165 /** retrieve the Sequence from a DAS server.
167 * @param connstr - the DAS - request string. e.g. http://www.ebi.ac.uk/das-srv/uniprot/das/aristotle/sequence?segment=P00280
168 * @return the requested Sequence
171 public String retrieveSequence( String connstr)
175 //logger.finest("trying: " + connstr) ;
176 URL dasUrl = new URL(connstr);
177 //DAS_httpConnector dhtp = new DAS_httpConnector() ;
178 logger.info("requesting sequence from " + connstr);
179 InputStream dasInStream =open(dasUrl);
182 SAXParserFactory spfactory =
183 SAXParserFactory.newInstance();
186 //String vali = System.getProperty("XMLVALIDATION");
187 String vali = "false";
188 boolean validate = false ;
189 if ((vali != null) && ( vali.equals("true")) )
191 spfactory.setValidating(validate);
193 SAXParser saxParser = null ;
197 spfactory.newSAXParser();
198 } catch (ParserConfigurationException e) {
199 //e.printStackTrace();
200 logger.log(Level.FINER,"Uncaught exception", e);
203 XMLReader xmlreader = saxParser.getXMLReader();
206 xmlreader.setFeature("http://xml.org/sax/features/validation", validate);
207 } catch (SAXException e) {
208 logger.finer("Cannot set validation to " + validate);
209 logger.log(Level.FINER,"Uncaught exception", e);
213 xmlreader.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd",validate);
214 } catch (SAXNotRecognizedException e){
215 //e.printStackTrace();
216 logger.finer("Cannot set load-external-dtd to" + validate);
217 logger.log(Level.FINER,"Uncaught exception", e);
218 //System.err.println("Cannot set load-external-dtd to" + validate);
222 //DAS_DNA_Handler cont_handle = new DAS_DNA_Handler() ;
223 DAS_Sequence_Handler cont_handle = new DAS_Sequence_Handler() ;
224 xmlreader.setContentHandler(cont_handle);
225 xmlreader.setErrorHandler(new org.xml.sax.helpers.DefaultHandler());
226 InputSource insource = new InputSource() ;
227 insource.setByteStream(dasInStream);
229 xmlreader.parse(insource);
230 String sequence = cont_handle.get_sequence();
231 version = cont_handle.getVersion();
232 //logger.finest("Got sequence from DAS: " +sequence);
234 logger.exiting(this.getClass().getName(), "retreiveSequence", sequence);
238 private InputStream open(URL url) {
241 InputStream inStream = null;
247 HttpURLConnection huc = null;
249 huc = DAS_FeatureRetrieve.openHttpURLConnection(url);
252 logger.finest(huc.getResponseMessage());
254 inStream = huc.getInputStream();
258 catch ( Exception ex){
259 ex.printStackTrace();
260 logger.log(Level.WARNING,"exception occured", ex);