#!/usr/bin/env python # ############################################################################## ### NZBGET POST-PROCESSING SCRIPT ### # Reset the Date Modified and Date Created for downlaoded files. # # This is useful for sorting "newly added" media. # This should run before other scripts. # # NOTE: This script requires Python to be installed on your system. ### NZBGET POST-PROCESSING SCRIPT ### ############################################################################## import os import sys # NZBGet V11+ # Check if the script is called from nzbget 11.0 or later if os.environ.has_key('NZBOP_SCRIPTDIR') and not os.environ['NZBOP_VERSION'][0:5] < '11.0': print "Script triggered from NZBGet (11.0 or later)." # NZBGet argv: all passed as environment variables. clientAgent = "nzbget" # Exit codes used by NZBGet POSTPROCESS_PARCHECK=92 POSTPROCESS_SUCCESS=93 POSTPROCESS_ERROR=94 POSTPROCESS_NONE=95 # Check nzbget.conf options status = 0 if os.environ['NZBOP_UNPACK'] != 'yes': print "Please enable option \"Unpack\" in nzbget configuration file, exiting" sys.exit(POSTPROCESS_ERROR) # Check par status if os.environ['NZBPP_PARSTATUS'] == '3': print "Par-check successful, but Par-repair disabled, exiting" sys.exit(POSTPROCESS_NONE) if os.environ['NZBPP_PARSTATUS'] == '1': print "Par-check failed, setting status \"failed\"" status = 1 # Check unpack status if os.environ['NZBPP_UNPACKSTATUS'] == '1': print "Unpack failed, setting status \"failed\"" status = 1 if os.environ['NZBPP_UNPACKSTATUS'] == '0' and os.environ['NZBPP_PARSTATUS'] != '2': # Unpack is disabled or was skipped due to nzb-file properties or due to errors during par-check for dirpath, dirnames, filenames in os.walk(os.environ['NZBPP_DIRECTORY']): for file in filenames: fileExtension = os.path.splitext(file)[1] if fileExtension in ['.rar', '.7z'] or os.path.splitext(fileExtension)[1] in ['.rar', '.7z']: print "Post-Process: Archive files exist but unpack skipped, setting status \"failed\"" status = 1 break if fileExtension in ['.par2']: print "Post-Process: Unpack skipped and par-check skipped (although par2-files exist), setting status \"failed\"g" status = 1 break if os.path.isfile(os.path.join(os.environ['NZBPP_DIRECTORY'], "_brokenlog.txt")) and not status == 1: print "Post-Process: _brokenlog.txt exists, download is probably damaged, exiting" status = 1 if not status == 1: print "Neither archive- nor par2-files found, _brokenlog.txt doesn't exist, considering download successful" # Check if destination directory exists (important for reprocessing of history items) if not os.path.isdir(os.environ['NZBPP_DIRECTORY']): print "Post-Process: Nothing to post-process: destination directory ", os.environ['NZBPP_DIRECTORY'], "doesn't exist" status = 1 # All checks done, now launching the script. directory = os.path.normpath(os.environ['NZBPP_DIRECTORY']) for dirpath, dirnames, filenames in os.walk(directory): for file in filenames: filepath = os.path.join(dirpath, file) print "reseting datetime for file", filepath os.utime(filepath, None) continue sys.exit(POSTPROCESS_SUCCESS) else: print "This script can only be called from NZBGet (11.0 or later)." sys.exit(0)