Emixa Native Release Helper
Overview
Streamlining App Versioning with Emixa Native Release Helper
Introduction:
When developing native applications, having a proper release strategy is crucial in avoiding errors and compatibility issues caused by versioning problems. Introducing Emixa Native Release Helper, a powerful Mendix module designed to simplify app versioning and enhance the user experience. With this module, users are ensured to have the latest version of their application, whether it's available in the Apple App Store or Google Play Store. Additionally, it provides a seamless way to handle Over-the-Air (OTA) deployments, ensuring users stay up to date. This module was made in collaboration with Maud van den Boomen and Pim van der Noll.
Module Overview:
Emixa Native Release Helper focuses on two key aspects:
- Checking for new versions of the app in the app stores (iOS and Android).
- Monitoring new package deployments and OTA availability.
Use case:
- The snippet SN_AppVersion_GetCurrent_OnHome checks if a new OTA or app version is available in the store. This check is triggered during key events: on application load, on resume and on online.
- The flow SUB_AppVersion_CheckForUpdateOrOTA is executed during these events. Steps executed:
- Check if OTA is being executed and if the app is reloaded. If not,
- Version in store is compared with the version on device. If a new version is detected, a page is opened, displaying a button that directs the user to the appstore page for an update. This update is mandatory.
- If newer version in store is not available, check if OTA needs to be executed. If so, the user receives a message that the app will be reloaded shortly.
Documentation
Typical usage scenario
When developing native applications, having a proper release strategy is crucial in avoiding errors and compatibility issues caused by versioning problems. Introducing Emixa Native Release Helper, a powerful Mendix module designed to simplify app versioning and enhance the user experience. With this module, users are ensured to have the latest version of their application, whether it's available in the Apple App Store or Google Play Store. Additionally, it provides a seamless way to handle Over-the-Air (OTA) deployments, ensuring users stay up to date. This module was made in collaboration with Maud van den Boomen and Pim van der Noll.
Features and limitations
Emixa Native Release Helper focuses on two key aspects:
- Checking for new versions of the app in the app stores (iOS and Android).
- Monitoring new package deployments and OTA availability.
Dependencies
- Native Mobile Resources (https://marketplace.mendix.com/link/component/109513)
- Nanoflow Commons (https://docs.mendix.com/appstore/modules/nanoflow-commons/)
- Community Commons (https://marketplace.mendix.com/link/component/170/)
- Emixa Commons (https://marketplace.mendix.com/link/component/993)
Installation
- Make sure project roles are assigned to 'User' module role of ReleaseHelper_Native.
- Make sure project roles are assigned to 'Anonymous' module role of ReleaseHelper_Native.
- Make sure 'Administrator' project role is assigned to 'Administrator' module role of ReleaseHelper_Native.
- Add ASU_DeploymentData_SetLastStartupDate to after startup flow.
- Add SN_AppVersion_GetCurrent_OnHome on your homepages.
- Optional: You can adjust the flow SUB_AppVersion_CheckForUpdateOrOTA so that a page of preference is shown when update is needed.
- Add SN_BundleInStore_Overview to Admin screen.
Configuration
- SN_BundleInStore_Overview: add the bundleids of your app per operating system (Apple and/or Android).
- Enable SCE_BundleInStore_GetLatestVersion.
- Enable SCE_DeploymentData_GetLatestVersion.
- Make sure that EmixaReleaseHelper_Native.Environment is well configured.
Want to add manual check?
- Add SN_ManualVersionCheck to admin page.
- Configure the version you want users to update to and press proceed.
Testing
For testers in Test and Acceptance environments, Emixa Native Release Helper offers the SN_AppVersion_GetCurrent_ForTesting snippet. This snippet enables testers to verify if they have the latest version, including OTA deployments and app versions.
Want to test bundleID version check?
- Place the production bundleID in constant "BundleID". This will simulate version check against the BundleID of your app.