2018-06-21 15:50:01 -04:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
import re
|
|
|
|
|
2018-08-13 16:27:15 -04:00
|
|
|
from flask import Flask, render_template, request
|
2018-06-21 15:50:01 -04:00
|
|
|
|
|
|
|
app = Flask(__name__)
|
|
|
|
|
|
|
|
from common import *
|
|
|
|
|
|
|
|
def parse_list(member, regex):
|
|
|
|
data_list = []
|
|
|
|
for key, value in member.items():
|
|
|
|
match = re.match(regex, key)
|
|
|
|
if match is not None and value != '':
|
|
|
|
data_list.append(match.group(1))
|
|
|
|
|
|
|
|
return ", ".join(data_list)
|
|
|
|
|
|
|
|
def parse_members(members):
|
|
|
|
data = []
|
|
|
|
for member in members:
|
|
|
|
props = {
|
|
|
|
'Name': member['Account Name'],
|
|
|
|
'Renewal Date': member['Renewal Date'],
|
|
|
|
'Card Number': member['Access Card Facility Code'] + '-' \
|
|
|
|
+ member['Access Card Number'],
|
|
|
|
'Account on Hold': "Yes" if member['Account on Hold'] != '' else "No" }
|
|
|
|
|
|
|
|
props['Certifications'] = parse_list(member, 'Certified: (.*)')
|
|
|
|
props['Door Access'] = parse_list(member, 'Access (.*)\?')
|
|
|
|
props['Memebership Level'] = parse_list(member, 'CMS (.*)')
|
|
|
|
|
|
|
|
data.append(props)
|
|
|
|
|
|
|
|
return data
|
|
|
|
|
|
|
|
@app.route("/")
|
|
|
|
def main():
|
|
|
|
# maybe not now: membership agreement signed
|
2018-08-13 16:27:15 -04:00
|
|
|
# TODO: renewal date check
|
|
|
|
term = request.args.get('term', '')
|
|
|
|
|
|
|
|
if len(term) < 3:
|
|
|
|
return render_template("members.html",
|
|
|
|
error="Enter at least 3 characters to search")
|
2018-06-21 15:50:01 -04:00
|
|
|
|
2018-08-13 16:27:15 -04:00
|
|
|
data = getMembershipworksData(
|
2018-08-07 18:33:12 -04:00
|
|
|
['members', 'staff'],
|
2018-06-21 15:50:01 -04:00
|
|
|
"lvl,xws,xms,xsc,xas,xfd,xac,phn,eml,lbl,xcf,nam,end")
|
|
|
|
|
2018-08-13 16:27:15 -04:00
|
|
|
members = parse_members(data)
|
|
|
|
members = [member for member in members
|
|
|
|
if term.lower() in member['Name'].lower()]
|
2018-06-21 15:50:01 -04:00
|
|
|
headers = ['Name', 'Certifications', 'Door Access', 'Memebership Level',
|
|
|
|
'Card Number', 'Renewal Date', 'Account on Hold']
|
|
|
|
|
2018-08-13 16:27:15 -04:00
|
|
|
if len(members) > 4:
|
|
|
|
return render_template(
|
|
|
|
"members.html", error="Too many results, please be more specific.")
|
|
|
|
|
|
|
|
return render_template("members.html", headers=headers, members=members)
|
2018-06-21 15:50:01 -04:00
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
app.run(debug=True, host='0.0.0.0')
|