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;
55 static Logger logger = Logger.getLogger("org.biojava.spice");
57 public SequenceThread(String sp_accession,Das1Source ds ) {
59 Das1Source[] dss =new Das1Source[1];
61 this.sp_accession = sp_accession;
62 this.sequenceServers =dss ;
63 clearSequenceListeners();
65 public SequenceThread(String sp_accession,Das1Source[] ds ) {
68 this.sp_accession = sp_accession;
69 this.sequenceServers =ds ;
70 clearSequenceListeners();
73 public void clearSequenceListeners(){
74 seqListeners = new ArrayList();
77 public void addSequenceListener(SequenceListener lis){
78 seqListeners.add(lis);
85 public void getSequence( ){
87 boolean gotSequence = false ;
89 for ( int i = 0 ; i< sequenceServers.length; i++){
91 if ( gotSequence ) break ;
93 Das1Source ds = sequenceServers[i];
94 String url = ds.getUrl() ;
95 char lastChar = url.charAt(url.length()-1);
96 if ( ! (lastChar == '/') )
98 String dascmd = url + "sequence?segment=";
99 String connstr = dascmd + sp_accession ;
103 String sequence = retrieveSequence(connstr);
104 // bug in aristotle das source?
105 sequence.replaceAll(" ","");
107 // set the sequence ...
109 triggerNewSequence(sp_accession,sequence);
114 catch (Exception ex) {
115 ex.printStackTrace();
116 logger.warning(ex.getMessage());
118 //triggerException(ex);
123 logger.log(Level.WARNING,"could not retreive UniProt sequence from any available DAS sequence server");
125 triggerNoSequence(sp_accession);
131 // private void triggerException(Exception e){
132 // Iterator iter = seqListeners.iterator();
133 // while (iter.hasNext()){
134 // SequenceListener li = (SequenceListener)iter.next();
135 // li.exceptionOccured(e);
139 private void triggerNewSequence(String sp_accession,String sequence){
141 Iterator iter = seqListeners.iterator();
142 while (iter.hasNext()){
143 SequenceListener li = (SequenceListener)iter.next();
144 //SequenceEvent event = new SequenceEvent(sequence);
145 SequenceEvent event = new SequenceEvent(sp_accession,sequence);
146 li.newSequence(event);
150 private void triggerNoSequence(String ac){
152 Iterator iter = seqListeners.iterator();
153 while (iter.hasNext()){
154 SequenceListener li = (SequenceListener)iter.next();
155 li.noObjectFound(ac);
160 /** retrieve the Sequence from a DAS server.
162 * @param connstr - the DAS - request string. e.g. http://www.ebi.ac.uk/das-srv/uniprot/das/aristotle/sequence?segment=P00280
163 * @return the requested Sequence
166 public String retrieveSequence( String connstr)
170 //logger.finest("trying: " + connstr) ;
171 URL dasUrl = new URL(connstr);
172 //DAS_httpConnector dhtp = new DAS_httpConnector() ;
173 logger.info("requesting sequence from " + connstr);
174 InputStream dasInStream =open(dasUrl);
177 SAXParserFactory spfactory =
178 SAXParserFactory.newInstance();
181 //String vali = System.getProperty("XMLVALIDATION");
182 String vali = "false";
183 boolean validate = false ;
184 if ((vali != null) && ( vali.equals("true")) )
186 spfactory.setValidating(validate);
188 SAXParser saxParser = null ;
192 spfactory.newSAXParser();
193 } catch (ParserConfigurationException e) {
194 //e.printStackTrace();
195 logger.log(Level.FINER,"Uncaught exception", e);
198 XMLReader xmlreader = saxParser.getXMLReader();
201 xmlreader.setFeature("http://xml.org/sax/features/validation", validate);
202 } catch (SAXException e) {
203 logger.finer("Cannot set validation to " + validate);
204 logger.log(Level.FINER,"Uncaught exception", e);
208 xmlreader.setFeature("http://apache.org/xml/features/nonvalidating/load-external-dtd",validate);
209 } catch (SAXNotRecognizedException e){
210 //e.printStackTrace();
211 logger.finer("Cannot set load-external-dtd to" + validate);
212 logger.log(Level.FINER,"Uncaught exception", e);
213 //System.err.println("Cannot set load-external-dtd to" + validate);
217 //DAS_DNA_Handler cont_handle = new DAS_DNA_Handler() ;
218 DAS_Sequence_Handler cont_handle = new DAS_Sequence_Handler() ;
219 xmlreader.setContentHandler(cont_handle);
220 xmlreader.setErrorHandler(new org.xml.sax.helpers.DefaultHandler());
221 InputSource insource = new InputSource() ;
222 insource.setByteStream(dasInStream);
224 xmlreader.parse(insource);
225 String sequence = cont_handle.get_sequence();
226 //logger.finest("Got sequence from DAS: " +sequence);
227 logger.exiting(this.getClass().getName(), "retreiveSequence", sequence);
231 private InputStream open(URL url) {
234 InputStream inStream = null;
240 HttpURLConnection huc = null;
242 huc = DAS_FeatureRetrieve.openHttpURLConnection(url);
245 logger.finest(huc.getResponseMessage());
247 inStream = huc.getInputStream();
251 catch ( Exception ex){
252 ex.printStackTrace();
253 logger.log(Level.WARNING,"exception occured", ex);