Microsystems or microservices is an architecture that is particularly effective at developing large, complex, and constantly changing systems in terms of requirements.
In a mobile application development environment, it is difficult to properly implement microsystems due to technological barriers. While microsystems value independence, the components of a mobile application often operate in close cohesion. Or the fact that microsystems interact with each other dynamically and flexibly, the components of the mobile application appreciate the binding and type-safe data. However, microsystems design theories and principles can be applied in a custom way to be able to make mobile applications like microsystems. Suitable for applications with high complexity and expansion requirements.
Two principles when building microsystems architecture:
-
Eliminate and optimize component dependencies so that it becomes isolated. This makes it easy to pack a component as a package and can be shipped anywhere in the system.
-
Use a unique set of protocols to communicate with all components in the system. So a component can interact with any other component. From the outside they are completely similar and can be interchangeable without changing core business.
Boardy helps to build mobile app microsystems like in a simple way. Inspired by computer motherboards. Boardy builds a system of microsystems based on Boards. Each Board corresponds to a microsystems contained within it is a component of the mobile application, which will perform a specific task. All boards are then integrated together into one motherboard to form complete systems. The components do not interact directly with each other, but through the standard Boardy protocol suite. The core business logic is protected from change and external impact. Just changing how boards can be integrated can create a new business so changes or scaling are made easy, ensuring both maintenance and development requirements at the same time.
Important
A board should be a stateless component, it should not hold any variables that represent the state of the context. Its lifecycle is automatically managed by its Motherboard so in most cases you do not need to care when it is created or destroyed. However, although not recommended, in some cases you can still use it as a stateful component. In that case, when you're done you need to call complete() to dispose of it to free up resources.
To run the example project, clone the repo, and run pod install
from the Example directory first.
- iOS 10+
- Xcode 11+
- Swift 5.1+
Boardy is available through CocoaPods. To install it, simply add the following line to your Podfile:
pod 'Boardy'
Install subspecs for more features:
# Utilities toolkit
pod 'Boardy/ComponentKit'
# Modularization
pod 'Boardy/ModulePlugin'
# Build a complex UI using Boardy
pod 'Boardy/Composable'
- Run script built-in CocoaPods.Boardy
sh Pods/Boardy/tools/install-template.sh
- Create new module using Boardy
cd submodules/YourEmptyModuleDirectory
sh ../../Pods/Boardy/tools/init-module.sh YourModuleName
The script should create 2 modules:
- YourModuleName: Interface-only module which will be used for communicate with other microservices via public protocols (such as ServiceMap or public IOInterface).
- YourModuleNamePlugins: Implementation module which includes internal microservices that implement protocols in the Interface module and and module plugins for integration into the main app.
- Microsystems for mobile app
- Boardy Modularization
- Handle URL opening / deep link
- Configure Activation Barrier for your Board
- Boardy ComponentKit
congncif, [email protected]
Boardy is available under the MIT license. See the LICENSE file for more info.