Since 2017 the feature to save and manage Dev Tools console commands is still being worked on elastic/kibana#10095.
In the meantime, I have not found any tool that would help to backup consoles queries easily for cases when your browsers data was cleared. So...
Kibana Dev Tools Saver is a Python script designed to extract and save Kibana's Dev Tools console data from Google Chrome's localStorage
. It navigates through the LevelDB storage utilized by Chrome to store web data and filters out Kibana console queries for specified origins. The script offers flexibility in output options, allowing users to save the queries to files or view them directly in the console.
Note: Only
Google Chrome's
localStorage is supported at the moment.
- Extract Dev Tools Queries: Navigate Chrome's underlying LevelDB structure to access
localStorage
data related to Kibana's Dev Tools. - Configurable Origins: Specify which Kibana instances (by origin) you want to extract queries from.
- Flexible Output: Choose to print extracted queries to the console or save them to files.
- Continuous Monitoring: Option to keep the script running and periodically update the saved queries.
- Logging & Error Handling: Comprehensive logging provides insights into the script's operations and any potential issues.
- Customizable Directories: Specify source and temporary directories for Chrome's LevelDB.
Ensure you have Python3 and the required libraries installed:
pip3 install plyvel argparse logging
OR
pip3 install -r requirements.txt
- Clone the repository:
git clone https://github.com/yourusername/kibana-dev-tools-saver.git
cd kibana-dev-tools-saver
- Run the script:
python3 kibana-dev-tools-saver.py
Short | Long | Description |
---|---|---|
-sd |
--source-dir |
Specify the source directory of Chrome's LevelDB. (Default set in the script) |
-td |
--temp-dir |
Specify a temporary directory to copy LevelDB for processing. (Default set in the script) |
-sf |
--save-folder |
Specify a target folder to save the console outputs. (Defaults to console output if not specified) |
-p |
--prefix |
Add a prefix to the saved file names. (Optional) |
-t |
--time |
Set a time interval (in seconds) for how often the script should rerun and refresh the saved queries. (Optional) |
-q |
--quiet |
Suppress certain output logs. Useful when you're saving to a file and don't want to see every update in the console. |
-ku |
--kibana-urls |
Specify Kibana URLs separated by a comma to indicate from which origins you'd like to extract data. |
As I developed it in Windows 10 WSL v2 Ubuntu Linux the path to Chrome localStorage folder is specified through the mount.
Specify custom LevelDB directories and Kibana URLs: Replace with your Windows username.
python3 kibana-dev-tools-saver.py -sd "/mnt/c/Users/<user>/AppData/Local/Google/Chrome/User Data/Default/Local Storage/leveldb/" -ku "https://kibana1.example.com,https://kibana2.example.com"
Run continuously every 60 seconds in quite mode and save to specific folder with a prefix using specific temp folder:
python3 kibana-dev-tools-saver.py -t 60 -sf /path/to/save -p myprefix_ -td /tmp/kibana-dev-tools-saver -q
Instead of using arguments you can specify defaults inside of the script.
Sometimes the script copies levelDB while Chrome is writting to it, which results in the script's copy of this DB stored in temp to become corrupted. Re-run the script few more times to see if the problem disappears, or else open an issue and provide information about your env.
Traceback (most recent call last):
File "/opt/work/kibana-dev-tools-saver/./kibana-dev-tools-saver.py", line 121, in <module>
main()
File "/opt/work/kibana-dev-tools-saver/./kibana-dev-tools-saver.py", line 88, in main
for origin, text_content in extract_console_data_from_leveldb():
File "/opt/work/kibana-dev-tools-saver/./kibana-dev-tools-saver.py", line 71, in extract_console_data_from_leveldb
db = plyvel.DB(args.temp_dir, create_if_missing=False)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "plyvel/_plyvel.pyx", line 247, in plyvel._plyvel.DB.__init__
File "plyvel/_plyvel.pyx", line 91, in plyvel._plyvel.raise_for_status
plyvel._plyvel.CorruptionError: b'Corruption: 1 missing files; e.g.: /tmp/kibana-dev-tools-saver//000446.ldb'
This tool is provided "as is" without any warranties or guarantees of any kind. Users should use Kibana Dev Tools Saver responsibly and at their own risk. Always make sure to have backups of important data. The author or contributors are not responsible for any loss of data, adverse effects, or any other negative impacts resulting from the use of this script. Make sure to always review the code and understand its operations before executing it in a live environment.
Feel free to submit issues/suggestions, or make changes and open pull requests. All contributions are welcome!
This project is open-source and available under the MIT License.