All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.biojava.nbio.structure.quaternary.io.RemoteRawBioUnitDataProvider Maven / Gradle / Ivy

There is a newer version: 7.2.2
Show newest version
/*
 *                    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/
 *
 */
package org.biojava.nbio.structure.quaternary.io;

import org.biojava.nbio.structure.align.client.JFatCatClient;
import org.biojava.nbio.structure.align.util.HTTPConnectionTools;
import org.biojava.nbio.structure.io.mmcif.model.*;
import org.w3c.dom.Document;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.InputSource;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import java.io.InputStream;
import java.io.StringReader;
import java.net.URL;
import java.util.List;

/** A BioUnitDataProvider that fetches the symmetry operations via remote calls to servers from RCSB PDB
 *
 * @author Andreas Prlic
 *
 */
public class RemoteRawBioUnitDataProvider implements RawBioUnitDataProvider {

	String pdbId;

	public static String DEFAULT_SERVERNAME = "http://pepper.rcsb.org:8080/pdb/rest/biolassembly/";

	public static String NR_BIOL_APPEND = "nrBiolAssemblies?structureId=%s";

	public static String GET_ASSEMBLY =  "pdbxStructAssemblies?structureId=%s";

	public static String GET_ASSEMBLY_GENS =  "pdbxStructAssemblyGens?structureId=%s";

	public static String GET_STRUCT_OPER = "pdbxStructOperList?structureId=%s";

	String serverName;
	private static final int DEFAULT_TIMEOUT = 5000;

	int timeout;
	public RemoteRawBioUnitDataProvider(){
		serverName = DEFAULT_SERVERNAME;
		timeout = DEFAULT_TIMEOUT;
	}

	public static void main(String[] args){

		RemoteRawBioUnitDataProvider me = new RemoteRawBioUnitDataProvider();

		me.setPdbId("4hhb");

		System.out.println("Nr biol assemblies: " + me.getNrBiolAssemblies());
		System.out.println("has biol assembly:" + me.hasBiolAssembly());
		System.out.println("assemblies: " + me.getPdbxStructAssemblies());
		System.out.println("assemblygens:" + me.getPdbxStructAssemblyGens());
		System.out.println("operations:" + me.getPdbxStructOperList());


	}


	public int getTimeout() {
		return timeout;
	}




	public void setTimeout(int timeout) {
		this.timeout = timeout;
	}




	@Override
	public void setPdbId(String pdbId) {
		this.pdbId = pdbId;

	}



	@Override
	public int getNrBiolAssemblies() {

		String serverURL = serverName + NR_BIOL_APPEND;
		int nrBiolAssemblies = -1;
		try {
			String u = String.format(serverURL,pdbId) ;


			URL url = new URL(u);
			System.out.println("requesting nr biol assemblies from server..."  + url);
			// have a short timeout for this...
			// 5 sec
			InputStream stream = HTTPConnectionTools.getInputStream(url,timeout);

			String xml = null;

			if ( stream != null) {

				xml = JFatCatClient.convertStreamToString(stream);
				System.out.println("got XML from server: " + xml);

				nrBiolAssemblies = extractNrBiolAssemblies(xml);
			}
		} catch (Exception e){
			e.printStackTrace();
		}
		return nrBiolAssemblies;
	}

	private static int extractNrBiolAssemblies(String xml) {
		int nrBiolAssemblies = -1;

		try {
			DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
			DocumentBuilder db = factory.newDocumentBuilder();
			InputSource inStream = new InputSource();
			inStream.setCharacterStream(new StringReader(xml));
			Document doc = db.parse(inStream);

			// normalize text representation
			doc.getDocumentElement().normalize();


			//Element rootElement = doc.getDocumentElement();

			NodeList listOfPairs = doc.getElementsByTagName("nrBiolAssemblies");
			//int numArrays = listOfArrays.getLength();

			// go over the blocks
			for(int i=0; i 0)
			return true;
		return false;
	}

	@Override
	public PdbxStructAssembly getPdbxStructAssembly(int biolAssemblyNr) {
		PdbxStructAssembly pdbxStructAssembly = null;

		return pdbxStructAssembly;
	}

	@Override
	public List getPdbxStructAssemblyGen(int biolAssemblyNr) {

		List pdbxStructAssemblyGen = null;

		return pdbxStructAssemblyGen;
	}
	@Override
	public List getPdbxStructAssemblies() {
		String serverURL = serverName + GET_ASSEMBLY;
		List assemblies = null;
		try {
			String u = String.format(serverURL,pdbId) ;


			URL url = new URL(u);
			System.out.println("requesting biol assemblies from server..."  + url);
			// have a short timeout for this...
			// 5 sec
			InputStream stream = HTTPConnectionTools.getInputStream(url,timeout);

			String xml = null;

			if ( stream != null) {

				xml = JFatCatClient.convertStreamToString(stream);
				System.out.println("got XML from server: " + xml);
				PdbxStructAssemblyXMLContainer tmp = PdbxStructAssemblyXMLContainer.fromXML(xml);
				assemblies = tmp.getPdbxStructAssemblies();
				//pdbxStructAssembly = extractNrBiolAssemblies(xml);
			}
		} catch (Exception e){
			e.printStackTrace();
		}
		return assemblies;
	}

	@Override
	public List getPdbxStructAssemblyGens() {
		String serverURL = serverName + GET_ASSEMBLY_GENS;
		List assemblies = null;
		try {
			String u = String.format(serverURL,pdbId) ;


			URL url = new URL(u);
			System.out.println("requesting  biol assembly gens from server..."  + url);
			// have a short timeout for this...
			// 5 sec
			InputStream stream = HTTPConnectionTools.getInputStream(url,timeout);

			String xml = null;

			if ( stream != null) {

				xml = JFatCatClient.convertStreamToString(stream);
				System.out.println("got XML from server: " + xml);
				PdbxStructAssemblyGenXMLContainer tmp = PdbxStructAssemblyGenXMLContainer.fromXML(xml);
				assemblies = tmp.getPdbxStructAssemblyGens();
				//pdbxStructAssembly = extractNrBiolAssemblies(xml);
			}
		} catch (Exception e){
			e.printStackTrace();
		}

		return assemblies;

	}

	@Override
	public List getPdbxStructOperList() {
		String serverURL = serverName + GET_STRUCT_OPER;
		List oper = null;
		try {
			String u = String.format(serverURL,pdbId) ;


			URL url = new URL(u);
			System.out.println("requesting operators from server..."  + url);
			// have a short timeout for this...
			// 5 sec
			InputStream stream = HTTPConnectionTools.getInputStream(url,timeout);

			String xml = null;

			if ( stream != null) {

				xml = JFatCatClient.convertStreamToString(stream);
				System.out.println("got XML from server: " + xml);
				PdbxStructOperListXMLContainer container =  PdbxStructOperListXMLContainer.fromXML(xml);
				oper = container.getPdbxStructOperLists();
			}
		} catch (Exception e){
			e.printStackTrace();
		}

		return oper;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy