HACachesContainer
public class HACachesContainer
Container for caches
You can create your own cache accessible in this container like so:
Create a key to represent your cache:
struct YourValueTypeKey: HACacheKey {
func create(connection: HAConnection) -> HACache<YourValueType> {
return HACache(connection: connection, populate: …, subscribe: …)
}
}
Add a convenience getter to the container itself:
extension HACachesContainer {
var yourValueType: HACache<YourValueType> { self[YourValueTypeKey.self] }
}
Then, access it from a connection like connection.caches.yourValueType
.
-
Create the caches container
It is not intended that this is accessible outside of the library itself, since we do not make guarantees around its lifecycle. However, to make it easier to write e.g. a mock connection class, it is made available.
Declaration
Swift
public init(connection: HAConnection)
Parameters
connection
The connection to create using
-
Get a cache by its key
See also
HACachesContainer
class description for how to use keys to retrieve caches.- Subscript: The key to look up
Declaration
Swift
public subscript<KeyType>(key: KeyType.Type, data: [String : Any] = [:]) -> HACache<KeyType.Value> where KeyType : HACacheKey { get }
Return Value
Either the existing cache for the key, or a new one created on-the-fly if none was available
-
Cache of entity states, see
HACachedStates
for values.Declaration
Swift
func states(_ data: [String : Any] = [:]) -> HACache<HACachedStates>
Parameters
data
The data passed to connection request
Return Value
The cache object with states
-
Cache of the current user.
Declaration
Swift
var user: HACache<HAResponseCurrentUser> { get }