Nothing
#' Get tweets from full archive search
#'
#' This function collects tweets by query string or strings
#' between specified date ranges.
#'
#' The function can also collect tweets by users. These may be specified alongside
#' a query string or without. When no query string is supplied, the function collects
#' all tweets by that user.
#'
#' If a filename is supplied, the function will
#' save the result as a RDS file.
#'
#' If a data path is supplied, the function will also return
#' tweet-level data in a data/ path as a series of JSONs beginning "data_";
#' while user-level data will be returned as a series of JSONs beginning "users_".
#'
#' @param query string or character vector, search query or queries
#' @param start_tweets string, starting date
#' @param end_tweets string, ending date
#' @param bearer_token string, bearer token
#' @param n integer, upper limit of tweets to be fetched
#' @param file string, name of the resulting RDS file
#' @param data_path string, if supplied, fetched data can be saved to the designated path as jsons
#' @param export_query If `TRUE`, queries are exported to data_path
#' @param bind_tweets If `TRUE`, tweets captured are bound into a data.frame for assignment
#' @param page_n integer, amount of tweets to be returned by per page
#' @param context_annotations If `TRUE`, context_annotations will be fetched. Note it will limit the page_n to 100 due restrictions of Twitter API.
#' @param verbose If `FALSE`, query progress messages are suppressed
#' @param ... arguments will be passed to [build_query()] function. See `?build_query()` for further information.
#'
#' @return When bind_tweets is `TRUE` (default), the function returns a data frame. Nothing otherwise.
#' @export
#'
#' @examples
#' \dontrun{
#' bearer_token <- "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
#'
#' get_all_tweets(query = "BLM",
#' start_tweets = "2020-01-01T00:00:00Z",
#' end_tweets = "2020-01-05T00:00:00Z",
#' bearer_token = get_bearer(),
#' data_path = "data",
#' n = 500)
#'
#' get_all_tweets(users = c("cbarrie", "jack"),
#' start_tweets = "2021-01-01T00:00:00Z",
#' end_tweets = "2021-06-01T00:00:00Z",
#' bearer_token = get_bearer(),
#' n = 1000)
#'
#' get_all_tweets(start_tweets = "2021-01-01T00:00:00Z",
#' end_tweets = "2021-06-01T00:00:00Z",
#' bearer_token = get_bearer(),
#' n = 1500,
#' conversation_id = "1392887366507970561")
#' }
get_all_tweets <-
function(query = NULL,
start_tweets,
end_tweets,
bearer_token = get_bearer(),
n = 100,
file = NULL,
data_path = NULL,
export_query = TRUE,
bind_tweets = TRUE,
page_n = 500,
context_annotations = FALSE,
verbose = TRUE,
...) {
if (missing(start_tweets)) {
stop("Start time must be specified.")
}
if (missing(end_tweets)) {
stop("End time must be specified.")
}
# Check file storage conditions
check_data_path(data_path = data_path, file = file, bind_tweets = bind_tweets, verbose = verbose)
# Build query
built_query <- build_query(query, ...)
# Building parameters for get_tweets()
params <- list(
"query" = built_query,
"max_results" = page_n,
"start_time" = start_tweets,
"end_time" = end_tweets,
"tweet.fields" = "attachments,author_id,conversation_id,created_at,entities,geo,id,in_reply_to_user_id,lang,public_metrics,possibly_sensitive,referenced_tweets,source,text,withheld",
"user.fields" = "created_at,description,entities,id,location,name,pinned_tweet_id,profile_image_url,protected,public_metrics,url,username,verified,withheld",
"expansions" = "author_id,entities.mentions.username,geo.place_id,in_reply_to_user_id,referenced_tweets.id,referenced_tweets.id.author_id",
"place.fields" = "contained_within,country,country_code,full_name,geo,id,name,place_type"
)
endpoint_url <- "https://api.twitter.com/2/tweets/search/all"
if (context_annotations){
params <- add_context_annotations(params, verbose)
}
.vcat(verbose, "query: ", params[["query"]], "\n")
# Get tweets
get_tweets(params = params, endpoint_url = endpoint_url, n = n, file = file, bearer_token = bearer_token,
export_query = export_query, data_path = data_path, bind_tweets = bind_tweets, verbose = verbose)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.