def anon_serialize_context(context, language=GLSetting.memory_copy.default_language): """ @param context: a valid Storm object @return: a dict describing the contexts available for submission, (e.g. checks if almost one receiver is associated) """ mo = Rosetta() mo.acquire_storm_object(context) fo = Fields(context.localized_fields, context.unique_fields) context_dict = { "id": context.id, "escalation_threshold": 0, "file_max_download": context.file_max_download, "file_required": context.file_required, "selectable_receiver": context.selectable_receiver, "tip_max_access": context.tip_max_access, "tip_timetolive": context.tip_timetolive, "submission_introduction": u'NYI', # unicode(context.submission_introduction), # optlang "submission_disclaimer": u'NYI', # unicode(context.submission_disclaimer), # optlang "select_all_receivers": context.select_all_receivers, "maximum_selectable_receivers": context.maximum_selectable_receivers, 'require_pgp': context.require_pgp, "show_small_cards": context.show_small_cards, "presentation_order": context.presentation_order, # list is needed because .values returns a generator "receivers": list(context.receivers.values(models.Receiver.id)), 'name': mo.dump_translated('name', language), "description": mo.dump_translated('description', language), "fields": fo.dump_fields(language) } if not len(context_dict['receivers']): return None return context_dict
def anon_serialize_context(context, language=GLSetting.memory_copy.default_language): """ @param context: a valid Storm object @return: a dict describing the contexts available for submission, (e.g. checks if almost one receiver is associated) """ mo = Rosetta() mo.acquire_storm_object(context) fo = Fields(context.localized_fields, context.unique_fields) context_dict = { "id": context.id, "escalation_threshold": 0, "file_max_download": context.file_max_download, "file_required": context.file_required, "selectable_receiver": context.selectable_receiver, "tip_max_access": context.tip_max_access, "tip_timetolive": context.tip_timetolive, "submission_introduction": u'NYI', # unicode(context.submission_introduction), # optlang "submission_disclaimer": u'NYI', # unicode(context.submission_disclaimer), # optlang "select_all_receivers": context.select_all_receivers, "maximum_selectable_receivers": context.maximum_selectable_receivers, 'require_pgp': context.require_pgp, "show_small_cards": context.show_small_cards, "show_receivers": context.show_receivers, "enable_private_messages": context.enable_private_messages, "presentation_order": context.presentation_order, # list is needed because .values returns a generator "receivers": list(context.receivers.values(models.Receiver.id)), 'name': mo.dump_translated('name', language), "description": mo.dump_translated('description', language), "fields": fo.dump_fields(language) } if not len(context_dict['receivers']): return None return context_dict
def anon_serialize_context(context, language=GLSetting.memory_copy.default_language): """ @param context: a valid Storm object @return: a dict describing the contexts available for submission, (e.g. checks if almost one receiver is associated) """ context_dict = { "receivers": [] } for receiver in context.receivers: context_dict['receivers'].append(unicode(receiver.id)) if not len(context_dict['receivers']): return None context_dict.update({ "context_gus": unicode(context.id), "escalation_threshold": None, "file_max_download": int(context.file_max_download), "file_required": context.file_required, "selectable_receiver": bool(context.selectable_receiver), "tip_max_access": int(context.tip_max_access), "tip_timetolive": int(context.tip_timetolive), "receipt_description": u'NYI', # unicode(context.receipt_description), # optlang "submission_introduction": u'NYI', # unicode(context.submission_introduction), # optlang "submission_disclaimer": u'NYI', # unicode(context.submission_disclaimer), # optlang "select_all_receivers": context.select_all_receivers }) mo = Rosetta() mo.acquire_storm_object(context) context_dict['name'] = mo.dump_translated('name', language) context_dict['description'] = mo.dump_translated('description', language) fo = Fields(context.localized_fields, context.unique_fields) context_dict['fields'] = fo.dump_fields(language) return context_dict
def default_context_fields(): source = opportunistic_appdata_init() if not source.has_key('fields'): raise Exception("Invalid Application Data initialization") f = source['fields'] fo = Fields() fo.noisy = True fo.default_fields(f) default_fields_unhappy = fo.dump_fields('en') ret_fields = [] the_first_is_required = False for field in default_fields_unhappy: if not the_first_is_required: field['required'] = True the_first_is_required = True ret_fields.append(field) return ret_fields