R/emaildataleakQuery.R

#' Query dataleak database - email
#'
#' Query dataleak database for single email
#'
#' @import httr
#' @importFrom jsonlite fromJSON
#' @importFrom data.table as.data.table
#' @param email target email address
#' @param auth_token authentication token for the API. See [be_auth_token()]
#' @export
emaildataleakQuery <- function(email, auth_token = be_auth_token()) {
  content_query <- httr::GET(
    url = sprintf("https://api.binaryedge.io/v2/query/dataleaks/email/%s", email),
    httr::add_headers("X-Key" = auth_token),
    httr::user_agent(.be_ua)
  )

  httr::stop_for_status(content_query)

  raise <- httr::content(content_query, as = "text", encoding = "UTF-8")

  jsonlite::fromJSON(raise, flatten = TRUE) %>%
    data.table::as.data.table() %>%
    tidyr::unnest() %>%
    replace(. == "NULL", NA)
}

#' @rdname emaildataleakQuery
#' @export
email_data_leak_query <- emaildataleakQuery
balgan/rbinaryedge documentation built on May 5, 2019, 2:44 a.m.