A long-lived project that still receives updates
Extracts a universal apk from an .aab file
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 0.2.0
~> 2.0
>= 2.137.0
~> 0.12.2
~> 13.0
~> 3.4
= 0.49.1
~> 0.12.0
 Project Readme

Bundletool for Fastlane

fastlane Plugin Badge Gem Version YourActionName Actions Status Gem Total Downloads

Getting Started

This project is a fastlane plugin. To get started with fastlane-plugin-bundletool, add it to your project by running:

fastlane add_plugin bundletool

or in your Pluginfile under fastlane folder write the following line and run bundle install.

gem 'fastlane-plugin-bundletool'

About bundletool

bundletool is the underlying tool that Gradle, Android Studio, and Google Play use to build an Android App Bundle or convert an app bundle into the various APKs that are deployed to devices. bundletool is also available to you as a command line tool, so you can recreate, inspect, and verify Google Play’s server-side build of your app’s APKs.

https://developer.android.com/studio/command-line/bundletool

The motivation of this plugin is to extract an universal .apk or split .apks from an .aab file. Since we cannot distribute aab files, it's great that we can extract from the very same binary a file that we can distribute internally.

Usage

In your Fastfile you need to use bundletool action. After you build the .aab file you can run the following code.

bundletool(
  ks_path: keystore_path,
  ks_password: keystore_password,
  ks_key_alias: keystore_alias,
  ks_key_alias_password: keystore_alias_password,
  bundletool_version: '1.10.0', # For searching a specific version of bundletool visit https://github.com/google/bundletool/releases
  aab_path: aab_path,
  apk_output_path: apk_output_path,
  verbose: true,
  cache_path: cache_path,
  universal_apk: true
)

This will output the universal .apk in the output path you set.

Options

Key Description Env Var(s) Default
ks_path Path to .jks file FL_BUNDLETOOL_KEYSTORE_FILE
ks_password .jks password FL_BUNDLETOOL_KEYSTORE_PASSWORD
ks_key_alias Alias for jks FL_BUNDLETOOL_KEY_ALIAS
ks_key_alias_password Alias password for .jks FL_BUNDLETOOL_KEY_PASSWORD
bundletool_version Version of bundletool to use, by default 0.11.0 will FL_BUNDLETOOL_VERSION 0.11.0
be used
download_url Url to download bundletool from, should point to a jar FL_BUNDLETOOL_DOWNLOAD_URL
file
aab_path Path where the aab file is FL_BUNDLETOOL_AAB_PATH
apk_output_path Path where the apk file is going to be placed FL_BUNDLETOOL_APK_OUTPUT_PATH .
verbose Show every messages of the action FL_BUNDLETOOL_VERBOSE false
cache_path Cache downloaded bundletool binary into the cache path FL_BUNDLETOOL_CACHE_PATH
universal_apk Create universal APK (true) or split APKs (false) FL_BUNDLETOOL_UNIVERSAL_APK true
----------------------- --------------------------------------------------------- --------------------------------- ---------

Use case

Here you can find a post I did explaining why I have to create this action.

https://medium.com/@gonzalez.martin90/bundletool-with-fastlane-8f8862ab16e0

Issues and Feedback

For any other issues and feedback about this plugin, please submit it to this repository.

Troubleshooting

If you have trouble using plugins, check out the Plugins Troubleshooting guide.

Using fastlane Plugins

For more information about how the fastlane plugin system works, check out the Plugins documentation.

About fastlane

fastlane is the easiest way to automate beta deployments and releases for your iOS and Android apps. To learn more, check out fastlane.tools.