2016-02-22 17:17:18 +00:00
|
|
|
|
import re
|
2016-04-12 14:19:51 +01:00
|
|
|
|
import csv
|
|
|
|
|
|
from io import StringIO
|
2016-02-19 16:38:04 +00:00
|
|
|
|
from functools import wraps
|
2016-03-16 16:57:10 +00:00
|
|
|
|
from flask import (abort, session, request, url_for)
|
2016-02-19 16:38:04 +00:00
|
|
|
|
|
|
|
|
|
|
|
2016-01-18 11:15:14 +00:00
|
|
|
|
class BrowsableItem(object):
|
|
|
|
|
|
"""
|
|
|
|
|
|
Maps for the template browse-list.
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
def __init__(self, item, *args, **kwargs):
|
|
|
|
|
|
self._item = item
|
|
|
|
|
|
super(BrowsableItem, self).__init__()
|
|
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
|
def title(self):
|
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
|
def link(self):
|
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
|
def hint(self):
|
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
@property
|
|
|
|
|
|
def destructive(self):
|
|
|
|
|
|
pass
|
2016-02-01 16:57:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
2016-03-30 11:30:18 +01:00
|
|
|
|
def user_has_permissions(*permissions, admin_override=False, any_=False):
|
2016-02-19 16:38:04 +00:00
|
|
|
|
def wrap(func):
|
|
|
|
|
|
@wraps(func)
|
|
|
|
|
|
def wrap_func(*args, **kwargs):
|
|
|
|
|
|
from flask_login import current_user
|
2016-03-18 16:20:37 +00:00
|
|
|
|
if current_user and current_user.has_permissions(permissions=permissions,
|
2016-03-30 11:30:18 +01:00
|
|
|
|
admin_override=admin_override, any_=any_):
|
2016-02-29 14:57:07 +00:00
|
|
|
|
return func(*args, **kwargs)
|
|
|
|
|
|
else:
|
2016-02-19 16:38:04 +00:00
|
|
|
|
abort(403)
|
|
|
|
|
|
return wrap_func
|
|
|
|
|
|
return wrap
|
2016-03-07 18:47:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def get_errors_for_csv(recipients, template_type):
|
|
|
|
|
|
|
|
|
|
|
|
errors = []
|
|
|
|
|
|
|
|
|
|
|
|
missing_column_headers = list(recipients.missing_column_headers)
|
|
|
|
|
|
|
|
|
|
|
|
if len(missing_column_headers) == 1:
|
|
|
|
|
|
errors.append("add a column called ‘{}’".format("".join(missing_column_headers)))
|
|
|
|
|
|
elif len(missing_column_headers) == 2:
|
|
|
|
|
|
errors.append("add 2 columns, ‘{}’".format("’ and ‘".join(missing_column_headers)))
|
|
|
|
|
|
elif len(missing_column_headers) > 2:
|
|
|
|
|
|
errors.append(
|
|
|
|
|
|
"add columns called ‘{}’, and ‘{}’".format(
|
|
|
|
|
|
"’, ‘".join(missing_column_headers[0:-1]),
|
|
|
|
|
|
missing_column_headers[-1]
|
|
|
|
|
|
)
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
if recipients.rows_with_bad_recipients:
|
|
|
|
|
|
number_of_bad_recipients = len(list(recipients.rows_with_bad_recipients))
|
|
|
|
|
|
if 'sms' == template_type:
|
|
|
|
|
|
if 1 == number_of_bad_recipients:
|
|
|
|
|
|
errors.append("fix 1 phone number")
|
|
|
|
|
|
else:
|
|
|
|
|
|
errors.append("fix {} phone numbers".format(number_of_bad_recipients))
|
|
|
|
|
|
elif 'email' == template_type:
|
|
|
|
|
|
if 1 == number_of_bad_recipients:
|
|
|
|
|
|
errors.append("fix 1 email address")
|
|
|
|
|
|
else:
|
|
|
|
|
|
errors.append("fix {} email addresses".format(number_of_bad_recipients))
|
|
|
|
|
|
|
|
|
|
|
|
if recipients.rows_with_missing_data:
|
|
|
|
|
|
number_of_rows_with_missing_data = len(list(recipients.rows_with_missing_data))
|
|
|
|
|
|
if 1 == number_of_rows_with_missing_data:
|
2016-04-18 11:27:23 +01:00
|
|
|
|
errors.append("enter missing data in 1 row")
|
2016-03-07 18:47:05 +00:00
|
|
|
|
else:
|
2016-04-18 11:27:23 +01:00
|
|
|
|
errors.append("enter missing data in {} rows".format(number_of_rows_with_missing_data))
|
2016-03-07 18:47:05 +00:00
|
|
|
|
|
|
|
|
|
|
return errors
|
2016-03-16 16:57:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
2016-04-12 14:19:51 +01:00
|
|
|
|
def generate_notifications_csv(json_list):
|
|
|
|
|
|
from app import format_datetime
|
|
|
|
|
|
content = StringIO()
|
|
|
|
|
|
retval = None
|
|
|
|
|
|
with content as csvfile:
|
|
|
|
|
|
csvwriter = csv.writer(csvfile)
|
|
|
|
|
|
csvwriter.writerow(['Recipient', 'Template', 'Type', 'Job', 'Status', 'Time'])
|
|
|
|
|
|
for x in json_list:
|
|
|
|
|
|
csvwriter.writerow([
|
|
|
|
|
|
x['to'],
|
|
|
|
|
|
x['template']['name'],
|
|
|
|
|
|
x['template']['template_type'],
|
|
|
|
|
|
x['job']['original_file_name'],
|
|
|
|
|
|
x['status'],
|
|
|
|
|
|
format_datetime(x['created_at'])])
|
|
|
|
|
|
retval = content.getvalue()
|
|
|
|
|
|
return retval
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-03-16 16:57:10 +00:00
|
|
|
|
def get_page_from_request():
|
|
|
|
|
|
if 'page' in request.args:
|
|
|
|
|
|
try:
|
|
|
|
|
|
return int(request.args['page'])
|
|
|
|
|
|
except ValueError:
|
|
|
|
|
|
return None
|
|
|
|
|
|
else:
|
|
|
|
|
|
return 1
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-04-04 16:34:06 +01:00
|
|
|
|
def generate_previous_next_dict(view, service_id, view_dict, page, title, label):
|
|
|
|
|
|
if 'page' in view_dict:
|
|
|
|
|
|
view_dict.pop('page')
|
|
|
|
|
|
if 'service_id' in view_dict:
|
|
|
|
|
|
view_dict.pop('service_id')
|
2016-03-16 16:57:10 +00:00
|
|
|
|
return {
|
2016-04-04 16:34:06 +01:00
|
|
|
|
'url': url_for(view, service_id=service_id, page=page, **view_dict),
|
2016-03-16 16:57:10 +00:00
|
|
|
|
'title': title,
|
|
|
|
|
|
'label': label
|
|
|
|
|
|
}
|
2016-03-30 17:12:00 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def email_safe(string):
|
|
|
|
|
|
return "".join([
|
|
|
|
|
|
character.lower() if character.isalnum() or character == "." else "" for character in re.sub("\s+", ".", string.strip()) # noqa
|
|
|
|
|
|
])
|