No description
  • Kotlin 98.9%
  • Java 0.7%
  • Shell 0.4%
Find a file
2026-03-27 12:58:03 +03:00
.idea Update all the dependencies for Android 16 2025-06-13 10:24:56 -03:00
.reuse Make Seedvault almost REUSE compliant 2024-05-23 00:44:51 +05:30
app Merge tag '16-5.8' of https://github.com/seedvault-app/seedvault into lineage-23.0 2026-01-21 22:11:38 +02:00
contactsbackup Release 16-5.8 2026-01-13 13:09:42 -03:00
core Fix free space reporting for SAF backend 2025-10-15 15:56:04 -03:00
doc Add padding to all blobs using the Padmé algorithm 2024-10-08 19:38:14 -03:00
gradle Lower minSdk again until we can upgrade emulator image 2025-06-13 10:24:57 -03:00
libs Add missing koin dependency 2025-06-13 10:24:57 -03:00
LICENSES Make Seedvault almost REUSE compliant 2024-05-23 00:44:51 +05:30
permissions use AOSP naming convention for privapp whitelist 2026-03-27 12:55:55 +03:00
storage Seedvault: Use colorError from appcompat 2025-11-22 16:45:16 +02:00
.editorconfig Update and fix ktlint 2025-06-13 10:24:56 -03:00
.gitignore Add '/build' folders to .gitignore 2024-01-19 03:34:38 +00:00
allowlist_com.stevesoltys.seedvault.xml misc: Add SPDX copyright headers 2024-05-23 00:44:51 +05:30
Android.bp use AOSP naming convention for privapp whitelist 2026-03-27 12:55:55 +03:00
build.gradle.kts Update and fix ktlint 2025-06-13 10:24:56 -03:00
CHANGELOG.md Release 16-5.8 2026-01-13 13:09:42 -03:00
default-permissions_com.stevesoltys.seedvault.xml misc: Add SPDX copyright headers 2024-05-23 00:44:51 +05:30
gradle.properties enable and fix non-transitive R Classes (nonTransitiveRClass) 2025-03-12 10:27:20 -03:00
gradlew Bump AGP, Gradle and dependencies to latest stable release 2024-07-27 13:06:19 +07:00
gradlew.bat Bump AGP, Gradle and dependencies to latest stable release 2024-07-27 13:06:19 +07:00
logcat-verbose.sh Show when launchable system apps do not allow backup 2024-10-10 13:42:22 -03:00
README.md Update README.md for Android 16 2025-07-11 15:22:46 -03:00
SECURITY.md Create SECURITY.md 2024-12-11 18:38:07 +05:30
settings.gradle.kts Add core gradle module with unified storage backends 2024-09-12 09:18:21 -03:00

Seedvault

Build Translation

A backup application for the Android Open Source Project. Needs to be integrated in your Android ROM and can not be installed as a regular app.

If you are having an issue/question, please look at our FAQ or ask a new question.

Components

Features

  • Backup application data to a flash drive.
  • Restore application data from a flash drive.
  • User-friendly encryption using a mnemonic phrase (BIP39).
  • Automatic daily backups that run in the background.

Requirements

SeedVault is developed along with AOSP releases.

We update it every time Google releases a new Android version, make any changes required for basic functionality, and any improvements possible through API changes in the OS.

This means that for ROMs using SeedVault it's recommended to use the same branch as your android version

  • This current branch android16 is meant for usage with Android 16
  • This is indicated by the version name starting with 16, and the version code starting with 36 - the Android 16 API version

For older versions of Android, check out the branches.

Trying to use an older branch on a newer version may lead to issues and is not something we can support.

What makes this different?

This application is compiled with the operating system and does not require a rooted device for use. It uses the same internal APIs as adb backup which is deprecated and thus needs a replacement.

Permissions

  • android.permission.BACKUP to back up application data.
  • android.permission.ACCESS_NETWORK_STATE to check if there is internet access when network storage is used.
  • android.permission.MANAGE_USB to access the serial number of USB mass storage devices.
  • android.permission.WRITE_SECURE_SETTINGS to change system backup settings and enable call log backup.
  • android.permission.QUERY_ALL_PACKAGES to get information about all installed apps for backup.
  • android.permission.QUERY_USERS to get the name of the user profile that gets backed up.
  • android.permission.INSTALL_PACKAGES to re-install apps when restoring from backup.
  • android.permission.MANAGE_EXTERNAL_STORAGE to backup and restore files from device storage.
  • android.permission.ACCESS_MEDIA_LOCATION to backup original media files e.g. without stripped EXIF metadata.
  • android.permission.FOREGROUND_SERVICE to do periodic storage backups without interruption.
  • android.permission.FOREGROUND_SERVICE_DATA_SYNC to do periodic storage backups without interruption.
  • android.permission.MANAGE_DOCUMENTS to retrieve the available storage roots (optional) for better UX.
  • android.permission.USE_BIOMETRIC to authenticate saving a new recovery code
  • android.permission.INTERACT_ACROSS_USERS_FULL to use storage roots in other users (optional).
  • android.permission.POST_NOTIFICATIONS to inform users about backup status and errors.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/seedvault-app/seedvault.

See DEVELOPMENT.md for information on developing Seedvault locally.

This project aims to adhere to the official Kotlin coding style.

Translating

Seedvault can be translated with Weblate, as provided by CalyxOS.

Translation status

Third-party tools

Warning

The Seedvault developers make no guarantees about external software projects. Please be aware that disclosing your secret recovery key to other software has security risks.

The Seedvault backup parser allows you to decrypt and inspect your backups (version 0 backup). It can also re-encrypt them.

The Seedvault extractor allows you to decrypt and inspect your backups from newer versions of Seedvault (version 1 backup). It is currently work-in-progress.

License

This application is available as open source under the terms of the Apache-2.0 License.

Funding

Calyx Institute

This project is primarily developed and maintained by the Calyx Institute for usage in CalyxOS.

NGI0 PET Fund

This project was funded through the NGI0 PET Fund, a fund established by NLnet with financial support from the European Commission's Next Generation Internet programme, under the aegis of DG Communications Networks, Content and Technology under grant agreement No 825310.

NGI0 Entrust Fund

This project was funded through the NGI0 Entrust Fund, a fund established by NLnet with financial support from the European Commission's Next Generation Internet programme, under the aegis of DG Communications Networks, Content and Technology under grant agreement No 101069594.