No description
Find a file
2022-07-26 17:30:08 +02:00
.gitignore Initial commit 2022-05-13 20:44:05 +02:00
exporter.py add timestamps checking to prevent update of files that contain newest version 2022-07-26 17:30:08 +02:00
LICENSE Initial commit 2022-05-13 18:14:52 +00:00
README.md add verbosity option, update README 2022-06-23 13:50:06 +02:00

BookStack-Python-exporter

Customizable script for exporting notes from BookStack through API

Features:

  • export keeping the tree structure by making folders from Shelves, Books and Chapters
  • export multiple formats at once
  • export at multiple levels at once (export Books or/and Chapters or/and Pages as files)
  • customizable path for placing exported notes
  • authorization token is loaded from txt file

Requirements:

  • Python at least in version 3.6

Full example on how to use the script:

  1. Clone the repo
  2. next to the script place token.txt file containing token id and token secret in format: TOKEN_ID:TOKEN_SECRET
  3. in the same directory run the command, specifying your app domain with https prefix (every parameter is optional as it have default value, this is a full possible example):
python exporter.py \
    -H https://wiki.example.com \
    -f pdf,md,plaintext,html \
    -l pages,chapters,books
    -t ./token.txt \
    -V debug \
    -p ./ 

Customization:

options:
  -p PATH, --path PATH  Path where exported files will be placed.
                        Default: .
  -t TOKEN_FILE, --token-file TOKEN_FILE
                        File containing authorization token in format TOKEN_ID:TOKEN_SECRET
                        Default: ./token.txt
  -H HOST, --host HOST  Your domain with protocol prefix, example: https://example.com
                        Default: https://localhost
  -f FORMATS, --formats FORMATS
                        Coma separated list of formats to use for export. 
                        Available ones: markdown,plaintext,pdf,html
                        default: markdown
  -l LEVEL, --level LEVEL
                        Coma separated list of levels at which should be export performed. 
                        Available levels: ['pages', 'chapters', 'books']
                        Default: pages
  -V LOG_LEVEL, --log-level LOG_LEVEL
                        Set verbosity level. 
                        Available levels: dict_keys(['debug', 'info', 'warning', 'error'])
                        Default: info

TODO:

  • choosing verbosity level through command line parameter Done
  • choosing on what level should the notes be exported (Books, Chapters, Pages) Done
  • WIP: choosing if update note file only if the last edit timestamp from API is later that the local file timestamp
  • suggestions?