R/create_journal_citation.R

Defines functions create_journal_citation

Documented in create_journal_citation

#' Create journal citation
#'
#' @param packageId (character) Data package identifier
#' @param articleDoi (character) Article DOI. Required if \code{articleUrl} is
#' missing.
#' @param articleUrl (character) Article URL. Required if \code{articleDoi} is
#' missing.
#' @param articleTitle (character) Article title
#' @param journalTitle (character) Journal title
#' @param relationType (character) Relation between citation and data package.
#' Can be: "IsCitedBy" this data package is formally cited in the manuscript;
#' "IsDescribedBy" - this data package is explicitly described within the
#' manuscript; "IsReferencedBy" - this data package is implicitly described
#' within the manuscript.
#' @param env (character) Repository environment. Can be: "production",
#' "staging", or "development".
#'
#' @return (numeric) Journal citation identifier
#'
#' @details Creates a new journal citation entry in the EDI data repository
#'
#' @note User authentication is required (see \code{login()})
#' 
#' @family Journal Citations
#'
#' @export
#'
#' @examples
#' \dontrun{
#'
#' login()
#'
#' # Create journal citation
#' journalCitationId <- create_journal_citation(
#'   packageId = "edi.17.1",
#'   articleDoi = "10.1890/11-1026.1",
#'   articleTitle = "Corridors promote fire via connectivity and edge effects",
#'   journalTitle = "Ecological Applications",
#'   relationType = "IsCitedBy",
#'   env = "staging"
#' )
#' journalCitationId
#' #> [1] 74
#'
#' # Delete journal citation
#' delete_journal_citation(journalCitationId, env = "staging")
#' #> [1] TRUE
#'
#' logout()
#' }
#'
create_journal_citation <- function(packageId,
                                    articleDoi = NULL,
                                    articleUrl = NULL,
                                    articleTitle = NULL,
                                    journalTitle = NULL,
                                    relationType,
                                    env = "production") {
  if (is.null(c(articleDoi, articleUrl))) {
    stop('One of "articleDoi" or "articleUrl" is required.', call. = FALSE)
  }
  # Build citation
  citation <- xml2::xml_new_document()
  xml2::xml_add_child(citation, "journalCitation")
  xml2::xml_add_child(citation, "packageId", packageId)
  if (!is.null(articleDoi)) {
    xml2::xml_add_child(citation, "articleDoi", articleDoi)
  }
  if (!is.null(articleUrl)) {
    xml2::xml_add_child(citation, "articleUrl", articleUrl)
  }
  if (!is.null(articleTitle)) {
    xml2::xml_add_child(citation, "articleTitle", articleTitle)
  }
  xml2::xml_add_child(citation, "relationType", relationType)
  fname <- paste0(tempdir(), "/payload.xml")
  xml2::write_xml(citation, fname)
  on.exit(file.remove(fname))
  # Submit request
  url <- paste0(base_url(env), "/package/citation/eml")
  cookie <- bake_cookie()
  resp <- httr::POST(
    url,
    set_user_agent(),
    cookie,
    body = httr::upload_file(fname),
    handle = httr::handle("")
  )
  msg <- httr::content(resp, as = "text", encoding = "UTF-8")
  httr::stop_for_status(resp, msg)
  parsed <- unlist(strsplit(resp$headers$location, split = "/"))
  res <- parsed[length(parsed)]
  return(as.numeric(res))
}
ropensci/EDIutils documentation built on Oct. 19, 2023, 7:21 p.m.