def conference_data(meeting): try: Conference.find_one(Q('endpoint', 'iexact', meeting)) except ModularOdmException: raise HTTPError(http.NOT_FOUND) nodes = Node.find( Q('tags', 'eq', meeting) & Q('is_public', 'eq', True) & Q('is_deleted', 'eq', False)) data = [ _render_conference_node(each, idx) for idx, each in enumerate(nodes) ] return data
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): meeting = meeting.strip() admin_emails = attrs.pop('admins', []) admin_objs = [] for email in admin_emails: try: user = User.find_one(Q('username', 'iexact', email)) admin_objs.append(user) except ModularOdmException: raise RuntimeError('Username {0!r} is not registered.'.format(email)) custom_fields = attrs.pop('field_names', {}) conf = Conference( endpoint=meeting, admins=admin_objs, **attrs ) conf.field_names.update(custom_fields) try: conf.save() except ModularOdmException: conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): if isinstance(value, dict): current = getattr(conf, key) current.update(value) setattr(conf, key, current) else: setattr(conf, key, value) conf.admins = admin_objs changed_fields = conf.save() if changed_fields: print('Updated {}: {}'.format(meeting, changed_fields)) else: print('Added new Conference: {}'.format(meeting))
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): meeting = meeting.strip() admin_emails = attrs.pop("admins") admin_objs = [] for email in admin_emails: try: user = User.find_one(Q("username", "iexact", email)) admin_objs.append(user) except ModularOdmException: raise RuntimeError("Username {0!r} is not registered.".format(email)) conf = Conference(endpoint=meeting, admins=admin_objs, **attrs) try: conf.save() except ModularOdmException: print("{0} Conference already exists. Updating existing record...".format(meeting)) conf = Conference.find_one(Q("endpoint", "eq", meeting)) for key, value in attrs.items(): setattr(conf, key, value) conf.admins = admin_objs changed_fields = conf.save() if changed_fields: print("Changed: {}".format(changed_fields)) else: print("Added new Conference: {}".format(meeting))
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): meeting = meeting.strip() admin_emails = attrs.pop('admins') admin_objs = [] for email in admin_emails: try: user = User.find_one(Q('username', 'iexact', email)) admin_objs.append(user) except ModularOdmException: raise RuntimeError('Username {0!r} is not registered.'.format(email)) conf = Conference( endpoint=meeting, admins=admin_objs, **attrs ) try: conf.save() except ModularOdmException: print('{0} Conference already exists. Updating existing record...'.format(meeting)) conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): setattr(conf, key, value) conf.admins = admin_objs changed_fields = conf.save() if changed_fields: print('Changed: {}'.format(changed_fields))
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): meeting = meeting.strip() admin_emails = attrs.pop('admins', []) admin_objs = [] for email in admin_emails: try: user = User.find_one(Q('username', 'iexact', email)) admin_objs.append(user) except ModularOdmException: raise RuntimeError('Username {0!r} is not registered.'.format(email)) conf = Conference( endpoint=meeting, admins=admin_objs, **attrs ) try: conf.save() except ModularOdmException: conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): setattr(conf, key, value) conf.admins = admin_objs changed_fields = conf.save() if changed_fields: print('Updated {}: {}'.format(meeting, changed_fields)) else: print('Added new Conference: {}'.format(meeting))
def conference_data(meeting): try: Conference.find_one(Q('endpoint', 'iexact', meeting)) except ModularOdmException: raise HTTPError(httplib.NOT_FOUND) nodes = Node.find( Q('tags', 'iexact', meeting) & Q('is_public', 'eq', True) & Q('is_deleted', 'eq', False) ) ret = [ _render_conference_node(each, idx) for idx, each in enumerate(nodes) ] return ret
def test_add_conference(self): user = UserFactory() add_conference('spsp2014', name='SPSP', admins=[user.username], active=True) conf = Conference.find_one(Q('endpoint', 'eq', 'spsp2014')) assert_equal(conf.name, 'SPSP') assert_true(conf.active) assert_in(user, conf.admins)
def conference_data(meeting): try: conf = Conference.find_one(Q("endpoint", "iexact", meeting)) except ModularOdmException: raise HTTPError(httplib.NOT_FOUND) nodes = Node.find(Q("tags", "iexact", meeting) & Q("is_public", "eq", True) & Q("is_deleted", "eq", False)) ret = [_render_conference_node(each, idx, conf) for idx, each in enumerate(nodes)] return ret
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): conf = Conference(endpoint=meeting, **attrs) try: conf.save() except ModularOdmException: print('{0} Conference already exists. Updating existing record...'. format(meeting)) conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): setattr(conf, key, value) conf.save()
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): conf = Conference( endpoint=meeting, **attrs ) try: conf.save() except ModularOdmException: print('{0} Conference already exists. Updating existing record...'.format(meeting)) conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): setattr(conf, key, value) conf.save()
def conference_data(meeting): try: conf = Conference.find_one(Q('endpoint', 'iexact', meeting)) except ModularOdmException: raise HTTPError(httplib.NOT_FOUND) nodes = Node.objects.filter(tags__id__in=Tag.objects.filter( name__iexact=meeting, system=False).values_list('id', flat=True), is_public=True, is_deleted=False) ret = [ _render_conference_node(each, idx, conf) for idx, each in enumerate(nodes) ] return ret
def conference_results(meeting): """Return the data for the grid view for a conference. :param str meeting: Endpoint name for a conference. """ try: conf = Conference.find_one(Q('endpoint', 'iexact', meeting)) except ModularOdmException: raise HTTPError(http.NOT_FOUND) data = conference_data(meeting) return { 'data': json.dumps(data), 'label': meeting, 'meeting': conf.to_storage(), }
def populate_conferences(dev=False): if dev: Conference.remove() date_format = '%b %d %Y' for meeting, attrs in MEETING_DATA.iteritems(): meeting = meeting.strip() admin_emails = attrs.pop('admins', []) admin_objs = [] if not dev: for email in admin_emails: try: user = User.find_one(Q('username', 'iexact', email)) admin_objs.append(user) except ModularOdmException: raise RuntimeError('Username {0!r} is not registered.'.format(email)) # Convert string into datetime object try: attrs['end_date'] = datetime.strptime(attrs.get('end_date'), date_format) attrs['start_date'] = datetime.strptime(attrs.get('start_date'), date_format) except TypeError: print '** Meeting {} does not have a start or end date. **'.format(meeting) custom_fields = attrs.pop('field_names', {}) conf = Conference( endpoint=meeting, admins=admin_objs, **attrs ) conf.field_names.update(custom_fields) try: conf.save() except ModularOdmException: conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): if isinstance(value, dict): current = getattr(conf, key) current.update(value) setattr(conf, key, current) else: setattr(conf, key, value) conf.admins = admin_objs changed_fields = conf.save() if changed_fields: print('Updated {}: {}'.format(meeting, changed_fields)) else: print('Added new Conference: {}'.format(meeting))
def conference_results(meeting): """Return the data for the grid view for a conference. :param str meeting: Endpoint name for a conference. """ try: conf = Conference.find_one(Q('endpoint', 'iexact', meeting)) except ModularOdmException: raise HTTPError(httplib.NOT_FOUND) data = conference_data(meeting) return { 'data': data, 'label': meeting, 'meeting': conf.to_storage(), # Needed in order to use base.mako namespace 'settings': settings, }
def conference_results(meeting): """Return the data for the grid view for a conference. :param str meeting: Endpoint name for a conference. """ try: conf = Conference.find_one(Q("endpoint", "iexact", meeting)) except ModularOdmException: raise HTTPError(httplib.NOT_FOUND) data = conference_data(meeting) return { "data": json.dumps(data), "label": meeting, "meeting": conf.to_storage(), # Needed in order to use base.mako namespace "settings": settings, }
def populate_conferences(email): for meeting, attrs in MEETING_DATA.iteritems(): admin_objs = [] try: user = User.find_one(Q('username', 'iexact', email)) admin_objs.append(user) except ModularOdmException: raise RuntimeError('Username {0!r} is not registered.'.format(email)) conf = Conference( endpoint=meeting, admins=admin_objs, **attrs ) try: conf.save() except ModularOdmException: print('{0} Conference already exists. Updating existing record...'.format(meeting)) conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): setattr(conf, key, value) conf.admins = admin_objs conf.save()
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): custom_fields = attrs.pop("field_names", {}) conf = Conference(endpoint=meeting, **attrs) conf.field_names.update(custom_fields) try: conf.save() except ModularOdmException: conf = Conference.find_one(Q("endpoint", "eq", meeting)) for key, value in attrs.items(): if isinstance(value, dict): current = getattr(conf, key) current.update(value) setattr(conf, key, current) else: setattr(conf, key, value) changed_fields = conf.save() if changed_fields: print("Updated {}: {}".format(meeting, changed_fields)) else: print("Added new Conference: {}".format(meeting))
def populate_conferences(): for meeting, attrs in MEETING_DATA.iteritems(): custom_fields = attrs.pop('field_names', {}) conf = Conference(endpoint=meeting, **attrs) conf.field_names.update(custom_fields) try: conf.save() except ModularOdmException: conf = Conference.find_one(Q('endpoint', 'eq', meeting)) for key, value in attrs.items(): if isinstance(value, dict): current = getattr(conf, key) current.update(value) setattr(conf, key, current) else: setattr(conf, key, value) changed_fields = conf.save() if changed_fields: print('Updated {}: {}'.format(meeting, changed_fields)) else: print('Added new Conference: {}'.format(meeting))