Building Android apps with Genero
Genero provides a command-line tool to create applications for Android™ devices.
Basics
- AAB packages can by published on the Google Play Store. To install the app from an AAB package onto your development device or emulator, you need the bundletool utility.
- APK packages (the former package format) can installed onto your development device or emulator. APK packages cannot be uploaded to the Google Play Store.
Genero provides the gmabuildtool command line tool, to build the AAB/APK packages for your mobile application.
For more details about Android packages and bundles, go to https://developer.android.com/guide/app-bundle.
You need to comply with some Google conditions before publishing your app on the Play Store. This topic describes how the gmabuildtool tool builds Google Play Store ready packages.
For testing purposes, the tool can deploy APK packages and automatically launch the app on a specific device or emulator.
The gmabuildtool has also an option to update the Android SDK and an option to manage scaffold archives.
This documentation section implies that you are familiar with Android app programming concepts and requirements. For example, you will need the Android SDK tools to be installed (and up to date) to build your Android apps. For more details, visit the Android SDK tools download page.
Prerequisites
- The Genero BDL development environment (FGLDIR) must be installed to compile your program files.
-
The Java JDK must be installed.
JDK 17 is required to build Android apps. For the latest information regarding system requirements and Java support, please refer to the Supported platforms and databases document, available on the "Products" download page of the Four Js Web site.
- The GMA software components must be installed.
The GMA buildtool and GMA binary archive are provided in the GMA distribution archive (fjs-gma-*.zip).
To set up the GMA installation directory, perform the following steps:- Create a dedicated directory (gma-install-dir)
- Extract the content of the fjs-gma-*.zip.
- Add the gma-install-dir directory to your PATH environment variable, in order to find the gmabuildtool command.
The gma-install-dir will contain the gmabuildtool command, and the original GMA scaffold archive (gma-install-dir/artifacts).
- The Android SDK must be installed (an internet connection is required to download the SDK packages). For more details, see Install Genero Mobile for Android.
- Download/upgrade the required Android SDK packages, by using the gmabuildtool updatesdk ... command. Execute the gmabuildtool updatesdk ... command every time a new version of the GMA buildtool and GMA binary archive is installed. For more details, see Update the Android SDK with the GMA buildtool.
- Android-specific app resources such as icons (in all required sizes) are required, along with the application program files.
- To install AAB packages on your development device or emulator, get the bundletool utility (see https://github.com/google/bundletool/releases).
- If you plan to publish your app on Google Play, register to Google Play as a developer and create a Google Play project.
Environment settings
- Android SDK environment settings (ANDROID_HOME, PATH)
- Java JDK environment settings (JAVA_HOME, PATH)
Update the Android SDK with the GMA buildtool
After a fresh installation of the GMA buildtool and GMA binary archive, upgrade the Android SDK, to download all required Android SDK packages, with the gmabuildtool updatesdk ... command.
The Android SDK installation directory
is required for the SDK update. It can be specified by the ANDROID_HOME environment variable or with
the --android-sdk
option:
gmabuildtool updatesdk
--android-sdk /use/local/32bits/android-sdk/r22.6.2
--accept-licenses
option to silently accept all Android SDK
licenses.gmabuildtool updatesdk
--accept-licenses
...
--proxy-host
and
--proxy-port
options:gmabuildtool updatesdk
--proxy-host amadeus --proxy-port 3232
...
--no-install-extras
option to skip the installation of extra SDK modules
such as Google's driver for Windows®
and the HAXM for Windows and OS
X:gmabuildtool updatesdk
--no-install-extras
...
On Windows and Mac® extras may be installed if
--no-install-extras
option is not used. The installation is preceded by a prompt
asking the user to continue with the installation. Use the --no-interactions
option
to skip user interaction. This option answers yes silently to the prompt for permission to
install.
This option also silently accepts licenses. gmabuildtool updatesdk
--no-interactions
is the same as the command gmabuildtool updatesdk
--no-interactions --accept licenses
gmabuildtool updatesdk
--no-interactions
...
Manage GMA scaffold archives
The GMA scaffold archives can be managed by the gmabuildtool scaffold ... command.
In order to get the list of plugins installed in the GMA development environment, use the
--list-plugins
option:
$ gmabuildtool scaffold --list-plugins
...
cordova-plugin-device-motion.aar
cordova-plugin-media.aar
...
To install additional plugins in the GMA installation directory, use the
--install-plugins
option, for example:
$ gmabuildtool scaffold --install-plugins path-to-plugin-sources
For more usage examples, see Cordova plugins.
Building AAB/APK packages
The gmabuildtool build ... command creates the AAB and/or APK packages from a set of files, using the build options passed as parameter:
gmabuildtool build
... build options ...
The process will be explained in details in the next sections of this topic.
For a complete description of the build
command options, see gmabuildtool.
Gradle build cache
To build Android apps, the GMA buildtool uses the Gradle toolkit.
Gradle can speed up AAB/APK creation time, by reusing outputs saved in a cache produced from previous builds. The gmabuildtool command uses the Gradle build cache.
On Unix-like platforms, the gmabuildtool Gradle build cache is in the /tmp/gma directory. On Windows, it is in C:\tmp\gma.
The Gradle build cache directory used by gmabuildtool (/tmp/gma or C:\tmp\gma) can grow to a significant size and consequently fill the disk. Take care to monitor the size of this cache and manually clean out the cache files, to ensure that it does not become too large in size.
Cleaning intermediate build files
The build process is optimized to avoid a complete AAB/APK package rebuild every time you invoke the GMA buildtool.
The GMA buildtool creates intermediate archive files, that can be reused in the next build, if no changes are detected in application program files. However, these files might be corrupted, in case of user interruption or gradle build failure.
In this situation, you can use the --clean
option of the gmabuildtool
build ... command, to clean up the scaffold build directory, and restart with a fresh
build:
gmabuildtool build --clean
... build options ...
Specifying the GBC to be used
--build-gbc-runtime
option to specify which GBC has to be bundled with
the app
package:gmabuildtool build --build-gbc-runtime gbc-archive ...
The gbc-archive parameter is the ZIP archive of the GBC front-end, to be created as described in the Create a runtime zip topic in the Genero Browser Client User Guide.
The parameter for the --build-gbc-runtime
option can also be a regular
(unzipped) GBC directory.
If the --build-gbc-runtime
option is not used, gmabuildtool
will use the GBC found in FGLGBCDIR, and if
that environment variable is not defined, it defaults to FGLDIR/web_utilities/gbc/gbc.
Using an options file
@argfile
argument:$ cat myoptions.txt
--build-output-apk-name MyApp
--build-app-package-name com.example.myapp
--main-app-path /tmp/app/main.42m
...
$ gmabuildtool build @./myoptions.txt
$ gmabuildtool build @com_options.txt @app_options.txt -v
Elements used in building the Android app
- The GMA binary archive, containing the GMA front-end and the FGLGWS runtime system. The original
scaffold is provided in gma-install-dir/artifacts and
unzipped for app package builds into a directory defined by the
--build-project
option. - The app manifest file
AndroidManifest.xml
to be created/used (--generate-default-manifest
,--custom-manifest-file
options) - The GBC to be used (
--build-gbc-runtime
option) - The compiled application program and resource files (.42m,
.42f, etc) (found from the
--main-app-path
option) - The default path to Android app resources (
--root-path
), when not using resource dedicated options such as--build-app-icon-hdpi
. The root path will also be used to create all intermediate build files. - The prefix for the app package filename to be generated
(
--build-output-apk-name
option) - The package name and the name of the app (
--build-app-package-name
option) - The version code of the app (
--build-app-version-code
option) - The version name of the app (
--build-app-version-name
option) - Android app specific resources:
- Android app icons (all sizes)
(
--build-app-icon*
and--build-status-icon-*
options)
- Android app icons (all sizes)
(
- Android app signing keystore alias and
file, to publish the app (
--build-signing-keystore
and related options)
The app manifest file
Every Android app must be created with an app manifest file named AndroidManifest.xml.
The gmabuildtool provides options to create a default manifest file that can be modified, and an option to specify the manifest file to be used when building the AAB/APK.
The --generate-default-manifest/-gdm
option can be used to generate a default
AndroidManifest.xml file, that can be modified to build the app package. The
file is generated in the build directory (--build-apk-outputs/-bo
option). This
option takes into account manifest-related options such as
--build-app-permissions/-ba
.
To build the app packages, a user-defined manifest file can be specified with the --custom-manifest-file/-cmf
option. The basename of the provided file path
must be AndroidManifest.xml
. If this option is not used,
gmabuildtool
will generate a new manifest file.
Note that the build process to produce the AAB/APK packages may add permissions coming from external librairies, that are not present in the provided manifest file.
For more details about app manifest files, see the Android documentation.
Generate the keystore file to sign your app
In order to build an AAB package that can be deployed on Google Play Store, you need to sign your Android app with a keystore.
There is critical information regarding app signing in the Android documentation. For example, in order to install new versions as updates to your app, each app package must use the same certificate: The signing key must not change during the lifetime of your app. Make sure that you read all details about Android app signing.
The keystore is used by the gmabuildtool to sign the APK with the apksigner utility from Android SDK and to sign the AAB with the jarsigner utility from Java SDK.
The signing credentials are passed to gmabuildtool
with the
--build-signing-keystore
, --build-signing-alias
,
--build-signing-storepass
and --build-signing-keypass
options.
Using --build-signing-keystore
option makes all other
--build-signing-*
options mandatory.
Default values of all --build-signing-*
options will only apply, if the
--build-signing-keystore
option is not specified. This is done to avoid setting
some weak default password if user misses to use some options. For defaults, see gmabuildtool command reference.
The passwords specified with --build-signing-keypass
and
--build-signing-storepass must be 6 char long minimum (required by key generation), and must be
identical since different passwords is not supported by the PKCS12 key format. Passwords can be
different, when specifying a path to an existing key file that is in a encryption format allowing
this.
When no keystore exists, or if the alias in the key does not exists, the gmabuildtool will automatically create a keystore of type PKCS12.
Controlling the production of AAB/APK package files
--output-format
option to specify
"aab"
or "apk"
types:gmabuildtool ... --output-format aab
The
--output-format
option supports also the "all"
value, to build all
type of packages. Uppercase AAB or APK values are accepted.- The filename prefix defined by the
--build-output-apk-name
option (by default, "app"), - When building a debug version, the
-debug
suffix, - The
.aab
or.apk
file extension.
Directory structures required for the build
To build an Android app, you must prepare the main-app-dir directory
containing the program files (.42m, .42f, ...) and
resource files (images, database files, webcomponents) needed by the Genero application. The
main-app-dir is implicitly defined by the parent directory of the --main-app-path
option argument. This directory must have a structure as
described in Directory structure for GMA apps:
main-app-dir
|
|-- main.42m
|-- comutils.42m
|-- mainform.42f
|-- fglprofile
|-- defaults/*.42s
| ...
--root-path
option. This root directory also defines the default directory
for scaffold and temporary files used by the build process. It is strongly recommended to use
different locations for the root directory and for the main application directory:root-dir
|
|-- project
| |-- scaffold
| |-- build
| | ...
|
|-- icons
| |-- ic_app_hdpi.png
| |-- ic_app_mdpi.png
| |-- ic_app_xhdpi.png
| |-- ic_app_xxhdpi.png
| | ...
- root-dir/project is the default directory for scaffold
and temporary files used by the build process. You can use a different directory with the
--build-project
option. - root-dir/project/scaffold contains the scaffold files copied automatically by gmabuildtool from gma-install-dir/artifacts.
- root-dir/project/build us used as working directory for the gradle process.
- root-dir/icons is the default directory containing the
app icons. You can specify app icons with options such as
--build-app-icon-hdpi
.
Android permissions
To use a mobile device feature such as the camera, an Android app must be created with the corresponding Android permission.
The permissions implemented in the APK/AAB package will be a merge of the permissions set by default (typically for mobile front-calls), the permissions defined for the app with the gmabuildtool, and the permissions already implemented by external libraries required to build the GMA app. The manifest file used by the gmabuildtool may show less permissions than the APK/AAB package implements.
Android distinguishes "Normal Permissions" and "Dangerous Permissions": Dangerous Permissions require a user validation at runtime, the first time the device feature is used.
Before Android 6, Dangerous Permissions defined by the app were set at app installation. Starting with version 6, Dangerous Permissions must be requested by the app code on demand.
Android permissions can be
specified with the --build-app-permissions
option of the
gmabuildtool. Define the list of permissions as a single argument, by using the
comma as separator.
gmabuildtool build \
...
--build-app-permissions android.permission.READ_CALENDAR,... \
...
Assuming that the permission was specified when building the app package, a Dangerous Permission
required for a core GMA feature (like internet access), or a built-in front call, will make the GMA
automatically ask for user confirmation. For example, if the app code makes a chooseContact
front call,
the GMA will automatically request the user to access the contacts database.
Other permissions (not related to core GMA features or built-in front calls) need to be specified when building the app.
Dangerous Permissions not related to core GMA features or built-in front calls, need to be
enabled by the app code. To request the user for a specific permission, perform a askForPermission
front
call, before using the feature.
Several Android "Normal Permissions" required for core GMA app features and built-in mobile front calls are automatically defined in the app manifest file by gmabuildtool. To identify these default permissions, inspect the manifest file of the generated APK/AAB file.
Dangerous Permissions listed below are not set by default: They must be specified
explicitly with the --build-app-permissions
option, when building the app
package.
android.permission.ACCESS_FINE_LOCATION
: For mobile.getGeolocation front call.android.permission.ACCESS_COARSE_LOCATION
: For mobile.getGeolocation front call.android.permission.READ_CONTACTS
: For mobile.chooseContact front call.android.permission.GET_ACCOUNTS
: Only on Android 5.1 and lower (< API 23), for mobile.chooseContact front call.android.permission.CAMERA
: For mobile.takeVideo, mobile.takePhoto front calls.android.permission.WRITE_EXTERNAL_STORAGE
: For mobile.importContact, mobile.takeVideo, mobile.takePhoto front calls.android.permission.READ_EXTERNAL_STORAGE
: For standard.openFile, standard.openFiles, mobile.chooseVideo, mobile.takeVideo, mobile.choosePhoto, mobile.takePhoto front calls.
For a complete list of Android permissions, see Android's Manifest permissions.
Define app's color theme
The app colors can be defined with a GBC theme.
"theme-primary-background-color"
is used to
defined the main color of the app.See GBC documentation for more details about GBC customization and theme colors usage.
The GBC theme is applied when the app starts, and every time the theme is changed by a theme.setTheme
frontcall.
The GBC theme is also used to colorize some native UI elements such as the date/time picker, and the navigation bar. When changing the theme dynamically during the app execution, the colors will only apply to new created native widgets such as the date/time picker. Already existing native widgets like the navigation bar will not be affected by a theme change. However, the last used theme is saved in application settings, and all native widgets will get the expected colors when the app is restarted.
The --build-app-colors
is deprecated, use GBC theming to define
application colors.
Debug and release versions
Android apps can be generated in a debug or release version. Release versions meet the requirements for distribution on Google Play, while debug versions are used in development. In debug mode, the app installed on the device will listen on the debug TCP port to allow fgldb -m connections.
--build-mode
option of the
gmabuildtool command:gmabuildtool build \
--build-mode debug \
...
By default the app is built in release mode.
Building an Android app with gmabuildtool
- Prepare the root distribution directory root-dir/gma,
with Android app resources (icons) under
root-dir/gma. Or use specific options such as
--build-app-icon-hdpi
to define the location of app icons. - Create the main application directory with Genero program files, based on the default directory structure.
- Execute the gmabuildtool command with the
build
verb and related build options, to create the Android packages. The location of main application directory must be specified with the--main-app-path
option.
For example:
$ gmabuildtool build \
--main-app-path /home/mike/my_genero_app/main.42m \
--root-path /home/mike/my_app_project \
--android-sdk /home/mike/android/sdk \
--build-apk-outputs /home/mike/work/example/outputs \
--output-format aab \
--build-output-apk-name MyApp \
--build-app-package-name com.example.myapp \
--build-app-version-code 1002 \
--build-app-version-name "10.02" \
--build-signing-alias android_alias \
--build-signing-keystore /home/mike/work/example/sign/android.keystore \
--build-signing-keypass fourjs \
--build-signing-storepass fourjs \
--build-mode release \
--build-app-permissions android.permission.ACCESS_WIFI_STATE,android.permission.CALL_PHONE
Building an app with GMA custom extensions
The gmabuildtool build ... command supports AAB/APK creation for applications using GMA custom extensions written in Java.
Before building the app package, create the custom GMA binary archive with your extensions, as described in Packaging custom Java extensions for GMA.
--build-project
option
to specify the path to the Android Studio
project that was used to build your custom GMA binary archive:$ gmabuildtool build
...
--build-project /home/mike/android_project/mycustgma
...
Other options have to be specified as for a regular build using the original standard GMA binary archive.
Deploy and launch the app
After building the app packages, you can deploy and launch your app for testing purpose, on your local mobile device or simulator.
There must be only one Android device connected or running Android emulator.
Android App Bundle (AAB/.aab) packages cannot be installed directly on your local device or simulator (these are archives to be uploaded on the Google Play Store).
$ bundletool build-apks \
--bundle=/MyApp/outputs/my_app.aab \
--output=/MyApp/outputs/my_app.apks
bundletool install-apks --apks=/MyApp/outputs/my_app.apks
Alternatively, the APK/.apk packages can be installed and started with the
gmabuildtool test ... command, by using the --test-apk
option to
specify the APK filename to be installed:
$ gmabuildtool test \
--test-apk /MyApp/outputs/MyApp-arm-debug.apk