2017-11-17 14:56:38 +00:00
|
|
|
import codecs
|
2017-11-27 17:52:34 +00:00
|
|
|
import sqlite3
|
2017-11-17 14:56:38 +00:00
|
|
|
|
2017-11-27 17:52:34 +00:00
|
|
|
import source_code
|
2017-12-02 14:19:05 +00:00
|
|
|
from event_handler import EventHandler
|
|
|
|
from stateful_event_handler import StatefulEventHandler
|
2017-11-17 14:56:38 +00:00
|
|
|
from tornado.ioloop import IOLoop
|
|
|
|
|
2017-11-27 17:52:34 +00:00
|
|
|
from login_component import authorize_login
|
2017-11-17 14:56:38 +00:00
|
|
|
|
|
|
|
|
|
|
|
def echo_handler(data):
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
2017-12-03 17:52:22 +00:00
|
|
|
def rot13_handler(data):
|
2017-11-17 14:56:38 +00:00
|
|
|
data['data'] = codecs.encode(data['data'], 'rot13')
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
2017-12-03 17:52:22 +00:00
|
|
|
def change_case_handler(data):
|
2017-11-17 14:56:38 +00:00
|
|
|
data['data'] = data['data'].upper() if data['data'].islower() else data['data'].lower()
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
2017-12-03 17:52:22 +00:00
|
|
|
def reverse_handler(data):
|
2017-11-17 14:56:38 +00:00
|
|
|
data['data'] = data['data'][::-1]
|
|
|
|
return data
|
|
|
|
|
|
|
|
|
2017-12-05 19:34:06 +00:00
|
|
|
def login_handler(data):
|
2017-11-27 17:52:34 +00:00
|
|
|
email, password = data['data']['email'], data['data']['password']
|
|
|
|
try:
|
|
|
|
sql_statement = source_code.find_local_variable_value(authorize_login, 'sql_statement')
|
|
|
|
yield (
|
|
|
|
'anchor_logger',
|
|
|
|
'The SQL statement executed by the server will look like this:\n `{}`'.format(sql_statement)
|
|
|
|
)
|
|
|
|
|
|
|
|
yield ('anchor_webide',
|
|
|
|
source_code.get_source_code(authorize_login, strip_comments=False))
|
|
|
|
|
|
|
|
sql_statement_with_values = sql_statement.format(email, password)
|
|
|
|
yield (
|
|
|
|
'anchor_logger',
|
|
|
|
'After the submitted parameters are substituted it looks like this:\n `{}`'.format(
|
|
|
|
sql_statement_with_values
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
logged_in_email, is_admin = authorize_login(email, password)
|
|
|
|
|
|
|
|
yield (
|
|
|
|
'anchor_logger',
|
|
|
|
'After the query is executed, it returns _{}_ as email address, and _{}_ for is_admin'.format(
|
|
|
|
logged_in_email, is_admin
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
if logged_in_email is not None:
|
|
|
|
response = 'Logged in as _{}_. You __{}have__ admin privileges.'.format(
|
|
|
|
logged_in_email,
|
|
|
|
'' if is_admin else 'don\'t '
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
response = 'Bad username/password!'
|
|
|
|
except sqlite3.Warning:
|
|
|
|
response = 'Invalid request!'
|
|
|
|
|
|
|
|
yield ('anchor_login', '# Login page\n' + response)
|
|
|
|
|
|
|
|
|
2017-12-05 19:34:06 +00:00
|
|
|
def source_code_handler(data):
|
2017-11-27 17:52:34 +00:00
|
|
|
yield (data['anchor'],
|
|
|
|
source_code.get_source_code(authorize_login, strip_comments=True))
|
|
|
|
|
|
|
|
|
2017-11-17 14:56:38 +00:00
|
|
|
if __name__ == '__main__':
|
2017-12-02 14:19:05 +00:00
|
|
|
anchor_a = EventHandler('anchor_a', change_case_handler)
|
|
|
|
anchor_b = EventHandler('anchor_b', rot13_handler)
|
|
|
|
anchor_c = EventHandler('anchor_c', reverse_handler)
|
|
|
|
anchor_login = StatefulEventHandler('anchor_login', login_handler)
|
|
|
|
anchor_webide = StatefulEventHandler('anchor_webide', source_code_handler)
|
2017-11-17 14:56:38 +00:00
|
|
|
IOLoop.instance().start()
|
2017-11-27 17:52:34 +00:00
|
|
|
|