mirror of
https://github.com/clinton-hall/nzbToMedia.git
synced 2025-07-12 08:16:03 -07:00
90 lines
3.5 KiB
Python
Executable file
90 lines
3.5 KiB
Python
Executable file
#!/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.
|
|
# 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".
|
|
print "Please check your Par-repair settings for future downloads."
|
|
sys.exit(POSTPROCESS_NONE)
|
|
|
|
if os.environ['NZBPP_PARSTATUS'] == '1' or os.environ['NZBPP_PARSTATUS'] == '4':
|
|
print "Par-repair 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'] == '0':
|
|
# Unpack was skipped due to nzb-file properties or due to errors during par-check
|
|
|
|
if os.environ['NZBPP_HEALTH'] < 1000:
|
|
print "Download health is compromised and Par-check/repair disabled or no .par2 files found. Setting status \"failed\"."
|
|
print "Please check your Par-check/repair settings for future downloads."
|
|
status = 1
|
|
|
|
else:
|
|
print "Par-check/repair disabled or no .par2 files found, and Unpack not required. Health is ok so handle as though download successful".
|
|
print "Please check your Par-check/repair settings for future downloads."
|
|
|
|
# Check if destination directory exists (important for reprocessing of history items)
|
|
if not os.path.isdir(os.environ['NZBPP_DIRECTORY']):
|
|
print "Nothing to post-process: destination directory", os.environ['NZBPP_DIRECTORY'], "doesn't exist. Setting status \"failed\"."
|
|
status = 1
|
|
|
|
# All checks done, now launching the script.
|
|
|
|
if status == 1:
|
|
sys.exit(POSTPROCESS_NONE)
|
|
|
|
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
|
|
try:
|
|
os.utime(filepath, None)
|
|
continue
|
|
except:
|
|
print "Error: unable to reset time for file", filePath
|
|
sys.exit(POSTPROCESS_ERROR)
|
|
sys.exit(POSTPROCESS_SUCCESS)
|
|
|
|
else:
|
|
print "This script can only be called from NZBGet (11.0 or later)."
|
|
sys.exit(0)
|