ece73b5b2a
Wrap all loggers used by job, extractor, downloader, and postprocessor objects into a (custom) LoggerAdapter that provides access to the underlying job, extractor, pathfmt, and kwdict objects and their properties. __init__() signatures for all downloader and postprocessor classes have been changed to take the current Job object as their first argument, instead of the current extractor or pathfmt. (#574, #575)
41 lines
1.1 KiB
Python
41 lines
1.1 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright 2018-2020 Mike Fährmann
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License version 2 as
|
|
# published by the Free Software Foundation.
|
|
|
|
"""Common classes and constants used by postprocessor modules."""
|
|
|
|
|
|
class PostProcessor():
|
|
"""Base class for postprocessors"""
|
|
|
|
def __init__(self, job):
|
|
name = self.__class__.__name__[:-2].lower()
|
|
self.log = job.get_logger("postprocessor." + name)
|
|
|
|
@staticmethod
|
|
def prepare(pathfmt):
|
|
"""Update file paths, etc."""
|
|
|
|
@staticmethod
|
|
def run(pathfmt):
|
|
"""Execute the postprocessor for a file"""
|
|
|
|
@staticmethod
|
|
def run_metadata(pathfmt):
|
|
"""Execute the postprocessor for a file"""
|
|
|
|
@staticmethod
|
|
def run_after(pathfmt):
|
|
"""Execute postprocessor after moving a file to its target location"""
|
|
|
|
@staticmethod
|
|
def run_final(pathfmt, status):
|
|
"""Postprocessor finalization after all files have been downloaded"""
|
|
|
|
def __repr__(self):
|
|
return self.__class__.__name__
|