Swiftpack.co - ralfebert/MiniCache as Swift Package

Swiftpack.co is a collection of thousands of indexed Swift packages. Search packages.
See all packages published by ralfebert.
ralfebert/MiniCache 0.6.0
A persistent key/value cache for Codable values.
⭐️ 0
🕓 1 year ago
iOS macOS
.package(url: "https://github.com/ralfebert/MiniCache.git", from: "0.6.0")

MiniCache

A persistent key/value cache for Codable values.

Creating a cache manager

let cacheManager = MiniCacheManager(name: "MiniCache")

To define a global cache manager for your app, you could define a static shared property:

extension MiniCacheManager {
    static let shared = MiniCacheManager(name: "MiniCache")
}

Creating a cache

To create a cache, declare a MiniCache<Key, Value> and initialize it using the cache manager:

let cache: MiniCache<String, Int> = self.cacheManager.cache(cacheName: "Counter", cacheVersion: .appVersion, maxAge: .days(7))

Any type that is conform to Codable can be used as Key/Value type.

Accessing cache values

Writing:

cache["foo"] = 1

Reading:

let value = cache["foo"]

Cache expiry by version

When creating a cache, you can specify a cache version. When the cache is accessed, all entries that don't match the cache version, are automatically cleared. This can be used to prevent data from older versions of the app being read in newer versions. Valid values:

  • .appVersion: The app version and build number as defined in your Info.plist file is used as cache version. So whenever a cache is accessed from a new app version, the cache is cleared automatically.
  • .custom: A custom version string that you need to change manually when you change something about the Codable types used for caching that's incompatible to old cache entries.

Cache expiry by age

For every cache, you need to define a maxAge that configures how long cache entries stay valid:

  • maxAge: .days(7)
  • maxAge: .hours(1)
  • maxAge: .timeInterval(1000)

Thread safety

Only the thread that creates the MiniCacheManager is allowed to use it. When compiled with DEBUG, when this rule is violated, this is a fatalError, when compiled without DEBUG, an error will be logged.

Error handling

  • When a cache value cannot be decoded, nil is returned and an error is logged.
  • When the cache database cannot be opened, the database file is removed to recover.
  • All other (unexpected) errors will be a fatalError when compiled with DEBUG and a error log entry otherwise.

Internal storage

Core Data is used internally to implement the persistent cache storage. This is an implementation detail, nothing of Core Data is exposed to the outside. All data from a MiniCacheManager will be persisted in the app Caches directory in a file [name].sqlite.

GitHub

link
Stars: 0
Last commit: 1 year ago
Advertisement: IndiePitcher.com - Cold Email Software for Startups

Swiftpack is being maintained by Petr Pavlik | @ptrpavlik | @swiftpackco | API | Analytics