106 lines
2.4 KiB
Python
106 lines
2.4 KiB
Python
# https://github.com/python-escpos/python-escpos
|
|
# https://python-escpos.readthedocs.io/en/latest/
|
|
|
|
import sys
|
|
import os
|
|
import re
|
|
import flask
|
|
from flask import request
|
|
import flask_apscheduler
|
|
import urllib
|
|
import json
|
|
from datetime import datetime
|
|
from escpos.escpos import Escpos
|
|
from escpos import printer
|
|
|
|
# Create the application.
|
|
APP = flask.Flask(__name__)
|
|
|
|
# Connect to the printer
|
|
# Get the printer's USB initializing code with $ sudo lsbusb
|
|
lp = printer.Usb(0x4b8,0xe15)
|
|
|
|
# Define the JSON databased for storing printed items
|
|
db = 'printed.json'
|
|
if not os.path.exists(db):
|
|
with open(db, 'w') as f:
|
|
f.write(json.dumps({ "printed" : [] }, indent=4))
|
|
|
|
# Check the Multifeeder regulary (every 10 min)
|
|
# https://github.com/viniciuschiele/flask-apscheduler
|
|
# Thanks Crunk for pointing to this extention!
|
|
scheduler = flask_apscheduler.APScheduler()
|
|
scheduler.api_enabled = False
|
|
scheduler.init_app(APP)
|
|
scheduler.start()
|
|
|
|
def update_db(item):
|
|
items = json.loads(open(db).read())
|
|
if not item in items['printed']:
|
|
with open(db, 'w') as out:
|
|
items['printed'].append(item)
|
|
out.write(json.dumps(items, indent=4))
|
|
out.close()
|
|
|
|
def html2plain(html):
|
|
plain = re.sub('<[^<]+?>', '', text)
|
|
return plain
|
|
|
|
@scheduler.task('interval', id='check', minutes=10)
|
|
def check():
|
|
print('Checking the Multifeeder!')
|
|
|
|
url = 'https://multi.vvvvvvaria.org/API/latest/10'
|
|
response = urllib.request.urlopen(url).read()
|
|
feed = json.loads(response)
|
|
for post in feed:
|
|
year = post['published_parsed'][0]
|
|
month = post['published_parsed'][1]
|
|
day = post['published_parsed'][2]
|
|
post_date = date(year, month, day)
|
|
|
|
plaintext = html2plain(post.summary)
|
|
|
|
item = {
|
|
'source' : post.feed_details.rss,
|
|
'date' : post_date,
|
|
'printed' : plaintext
|
|
}
|
|
update_db(item)
|
|
|
|
@APP.route('/print/', methods=['GET', 'POST'])
|
|
def print():
|
|
|
|
buffer = printer.Dummy()
|
|
plaintext = request.args.get('printing', '')
|
|
|
|
if plaintext:
|
|
|
|
buffer.text(plaintext)
|
|
buffer.cut()
|
|
|
|
lp._raw(buffer.output)
|
|
|
|
date = datetime.now()
|
|
date_str = date.strftime('%Y-%m-%d_%H-%M-%S')
|
|
|
|
item = {
|
|
'source' : 'TeleVex',
|
|
'date' : date_str,
|
|
'printed' : plaintext
|
|
}
|
|
update_db(item)
|
|
|
|
return flask.render_template('index.html', plaintext=plaintext)
|
|
|
|
@APP.route('/printed/', methods=['GET', 'POST'])
|
|
def printed():
|
|
|
|
items = json.loads(open(db).read())
|
|
|
|
return flask.render_template('printed.html', items=items)
|
|
|
|
if __name__ == '__main__':
|
|
APP.debug=True
|
|
APP.run(port=5000)
|