Mercurial > repos > prog > lcmsmatching
diff NcbigeneConn.R @ 2:20d69a062da3 draft
planemo upload for repository https://github.com/workflow4metabolomics/lcmsmatching.git commit d4048accde6bdfd5b3e14f5394902d38991854f8
author | prog |
---|---|
date | Thu, 02 Mar 2017 08:55:00 -0500 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/NcbigeneConn.R Thu Mar 02 08:55:00 2017 -0500 @@ -0,0 +1,45 @@ +##################### +# CLASS DECLARATION # +##################### + +NcbigeneConn <- methods::setRefClass("NcbigeneConn", contains = "RemotedbConn") + +############### +# CONSTRUCTOR # +############### + +NcbigeneConn$methods( initialize = function(...) { + # From NCBI E-Utility manual: "In order not to overload the E-utility servers, NCBI recommends that users post no more than three URL requests per second and limit large jobs to either weekends or between 9:00 PM and 5:00 AM Eastern time during weekdays". + callSuper(scheduler = UrlRequestScheduler$new(n = 3), ...) +}) + +########################## +# GET ENTRY CONTENT TYPE # +########################## + +NcbigeneConn$methods( getEntryContentType = function() { + return(BIODB.XML) +}) + +##################### +# GET ENTRY CONTENT # +##################### + +NcbigeneConn$methods( getEntryContent = function(id) { + + # Initialize return values + content <- rep(NA_character_, length(id)) + + # Request + content <- vapply(id, function(x) .self$.get.url(get.entry.url(BIODB.NCBIGENE, x, content.type = BIODB.XML)), FUN.VALUE = '') + + return(content) +}) + +################ +# CREATE ENTRY # +################ + +NcbigeneConn$methods( createEntry = function(content, drop = TRUE) { + return(createNcbigeneEntryFromXml(content, drop = drop)) +})