Skip to content

jndmose/REDCapR

 
 

Repository files navigation

Build Status

REDCapR

We’ve been using R with REDCap’s API since the Fall 2012 and have developed a few functions that we're assembling in an R package: REDCapR.

It was taking us about 50 lines of code to contact REDCap and robustly transform the returned CSV into an R data.frame. The same thing can be done in one line of code with the package's redcap_read() function:

ds <- redcap_read(redcap_uri=uri, token=token)$data

The REDCapR package includes the Bundle of CA Root Certificates from the official cURL site. Your REDCap server's identity is always verified, unless the setting is overridden (or alternative certificates can also be provided).

The redcap_read() function also accepts values for subsetting/filtering the records and fields. The current documentation can be found in the GitHub repository. A vignette has also been started.

#Return only records with IDs of 1 and 4
desired_records <- c(1, 4)
ds_some_rows <- redcap_read(
   redcap_uri = uri, 
   token = token, 
   records = desired_records
)$data

#Return only the fields recordid, first_name, and age
desired_fields <- c("recordid", "first_name", "age")
ds_some_fields <- redcap_read(
   redcap_uri = uri, 
   token = token, 
   fields = desired_fields
)$data

We have completed redcap_write(), but aren't releasing it until appropriate unit/regression/integration tests are written. We first need a way to automate deleting the newly inserted records, so the database's state is cleaned up before subsequent tests.

Once the redcap_write() function is tested and documented, we'll release it on CRAN. In the next few months, we hope to implement everything exposed by the REDCap API. If there's a feature that would help your projects, feel free to post something here in the forums, or create an issue in REDCapR's GitHub repository.

Our group has benefited so much from REDCap and the surrounding community, and we'd like to contribute back. Suggestions, criticisms, and code contributions are welcome. And if anyone is interested in trying a direction that suits them better, we'll be happy to explain the package's internals and help you fork your own version. We have some starting material described in the ./documentation_for_developers/ directory. Also two other libraries exist for communicating with REDCap: redcap and its current fork written for R, and PyCap written for Python.

Thanks, Will Beasley, David Bard, & Thomas Wilson

University of Oklahoma Health Sciences Center, Department of Pediatrics, Biomedical & Behavioral Research Core.

The development version of REDCapR can be installed from GitHub after installing the devtools package.

install.packages("devtools")
devtools::install_github(repo="OuhscBbmc/REDCapR")

About

R utilities for interacting with a REDCap data system (http://www.project-redcap.org/)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published