
org.biojava.nbio.structure.io.sifts.SiftsMappingProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of biojava-structure Show documentation
Show all versions of biojava-structure Show documentation
The protein structure modules of BioJava.
/**
* BioJava development code
*
* This code may be freely distributed and modified under the
* terms of the GNU Lesser General Public Licence. This should
* be distributed with the code. If you do not have a copy,
* see:
*
* http://www.gnu.org/copyleft/lesser.html
*
* Copyright for this code is held jointly by the individual
* authors. These should be listed in @author doc comments.
*
* For more information on the BioJava project and its aims,
* or to join the biojava-l mailing list, visit the home page
* at:
*
* http://www.biojava.org/
*
* Created on Feb 22, 2012
* Created by Andreas Prlic
*
* @since 3.0.2
*/
package org.biojava.nbio.structure.io.sifts;
import org.biojava.nbio.structure.align.util.AtomCache;
import org.biojava.nbio.structure.io.util.FileDownloadUtils;
import org.biojava.nbio.core.util.InputStreamProvider;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.net.URL;
import java.util.List;
public class SiftsMappingProvider {
private final static Logger logger = LoggerFactory.getLogger(SiftsMappingProvider.class);
static String EBI_SIFTS_FILE_LOCATION = "ftp://ftp.ebi.ac.uk/pub/databases/msd/sifts/xml/%s.xml.gz";
static String RCSB_SIFTS_FILE_LOCATION = "http://www.rcsb.org/pdb/files/%s.sifts.xml.gz";
static String fileLoc = EBI_SIFTS_FILE_LOCATION;
public static void main(String[] args){
try {
List entities = getSiftsMapping("1gc1");
for (SiftsEntity e : entities){
System.out.println(e.getEntityId() + " " +e.getType());
for ( SiftsSegment seg: e.getSegments()) {
System.out.println(" Segment: " + seg.getSegId() + " " + seg.getStart() + " " + seg.getEnd()) ;
for ( SiftsResidue res: seg.getResidues() ) {
System.out.println(" " + res);
}
}
}
} catch (Exception e){
e.printStackTrace();
}
}
public static void setFileLocation(String myFileLocation){
fileLoc = myFileLocation;
}
public static List getSiftsMapping(String pdbId) throws IOException{
// grab files from here:
AtomCache cache = new AtomCache();
String path = cache.getCachePath();
pdbId = pdbId.toLowerCase();
String dirHash = pdbId.substring(1,3);
File siftsDir = new File(path , "SIFTS");
if ( ! siftsDir.exists()) {
logger.info("Creating directory {}", siftsDir.toString());
siftsDir.mkdir();
}
File hashDir = new File(siftsDir, dirHash);
if ( ! hashDir.exists()){
logger.info("Creating directory {}", hashDir.toString());
hashDir.mkdir();
}
File dest = new File( hashDir, pdbId + ".sifts.xml.gz");
if ( ! dest.exists()){
String u = String.format(fileLoc,pdbId);
URL url = new URL(u);
logger.info("Downloading SIFTS file {} to {}",url,dest);
FileDownloadUtils.downloadFile(url, dest);
}
InputStreamProvider prov = new InputStreamProvider();
InputStream is = prov.getInputStream(dest);
SiftsXMLParser parser = new SiftsXMLParser();
parser.parseXmlFile(is);
//System.out.println(parser.getEntities());
return parser.getEntities();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy