An iOS app designed using Clean Architecture and MVVM. Each layer of the architecture has a Source Level Boundary, created with the Boundaries framework.
This is an example of an Appstore application, which fetches the data using the service https://itunes.apple.com/us/rss/topfreeapplications/limit=20/json, the data is stored locally on the app providing offline support. The app processes the data by categories with a UI that mimics the real app. This is an universal app showing the apps on a Grid for the iPad and on a list for the iPhone.
The code is divided in 3 layers, Core, ViewModel and View. The Core is structured following the main premises of Clean Architecture. The app follows the dependency inversion principle using the protocol oriented approach that Swift has on its foundations. The app has unit test for each layer.
On this layer belongs all the classes which main concern is handling the data and the high level rules of the app.
On this group belongs the AppSyncData protocol which represents the data to be consumed by the app.
Services represents external agents like the web service used for getting the data and the repository in which data is stored, grouped and fetched. All the interfaces on this group are protocols, this allows mock objects to conform these protocols and being used for testing purposes on higher layers (like use cases and view models).
The code in this layer contains application specific business rules. Each use case is represented by a protocol, the internal implementation is separated from the interface. Having a protocol per Use Case enforces the Interface Segregation Principle, facilitates unit testing and enforces the architectural boundaries. The use cases are accessed via a Boundary class . The objects on this group relies on the entities and the services via a plugin and returns the data using DTOs to avoid exposing the entity layer and to model the data in a convenient way to be consumed by the App.
The objects in this layer have the responsibilities described in the MVVM architectural pattern. The ViewModels relies on the UseCases to get the data and model in a convenient way to be shown in the UI.
The objects on this layer are the UIViewControllers and the UIViews used to present the data to the user. The view controller binds the data from the ViewModels to the UI objects, for tracking changes simple closure are used. This project doesn't include any binding framework to keep this as simple as posible and avoid coupling the layers with any reactive code.
MIT License