fix level and format parameters when more than one given
This commit is contained in:
parent
ff31611d46
commit
947c25d34d
2 changed files with 32 additions and 32 deletions
29
README.md
29
README.md
|
@ -18,8 +18,9 @@ Full example on how to use the script:
|
||||||
```bash
|
```bash
|
||||||
python exporter.py \
|
python exporter.py \
|
||||||
-H https://wiki.example.com \
|
-H https://wiki.example.com \
|
||||||
-f pdf,md,plaintext,html \
|
-f pdf md plaintext html \
|
||||||
-l pages,chapters,books
|
-l pages chapters books \
|
||||||
|
--force-update-files \
|
||||||
-t ./token.txt \
|
-t ./token.txt \
|
||||||
-V debug \
|
-V debug \
|
||||||
-p ./
|
-p ./
|
||||||
|
@ -29,25 +30,19 @@ Customization:
|
||||||
```text
|
```text
|
||||||
options:
|
options:
|
||||||
-p PATH, --path PATH Path where exported files will be placed.
|
-p PATH, --path PATH Path where exported files will be placed.
|
||||||
Default: .
|
|
||||||
-t TOKEN_FILE, --token-file TOKEN_FILE
|
-t TOKEN_FILE, --token-file TOKEN_FILE
|
||||||
File containing authorization token in format TOKEN_ID:TOKEN_SECRET
|
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
|
-H HOST, --host HOST Your domain with protocol prefix, example: https://example.com
|
||||||
Default: https://localhost
|
-f {markdown,plaintext,pdf,html} [{markdown,plaintext,pdf,html} ...],
|
||||||
-f FORMATS, --formats FORMATS
|
--formats {markdown,plaintext,pdf,html} [{markdown,plaintext,pdf,html} ...]
|
||||||
Coma separated list of formats to use for export.
|
Space separated list of formats to use for export.
|
||||||
Available ones: markdown,plaintext,pdf,html
|
-l {pages,chapters,books} [{pages,chapters,books} ...], --level {pages,chapters,books} [{pages,chapters,books} ...]
|
||||||
default: markdown
|
Space separated list of levels at which should be export performed.
|
||||||
-l LEVEL, --level LEVEL
|
--force-update-files Set this option to skip checking local files timestamps against remote last edit
|
||||||
Coma separated list of levels at which should be export performed.
|
timestamps.This will cause overwriting local files, even if they seem to be already in
|
||||||
Available levels: ['pages', 'chapters', 'books']
|
newest version.
|
||||||
Default: pages
|
-V {debug,info,warning,error}, --log-level {debug,info,warning,error}
|
||||||
-V LOG_LEVEL, --log-level LOG_LEVEL
|
|
||||||
Set verbosity level.
|
Set verbosity level.
|
||||||
Available levels: dict_keys(['debug', 'info', 'warning', 'error'])
|
|
||||||
Default: info
|
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### TODO:
|
### TODO:
|
||||||
|
|
33
exporter.py
33
exporter.py
|
@ -37,22 +37,23 @@ parser.add_argument('-t', '--token-file', type=str, default=f'.{os.path.sep}toke
|
||||||
help='File containing authorization token in format TOKEN_ID:TOKEN_SECRET')
|
help='File containing authorization token in format TOKEN_ID:TOKEN_SECRET')
|
||||||
parser.add_argument('-H', '--host', type=str, default='https://localhost',
|
parser.add_argument('-H', '--host', type=str, default='https://localhost',
|
||||||
help='Your domain with protocol prefix, example: https://example.com')
|
help='Your domain with protocol prefix, example: https://example.com')
|
||||||
parser.add_argument('-f', '--formats', type=str, default='markdown',
|
parser.add_argument('-f', '--formats', type=str, default=['markdown'], nargs="+",
|
||||||
help=f'Coma separated list of formats to use for export.', choices=FORMATS.keys())
|
help=f'Space separated list of formats to use for export.', choices=FORMATS.keys())
|
||||||
parser.add_argument('-l', '--level', type=str, default='pages',
|
parser.add_argument('-l', '--level', type=str, default=['pages'], nargs="+",
|
||||||
help=f'Coma separated list of levels at which should be export performed. ', choices=LEVELS)
|
help=f'Space separated list of levels at which should be export performed. ', choices=LEVELS)
|
||||||
|
parser.add_argument('--force-update-files', action='store_true',
|
||||||
|
help="Set this option to skip checking local files timestamps against remote last edit timestamps."
|
||||||
|
"This will cause overwriting local files, even if they seem to be already in newest version.")
|
||||||
|
parser.set_defaults(force_update_files=False)
|
||||||
parser.add_argument('-V', '--log-level', type=str, default='info',
|
parser.add_argument('-V', '--log-level', type=str, default='info',
|
||||||
help=f'Set verbosity level. ', choices=LOG_LEVEL.keys())
|
help=f'Set verbosity level. ', choices=LOG_LEVEL.keys())
|
||||||
|
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
|
||||||
if args.log_level not in LOG_LEVEL.keys():
|
|
||||||
error(f"Bad log level {args.log_level}, available levels: {LOG_LEVEL.keys()}")
|
|
||||||
exit(1)
|
|
||||||
|
|
||||||
logging.basicConfig(format='%(levelname)s :: %(message)s', level=LOG_LEVEL.get(args.log_level))
|
logging.basicConfig(format='%(levelname)s :: %(message)s', level=LOG_LEVEL.get(args.log_level))
|
||||||
|
|
||||||
formats = args.formats.split(',')
|
formats: list[str] = args.formats
|
||||||
|
|
||||||
for frmt in formats:
|
for frmt in formats:
|
||||||
if frmt not in FORMATS.keys():
|
if frmt not in FORMATS.keys():
|
||||||
error("Unknown format name (NOT file extension), "
|
error("Unknown format name (NOT file extension), "
|
||||||
|
@ -61,7 +62,7 @@ for frmt in formats:
|
||||||
|
|
||||||
API_PREFIX: str = f"{args.host.removesuffix(os.path.sep)}/api"
|
API_PREFIX: str = f"{args.host.removesuffix(os.path.sep)}/api"
|
||||||
FS_PATH: str = args.path.removesuffix(os.path.sep)
|
FS_PATH: str = args.path.removesuffix(os.path.sep)
|
||||||
LEVEL_CHOICE: list[str] = args.level.split(',')
|
LEVEL_CHOICE: list[str] = args.level
|
||||||
for lvl in LEVEL_CHOICE:
|
for lvl in LEVEL_CHOICE:
|
||||||
if lvl not in LEVELS:
|
if lvl not in LEVELS:
|
||||||
error(f"Level {lvl} is not supported, can be only one of {LEVELS}")
|
error(f"Level {lvl} is not supported, can be only one of {LEVELS}")
|
||||||
|
@ -72,6 +73,7 @@ with open(args.token_file, 'r') as f:
|
||||||
|
|
||||||
HEADERS = {'Content-Type': 'application/json; charset=utf-8',
|
HEADERS = {'Content-Type': 'application/json; charset=utf-8',
|
||||||
'Authorization': f"Token {TOKEN}"}
|
'Authorization': f"Token {TOKEN}"}
|
||||||
|
SKIP_TIMESTAMPS: bool = args.force_update_files
|
||||||
|
|
||||||
|
|
||||||
class Node:
|
class Node:
|
||||||
|
@ -194,6 +196,10 @@ def api_get_listing(path: str) -> list:
|
||||||
|
|
||||||
|
|
||||||
def check_if_update_needed(file_path: str, document: Node) -> bool:
|
def check_if_update_needed(file_path: str, document: Node) -> bool:
|
||||||
|
if SKIP_TIMESTAMPS:
|
||||||
|
return True
|
||||||
|
debug(f"Checking for update for file {file_path}")
|
||||||
|
|
||||||
if not os.path.exists(file_path):
|
if not os.path.exists(file_path):
|
||||||
debug(f"Document {file_path} is missing on disk, update needed.")
|
debug(f"Document {file_path} is missing on disk, update needed.")
|
||||||
return True
|
return True
|
||||||
|
@ -205,10 +211,10 @@ def check_if_update_needed(file_path: str, document: Node) -> bool:
|
||||||
changes: int = document.changed_since(local_last_edit)
|
changes: int = document.changed_since(local_last_edit)
|
||||||
|
|
||||||
if changes > 0:
|
if changes > 0:
|
||||||
info(f"Document \"{document.get_name()}\" consists of {changes} outdated documents, update needed.")
|
info(f"Document \"{file_path}\" consists of {changes} outdated documents, update needed.")
|
||||||
return True
|
return True
|
||||||
|
|
||||||
debug(f"Document \"{document.get_name()}\" consists of {changes} outdated documents.")
|
debug(f"Document \"{file_path}\" consists of {changes} outdated documents, skipping updating.")
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
@ -218,9 +224,8 @@ def export(documents: list[Node], level: str):
|
||||||
|
|
||||||
for frmt in formats:
|
for frmt in formats:
|
||||||
path: str = f"{FS_PATH}{os.path.sep}{document.get_path()}{os.path.sep}{document.get_name()}.{FORMATS[frmt]}"
|
path: str = f"{FS_PATH}{os.path.sep}{document.get_path()}{os.path.sep}{document.get_name()}.{FORMATS[frmt]}"
|
||||||
debug(f"Checking for update for file {path}")
|
|
||||||
if not check_if_update_needed(path, document):
|
if not check_if_update_needed(path, document):
|
||||||
debug("Already updated")
|
|
||||||
continue
|
continue
|
||||||
|
|
||||||
data: bytes = api_get_bytes(f'{level}/{document.get_id()}/export/{frmt}')
|
data: bytes = api_get_bytes(f'{level}/{document.get_id()}/export/{frmt}')
|
||||||
|
|
Loading…
Reference in a new issue