I am trying to read data from a Bigquery table into a Shiny App following Golem's framework.
This can be easily done by adding the following code before the ui and server functions in an App.R file
bq_auth(path = "xxxxxxxxxxxx.json") # authenticating biqrquery with service account json file
# Establishing connection
con <- dbConnect(
           bigrquery::bigquery(),
           project = "project id",
           dataset = "dataset name",
           billing = "project id"
)
But I am a little bit lost on how is the way to do it when using Golem.
Following this thread I created a reactiveValue() on the app_server.R file.
#' The application server-side
#' 
#' @param input,output,session Internal parameters for {shiny}. 
#'     DO NOT REMOVE.
#' @import shiny
#' @import bigrquery  
#' @noRd
app_server <- function( input, output, session ) {
# Your application server logic 
bq <- reactiveValues()
observe({
    bq$con <- dbConnect(drv = bigquery(),
                    project = "project_id",
                    dataset = "datset_id",
                    billing = "project_id")
})
}
I also imported bigrquery but this has seem to broke something as now I get the following errors when I run run_dev.R:
> golem::document_and_reload()
Loading Dashboard
Error : object ‘DBI’ is not exported by 'namespace:bigrquery'
-- Error documenting your package ----------------------------------------------------------------
> 
> # Run the application
> run_app()
Error in run_app() : could not find function "run_app"
 
                        
Here is the issue, based on your error:
Somewhere in your code, you're trying to call bigrquery::DBI(), but it's not a function from this package. Hence the error with
{golem}: you can't load everything if you have a namespace error :)You should either find this code error in :
bigrquery::DBI()importFrom(bigrquery, DBI)@importFrom bigrquery DBIRemoving this should solve the issue.
Cheers, Colin