R/install_r.R

Defines functions .install_mac_r .install_win_r .download_r .find_win_exe_url install_r

Documented in .download_r .find_win_exe_url .install_mac_r install_r .install_win_r

#' Install R from MRAN date into electricShine folder
#'
#' @param cran_like_url CRAN-like url e.g. https://cran.r-project.org/bin/windows/base
#' @param app_root_path path to current electricShine app build
#' @param mac_url mac R installer url
#' @param permission_to_install have permission to install R?
#'
#' @export
#'
install_r <- function(cran_like_url = NULL,
                      app_root_path,
                      mac_url = "https://mac.r-project.org/el-capitan/R-3.6-branch/R-3.6-branch-el-capitan-sa-x86_64.tar.gz",
                      permission_to_install  = FALSE){
  
  
  
  if (permission_to_install == FALSE) {
    
    permission_to_install <- .prompt_install_r(app_root_path)
    
  }
  
  if (permission_to_install == FALSE) {
    message("R is bundled into the electricShine app. electrify() requires this to be accepted, 
            otherwise steps to build the app must be run individually.")
  } else {
    
    
    
    os <- electricShine::get_os()
    
    app_root_path <- normalizePath(app_root_path,
                                   winslash = "/",
                                   mustWork = FALSE)
    # Make NULL here so can check if not null later
    rlang_path <- NULL
    
    if (identical(os, "mac")) {
      rlang_path <- .install_mac_r(app_root_path = app_root_path,
                                   mac_url = mac_url)
    }
    
    if (identical(os, "win")) {
      
      win_url <- .find_win_exe_url(cran_like_url = cran_like_url)
      
      win_installer_path <- .download_r(d_url = win_url)
      
      rlang_path <- .install_win_r(win_installer_path,
                                   app_root_path)
      
      rlang_path <- base::file.path(rlang_path,
                                    "bin",
                                    fsep = "/")
    }
    
    # Check that Rscript is present (ie R at least probably installed)
    # TODO: Mod this check to a system call that checks if R is functional (see testthat tests for install_r())
    if (length(list.files(rlang_path,
                          pattern = "Rscript")) != 1L) {
      stop("R install didn't work as expected.")
    } 
    
    return(rlang_path)
    
  }
}


#' Find Windows R installer URL from MRAN snapshot
#'
#' @param cran_like_url  url to cran-like repository
#'
#' @return url for Windows R installer  
#'
.find_win_exe_url <- function(cran_like_url = NULL){
  
  
  baseUrl <-  file.path(cran_like_url,
                        "bin",
                        "windows",
                        "base")
  
  # Read snapshot html
  readCran <- base::readLines(baseUrl,
                              warn = FALSE)
  
  # Find the name of the windows exe
  filename <- base::regexpr("R-[0-9.]+.+-win\\.exe", readCran)
  filename <- base::regmatches(readCran, filename)
  
  if (base::regexpr("R-[0-9.]+.+-win\\.exe", filename)[[1]] != 1L) {
    stop("Was unable to resolve url of R.exe installer for Windows.") 
  }
  
  # Construct the url of the download
  win_exe_url <- base::file.path(baseUrl, 
                                 filename,
                                 fsep = "/")
  
  return(win_exe_url)
}



#' Download R installer given its url
#'
#' @param d_url download file from url
#'
#' @return Path to R.exe installer
.download_r <- function(d_url) {
  
  installer_filename <- basename(d_url)
  download_path <- base::file.path(tempdir(), 
                                   installer_filename,
                                   fsep = "/")
  utils::download.file(url = d_url, 
                       destfile = download_path, 
                       mode = "wb")
  return(download_path)
}




#' Install R for Windows at given path
#'
#' @param win_installer_path path of Windows R installer 
#' @param app_root_path top level of new electricShine app build
#'
#' @return NA, installs R to path

.install_win_r <- function(win_installer_path,
                           app_root_path){
  
  # create the path R installer will install to
  install_r_to_path <- base::file.path(app_root_path, 
                                       "app",
                                       fsep = "/")
  base::dir.create(install_r_to_path)
  
  install_r_to_path <- base::file.path(app_root_path, 
                                       "app",
                                       "r_lang",
                                       fsep = "/")

  base::dir.create(install_r_to_path)
  
  # Quote path in case user's path has spaces, etc
  quoted_install_r_to_path <- base::shQuote(install_r_to_path)
  quoted_win_installer_path <- base::shQuote(win_installer_path)
  
  # install R
  base::system(glue::glue("{quoted_win_installer_path} /SILENT /DIR={quoted_install_r_to_path}"))
  
  return(install_r_to_path)
}



#' Download and untar mac R into app folder
#'
#' @param app_root_path top level of new electricShine app build
#' @param mac_url url for mac R language download
#'
#' @return NA
.install_mac_r <- function(app_root_path,
                           mac_url){
  os <- electricShine::get_os()
  
  installer_path <- .download_r(mac_url)
  # path R installer will install to
  install_r_to_path <- base::file.path(app_root_path, 
                                       "app",
                                       "r_lang",
                                       fsep = "/")
  
  # untar files to the app folder
  utils::untar(tarfile = installer_path, 
               exdir = install_r_to_path)
  
  if (identical(os, "mac")) {
    
    r_executable_path <- file.path(app_root_path, 
                                   "app/r_lang/Library/Frameworks/R.framework/Versions")
    r_executable_path <- list.dirs(r_executable_path, 
                                   recursive = FALSE)[[1]]
    r_executable_path <- file.path(r_executable_path,
                                   "Resources/bin/R", 
                                   fsep = "/")
    electricShine::modify_mac_r(r_executable_path)
  }    
  
  return(dirname(r_executable_path))
  
}
chasemc/electricShine documentation built on Oct. 12, 2022, 8:50 a.m.