R/get_all_committees.R

Defines functions get_all_committees

Documented in get_all_committees

#' Parliamentary committees over all sessions
#'
#' @description Imports data on all committee names and ids over all sessions
#' in the data.stortinget.no API.
#'
#' @usage get_all_committees()
#'
#'
#' @return A data frame of committees, with the variables:
#'
#' |                   |                           |
#' |:------------------|:--------------------------|
#' | **response_date** | Date of data retrieval    |
#' | **version**       | Data version from the API |
#' | **id**            | Id of the committee       |
#' | **name**          | Name of the committee     |
#' | **sessionid**     | Id of session (empty)     |
#'
#' @md
#'
#' @seealso [get_session_committees]
#'
#'
#' @examples
#' \dontrun{
#' coms <- get_all_committees()
#' head(coms)
#' }
#'
#' @import httr rvest
#' @export
get_all_committees <- function(){

  url <- "https://data.stortinget.no/eksport/allekomiteer"

  base <- GET(url)

  resp <- http_type(base)
  if(resp != "text/xml") stop(paste0("Response of ", url, " is not text/xml."), call. = FALSE)

  status <- http_status(base)
  if(status$category != "Success") stop(paste0("Response of ", url, " returned as '", status$message, "'"), call. = FALSE)

  tmp <- read_html(base)


  tmp <- data.frame(response_date = tmp %>% html_elements("komiteer_liste > komite > respons_dato_tid") %>% html_text(),
                    version = tmp %>% html_elements("komiteer_liste > komite > versjon") %>% html_text(),
                    id = tmp %>% html_elements("komiteer_liste > komite > id") %>% html_text(),
                    name = tmp %>% html_elements("komiteer_liste > komite > navn") %>% html_text(),
                    sessionid = tmp %>% html_elements("sesjon_id") %>% html_text())

  return(tmp)

}

Try the stortingscrape package in your browser

Any scripts or data that you put into this service are public.

stortingscrape documentation built on March 31, 2023, 10:30 p.m.