def test_401_response(self): start_count = Call.by_domain(self.domain).count() response = Client().post('/twilio/ivr/xxxxx', { 'From': self.phone_number, 'CallSid': 'xyz', }) self.assertEqual(response.status_code, 401) end_count = Call.by_domain(self.domain).count() self.assertEqual(start_count, end_count)
def test_log_call(self): if self.__class__ == LogCallTestCase: # The test runner picks up this base class too, but we only # want to run the test on subclasses. return self.assertEqual(Call.by_domain(self.domain).count(), 0) response = self.simulate_inbound_call(self.phone_number) self.check_response(response) self.assertEqual(Call.by_domain(self.domain).count(), 1) call = Call.by_domain(self.domain)[0] self.assertEqual(call.couch_recipient_doc_type, 'CommCareCase') self.assertEqual(call.couch_recipient, self.case.get_id) self.assertEqual(call.direction, INCOMING)
def rows(self): data = Call.by_domain( self.domain, start_date=self.datespan.startdate_utc, end_date=self.datespan.enddate_utc ).order_by('date') result = [] # Store the results of lookups for faster loading contact_cache = {} form_map = {} xforms_sessions = {} direction_map = { INCOMING: _("Incoming"), OUTGOING: _("Outgoing"), } # Retrieve message log options message_log_options = getattr(settings, "MESSAGE_LOG_OPTIONS", {}) abbreviated_phone_number_domains = message_log_options.get("abbreviated_phone_number_domains", []) abbreviate_phone_number = (self.domain in abbreviated_phone_number_domains) for call in data: doc_info = self.get_recipient_info(call.couch_recipient_doc_type, call.couch_recipient, contact_cache) form_unique_id = call.form_unique_id if form_unique_id in [None, ""]: form_name = "-" elif form_unique_id in form_map: form_name = form_map.get(form_unique_id) else: form_name = get_form_name(form_unique_id) form_map[form_unique_id] = form_name phone_number = call.phone_number if abbreviate_phone_number and phone_number is not None: phone_number = phone_number[0:7] if phone_number[0:1] == "+" else phone_number[0:6] timestamp = ServerTime(call.date).user_time(self.timezone).done() if call.direction == INCOMING: answered = "-" else: answered = _("Yes") if call.answered else _("No") if call.xforms_session_id: xforms_sessions[call.xforms_session_id] = None row = [ call.xforms_session_id, self._fmt_timestamp(timestamp), self._fmt_contact_link(call.couch_recipient, doc_info), self._fmt(phone_number), self._fmt(direction_map.get(call.direction,"-")), self._fmt(form_name), self._fmt("-"), self._fmt(answered), self._fmt(call.duration), self._fmt(_("Yes") if call.error else _("No")), self._fmt(cgi.escape(call.error_message) if call.error_message else None), ] if self.request.couch_user.is_previewer(): row.append(self._fmt(call.gateway_session_id)) result.append(row) all_session_ids = xforms_sessions.keys() session_submission_map = dict( SQLXFormsSession.objects.filter(session_id__in=all_session_ids).values_list( 'session_id', 'submission_id' ) ) xforms_sessions.update(session_submission_map) # Add into the final result the link to the submission based on the # outcome of the above lookups. final_result = [] for row in result: final_row = row[1:] session_id = row[0] if session_id: submission_id = xforms_sessions[session_id] if submission_id: final_row[5] = self._fmt_submission_link(submission_id) final_result.append(final_row) return final_result
def delete_call_logs(self, domain): Call.by_domain(domain).delete()
def rows(self): data = Call.by_domain( self.domain, start_date=self.datespan.startdate_utc, end_date=self.datespan.enddate_utc).order_by('date') result = [] # Store the results of lookups for faster loading contact_cache = {} form_map = {} xforms_sessions = {} direction_map = { INCOMING: _("Incoming"), OUTGOING: _("Outgoing"), } # Retrieve message log options message_log_options = getattr(settings, "MESSAGE_LOG_OPTIONS", {}) abbreviated_phone_number_domains = message_log_options.get( "abbreviated_phone_number_domains", []) abbreviate_phone_number = (self.domain in abbreviated_phone_number_domains) for call in data: doc_info = self.get_recipient_info(self.domain, call.couch_recipient_doc_type, call.couch_recipient, contact_cache) form_unique_id = call.form_unique_id if form_unique_id in [None, ""]: form_name = "-" elif form_unique_id in form_map: form_name = form_map.get(form_unique_id) else: form_name = get_form_name(form_unique_id) form_map[form_unique_id] = form_name phone_number = call.phone_number if abbreviate_phone_number and phone_number is not None: phone_number = phone_number[0:7] if phone_number[ 0:1] == "+" else phone_number[0:6] timestamp = ServerTime(call.date).user_time(self.timezone).done() if call.direction == INCOMING: answered = "-" else: answered = _("Yes") if call.answered else _("No") if call.xforms_session_id: xforms_sessions[call.xforms_session_id] = None row = [ call.xforms_session_id, self._fmt_timestamp(timestamp), self._fmt_contact_link(call.couch_recipient, doc_info), self._fmt(phone_number), self._fmt(direction_map.get(call.direction, "-")), self._fmt(form_name), self._fmt("-"), self._fmt(answered), self._fmt(call.duration), self._fmt(_("Yes") if call.error else _("No")), self._fmt( cgi.escape(call.error_message) if call. error_message else None), ] if self.request.couch_user.is_previewer(): row.append(self._fmt(call.gateway_session_id)) result.append(row) all_session_ids = list(xforms_sessions) session_submission_map = dict( SQLXFormsSession.objects.filter( session_id__in=all_session_ids).values_list( 'session_id', 'submission_id')) xforms_sessions.update(session_submission_map) # Add into the final result the link to the submission based on the # outcome of the above lookups. final_result = [] for row in result: final_row = row[1:] session_id = row[0] if session_id: submission_id = xforms_sessions[session_id] if submission_id: final_row[5] = self._fmt_submission_link(submission_id) final_result.append(final_row) return final_result