dfindexeddb 20241105__tar.gz → 20260205__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (53) hide show
  1. dfindexeddb-20260205/PKG-INFO +171 -0
  2. {dfindexeddb-20241105 → dfindexeddb-20260205}/README.md +34 -85
  3. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/blink.py +116 -74
  4. dfindexeddb-20260205/dfindexeddb/indexeddb/chromium/definitions.py +492 -0
  5. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/record.py +651 -346
  6. dfindexeddb-20260205/dfindexeddb/indexeddb/chromium/sqlite.py +362 -0
  7. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/v8.py +100 -78
  8. dfindexeddb-20260205/dfindexeddb/indexeddb/cli.py +415 -0
  9. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/definitions.py +7 -4
  10. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/gecko.py +98 -74
  11. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/record.py +78 -26
  12. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/definitions.py +5 -3
  13. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/record.py +86 -53
  14. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/webkit.py +85 -71
  15. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/types.py +4 -1
  16. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/cli.py +146 -138
  17. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/definitions.py +6 -2
  18. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/descriptor.py +70 -56
  19. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/ldb.py +39 -33
  20. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/log.py +41 -30
  21. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/chrome_notifications.py +30 -18
  22. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/interface.py +5 -6
  23. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/manager.py +10 -9
  24. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/record.py +71 -62
  25. dfindexeddb-20260205/dfindexeddb/leveldb/utils.py +208 -0
  26. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/utils.py +36 -31
  27. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/version.py +2 -2
  28. dfindexeddb-20260205/dfindexeddb.egg-info/PKG-INFO +171 -0
  29. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/SOURCES.txt +1 -1
  30. {dfindexeddb-20241105 → dfindexeddb-20260205}/pyproject.toml +21 -7
  31. {dfindexeddb-20241105 → dfindexeddb-20260205}/setup.py +1 -0
  32. dfindexeddb-20241105/AUTHORS +0 -12
  33. dfindexeddb-20241105/PKG-INFO +0 -424
  34. dfindexeddb-20241105/dfindexeddb/indexeddb/chromium/definitions.py +0 -377
  35. dfindexeddb-20241105/dfindexeddb/indexeddb/cli.py +0 -254
  36. dfindexeddb-20241105/dfindexeddb/leveldb/utils.py +0 -116
  37. dfindexeddb-20241105/dfindexeddb.egg-info/PKG-INFO +0 -424
  38. {dfindexeddb-20241105 → dfindexeddb-20260205}/LICENSE +0 -0
  39. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/__init__.py +0 -0
  40. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/errors.py +0 -0
  41. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/__init__.py +0 -0
  42. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/__init__.py +0 -0
  43. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/__init__.py +0 -0
  44. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/__init__.py +0 -0
  45. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/utils.py +0 -0
  46. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/__init__.py +0 -0
  47. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/__init__.py +0 -0
  48. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/notification_database_data_pb2.py +0 -0
  49. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/dependency_links.txt +0 -0
  50. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/entry_points.txt +0 -0
  51. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/requires.txt +0 -0
  52. {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/top_level.txt +0 -0
  53. {dfindexeddb-20241105 → dfindexeddb-20260205}/setup.cfg +0 -0
@@ -0,0 +1,171 @@
1
+ Metadata-Version: 2.4
2
+ Name: dfindexeddb
3
+ Version: 20260205
4
+ Summary: dfindexeddb is an experimental Python tool for performing digital forensic analysis of IndexedDB and leveldb files.
5
+ Author-email: Syd Pleno <sydp@google.com>
6
+ Maintainer-email: dfIndexeddb Developers <dfindexeddb-dev@googlegroups.com>
7
+ License-Expression: Apache-2.0
8
+ Project-URL: Homepage, https://github.com/google/dfindexeddb
9
+ Project-URL: Documentation, https://github.com/google/dfindexeddb/tree/main/docs
10
+ Project-URL: Repository, https://github.com/google/dfindexeddb
11
+ Project-URL: Bug Tracker, https://github.com/google/dfindexeddb/issues
12
+ Classifier: Development Status :: 3 - Alpha
13
+ Classifier: Programming Language :: Python
14
+ Requires-Python: >=3.9
15
+ Description-Content-Type: text/markdown
16
+ License-File: LICENSE
17
+ Requires-Dist: python-snappy==0.6.1
18
+ Requires-Dist: zstd==1.5.5.1
19
+ Provides-Extra: plugins
20
+ Requires-Dist: protobuf; extra == "plugins"
21
+ Requires-Dist: dfdatetime; extra == "plugins"
22
+ Dynamic: license-file
23
+
24
+ # dfIndexeddb
25
+
26
+ dfindexeddb is an experimental Python tool for performing digital forensic
27
+ analysis of IndexedDB and LevelDB files.
28
+
29
+ It parses LevelDB, IndexedDB and JavaScript structures from these files without
30
+ requiring native libraries. (Note: only a subset of IndexedDB key types and
31
+ JavaScript types for Firefox, Safari and Chromium-based browsers are currently supported).
32
+
33
+ The content of IndexedDB files is dependent on what a web application stores
34
+ locally/offline using the web browser's
35
+ [IndexedDB API](https://www.w3.org/TR/IndexedDB/). Examples of content might
36
+ include:
37
+ * text from a text/source-code editor application,
38
+ * emails and contact information from an e-mail application,
39
+ * images and metadata from a photo gallery application
40
+
41
+
42
+ ## Installation
43
+
44
+ 1. [Linux] Install the snappy compression development package
45
+
46
+ ```
47
+ $ sudo apt install libsnappy-dev
48
+ ```
49
+
50
+ 2. Create a virtual environment and install the package
51
+
52
+ ```
53
+ $ python3 -m venv .venv
54
+ $ source .venv/bin/activate
55
+ $ pip install dfindexeddb
56
+ ```
57
+
58
+ ### Optional plugins
59
+
60
+ To also install the dependencies for leveldb/indexeddb plugins, run
61
+ ```
62
+ $ pip install 'dfindexeddb[plugins]'
63
+ ```
64
+
65
+
66
+ ## Installation from source
67
+
68
+ 1. [Linux] Install the snappy compression development package
69
+
70
+ ```
71
+ $ sudo apt install libsnappy-dev
72
+ ```
73
+
74
+ 2. Clone or download/unzip the repository to your local machine.
75
+
76
+ 3. Create a virtual environment and install the package
77
+
78
+ ```
79
+ $ python3 -m venv .venv
80
+ $ source .venv/bin/activate
81
+ $ pip install .
82
+ ```
83
+
84
+ ### Optional plugins
85
+
86
+ To also install the dependencies for leveldb/indexeddb plugins, run
87
+ ```
88
+ $ pip install '.[plugins]'
89
+ ```
90
+
91
+ ## Usage
92
+
93
+ Two CLI tools for parsing IndexedDB/LevelDB files are available after
94
+ installation:
95
+
96
+
97
+ ### IndexedDB
98
+
99
+ ```
100
+ $ dfindexeddb -h
101
+ usage: dfindexeddb [-h] {blink,gecko,db,ldb,log} ...
102
+
103
+ A cli tool for parsing IndexedDB files
104
+
105
+ positional arguments:
106
+ {blink,gecko,db,ldb,log}
107
+ blink Parse a file as a blink-encoded value.
108
+ gecko Parse a file as a gecko-encoded value.
109
+ db Parse a directory/file as IndexedDB.
110
+ ldb Parse a ldb file as IndexedDB.
111
+ log Parse a log file as IndexedDB.
112
+
113
+ options:
114
+ -h, --help show this help message and exit
115
+ ```
116
+
117
+ #### Examples:
118
+
119
+ | Platform / Source | Format | Command |
120
+ | :--- | :--- | :--- |
121
+ | **Firefox** (sqlite) | JSON | `dfindexeddb db -s SOURCE --format firefox -o json` |
122
+ | **Safari** (sqlite) | JSON-L | `dfindexeddb db -s SOURCE --format safari -o jsonl` |
123
+ | **Chrome** (LevelDB/sqlite) | JSON | `dfindexeddb db -s SOURCE --format chrome` |
124
+ | **Chrome** (.ldb) | JSON-L | `dfindexeddb ldb -s SOURCE -o jsonl` |
125
+ | **Chrome** (.log) | Python repr | `dfindexeddb log -s SOURCE -o repr` |
126
+ | **Chrome** (Blink) | JSON | `dfindexeddb blink -s SOURCE` |
127
+ | **Filter Records by key** | JSON | `dfindexeddb db -s SOURCE --format chrome --filter_key search_term` |
128
+ | **Filter Records by value** | JSON | `dfindexeddb db -s SOURCE --format chrome --filter_value "search_term"` |
129
+
130
+
131
+ ### LevelDB
132
+
133
+ ```
134
+ $ dfleveldb -h
135
+ usage: dfleveldb [-h] {db,log,ldb,descriptor} ...
136
+
137
+ A cli tool for parsing leveldb files
138
+
139
+ positional arguments:
140
+ {db,log,ldb,descriptor}
141
+ db Parse a directory as leveldb.
142
+ log Parse a leveldb log file.
143
+ ldb Parse a leveldb table (.ldb) file.
144
+ descriptor Parse a leveldb descriptor (MANIFEST) file.
145
+
146
+ options:
147
+ -h, --help show this help message and exit
148
+ ```
149
+
150
+ #### Examples
151
+
152
+ | Source | Type | Command |
153
+ | :--- | :--- | :--- |
154
+ | **LevelDB Folder** | Records | `dfleveldb db -s SOURCE` |
155
+ | **Log file** (.log) | Physical Records | `dfleveldb log -s SOURCE -t physical_records` |
156
+ | **Log file** (.log) | Blocks | `dfleveldb log -s SOURCE -t blocks` |
157
+ | **Log file** (.log) | Write Batches | `dfleveldb log -s SOURCE -t write_batches` |
158
+ | **Log file** (.log) | Internal Key Records | `dfleveldb log -s SOURCE -t parsed_internal_key` |
159
+ | **Table file** (.ldb) | Records | `dfleveldb ldb -s SOURCE -t record` |
160
+ | **Table file** (.ldb) | Blocks | `dfleveldb ldb -s SOURCE -t blocks` |
161
+ | **Descriptor** (MANIFEST) | Version Edits | `dfleveldb descriptor -s SOURCE -t versionedit` |
162
+
163
+ #### Optional Plugins
164
+
165
+ To apply a plugin parser for a leveldb file/folder, add the
166
+ `--plugin [Plugin Name]` argument. Currently, there is support for the
167
+ following artifacts:
168
+
169
+ | Plugin Name | Artifact Name |
170
+ | -------- | ------- |
171
+ | `ChromeNotificationRecord` | Chrome/Chromium Notifications |
@@ -32,6 +32,8 @@ include:
32
32
  $ pip install dfindexeddb
33
33
  ```
34
34
 
35
+ ### Optional plugins
36
+
35
37
  To also install the dependencies for leveldb/indexeddb plugins, run
36
38
  ```
37
39
  $ pip install 'dfindexeddb[plugins]'
@@ -56,6 +58,8 @@ To also install the dependencies for leveldb/indexeddb plugins, run
56
58
  $ pip install .
57
59
  ```
58
60
 
61
+ ### Optional plugins
62
+
59
63
  To also install the dependencies for leveldb/indexeddb plugins, run
60
64
  ```
61
65
  $ pip install '.[plugins]'
@@ -71,15 +75,17 @@ installation:
71
75
 
72
76
  ```
73
77
  $ dfindexeddb -h
74
- usage: dfindexeddb [-h] {db,ldb,log} ...
78
+ usage: dfindexeddb [-h] {blink,gecko,db,ldb,log} ...
75
79
 
76
- A cli tool for parsing indexeddb files
80
+ A cli tool for parsing IndexedDB files
77
81
 
78
82
  positional arguments:
79
- {db,ldb,log}
80
- db Parse a directory as indexeddb.
81
- ldb Parse a ldb file as indexeddb.
82
- log Parse a log file as indexeddb.
83
+ {blink,gecko,db,ldb,log}
84
+ blink Parse a file as a blink-encoded value.
85
+ gecko Parse a file as a gecko-encoded value.
86
+ db Parse a directory/file as IndexedDB.
87
+ ldb Parse a ldb file as IndexedDB.
88
+ log Parse a log file as IndexedDB.
83
89
 
84
90
  options:
85
91
  -h, --help show this help message and exit
@@ -87,48 +93,17 @@ options:
87
93
 
88
94
  #### Examples:
89
95
 
90
- To parse IndexedDB records from an sqlite file for Firefox and output the
91
- results as JSON, use the following command:
92
-
93
- ```
94
- dfindexeddb db -s SOURCE --format firefox -o json
95
- ```
96
-
97
- To parse IndexedDB records from an sqlite file for Safari and output the
98
- results as JSON-L, use the following command:
99
-
100
- ```
101
- dfindexeddb db -s SOURCE --format safari -o jsonl
102
- ```
103
-
104
- To parse IndexedDB records from a LevelDB folder for Chrome/Chromium, using the
105
- manifest file to determine recovered records and output as JSON, use the
106
- following command:
107
-
108
- ```
109
- dfindexeddb db -s SOURCE --format chrome --use_manifest
110
- ```
111
-
112
- To parse IndexedDB records from a LevelDB ldb (.ldb) file and output the
113
- results as JSON-L, use the following command:
114
-
115
- ```
116
- dfindexeddb ldb -s SOURCE -o jsonl
117
- ```
118
-
119
- To parse IndexedDB records from a LevelDB log (.log) file and output the
120
- results as the Python printable representation, use the following command:
121
-
122
- ```
123
- dfindexeddb log -s SOURCE -o repr
124
- ```
125
-
126
- To parse a file as a Chrome/Chromium IndexedDB blink value and output the
127
- results as JSON:
96
+ | Platform / Source | Format | Command |
97
+ | :--- | :--- | :--- |
98
+ | **Firefox** (sqlite) | JSON | `dfindexeddb db -s SOURCE --format firefox -o json` |
99
+ | **Safari** (sqlite) | JSON-L | `dfindexeddb db -s SOURCE --format safari -o jsonl` |
100
+ | **Chrome** (LevelDB/sqlite) | JSON | `dfindexeddb db -s SOURCE --format chrome` |
101
+ | **Chrome** (.ldb) | JSON-L | `dfindexeddb ldb -s SOURCE -o jsonl` |
102
+ | **Chrome** (.log) | Python repr | `dfindexeddb log -s SOURCE -o repr` |
103
+ | **Chrome** (Blink) | JSON | `dfindexeddb blink -s SOURCE` |
104
+ | **Filter Records by key** | JSON | `dfindexeddb db -s SOURCE --format chrome --filter_key search_term` |
105
+ | **Filter Records by value** | JSON | `dfindexeddb db -s SOURCE --format chrome --filter_value "search_term"` |
128
106
 
129
- ```
130
- dfindexeddb blink -s SOURCE
131
- ```
132
107
 
133
108
  ### LevelDB
134
109
 
@@ -151,44 +126,18 @@ options:
151
126
 
152
127
  #### Examples
153
128
 
154
- To parse records from a LevelDB folder, use the following command:
155
-
156
- ```
157
- dfleveldb db -s SOURCE
158
- ```
159
-
160
- To parse records from a LevelDB folder, and use the sequence number to
161
- determine recovered records and output as JSON, use the
162
- following command:
163
-
164
- ```
165
- dfleveldb db -s SOURCE --use_sequence_number
166
- ```
167
-
168
- To parse blocks / physical records/ write batches / internal key records from a
169
- LevelDB log (.log) file, use the following command, specifying the type (block,
170
- physical_records, etc) via the `-t` option. By default, internal key records are parsed:
171
-
172
- ```
173
- $ dfleveldb log -s SOURCE [-t {blocks,physical_records,write_batches,parsed_internal_key}]
174
- ```
175
-
176
- To parse blocks / records from a LevelDB table (.ldb) file, use the following
177
- command, specifying the type (blocks, records) via the `-t` option. By
178
- default, records are parsed:
179
-
180
- ```
181
- $ dfleveldb ldb -s SOURCE [-t {blocks,records}]
182
- ```
183
-
184
- To parse version edit records from a Descriptor (MANIFEST) file, use the
185
- following command:
186
-
187
- ```
188
- $ dfleveldb descriptor -s SOURCE [-o {json,jsonl,repr}] [-t {blocks,physical_records,versionedit} | -v]
189
- ```
190
-
191
- #### Plugins
129
+ | Source | Type | Command |
130
+ | :--- | :--- | :--- |
131
+ | **LevelDB Folder** | Records | `dfleveldb db -s SOURCE` |
132
+ | **Log file** (.log) | Physical Records | `dfleveldb log -s SOURCE -t physical_records` |
133
+ | **Log file** (.log) | Blocks | `dfleveldb log -s SOURCE -t blocks` |
134
+ | **Log file** (.log) | Write Batches | `dfleveldb log -s SOURCE -t write_batches` |
135
+ | **Log file** (.log) | Internal Key Records | `dfleveldb log -s SOURCE -t parsed_internal_key` |
136
+ | **Table file** (.ldb) | Records | `dfleveldb ldb -s SOURCE -t record` |
137
+ | **Table file** (.ldb) | Blocks | `dfleveldb ldb -s SOURCE -t blocks` |
138
+ | **Descriptor** (MANIFEST) | Version Edits | `dfleveldb descriptor -s SOURCE -t versionedit` |
139
+
140
+ #### Optional Plugins
192
141
 
193
142
  To apply a plugin parser for a leveldb file/folder, add the
194
143
  `--plugin [Plugin Name]` argument. Currently, there is support for the