X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fws%2Fdbsources%2FPfam.java;h=316c1aac7d3e7711ddd38598a87fc1343838d09d;hb=e2ca25dc2cebc1603445864c1bcf41bb13fc2d61;hp=fb4e3960d3396674fd1e8bfa6fd4894cf379e8e8;hpb=7b9c6bc2db695c996b7bd4e536a6718b22042125;p=jalview.git diff --git a/src/jalview/ws/dbsources/Pfam.java b/src/jalview/ws/dbsources/Pfam.java index fb4e396..316c1aa 100644 --- a/src/jalview/ws/dbsources/Pfam.java +++ b/src/jalview/ws/dbsources/Pfam.java @@ -20,11 +20,14 @@ */ package jalview.ws.dbsources; -import jalview.bin.Cache; -import jalview.datamodel.DBRefSource; +import java.util.Locale; import com.stevesoft.pat.Regex; +import jalview.bin.Cache; +import jalview.datamodel.DBRefSource; +import jalview.util.Platform; + /** * TODO: later PFAM is a complex datasource - it could return a tree in addition * to an alignment TODO: create interface to pass alignment properties and tree @@ -35,14 +38,43 @@ import com.stevesoft.pat.Regex; */ abstract public class Pfam extends Xfam { - private static final String PFAM_DOMAIN_KEY = "PFAM_DOMAIN"; - private static final String DEFAULT_PFAM_DOMAIN = "http://pfam.xfam.org"; + public static final String FULL = "full", RP35 = "rp35", RP15 = "rp15", + RP75 = "rp75", RP55 = "rp55", SEED = "seed", UNIPROT = "uniprot"; + + public String getPfamDownloadURL(String id, String alType) + { + String url = Cache.getDefault(PFAM_BASEURL_KEY, DEFAULT_PFAM_BASEURL); + url = url.replace("$PFAMID$", id); + url = url.replace("$ALTYPE$", alType); + return url; + } + + static final String PFAM_BASEURL_KEY = "PFAM_INTERPRO_URL_TEMPLATE"; + + protected String alignmentType; + + /** + * docs are http://www.ebi.ac.uk/interpro/api/ + */ + private static final String DEFAULT_PFAM_BASEURL = "https://www.ebi.ac.uk/interpro/api/entry/pfam/$PFAMID$/?annotation=alignment:$ALTYPE$"; + + static + { + Platform.addJ2SDirectDatabaseCall(DEFAULT_PFAM_BASEURL); + } public Pfam() { super(); } + @Override + String getURL(String queries) + { + return getPfamDownloadURL(queries.trim().toUpperCase(Locale.ROOT), + alignmentType); + } + /* * (non-Javadoc) * @@ -98,7 +130,7 @@ abstract public class Pfam extends Xfam @Override protected String getURLPrefix() { - return Cache.getDefault(PFAM_DOMAIN_KEY, DEFAULT_PFAM_DOMAIN); + return Cache.getDefault(PFAM_BASEURL_KEY, DEFAULT_PFAM_BASEURL); } /* @@ -121,5 +153,4 @@ abstract public class Pfam extends Xfam { return DBRefSource.PFAM; } - }