Title: | Automated Construction of R Data Packages from REDCap Projects |
---|---|
Description: | Export all data, including metadata, from a REDCap (Research Electronic Data Capture) Project via the REDCap API <https://projectredcap.org/wp-content/resources/REDCapTechnicalOverview.pdf>. The exported (meta)data will be processed and formatted into a stand alone R data package which can be installed and shared between researchers. Several default reports are generated as vignettes in the resulting package. |
Authors: | Peter DeWitt [aut, cre] |
Maintainer: | Peter DeWitt <[email protected]> |
License: | GPL-2 |
Version: | 0.3.1 |
Built: | 2025-01-05 06:05:46 UTC |
Source: | https://github.com/dewittpe/redcapexporter |
Coerce REDCapExporter objects to data.frame.
## S3 method for class 'rcer_raw_metadata' as.data.frame(x, ...) ## S3 method for class 'rcer_raw_record' as.data.frame(x, ...) ## S3 method for class 'rcer_raw_project' as.data.frame(x, ...) ## S3 method for class 'rcer_raw_user' as.data.frame(x, ...)
## S3 method for class 'rcer_raw_metadata' as.data.frame(x, ...) ## S3 method for class 'rcer_raw_record' as.data.frame(x, ...) ## S3 method for class 'rcer_raw_project' as.data.frame(x, ...) ## S3 method for class 'rcer_raw_user' as.data.frame(x, ...)
x |
any R object. |
... |
additional arguments to be passed to or from methods. |
These functions are S3 methods for as.data.frame
for the raw
exports from the REDCap API.
data("avs_raw_record") avs_record <- as.data.frame(avs_raw_record) str(avs_record)
data("avs_raw_record") avs_record <- as.data.frame(avs_raw_record) str(avs_record)
Build a R Data Package from the core contents of a REDCap Project.
build_r_data_package(x, ...) ## S3 method for class 'rcer_rccore' build_r_data_package(x, path = NULL, author_roles = NULL, verbose = TRUE, ...) ## Default S3 method: build_r_data_package( x, uri = NULL, token = NULL, format = NULL, path = NULL, author_roles = NULL, verbose = TRUE, ... )
build_r_data_package(x, ...) ## S3 method for class 'rcer_rccore' build_r_data_package(x, path = NULL, author_roles = NULL, verbose = TRUE, ...) ## Default S3 method: build_r_data_package( x, uri = NULL, token = NULL, format = NULL, path = NULL, author_roles = NULL, verbose = TRUE, ... )
x |
a |
... |
arguments passed to |
path |
Path where the exported project source will be created/overwritten. |
author_roles |
a list naming specific roles for each user id found in the user table from an exported project. By default all users with be contributors ('ctb'). You will need to define a author/creator. |
verbose |
provide messages to tell the user what is happening |
uri |
The URI for the REDCap API. If |
token |
The API token for the project you want to export from. If
|
format |
The format to return. If |
To export the data from a REDCap project you will need to have an API Token. Remember, the token is the equivalent of a username and password. As such you should not list the token in plan text. Several alternative methods for passing the token to this method will be provided in examples and vignettes. We strongly encourage the use of the package secret https://cran.r-project.org/package=secret to build vaults to store tokens locally.
The initial export will consist of four pieces of data, the user data, metadata, project info, and records.
## Please read the vignette for examples: ## vignette(topic = "export", package = "REDCapExporter") library(REDCapExporter) # avs_raw_core <- export_core() data(avs_raw_core) tmppth <- tempdir() build_r_data_package(avs_raw_core, tmppth, author_roles = list(dewittp = c("cre", "aut"))) fs::dir_tree(tmppth)
## Please read the vignette for examples: ## vignette(topic = "export", package = "REDCapExporter") library(REDCapExporter) # avs_raw_core <- export_core() data(avs_raw_core) tmppth <- tempdir() build_r_data_package(avs_raw_core, tmppth, author_roles = list(dewittp = c("cre", "aut"))) fs::dir_tree(tmppth)
Define a type for each column of the records for a REDCap project based on the metadata for the project.
col_type( x, factors = TRUE, lubridate_args = list(quiet = TRUE, tz = NULL, locale = Sys.getlocale("LC_TIME"), truncated = 0), ... )
col_type( x, factors = TRUE, lubridate_args = list(quiet = TRUE, tz = NULL, locale = Sys.getlocale("LC_TIME"), truncated = 0), ... )
x |
a |
factors |
If |
lubridate_args |
a list of arguments passed to the date and time parsing calls. See Details. |
... |
not currently used |
REDCap text fields for dates and times are formatted via lubridate
REDCap | lubridate parsing function |
--------------------- | -------------------------- |
date_mdy | mdy |
date_dmy | dmy |
date_ymd | ymd |
datetime_dmy | dmy_hm |
datetime_mdy | mdy_hm |
datetime_ymd | ymd_hm |
datetime_seconds_dmy | dmy_hms |
datetime_seconds_mdy | mdy_hms |
datetime_seconds_ymd | ymd_hms |
time | hm |
time_mm_ss | ms |
Other text files are coerced as
REDCap | R coercion |
--------------------- | -------------------------- |
number | as.numeric |
number_1dp | as.numeric |
number_2dp | as.numeric |
integer | as.integer |
..default.. | as.character |
Variables inputted into REDCap via radio button or dropdown lists (multiple
choice - pick one) are coerced to factors by default but can be returned as
characters if the argument factors = FALSE
is set.
Calculated and slider (visual analog scale) variables are coerced via
as.numeric
.
Yes/No and True/False variables are include as integer values 0 = No or False, and 1 for Yes or True.
Checkboxes are the most difficult to work with between the metadata and records. A checkbox field_name in the metadata could be, for example, "eg_checkbox" and the columns in the records will be "eg_checkbox___<code>" were "code" could be numbers, or character strings. REDCapExporter attempts to coerce the "eg_checkbox___<code>" columns to integer values, 0 = unchecked and 1 = checked.
a rcer_col_type
object
data("avs_raw_metadata") col_type(avs_raw_metadata)
data("avs_raw_metadata") col_type(avs_raw_metadata)
These data sets are the results of calling export_content
. An
API token is required to reproduce these calls. No such token will be
provided publicly, so these data sets are provided so end users can run
examples for other tools provided in the REDCapExporter package.
avs_raw_project avs_raw_metadata avs_raw_user avs_raw_record avs_raw_core avs_raw_project_json avs_raw_metadata_json avs_raw_user_json avs_raw_record_json avs_raw_core_json
avs_raw_project avs_raw_metadata avs_raw_user avs_raw_record avs_raw_core avs_raw_project_json avs_raw_metadata_json avs_raw_user_json avs_raw_record_json avs_raw_core_json
An object of class rcer_raw_project
(inherits from character
) of length 1.
An object of class rcer_raw_metadata
(inherits from character
) of length 1.
An object of class rcer_raw_user
(inherits from character
) of length 1.
An object of class rcer_raw_record
(inherits from character
) of length 1.
An object of class rcer_rccore
of length 4.
An object of class rcer_raw_project
(inherits from character
) of length 1.
An object of class rcer_raw_metadata
(inherits from character
) of length 1.
An object of class rcer_raw_user
(inherits from character
) of length 1.
An object of class rcer_raw_record
(inherits from character
) of length 1.
An object of class rcer_rccore
of length 4.
avs_raw_project
provides meta data about the project itself in a csv format.
avs_raw_project_json
is the same information in json format.
avs_raw_metadata
is the data dictionary for the REDCap Project in a
csv format. This information can be used with format_record
to
build a data.frame
that is ready for analysis.
avs_raw_metadata_json
is the same metadata information in json format.
avs_raw_user
REDCap Project user table in csv format.
avs_raw_user_json
is the same information in json format.
avs_raw_record
REDCap Project records, i.e., 'the data' in csv format.
avs_raw_record_json
is the same information in json format.
## Not run: avs_raw_project <- export_content(content = "project", format = "csv") avs_raw_metadata <- export_content(content = "metadata", format = "csv") avs_raw_user <- export_content(content = "user", format = "csv") avs_raw_record <- export_content(content = "record", format = "csv") avs_raw_core <- export_core(format = "csv") ## End(Not run) data(avs_raw_project) data(avs_raw_user) data(avs_raw_metadata) data(avs_raw_record) data(avs_raw_core) str(avs_raw_project) str(avs_raw_user) str(avs_raw_metadata) str(avs_raw_record) str(avs_raw_core) avs <- format_record(avs_raw_record, avs_raw_metadata) str(avs)
## Not run: avs_raw_project <- export_content(content = "project", format = "csv") avs_raw_metadata <- export_content(content = "metadata", format = "csv") avs_raw_user <- export_content(content = "user", format = "csv") avs_raw_record <- export_content(content = "record", format = "csv") avs_raw_core <- export_core(format = "csv") ## End(Not run) data(avs_raw_project) data(avs_raw_user) data(avs_raw_metadata) data(avs_raw_record) data(avs_raw_core) str(avs_raw_project) str(avs_raw_user) str(avs_raw_metadata) str(avs_raw_record) str(avs_raw_core) avs <- format_record(avs_raw_record, avs_raw_metadata) str(avs)
Export specific data elements from REDCap
export_content(content, uri = NULL, token = NULL, format = NULL, ...)
export_content(content, uri = NULL, token = NULL, format = NULL, ...)
content |
The element to export, see Details. |
uri |
The URI for the REDCap API. If |
token |
The API token for the project you want to export from. If
|
format |
The format to return. If |
... |
additional arguments passed to |
The content
and format
arguments are used to control the
specific items to be exported, and in what format. **Review the API
documentation**
The uri
, token
, and format
arguments are set to
NULL
by default and will look to the
Sys.getenv("REDCap_API_URI")
,
Sys.getenv("REDCap_API_TOKEN")
, and
Sys.getenv("REDCap_API_format")
, respectively, to define the values if
not explicitly done so by the end user.
The raw return from the REDCap API with the class
rcer_raw_<content>
.
# A reproducible example would require a REDCap project, accessable via an # API token. An example of the return from these calls are provided as data # with this package. # avs_raw_metadata <- export_content(content = "metadata") data(avs_raw_metadata) str(avs_raw_metadata)
# A reproducible example would require a REDCap project, accessable via an # API token. An example of the return from these calls are provided as data # with this package. # avs_raw_metadata <- export_content(content = "metadata") data(avs_raw_metadata) str(avs_raw_metadata)
Export Core Contents of a REDCap Project.
export_core(uri = NULL, token = NULL, format = NULL, verbose = TRUE, ...)
export_core(uri = NULL, token = NULL, format = NULL, verbose = TRUE, ...)
uri |
The URI for the REDCap API. If |
token |
The API token for the project you want to export from. If
|
format |
The format to return. If |
verbose |
provide messages to tell the user what is happening |
... |
not currently used |
A rcer_rccore
object: a list with the project info, metadata,
user table, and records, all in a "raw" format direct from the API.
# A reproducible example would require a REDCap project, accessable via an # API token. An example of the return from these calls are provided as data # with this package. # avs_raw_core <- export_core() data(avs_raw_core) str(avs_raw_core)
# A reproducible example would require a REDCap project, accessable via an # API token. An example of the return from these calls are provided as data # with this package. # avs_raw_core <- export_core() data(avs_raw_core) str(avs_raw_core)
Use REDCap project metadata to build a well formatted data.frame
for
the record.
format_record(x, metadata = NULL, col_type = NULL, ...)
format_record(x, metadata = NULL, col_type = NULL, ...)
x |
a |
metadata |
a |
col_type |
a |
... |
other arguments passed to |
A data.frame
export_core
, export_content
, vignette("formatting", package = "REDCapExporter")
data("avs_raw_metadata") data("avs_raw_record") # Formatting the record can be called in different ways and the same result # will be generated identical( format_record(avs_raw_record, avs_raw_metadata), format_record(avs_raw_core) ) avs <- format_record(avs_raw_record, avs_raw_metadata) avs
data("avs_raw_metadata") data("avs_raw_record") # Formatting the record can be called in different ways and the same result # will be generated identical( format_record(avs_raw_record, avs_raw_metadata), format_record(avs_raw_core) ) avs <- format_record(avs_raw_record, avs_raw_metadata) avs
Read raw REDCap API return. Built to parse csv or json.
read_text(x)
read_text(x)
x |
the raw return from the API call to REDCap |
This is a non-exported function and not expected to be called by the end
user. Used by the as.data.frame
methods.
a data.frame
Tools for checking for, and setting up, a file based keyring for storing REDCap API tokens.
REDCapExporter_keyring_check(keyring = "REDCapExporter", password = NULL) REDCapExporter_add_api_token( project, keyring = "REDCapExporter", user = NULL, password = NULL, overwrite = FALSE ) REDCapExporter_get_api_token( project, keyring = "REDCapExporter", user = NULL, password = NULL )
REDCapExporter_keyring_check(keyring = "REDCapExporter", password = NULL) REDCapExporter_add_api_token( project, keyring = "REDCapExporter", user = NULL, password = NULL, overwrite = FALSE ) REDCapExporter_get_api_token( project, keyring = "REDCapExporter", user = NULL, password = NULL )
keyring |
a character vector identifying the name of the keyring,
defaults to |
password |
This is the password for the keyring. The default is an empty password. |
project |
the name of the REDCap project the API token is identified by. |
user |
user name to associate the token with. Defaults to
|
overwrite |
logical, if |
REDCapExporter_keyring_check
returns TRUE
, invisibly,
as does REDCapExporter_add_api_token
.
REDCapExporter_get_api_token
returns the token invisibly as not to
print the value to the console by default. Still, be careful with your
token.
vignette(topic = "api", package = "REDCapExporter")
## Not run: # Check if a keyring exisits. If it does not, create one. REDCapExporter_keyring_check() # add token if it does not already exist. If a token # already exists, then you will be told so unless overwrite is set to TRUE REDCapExporter_add_api_token("Project1") # get a token and set as an envrionmental variable Sys.setenv(REDCap_API_TOKEN = REDCapExporter_get_api_token("Project1")) ## End(Not run)
## Not run: # Check if a keyring exisits. If it does not, create one. REDCapExporter_keyring_check() # add token if it does not already exist. If a token # already exists, then you will be told so unless overwrite is set to TRUE REDCapExporter_add_api_token("Project1") # get a token and set as an envrionmental variable Sys.setenv(REDCap_API_TOKEN = REDCapExporter_get_api_token("Project1")) ## End(Not run)
Create the DESCRIPTION file for the R Data package based on an Exported REDCap Project
write_description_file(access_time, user, roles, project_info, path) write_authors(user, roles = NULL)
write_description_file(access_time, user, roles, project_info, path) write_authors(user, roles = NULL)
access_time |
The |
user |
User(s), as noted in the REDCap project meta data. This parameter is singular as it refers to the "user" content one can access from the REDCap API. |
roles |
roles the |
project_info |
project metadata |
path |
path to the root for the generated R data package. |
This is a non-exported function and is not expected to be called by the end user.
write_description_file
creates the DESCRIPTION file for the
exported R data package and write_authors
creates the "Authors@R"
field of the DESCRIPTION based on the "user" data extracted from the REDCap
project.