R/authorize_mooc_app.R

Defines functions is_didactr_authorized didactr_token check_didactr_auth didactr_auth mooc_app

Documented in check_didactr_auth didactr_auth didactr_token is_didactr_authorized

mooc_app = function() {
  httr::oauth_app(
    appname = "mooc-generator",
    key = "1083647771778-kg3v64gmmc727gdgrrq9dprjsaffeln2.apps.googleusercontent.com",
    secret = "i6qZqu8iGVpER08p0W2DQ2m4",
    redirect_uri = "http://localhost:1410/"
  )
}


#' Authorize Application for didactr
#'
#' @param cache A logical value or a string. \code{TRUE} means to cache
#' using the default cache file \code{.httr-oauth}
#' @param use_oob use a local webserver for the OAuth dance
#' @param token_file If the \code{token} has been saved, use this file
#' to load the credentials.
#' @param language Should the language API be authorized
#' using your token (experimental, and most likely doesn't work)
#' @param token you can pass the token directly instead of the file
#' if you want
#'
#' @return The auth token, a Token class.
#' @export
#'
#' @importFrom httr oauth_endpoints oauth2.0_token
#' @importFrom googledrive drive_auth
#' @importFrom rgoogleslides authorize
#' @importFrom methods formalArgs
#' @examples \dontrun{
#' didactr_auth()
#' }
didactr_auth = function(
  token_file = NULL,
  cache = FALSE,
  language = FALSE,
  use_oob = FALSE,
  token = NULL) {

  if (is.null(token_file)) {
    token_file = tempfile(fileext = ".rds")
  }
  if (is.null(token)) {
    if (!file.exists(token_file)) {
      scope = c("https://www.googleapis.com/auth/drive",
                "https://www.googleapis.com/auth/youtube.force-ssl",
                "https://www.googleapis.com/auth/presentations")
      if (language) {
        scope = c(scope,
                  "https://www.googleapis.com/auth/cloud-language",
                  "https://www.googleapis.com/auth/cloud-platform")
      }
      token <- httr::oauth2.0_token(
        endpoint = httr::oauth_endpoints("google"),
        app = mooc_app(),
        scope = scope,
        cache = cache,
        use_oob = use_oob)
    } else {
      token = readRDS(token_file)
    }
  }

  # for tuber
  options(google_token = token)
  if (!file.exists(token_file)) {
    saveRDS(token, token_file)
  }
  if ("oauth_token" %in% methods::formalArgs(googledrive::drive_auth)) {
    drive_args = list(oauth_token = token_file)
    # googledrive::drive_auth(oauth_token = token_file)
  } else {
    drive_args = list(token = token)
    # googledrive::drive_auth(token = token)
  }
  do.call(googledrive::drive_auth, args = drive_args)
  rgoogleslides::authorize(token = token)
  if (language) {
    options(googleAuthR.client_id =  mooc_app()$key,
            googleAuthR.client_secret =  mooc_app()$secret)
    googleAuthR::gar_auth(token = token)
  }
  return(invisible(token))
}


#' @param ... Arguments passed to \code{\link{didactr_auth}}
#' @rdname didactr_auth
#' @export
check_didactr_auth = function(...) {
  token = didactr_token(...)
  return(is.Token(token))
}

#' @rdname didactr_auth
#' @export
didactr_token = function(...) {
  suppressMessages(didactr_gl_auth())
  token = getOption("google_token")
  if (is.Token(token)) {
    appname = token$app$appname
    if (appname != mooc_app()$appname) {
      token = didactr_auth(...)
    }
    args = list(...)
    token_file = args$token_file
    if (is.null(token_file)) {
      token_file = tempfile(fileext = ".rds")
    }
    saveRDS(token, token_file)
    if ("oauth_token" %in% formalArgs(googledrive::drive_auth)) {
      googledrive::drive_auth(oauth_token = token_file)
    } else {
      googledrive::drive_auth(token = token)
    }
    rgoogleslides::authorize(token = token)
    if (!is.null(args$language)) {
      if (args$language) {
        options(googleAuthR.client_id =  mooc_app()$key,
                googleAuthR.client_secret =  mooc_app()$secret)
        googleAuthR::gar_auth(token = token)
      }
    }
  } else {
    token = didactr_auth(...)
  }
  return(token)
}

#' @rdname didactr_auth
#' @export
is_didactr_authorized = function() {
  token = getOption("google_token")
  if (!is.Token(token)) {
    return(FALSE)
  }
  appname = token$app$appname
  return(appname == mooc_app()$appname)
}
muschellij2/didactr documentation built on March 17, 2021, 12:45 p.m.