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.
- dfindexeddb-20260205/PKG-INFO +171 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/README.md +34 -85
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/blink.py +116 -74
- dfindexeddb-20260205/dfindexeddb/indexeddb/chromium/definitions.py +492 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/record.py +651 -346
- dfindexeddb-20260205/dfindexeddb/indexeddb/chromium/sqlite.py +362 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/v8.py +100 -78
- dfindexeddb-20260205/dfindexeddb/indexeddb/cli.py +415 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/definitions.py +7 -4
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/gecko.py +98 -74
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/record.py +78 -26
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/definitions.py +5 -3
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/record.py +86 -53
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/webkit.py +85 -71
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/types.py +4 -1
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/cli.py +146 -138
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/definitions.py +6 -2
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/descriptor.py +70 -56
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/ldb.py +39 -33
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/log.py +41 -30
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/chrome_notifications.py +30 -18
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/interface.py +5 -6
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/manager.py +10 -9
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/record.py +71 -62
- dfindexeddb-20260205/dfindexeddb/leveldb/utils.py +208 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/utils.py +36 -31
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/version.py +2 -2
- dfindexeddb-20260205/dfindexeddb.egg-info/PKG-INFO +171 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/SOURCES.txt +1 -1
- {dfindexeddb-20241105 → dfindexeddb-20260205}/pyproject.toml +21 -7
- {dfindexeddb-20241105 → dfindexeddb-20260205}/setup.py +1 -0
- dfindexeddb-20241105/AUTHORS +0 -12
- dfindexeddb-20241105/PKG-INFO +0 -424
- dfindexeddb-20241105/dfindexeddb/indexeddb/chromium/definitions.py +0 -377
- dfindexeddb-20241105/dfindexeddb/indexeddb/cli.py +0 -254
- dfindexeddb-20241105/dfindexeddb/leveldb/utils.py +0 -116
- dfindexeddb-20241105/dfindexeddb.egg-info/PKG-INFO +0 -424
- {dfindexeddb-20241105 → dfindexeddb-20260205}/LICENSE +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/__init__.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/errors.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/__init__.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/chromium/__init__.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/firefox/__init__.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/safari/__init__.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/indexeddb/utils.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/__init__.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/__init__.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb/leveldb/plugins/notification_database_data_pb2.py +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/dependency_links.txt +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/entry_points.txt +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/requires.txt +0 -0
- {dfindexeddb-20241105 → dfindexeddb-20260205}/dfindexeddb.egg-info/top_level.txt +0 -0
- {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
|
|
80
|
+
A cli tool for parsing IndexedDB files
|
|
77
81
|
|
|
78
82
|
positional arguments:
|
|
79
|
-
{db,ldb,log}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
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
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
dfindexeddb db -s SOURCE --format
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
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
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
dfleveldb
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
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
|