From 2af81209bae65773c2240c295057b8afd642f5cd Mon Sep 17 00:00:00 2001 From: Olivier Leroy Date: Tue, 28 May 2024 09:32:06 -0400 Subject: [PATCH] adding a way to display available data from NBM --- .github/workflows/publish.yml | 2 ++ _quarto.yml | 3 +- nbm_data.qmd | 53 +++++++++++++++++++++++++++++++++++ 3 files changed, 57 insertions(+), 1 deletion(-) create mode 100644 nbm_data.qmd diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml index 47e54cb..69a7b22 100644 --- a/.github/workflows/publish.yml +++ b/.github/workflows/publish.yml @@ -31,6 +31,8 @@ jobs: any::DT any::ggplot2 any::remotes + any::curl + any::jsonlite - name: Install package from GH run: | diff --git a/_quarto.yml b/_quarto.yml index 4388f47..5d88196 100644 --- a/_quarto.yml +++ b/_quarto.yml @@ -16,7 +16,8 @@ website: search: true contents: - section: "FCC Data" - contents: + contents: + - nbm_data.qmd - FCC_provider_list.qmd - isp_eda.qmd - fcc_funding.qmd diff --git a/nbm_data.qmd b/nbm_data.qmd new file mode 100644 index 0000000..00ee11b --- /dev/null +++ b/nbm_data.qmd @@ -0,0 +1,53 @@ +--- +title: "FCC NBM data" +date: last-modified +format: + html: + code-fold: true +engine: knitr +--- + +```{r} +#| label: utility functions +source("R/table_with_options.R") +``` + +This page will display all available data that can downloaded from FCC NBM. + +## Getting the Information about NBM Release: + +```{r} +#| label: setting URL and getting a table with release +filing_url <- "https://broadbandmap.fcc.gov/nbm/map/api/published/filing" + +# getting a list of release +get_release <- function(filing_url) { + req <- curl::curl_fetch_memory(filing_url) + release <- jsonlite::fromJSON(rawToChar(req$content))$data + return(release) +} + +release <- get_release(filing_url) +table_with_options(release) +``` + + + +```{R} +#| eval: FALSE +get_data_url <- paste0("https://broadbandmap.fcc.gov/nbm/map/api/", + "national_map_process/nbm_get_data_download/") +get_csv_to_dl <- function(release_file, release_nb) { + get_data_url_last <- paste0(get_data_url, + release_file[release_nb, "process_uuid"]) + + test <- curl_fetch_memory(get_data_url_last) + + csv_to_dl <- jsonlite::fromJSON(rawToChar(test$content))$data + return(csv_to_dl) +} + +big_list <- lapply(1:4, get_csv_to_dl, release_file = release) + +bob <- do.call(rbind, big_list) +```