HubPub 1.17.1
HubPub provides users with functionality to help with the Bioconductor Hub
structures. The package provides the ability to create a skeleton of a Hub
style package that the user can then populate with the necessary information.
There are also functions to help add resources to the Hub pacakge metadata
files as well as publish data to the Bioconductor S3 bucket.
Install the most recent version from Bioconductor:
if(!requireNamespace("BiocManager", quietly = TRUE))
    install.packages("BiocManager")
BiocManager::install("HubPub")Then load HubPub:
library(HubPub)The create_pkg() function creates the skeleton of a package that follows the
guidelines for a Bioconductor Hub type package. More information about what
are the requirements and content for a Hub style package the developer can look
at the “Creating A Hub Package” vignette from this package.
create_pkg() requires a path to where the packages is to be created and the type
of package that should be created (“AnnotationHub” or “ExperimentHub”). There is
also a variable use_git that indicates if the package should be set up with
git (default is TRUE).
NOTE: This function is intended for a developer that has not created the package yet. If the package has already been created, then this function will not benefit the developer. There are a couple other functions in this package that deal with resources that might be helpful, more on these later in the vignette.
fl <- tempdir()
create_pkg(file.path(fl, "examplePkg"), "ExperimentHub")
#> ✔ Creating '/tmp/RtmpackTVF/examplePkg/'.
#> ✔ Setting active project to "/tmp/RtmpackTVF/examplePkg".
#> ✔ Creating 'R/'.
#> ✔ Writing 'DESCRIPTION'.
#> Package: examplePkg
#> Title: What the Package Does (One Line, Title Case)
#> Version: 0.99.0
#> Date: 2025-04-30
#> Authors@R (parsed):
#>     * First Last <first.last@example.com> [aut, cre]
#> Description: What the package does (one paragraph).
#> License: Artistic-2.0
#> BugReports: https://support.bioconductor.org/t/examplePkg
#> Imports:
#>     ExperimentHub
#> Suggests:
#>     ExperimentHubData
#> Encoding: UTF-8
#> Roxygen: list(markdown = TRUE)
#> RoxygenNote: 7.3.2
#> biocViews: ExperimentHub
#> ✔ Writing 'NAMESPACE'.
#> ✔ Setting active project to "<no active project>".
#> ✔ Setting active project to "/tmp/RtmpackTVF/examplePkg".
#> ✔ Initialising Git repo.
#> ✔ Adding ".Rproj.user", ".Rhistory", ".Rdata", ".httr-oauth", ".DS_Store", and
#>   ".quarto" to '.gitignore'.
#> ✔ Writing 'R/examplePkg-package.R'.
#> ✔ Writing 'NEWS.md'.
#> ✔ Creating 'man/'.
#> ✔ Creating 'inst/scripts/'.
#> ✔ Writing 'inst/scripts/make-data.R'.
#> ✔ Writing 'inst/scripts/make-metadata.R'.
#> ✔ Writing 'R/zzz.R'.
#> ✔ Creating 'inst/extdata/'.
#> ✔ Adding testthat to 'Suggests' field in DESCRIPTION.
#> ✔ Adding "3" to 'Config/testthat/edition'.
#> ✔ Creating 'tests/testthat/'.
#> ✔ Writing 'tests/testthat.R'.
#> ☐ Call `usethis::use_test()` to initialize a basic test file and open it for
#>   editing.
#> ✔ Writing 'tests/testthat/test_metadata.R'.
#> [1] "/tmp/RtmpackTVF/examplePkg"Once the package is created the developer can go through and make any changes to the package. For example, the DESCRIPTON file contains very basic requirements but the developer should go back and fill in the ‘Title:’ and ‘Description:’ fields.
Another useful function in HubPub is add_resource(). This function can be
useful for developers who are creating a new Hub related package or for
developers who want to add a new resource to an existing Hub package. The
purpose of this function is to add a hub resource to the package metadata.csv
file. The function requires the name of the package (or the path to the newly
created package) and a named list with the data to be added to the resource. To
get the elements and content for this list look at ?hub_metadata. There is
also information in the “Creating A Hub Package” vignette from this package.
metadata <- hub_metadata(
    Title = "ENCODE",
    Description = "a test entry",
    BiocVersion = "4.1",
    Genome = NA_character_,
    SourceType = "JSON",
    SourceUrl = "http://www.encodeproject.org",
    SourceVersion = "x.y.z",
    Species = NA_character_,
    TaxonomyId = as.integer(9606),
    Coordinate_1_based = NA,
    DataProvider = "ENCODE Project",
    Maintainer = "tst person <tst@email.com>",
    RDataClass = "Rda",
    DispatchClass = "Rda",
    Location_Prefix = "s3://experimenthub/",
    RDataPath = "ENCODExplorerData/encode_df_lite.rda",
    Tags = "ENCODE:Homo sapiens"
)
add_resource(file.path(fl, "examplePkg"), metadata)
#> Warning: replacing previous import 'utils::findMatches' by
#> 'S4Vectors::findMatches' when loading 'ExperimentHubData'
#> No methods found in package 'rtracklayer' for request: 'trackName<-' when loading 'AnnotationHubData'
#> [1] "/tmp/RtmpackTVF/examplePkg/inst/extdata/metadata.csv"Then if you want to see what the metadata file looks like you can read in the csv file like the following.
resource <- file.path(fl, "examplePkg", "inst", "extdata", "metadata.csv")
tst <- read.csv(resource)
tst
#>    Title  Description BiocVersion Genome SourceType
#> 1 ENCODE a test entry         4.1     NA       JSON
#>                      SourceUrl SourceVersion Species TaxonomyId
#> 1 http://www.encodeproject.org         x.y.z      NA       9606
#>   Coordinate_1_based   DataProvider                 Maintainer RDataClass
#> 1                 NA ENCODE Project tst person <tst@email.com>        Rda
#>   DispatchClass     Location_Prefix                            RDataPath
#> 1           Rda s3://experimenthub/ ENCODExplorerData/encode_df_lite.rda
#>                  Tags
#> 1 ENCODE:Homo sapiensThe final function in HubPub helps the developer with publishing data resources
to an Bioconductor AWS S3. The function utilizes functions for the aws.s3
package to place files or directories on S3. The developer should have already
contacted the Bioconductor hubs maintainers to get the necessary credentials to
access the bucket. Once the credentials are received the developer should
declare them in the system environment before running this function. The
function requires a path to the file or name of the directory to be added to the
bucket and a name for how the object should be named on the bucket. If adding a
directory be sure there are no nested directories and only files.
The below code chunk demonstrates the use of the function using a dummy dataset. It will only work if the necessary global environments have been declared with the hub credentials.
## For publishing directories with multiple files
fl <- tempdir()
utils::write.csv(mtcars, file = file.path(fl, "mtcars1.csv"))
utils::write.csv(mtcars, file = file.path(fl, "mtcars2.csv"))
publish_resource(fl, "test_dir")
#> Warning in publish_resource(fl, "test_dir"): Not all system environment
#> variables are set, do so and rerun function.
#> copy '/tmp/RtmpackTVF/BiocStyle' to 's3://annotation-contributor/test_dir/BiocStyle'
#> copy '/tmp/RtmpackTVF/examplePkg' to 's3://annotation-contributor/test_dir/examplePkg'
#> copy '/tmp/RtmpackTVF/mtcars1.csv' to 's3://annotation-contributor/test_dir/mtcars1.csv'
#> copy '/tmp/RtmpackTVF/mtcars2.csv' to 's3://annotation-contributor/test_dir/mtcars2.csv'
#> copy '/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fbioc%2Fsrc%2Fcontrib.rds' to 's3://annotation-contributor/test_dir/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fbioc%2Fsrc%2Fcontrib.rds'
#> copy '/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fbooks%2Fsrc%2Fcontrib.rds' to 's3://annotation-contributor/test_dir/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fbooks%2Fsrc%2Fcontrib.rds'
#> copy '/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fdata%2Fannotation%2Fsrc%2Fcontrib.rds' to 's3://annotation-contributor/test_dir/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fdata%2Fannotation%2Fsrc%2Fcontrib.rds'
#> copy '/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fdata%2Fexperiment%2Fsrc%2Fcontrib.rds' to 's3://annotation-contributor/test_dir/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fdata%2Fexperiment%2Fsrc%2Fcontrib.rds'
#> copy '/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fworkflows%2Fsrc%2Fcontrib.rds' to 's3://annotation-contributor/test_dir/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fworkflows%2Fsrc%2Fcontrib.rds'
#> copy '/tmp/RtmpackTVF/repos_https%3A%2F%2Fcloud.r-project.org%2Fsrc%2Fcontrib.rds' to 's3://annotation-contributor/test_dir/repos_https%3A%2F%2Fcloud.r-project.org%2Fsrc%2Fcontrib.rds'
#> $`/tmp/RtmpackTVF/BiocStyle`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/examplePkg`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/mtcars1.csv`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/mtcars2.csv`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fbioc%2Fsrc%2Fcontrib.rds`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fbooks%2Fsrc%2Fcontrib.rds`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fdata%2Fannotation%2Fsrc%2Fcontrib.rds`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fdata%2Fexperiment%2Fsrc%2Fcontrib.rds`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/repos_https%3A%2F%2Fbioconductor.org%2Fpackages%2F3.22%2Fworkflows%2Fsrc%2Fcontrib.rds`
#> NULL
#> 
#> $`/tmp/RtmpackTVF/repos_https%3A%2F%2Fcloud.r-project.org%2Fsrc%2Fcontrib.rds`
#> NULL
## For publishing a single file
utils::write.csv(mtcars, file = file.path(fl, "mtcars3.csv"))
publish_resource(file.path(fl, "mtcars3.csv"), "test_dir")
#> Warning in publish_resource(file.path(fl, "mtcars3.csv"), "test_dir"): Not all
#> system environment variables are set, do so and rerun function.
#> copy '/tmp/RtmpackTVF/mtcars3.csv' to 's3://annotation-contributor/test_dir/mtcars3.csv'
#> $`/tmp/RtmpackTVF/mtcars3.csv`
#> NULLsessionInfo()
#> R version 4.5.0 (2025-04-11)
#> Platform: x86_64-pc-linux-gnu
#> Running under: Ubuntu 24.04.2 LTS
#> 
#> Matrix products: default
#> BLAS:   /home/biocbuild/bbs-3.22-bioc/R/lib/libRblas.so 
#> LAPACK: /usr/lib/x86_64-linux-gnu/lapack/liblapack.so.3.12.0  LAPACK version 3.12.0
#> 
#> locale:
#>  [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C              
#>  [3] LC_TIME=en_GB              LC_COLLATE=C              
#>  [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8   
#>  [7] LC_PAPER=en_US.UTF-8       LC_NAME=C                 
#>  [9] LC_ADDRESS=C               LC_TELEPHONE=C            
#> [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C       
#> 
#> time zone: America/New_York
#> tzcode source: system (glibc)
#> 
#> attached base packages:
#> [1] stats     graphics  grDevices utils     datasets  methods   base     
#> 
#> other attached packages:
#> [1] futile.logger_1.4.3 HubPub_1.17.1       BiocStyle_2.37.0   
#> 
#> loaded via a namespace (and not attached):
#>   [1] sys_3.4.3                   rstudioapi_0.17.1          
#>   [3] jsonlite_2.0.0              magrittr_2.0.3             
#>   [5] GenomicFeatures_1.61.0      rmarkdown_2.29             
#>   [7] fs_1.6.6                    BiocIO_1.19.0              
#>   [9] vctrs_0.6.5                 memoise_2.0.1              
#>  [11] Rsamtools_2.25.0            RCurl_1.98-1.17            
#>  [13] askpass_1.2.1               base64enc_0.1-3            
#>  [15] BiocBaseUtils_1.11.0        htmltools_0.5.8.1          
#>  [17] S4Arrays_1.9.0              usethis_3.1.0              
#>  [19] progress_1.2.3              lambda.r_1.2.4             
#>  [21] AnnotationHub_3.99.0        curl_6.2.2                 
#>  [23] SparseArray_1.9.0           sass_0.4.10                
#>  [25] bslib_0.9.0                 desc_1.4.3                 
#>  [27] testthat_3.2.3              httr2_1.1.2                
#>  [29] futile.options_1.0.1        cachem_1.1.0               
#>  [31] available_1.1.0             GenomicAlignments_1.45.0   
#>  [33] whisker_0.4.1               lifecycle_1.0.4            
#>  [35] pkgconfig_2.0.3             Matrix_1.7-3               
#>  [37] R6_2.6.1                    fastmap_1.2.0              
#>  [39] GenomeInfoDbData_1.2.14     BiocCheck_1.45.2           
#>  [41] MatrixGenerics_1.21.0       digest_0.6.37              
#>  [43] AnnotationDbi_1.71.0        S4Vectors_0.47.0           
#>  [45] OrganismDbi_1.51.1          rprojroot_2.0.4            
#>  [47] ExperimentHub_2.99.0        aws.signature_0.6.0        
#>  [49] GenomicRanges_1.61.0        RSQLite_2.3.9              
#>  [51] filelock_1.0.3              httr_1.4.7                 
#>  [53] abind_1.4-8                 compiler_4.5.0             
#>  [55] bit64_4.6.0-1               withr_3.0.2                
#>  [57] biocViews_1.77.0            BiocParallel_1.43.0        
#>  [59] DBI_1.2.3                   R.utils_2.13.0             
#>  [61] biomaRt_2.65.0              openssl_2.3.2              
#>  [63] rappdirs_0.3.3              DelayedArray_0.35.1        
#>  [65] rjson_0.2.23                tools_4.5.0                
#>  [67] R.oo_1.27.0                 glue_1.8.0                 
#>  [69] restfulr_0.0.15             R.cache_0.16.0             
#>  [71] grid_4.5.0                  stringdist_0.9.15          
#>  [73] generics_0.1.3              R.methodsS3_1.8.2          
#>  [75] hms_1.1.3                   xml2_1.3.8                 
#>  [77] XVector_0.49.0              BiocGenerics_0.55.0        
#>  [79] BiocVersion_3.22.0          pillar_1.10.2              
#>  [81] stringr_1.5.1               dplyr_1.1.4                
#>  [83] BiocFileCache_2.99.0        lattice_0.22-7             
#>  [85] AnnotationHubData_1.39.1    rtracklayer_1.69.0         
#>  [87] bit_4.6.0                   tidyselect_1.2.1           
#>  [89] RBGL_1.85.0                 Biostrings_2.77.0          
#>  [91] knitr_1.50                  biocthis_1.19.0            
#>  [93] bookdown_0.43               IRanges_2.43.0             
#>  [95] SummarizedExperiment_1.39.0 stats4_4.5.0               
#>  [97] xfun_0.52                   Biobase_2.69.0             
#>  [99] credentials_2.0.2           brio_1.1.5                 
#> [101] matrixStats_1.5.0           stringi_1.8.7              
#> [103] UCSC.utils_1.5.0            yaml_2.3.10                
#> [105] evaluate_1.0.3              codetools_0.2-20           
#> [107] tibble_3.2.1                BiocManager_1.30.25        
#> [109] graph_1.87.0                cli_3.6.5                  
#> [111] jquerylib_0.1.4             styler_1.10.3              
#> [113] roxygen2_7.3.2              GenomeInfoDb_1.45.3        
#> [115] gert_2.1.5                  dbplyr_2.5.0               
#> [117] png_0.1-8                   XML_3.99-0.18              
#> [119] RUnit_0.4.33                parallel_4.5.0             
#> [121] blob_1.2.4                  prettyunits_1.2.0          
#> [123] aws.s3_0.3.21               AnnotationForge_1.51.0     
#> [125] bitops_1.0-9                txdbmaker_1.5.1            
#> [127] ExperimentHubData_1.35.0    purrr_1.0.4                
#> [129] crayon_1.5.3                rlang_1.1.6                
#> [131] formatR_1.14                KEGGREST_1.49.0