Data sources for vitae

Using data to dynamically build your Résumé or CV makes many powerful integrations possible. By using data to populate entries in the document, it becomes easy to manipulate and select relevant experiences for a particular application. There are many sources of data which can be used to populate a CV with vitae, some commonly sources are summarised in this vignette.

The main purpose of sourcing your CV entries from common data sources is to extend the “do not repeat yourself” programming philosophy to maintaining a CV. If you maintain publications on ORCID you shouldn’t need to repeat these entries in your CV. If a list of talks you’ve made can be found on your website, avoid repeating the list in multiple locations to ensure that they both contain the same content.

This vignette is far from comprehensive, and there are no doubt many other interesting ways to populate your CV with data. If you’re using a data source that you think others should know about, consider making a pull request that adds your method to this vignette.

The simplest source of entries for vitae are maintained dataset(s) of past experiences and achievements. Just like any dataset, these entries can be loaded into the document as a data.frame or tibble using functions from base R or the readr package.

readr::read_csv("employment.csv") %>%
detailed_entries(???)

It is also possible to load in data from excel using the readxl package or from Google Sheets using the googlesheets package.

readxl::read_excel("awards.xlsx") %>%
brief_entries(???)

ORCID

If you maintain an ORCID profile, this information can be accessed using the rorcid package. It will require an ORCID authentication token to be setup, as rendering the CV is done non-interactively. From the rorcid documentation:

The token is a alphanumeric UUID, e.g. dc0a6b6b-b4d4-4276-bc89-78c1e9ede56e. You can get this token by running orcid_auth(), then storing that key (the uuid alone, not the “Bearer” part) either as en environment variable in your .Renviron file in your home directory, or as an R option in your .Rprofile file. See ?Startup for more information. Either an environment variable or R option work. If we don’t find either we do the next option.

Essentially, use rorcid::orcid_auth() to obtain a token, which is added to either the .Renviron (usethis::edit_r_environ()) or .Rprofile (usethis::edit_r_profile()) using ORCID_TOKEN=<YOUR TOKEN HERE>.

With the token setup, it is now possible to pull data from ORCID. As an example, here I source and display my education history using my ORCID ID of "0000-0001-6729-7695".

edu <- do.call("rbind",
rorcid::orcid_educations("0000-0001-6729-7695")$0000-0001-6729-7695$affiliation-group$summaries ) edu %>% detailed_entries( what = education-summary.role-title, when = glue::glue("{education-summary.start-date.year.value} - {education-summary.end-date.year.value}"), with = education-summary.organization.name, where = education-summary.organization.address.city ) Google scholar Google Scholar does not require authentication to extract publications. Using the scholar package, it is easy to extract a user’s publications from their Google Scholar ID. To obtain publications for an individual, you would first find your ID which is accessible from your profile URL. For example, Rob Hyndman’s ID would be "vamErfkAAAAJ" (https://scholar.google.com/citations?user=vamErfkAAAAJ&hl=en). scholar::get_publications("vamErfkAAAAJ") %>% detailed_entries( what = title, when = year, with = author, where = journal, why = cites ) Bibliography files The vitae package directly supports loading *.bib files using the bibliography_entries() function, which formats the entries in a bibliography style. bibliography_entries("publications.bib") It is also possible to display the contents of your bibliography using template specific entries formats. bibliography_entries("publications.bib") %>% detailed_entries(???) R packages A list of R packages that you have helped develop can be obtained using the pkgsearch package. pkgsearch::ps("O'Hara-Wild",size = 100) %>% filter(map_lgl(package_data, ~ grepl("Mitchell O'Hara-Wild", .x$Author, fixed = TRUE))) %>%
as_tibble() %>%
brief_entries(
what = title,
when = lubridate::year(date),
with = description
)