-
Notifications
You must be signed in to change notification settings - Fork 58
Expand file tree
/
Copy pathcache_gcs.R
More file actions
89 lines (77 loc) · 2.52 KB
/
cache_gcs.R
File metadata and controls
89 lines (77 loc) · 2.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#' Google Cloud Storage Cache
#' Google Cloud Storage backed cache, for remote caching.
#'
#' @examples
#'
#' \dontrun{
#' library(googleCloudStorageR)
#' # Set GCS credentials.
#' Sys.setenv("GCS_AUTH_FILE"="<google-service-json>",
#' "GCS_DEFAULT_BUCKET"="unique-bucket-name")
#'
#' gcs <- cache_gcs("unique-bucket-name")
#' mem_runif <- memoise(runif, cache = gcs)
#' }
#'
#'
#' @param cache_name Bucket name for storing cache files.
#' @param compress Argument passed to \code{saveRDS}. One of FALSE, "gzip",
#' "bzip2" or "xz". Default: FALSE.
#' @inheritParams cache_memory
#' @export
cache_gcs <- function(cache_name = googleCloudStorageR::gcs_get_global_bucket(),
algo = "sha512", compress = FALSE) {
if (!(requireNamespace("digest"))) { stop("Package `digest` must be installed for `cache_gcs()`.") } # nocov
if (!(requireNamespace("googleCloudStorageR"))) { stop("Package `googleCloudStorageR` must be installed for `cache_gcs()`.") } # nocov
path <- tempfile("memoise-")
dir.create(path)
cache_reset <- function() {
keys <- cache_keys()
lapply(keys, googleCloudStorageR::gcs_delete_object, bucket = cache_name)
}
cache_set <- function(key, value) {
temp_file <- file.path(path, key)
on.exit(unlink(temp_file))
saveRDS(value, file = temp_file, compress = compress)
suppressMessages(
googleCloudStorageR::gcs_upload(temp_file, name = key, bucket = cache_name)
)
}
cache_get <- function(key) {
temp_file <- file.path(path, key)
suppressMessages(
googleCloudStorageR::gcs_get_object(key,
bucket = cache_name,
saveToDisk = temp_file,
overwrite = TRUE)
)
readRDS(temp_file)
}
cache_has_key <- function(key) {
objs <- suppressMessages(
googleCloudStorageR::gcs_list_objects(prefix = key, bucket = cache_name)
)
is_here <- objs$name == key
# if not result is logical(0)
if(identical(is_here, logical(0))){
is_here <- FALSE
}
is_here
}
cache_drop_key <- function(key) {
googleCloudStorageR::gcs_delete_object(key, bucket = cache_name)
}
cache_keys <- function() {
items <- googleCloudStorageR::gcs_list_objects(bucket = cache_name)
items$name
}
list(
digest = function(...) digest::digest(..., algo = algo),
reset = cache_reset,
set = cache_set,
get = cache_get,
has_key = cache_has_key,
drop_key = cache_drop_key,
keys = cache_keys
)
}