code cleanup

This commit is contained in:
Davide Alberani 2016-07-09 19:02:00 +02:00
parent a27f9b0db9
commit 075d878ac1
2 changed files with 28 additions and 35 deletions

View file

@ -239,9 +239,7 @@ eventManServices.factory('User', ['$resource', '$rootScope',
/* WebSocket collection used to update the list of tickets of an Event. */ /* WebSocket collection used to update the list of tickets of an Event. */
eventManApp.factory('EventUpdates', ['$websocket', '$location', '$log', eventManApp.factory('EventUpdates', ['$websocket', '$location', '$log',
function($websocket, $location, $log) { function($websocket, $location, $log) {
var dataStream = null; var dataStream = null;
var data = {}; var data = {};
var methods = { var methods = {

View file

@ -331,7 +331,7 @@ class CollectionHandler(BaseHandler):
return filtered return filtered
def _clean_dict(self, data): def _clean_dict(self, data):
"""Filter a dictionary (in place) to remove unwanted keywords. """Filter a dictionary (in place) to remove unwanted keywords in db queries.
:param data: dictionary to clean :param data: dictionary to clean
:type data: dict""" :type data: dict"""
@ -433,6 +433,7 @@ class CollectionHandler(BaseHandler):
output = self.apply_filter(output, 'get_%s' % resource) output = self.apply_filter(output, 'get_%s' % resource)
self.write(output) self.write(output)
return return
return self.build_error(status=404, message='unable to access resource: %s' % resource)
if id_ is not None: if id_ is not None:
permission = '%s|%s' % (self.document, crud_method) permission = '%s|%s' % (self.document, crud_method)
if not self.has_permission(permission): if not self.has_permission(permission):
@ -449,7 +450,8 @@ class CollectionHandler(BaseHandler):
newData = self.apply_filter(newData, '%s_all' % method) newData = self.apply_filter(newData, '%s_all' % method)
self.write(newData) self.write(newData)
# PUT (update an existing document) is handled by the POST (create a new document) method # PUT (update an existing document) is handled by the POST (create a new document) method;
# in subclasses you can always separate sub-resources handlers like handle_post_tickets and handle_put_tickets
put = post put = post
@gen.coroutine @gen.coroutine
@ -464,6 +466,7 @@ class CollectionHandler(BaseHandler):
if method and callable(method): if method and callable(method):
self.write(method(id_, resource_id, **kwargs)) self.write(method(id_, resource_id, **kwargs))
return return
return self.build_error(status=404, message='unable to access resource: %s' % resource)
if id_: if id_:
permission = '%s|delete' % self.document permission = '%s|delete' % self.document
if not self.has_permission(permission): if not self.has_permission(permission):
@ -562,7 +565,7 @@ class EventsHandler(CollectionHandler):
collection = 'events' collection = 'events'
def filter_get(self, output): def filter_get(self, output):
if not self.has_permission('tckets-all|read'): if not self.has_permission('tickets-all|read'):
if 'tickets' in output: if 'tickets' in output:
output['tickets'] = [] output['tickets'] = []
return output return output
@ -584,6 +587,7 @@ class EventsHandler(CollectionHandler):
filter_input_put = filter_input_post filter_input_put = filter_input_post
def filter_input_post_tickets(self, data): def filter_input_post_tickets(self, data):
# Avoid users to be able to auto-update their 'attendee' status.
if not self.has_permission('event|update'): if not self.has_permission('event|update'):
if 'attended' in data: if 'attended' in data:
del data['attended'] del data['attended']
@ -620,47 +624,38 @@ class EventsHandler(CollectionHandler):
return ticket return ticket
return {} return {}
def handle_get_tickets(self, id_, resource_id=None, match_query=None): def handle_get_tickets(self, id_, resource_id=None):
# Return every ticket registered at this event, or the information # Return every ticket registered at this event, or the information
# about a specific ticket. # about a specific ticket.
query = {'_id': id_} query = {'_id': id_}
event = self.db.query('events', query)[0] event = self.db.query('events', query)[0]
if match_query is None:
match_query = resource_id
if resource_id: if resource_id:
return {'ticket': self._get_ticket_data(match_query, event.get('tickets') or [])} return {'ticket': self._get_ticket_data(resource_id, event.get('tickets') or [])}
tickets = self._filter_results(event.get('tickets') or [], self.arguments) tickets = self._filter_results(event.get('tickets') or [], self.arguments)
return {'tickets': tickets} return {'tickets': tickets}
def __handle_get_tickets_REMOVE(self, id_, resource_id=None): def handle_post_tickets(self, id_, resource_id, data):
if resource_id is None and not self.has_permission('event:tickets|all'):
return self.build_error(status=401, message='insufficient permissions: event:tickets|all')
return self.handle_get_persons(id_, resource_id, {'_id': resource_id})
def handle_post_tickets(self, id_, ticket_id, data):
# Add a ticket to the list of tickets registered at this event.
uuid, arguments = self.uuid_arguments uuid, arguments = self.uuid_arguments
self._clean_dict(data) self._clean_dict(data)
data['seq'] = self.get_next_seq('event_%s_tickets' % id_) data['seq'] = self.get_next_seq('event_%s_tickets' % id_)
data['seq_hex'] = '%06X' % data['seq'] data['seq_hex'] = '%06X' % data['seq']
if ticket_id is None:
doc = {}
else:
doc = self.db.query('events', {'_id': id_, 'tickets._id': ticket_id})
ret = {'action': 'add', '_id': ticket_id, 'ticket': data, 'uuid': uuid}
if '_id' in data:
del data['_id']
self.send_ws_message('event/%s/tickets/updates' % id_, json.dumps(ret))
if not doc:
data['_id'] = self.gen_id() data['_id'] = self.gen_id()
ret = {'action': 'add', 'ticket': data, 'uuid': uuid}
merged, doc = self.db.update('events', merged, doc = self.db.update('events',
{'_id': id_}, {'_id': id_},
{'tickets': data}, {'tickets': data},
operation='appendUnique', operation='appendUnique',
create=False) create=False)
if doc:
msg_ret = ret.copy()
msg_ret['ticket'] = msg_ret['ticket'].copy()
# Do not send ticket IDs over the WebSocket.
if '_id' in msg_ret['ticket']:
del msg_ret['ticket']['_id']
self.send_ws_message('event/%s/tickets/updates' % id_, json.dumps(msg_ret))
return ret return ret
def handle_put_tickets(self, id_, ticket_id, data, ticket=True): def handle_put_tickets(self, id_, ticket_id, data):
# Update an existing entry for a ticket registered at this event. # Update an existing entry for a ticket registered at this event.
self._clean_dict(data) self._clean_dict(data)
uuid, arguments = self.uuid_arguments uuid, arguments = self.uuid_arguments
@ -684,8 +679,7 @@ class EventsHandler(CollectionHandler):
new_ticket_data = self._get_ticket_data(ticket_query, new_ticket_data = self._get_ticket_data(ticket_query,
doc.get('tickets') or []) doc.get('tickets') or [])
env = self._dict2env(new_ticket_data) env = self._dict2env(new_ticket_data)
# always takes the ticket_id from the new ticket (it may have # always takes the ticket_id from the new ticket
# been a ticket_id).
ticket_id = str(new_ticket_data.get('_id')) ticket_id = str(new_ticket_data.get('_id'))
env.update({'PERSON_ID': ticket_id, 'TICKED_ID': ticket_id, 'EVENT_ID': id_, env.update({'PERSON_ID': ticket_id, 'TICKED_ID': ticket_id, 'EVENT_ID': id_,
'EVENT_TITLE': doc.get('title', ''), 'WEB_USER': self.current_user, 'EVENT_TITLE': doc.get('title', ''), 'WEB_USER': self.current_user,
@ -730,6 +724,7 @@ class UsersHandler(CollectionHandler):
if 'password' in data: if 'password' in data:
del data['password'] del data['password']
if '_id' in data: if '_id' in data:
# Also add a 'tickets' list with all the tickets created by this user
tickets = [] tickets = []
events = self.db.query('events', {'tickets.created_by': data['_id']}) events = self.db.query('events', {'tickets.created_by': data['_id']})
for event in events: for event in events:
@ -798,7 +793,7 @@ class UsersHandler(CollectionHandler):
class EbCSVImportPersonsHandler(BaseHandler): class EbCSVImportPersonsHandler(BaseHandler):
"""Importer for CSV files exported from eventbrite.""" """Importer for CSV files exported from Eventbrite."""
csvRemap = { csvRemap = {
'Nome evento': 'event_title', 'Nome evento': 'event_title',
'ID evento': 'event_id', 'ID evento': 'event_id',