AutomatedFanfic/root/app/runner_notify.py

175 lines
5.5 KiB
Python
Raw Normal View History

2020-12-22 09:06:55 +00:00
from io import StringIO
2016-09-08 10:09:42 +00:00
import re
from subprocess import check_output, STDOUT
2021-07-01 11:16:34 +00:00
from time import sleep
import ntpath
2016-09-08 10:09:42 +00:00
from os import utime
from os.path import join
2016-09-08 10:09:42 +00:00
2017-07-03 08:29:04 +00:00
from pushbullet import Pushbullet
2016-09-08 10:09:42 +00:00
from optparse import OptionParser
2020-12-22 09:06:55 +00:00
from configparser import ConfigParser
2016-09-08 10:09:42 +00:00
def enable_notifications(options):
if options.pushbullet:
fail = False
try:
pb = Pushbullet(options.pushbullet)
2017-09-18 19:41:09 +00:00
except BaseException:
2020-12-22 09:06:55 +00:00
print("Problem wtih connecting to pushbullet. API Key likely invalid")
fail = True
if options.pbdevice and not fail:
2016-09-08 10:09:42 +00:00
try:
pb = pb.get_device(options.pbdevice)
2017-09-18 19:41:09 +00:00
except BaseException:
2020-12-22 09:06:55 +00:00
print("Cannot get this device.")
fail = True
2016-09-08 10:09:42 +00:00
pass
if not fail:
temp_note = Notification()
temp_note.send_notification = pb.push_note
yield temp_note
2017-09-18 19:41:09 +00:00
2016-09-08 10:09:42 +00:00
def touch(fname, times=None):
with open(fname, 'a'):
utime(fname, times)
2017-09-18 19:41:09 +00:00
2016-09-08 10:09:42 +00:00
def main(options):
try:
2017-09-18 19:41:09 +00:00
res = check_output(
"python3.9 fanficdownload.py -c config.ini",
2017-09-18 19:41:09 +00:00
shell=True,
stderr=STDOUT)
except Exception as e:
2020-12-22 09:06:55 +00:00
print(e)
res = None
if not res:
return
else:
2020-12-22 09:06:55 +00:00
res = res.decode('utf-8')
print(res)
2016-09-08 10:09:42 +00:00
buf = StringIO(res)
regex = re.compile("Added (?:.*/)?(.*)-.* to library with id \d*")
searcher = regex.search
stripper = False
2016-09-08 10:09:42 +00:00
for line in buf.readlines():
r = searcher(line)
2016-09-08 10:09:42 +00:00
if r:
2021-07-01 11:16:34 +00:00
story = ntpath.basename(r.group(1).strip())
stripper = True
2016-09-08 10:09:42 +00:00
for notify in enable_notifications(options):
notify.send_notification("New Fanfiction Download", story)
if stripper and options.tag:
2017-07-03 03:48:57 +00:00
import sqlite3
with sqlite3.connect(join(options.library_path, "metadata.db")) as conn:
c = conn.cursor()
c.execute("delete from books_tags_link where id in (select id from books_tags_link where tag in (select id from tags where name like '%Last Update%'));")
2016-09-08 10:09:42 +00:00
return
2017-09-18 19:41:09 +00:00
2016-09-08 10:09:42 +00:00
if __name__ == "__main__":
option_parser = OptionParser(usage="usage: %prog [flags]")
2017-09-18 19:41:09 +00:00
option_parser.add_option(
'-p',
'--pushbullet',
action='store',
dest='pushbullet',
help='If you want to use pushbullet, pass in your key here.')
option_parser.add_option(
'-d',
'--device',
action='store',
dest='pbdevice',
help='If you wish to only send to a certian pushbullet device, put the device name here. If the device name is invalid, will just send to all pushbullets associated with the acc')
option_parser.add_option(
'-n',
'--notify',
action='store_true',
dest='notify',
help='Enable if you want to use system notifications. Only for Win/Linux.')
option_parser.add_option(
'-c',
'--config',
action='store',
dest='config',
help='Config file for inputs. Blank config file is provided. No default. If an option is present in whatever config file is passed it, the option will overwrite whatever is passed in through command line arguments unless the option is blank. Do not put any quotation marks in the options.')
option_parser.add_option(
'-t',
'--tag',
action='store_true',
dest='tag',
help='Strip Last Updated tags from calibredb. Requires library to be passed in.')
option_parser.add_option(
'-l',
'--library',
action='store',
dest='library',
help='Path to calibre library. If you are connecting to a calibre webserver then this should be the url.')
option_parser.add_option(
'-a',
'--library-path',
action='store',
dest='library_path',
help='Path location of library. Will be equal to library if nothing is passed in.')
2016-09-08 10:09:42 +00:00
(options, args) = option_parser.parse_args()
2017-09-18 19:41:09 +00:00
if options.library and not options.library_path:
options.library_path = options.library
2016-09-08 10:09:42 +00:00
if options.config:
touch(options.config)
config = ConfigParser(allow_no_value=True)
config.read(options.config)
2017-09-18 19:41:09 +00:00
def updater(option, newval): return newval if newval != "" else option
try:
options.pushbullet = updater(
options.pushbullet, config.get(
'runner', 'pushbullet'))
except BaseException:
pass
try:
options.pbdevice = updater(
options.pbdevice, config.get(
'runner', 'pbdevice'))
except BaseException:
pass
try:
options.tag = updater(
options.tag, config.getboolean(
'runner', 'tag'))
except BaseException:
pass
try:
options.library = updater(
options.library, config.get(
'locations', 'library'))
except BaseException:
pass
try:
options.library_path = updater(
options.library, config.get(
'locations', 'library_path'))
except BaseException:
pass
2016-09-08 10:09:42 +00:00
if options.pbdevice and not options.pushbullet:
raise ValueError("Can't use a pushbullet device without key")
if options.tag and not options.library:
2017-09-18 19:41:09 +00:00
raise ValueError(
"Can't strip tags from calibre library without a library location.")
2021-07-01 11:16:34 +00:00
while(True):
main(options)
sleep(60)