Skip to content

Latest commit

 

History

History
32 lines (19 loc) · 2.03 KB

STORAGE.md

File metadata and controls

32 lines (19 loc) · 2.03 KB

Storage

This module encapsulates the local persistence layer, and provides an implementation of that persistence layer based on CoreData.

High level class diagram

Storage high level class diagram

Public interface

The Storage module exposes its functionality via the StorageManagerType protocol.

This protocol declares getters to StorageType and methods to save or perform an operation on a StorageType

The CoreData stack

The default implementation of the StorageManagerType and StorageType protocols is based on CoreData.

StorageManagerType is implemented by the CoreDataManager class. As the name implies, this class manages a CoreData stack, aggregating a NSPersistentContainer.

When clients of this class request a StorageType, CoreDataManager will return an NSManagedObjectContext.

When CoreDataManager is requested a viewContext, it will provide the persistent container’s viewContext . When it is requested a newDerivedStorage it will return a new child context with a private dispatch queue.

File storage

The Storage module also exposes a protocol, called FileStorage to abstract saving and reading data to and from local storage.

The default implementation of this protocol, PListFileStorage provides support for .plist files.

File storage is used mostly for local app settings.

Model objects

This module also provides extensions to make the model objects declared in the Networking module coredata-compliant.

That is achieved by extending the model objects declared in Networking to make them extend NSManagedObject and provide @NSManaged properties and CoreData compliant accessors to some of those properties. Those extensions can be generated directly inside Xcode.