pin_versions()
lists available versions a pin.pin_versions_prune()
deletes old versions.pin_version_delete()
deletes a single version.
Usage
pin_versions(board, name, ...)
pin_version_delete(board, name, version, ...)
pin_versions_prune(board, name, n = NULL, days = NULL, ...)
Arguments
- board, name
A pair of board and pin name. For modern boards, use
board %>% pin_versions(name)
. For backward compatibility with the legacy API, you can also usepin_versions(name)
orpin_version(name, board)
.- ...
Additional arguments passed on to methods for a specific board.
- version
Version identifier.
- n, days
Pick one of
n
ordays
to choose how many versions to keep.n = 3
will keep the last three versions,days = 14
will keep all the versions created in the 14 days. Regardless of what values you set,pin_versions_prune()
will never delete the most recent version.
Examples
board <- board_temp(versioned = TRUE)
board %>% pin_write(data.frame(x = 1:5), name = "df")
#> Guessing `type = 'rds'`
#> Creating new version '20241213T233103Z-2950a'
#> Writing to pin 'df'
board %>% pin_write(data.frame(x = 2:6), name = "df")
#> Guessing `type = 'rds'`
#> Creating new version '20241213T233103Z-f19bb'
#> Writing to pin 'df'
board %>% pin_write(data.frame(x = 3:7), name = "df")
#> Guessing `type = 'rds'`
#> Creating new version '20241213T233103Z-a6b98'
#> Writing to pin 'df'
# pin_read() returns the latest version by default
board %>% pin_read("df")
#> x
#> 1 2
#> 2 3
#> 3 4
#> 4 5
#> 5 6
# but you can return earlier versions if needed
board %>% pin_versions("df")
#> # A tibble: 3 × 3
#> version created hash
#> <chr> <dttm> <chr>
#> 1 20241213T233103Z-2950a 2024-12-13 23:31:03 2950a
#> 2 20241213T233103Z-a6b98 2024-12-13 23:31:03 a6b98
#> 3 20241213T233103Z-f19bb 2024-12-13 23:31:03 f19bb
ver <- pin_versions(board, "df")$version[[1]]
board %>% pin_read("df", version = ver)
#> x
#> 1 1
#> 2 2
#> 3 3
#> 4 4
#> 5 5
# delete all versions created more than 30 days ago
board %>% pin_versions_prune("df", days = 30)
#> No old versions to delete