Skip to main content

SQBrite is a data recovery tool for SQLite databases

Project description

Continuous Integration status Scrutinizer Code Quality Latest Version Download format Supported Python versions

SQBrite is a data recovery/forensics tool for SQLite databases. It uses a Python 3 implementation of the SQLite on-disk file format to recover deleted table rows.

SQBrite’s name is inspired by PL Daniels’ undark, but is a completely separate implementation.

SQBrite demo terminal recording

Installing SQBrite

SQBrite requires Python 3. To install, simply run:

$ pip3 install --user sqbrite
$ sqbrite --help

Background

SQLite uses a paginated data model in which each database is a collection of same-size pages. There are several kinds of pages, of which one type (B-Tree Table Leaf pages) contains the starting point for actual data belonging to individual table rows.

When a row is deleted by means of a DELETE FROM table (...) statement, the space occupied by that row’s data (a record) within the relevant B-Tree Table Leaf page is marked as free and may subsequently be used to store new records or update existing records. However, it is common to see freed space within a page (a freeblock, in SQLite parlance) left alone after rows are deleted. In that case, it *may* be possible to retrieve deleted row data from within the freeblock.

Heuristics

The SQLite file format doesn’t keep track of where deleted records start and end within a leaf page’s freeblocks. This means that SQBrite needs a mechanism to find out where record headers start. This is achieved through the use of byte-wise regular expressions specific to tables in known databases. These regular expressions and the offset that separates matches from the first byte in a well-formed header are stored in a user-editable YAML file.

SQBrite aims to ship with heuristics for popular SQLite databases, so do send pull requests if you’ve got good results with your heuristics.

Features

  • Export all records to CSV or reinject “undeleted” records into a copy of the database

  • Extensible heuristics - just add entries to ~/.local/share/sqbrite/sqbrite.yaml!

  • SQBrite can recover records from within active B-tree table leaf pages or from former table-leaf Freelist pages.

  • Heuristics for iOS and Firefox databases

Limitations

  • SQBrite works better when ptrmap pages are present

  • The undelete subcommand may fail when re-inserting deleted rows into a table causes a constraint violation

  • SQBrite cannot recover records deleted with the SQLite secure_delete pragma enabled

  • Recovering data from overflow pages that have become Freelist leaf pages is not currently supported

Acknowledgments

Big thanks to @tobraha for contributing bugfixes in 2022.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sqbrite-0.17-py3-none-any.whl (30.8 kB view details)

Uploaded Python 3

File details

Details for the file sqbrite-0.17-py3-none-any.whl.

File metadata

  • Download URL: sqbrite-0.17-py3-none-any.whl
  • Upload date:
  • Size: 30.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.26.0 requests-toolbelt/0.9.1 urllib3/1.26.7 tqdm/4.63.0 importlib-metadata/4.8.1 keyring/21.8.0 rfc3986/2.0.0 colorama/0.4.3 CPython/3.10.2

File hashes

Hashes for sqbrite-0.17-py3-none-any.whl
Algorithm Hash digest
SHA256 73b4b5a84375042be840b9b9d9e3f3429a3aa6f0515ae2448429d3de3aaaea44
MD5 039826ca0c32c076ede9ba89b478fa3e
BLAKE2b-256 321cef683a7f0a2835499d28a54ee5772403b1fe7746f9369a72dba2f36908a1

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page