Skip to content

Create and restore a backup of the full Android app data, fully offline.

Notifications You must be signed in to change notification settings

ukustra/firefox-android-backup-restore

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 

Repository files navigation

Backup & restore of Firefox app data

This tutorial explains how one can create and restore a backup of the full Android app data, fully offline.

While the Firefox app itself does not support adb backup due to allowBackups="false" (bug 1808763), we can still access all data by connecting through a Firefox-specific debugger.

Repository: https://github.com/Rob--W/firefox-android-backup-restore

Requirements

All you need is adb, and a desktop Firefox instance to use about:debugging:

Relevant files

The data of Android apps are usually stored in internal storage, private to the app, inaccessible to other apps and adb. External storage at /sdcard/ can be accessed through adb, but we need to use a special subdirectory to make sure that the app can access it without requiring special storage permissions.

Examples of paths for Firefox (app ID org.mozilla.firefox):

  • Private app data: /data/user/0/org.mozilla.firefox/
  • Public directory: /sdcard/Android/data/org.mozilla.firefox/

The private app data directory contains several directories and files, the most important ones being:

  • shared_prefs/ - Firefox UI settings and customizations.
  • files/ - Firefox profile directory, with website data (cookies etc).
  • databases/ - Tabs, collections, autofill, logins & passwords, and more.

The following are also relevant for consistency, but not critical:

  • cache/ - Caches, including thumbnails and favicons.
  • nimbus_data/ - Feature flags. Optional, but can change behavior.
  • no_backup/ - Includes androidx.work database, e.g. add-on update checks.
  • glean_data/ - Telemetry data (very old profiles may also have telemetry/).

Backup

To backup, prepare to receive the backup data in the terminal:

adb reverse tcp:12101 tcp:12101
nc64 -l -s 127.0.0.1 -p 12101 > firefox-android-backup.tar.gz

If the second command doesn't work, download NetCat: https://stackoverflow.com/questions/34924089/windows-7-netcat-error-nc-is-not-recognized-as-an-internal-or-external-comman

Open the Firefox app on your phone, and visit about:blank (any webpage works). Copy the contents of snippets_for_firefox_debugging.js. Open about:debugging, scroll down to "Main Process" and click on Inspect. Switch to the Console, paste the code and run it. Then type and run:

fab_backup_create();

This copies relevant files to firefox-android-backup.tar.gz without changing any data, except for one log file. To remove the log file, run:

fab_cleanup();

Restore

The steps below will replace relevant files with the backup.

To restore the profile from the backup, put the backup archive on the device:

adb shell mkdir /sdcard/Android/data/org.mozilla.firefox/
adb push firefox-android-backup.tar.gz /sdcard/Android/data/org.mozilla.firefox/

Open the Firefox app on your phone, and visit about:blank (any webpage works). Copy the contents of snippets_for_firefox_debugging.js. Open about:debugging, scroll down to "Main Process" and click on Inspect. Switch to the Console, paste the code and run it.

Then type fab_backup_restore(); and run it. This has no visible output, unless an error occurs. Upon successful completion, the app is killed to prevent the old app instance from corrupting the restored data. The logs can be viewed with:

adb shell cat /sdcard/Android/data/org.mozilla.firefox/firefox-android-backup.log

When you are done, remove the archive and log file with:

fab_cleanup();

About

Create and restore a backup of the full Android app data, fully offline.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 100.0%