2019-09-06 10:39:23 +01:00
|
|
|
import uuid
|
2019-09-06 11:04:35 +01:00
|
|
|
from io import BytesIO
|
2019-08-09 08:44:11 +01:00
|
|
|
|
2019-09-06 11:04:35 +01:00
|
|
|
from flask import flash, redirect, render_template, request, url_for
|
2019-09-06 10:39:23 +01:00
|
|
|
|
|
|
|
|
from app import current_service
|
2019-09-06 11:04:35 +01:00
|
|
|
from app.extensions import antivirus_client
|
2019-08-09 08:44:11 +01:00
|
|
|
from app.main import main
|
2019-09-06 10:39:23 +01:00
|
|
|
from app.main.forms import PDFUploadForm
|
2019-08-09 08:44:11 +01:00
|
|
|
from app.utils import user_has_permissions
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@main.route("/services/<service_id>/uploads")
|
|
|
|
|
@user_has_permissions('send_messages')
|
|
|
|
|
def uploads(service_id):
|
|
|
|
|
return render_template('views/uploads/index.html')
|
2019-09-06 10:39:23 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@main.route("/services/<service_id>/upload-letter", methods=['GET', 'POST'])
|
|
|
|
|
@user_has_permissions('send_messages')
|
|
|
|
|
def upload_letter(service_id):
|
|
|
|
|
form = PDFUploadForm()
|
|
|
|
|
|
|
|
|
|
if form.validate_on_submit():
|
2019-09-06 11:04:35 +01:00
|
|
|
pdf_file_bytes = form.file.data.read()
|
|
|
|
|
|
|
|
|
|
virus_free = antivirus_client.scan(BytesIO(pdf_file_bytes))
|
|
|
|
|
if not virus_free:
|
|
|
|
|
flash('Your file has failed the virus check', 'dangerous')
|
|
|
|
|
return render_template('views/uploads/choose-file.html', form=form), 400
|
|
|
|
|
|
2019-09-06 10:39:23 +01:00
|
|
|
upload_id = uuid.uuid4()
|
|
|
|
|
|
|
|
|
|
return redirect(
|
|
|
|
|
url_for(
|
|
|
|
|
'main.uploaded_letter_preview',
|
|
|
|
|
service_id=current_service.id,
|
|
|
|
|
file_id=upload_id,
|
|
|
|
|
original_filename=form.file.data.filename,
|
|
|
|
|
)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
return render_template('views/uploads/choose-file.html', form=form)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@main.route("/services/<service_id>/preview-letter/<file_id>")
|
|
|
|
|
@user_has_permissions('send_messages')
|
|
|
|
|
def uploaded_letter_preview(service_id, file_id):
|
|
|
|
|
original_filename = request.args.get('original_filename')
|
|
|
|
|
|
|
|
|
|
return render_template('views/uploads/preview.html', original_filename=original_filename)
|