Suraj Shetty | 863b93c | 2019-05-21 07:57:06 +0530 | [diff] [blame] | 1 | import frappe |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 2 | import requests |
Suraj Shetty | af2eac4 | 2019-09-17 15:53:23 +0530 | [diff] [blame] | 3 | from frappe import _ |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 4 | |
| 5 | # api/method/erpnext.erpnext_integrations.exotel_integration.handle_incoming_call |
Suraj Shetty | c8c1742 | 2019-06-07 10:22:50 +0530 | [diff] [blame] | 6 | # api/method/erpnext.erpnext_integrations.exotel_integration.handle_end_call |
| 7 | # api/method/erpnext.erpnext_integrations.exotel_integration.handle_missed_call |
Suraj Shetty | 863b93c | 2019-05-21 07:57:06 +0530 | [diff] [blame] | 8 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 9 | |
Suraj Shetty | 863b93c | 2019-05-21 07:57:06 +0530 | [diff] [blame] | 10 | @frappe.whitelist(allow_guest=True) |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 11 | def handle_incoming_call(**kwargs): |
Suraj Shetty | af2eac4 | 2019-09-17 15:53:23 +0530 | [diff] [blame] | 12 | try: |
| 13 | exotel_settings = get_exotel_settings() |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 14 | if not exotel_settings.enabled: |
| 15 | return |
Suraj Shetty | 863b93c | 2019-05-21 07:57:06 +0530 | [diff] [blame] | 16 | |
Suraj Shetty | af2eac4 | 2019-09-17 15:53:23 +0530 | [diff] [blame] | 17 | call_payload = kwargs |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 18 | status = call_payload.get("Status") |
| 19 | if status == "free": |
Suraj Shetty | af2eac4 | 2019-09-17 15:53:23 +0530 | [diff] [blame] | 20 | return |
Suraj Shetty | 07fe299 | 2019-05-22 15:48:57 +0530 | [diff] [blame] | 21 | |
Suraj Shetty | af2eac4 | 2019-09-17 15:53:23 +0530 | [diff] [blame] | 22 | call_log = get_call_log(call_payload) |
| 23 | if not call_log: |
| 24 | create_call_log(call_payload) |
| 25 | else: |
| 26 | update_call_log(call_payload, call_log=call_log) |
| 27 | except Exception as e: |
| 28 | frappe.db.rollback() |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 29 | frappe.log_error(title=_("Error in Exotel incoming call")) |
Suraj Shetty | af2eac4 | 2019-09-17 15:53:23 +0530 | [diff] [blame] | 30 | frappe.db.commit() |
Suraj Shetty | 07fe299 | 2019-05-22 15:48:57 +0530 | [diff] [blame] | 31 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 32 | |
Suraj Shetty | bd03a51 | 2019-05-27 15:30:41 +0530 | [diff] [blame] | 33 | @frappe.whitelist(allow_guest=True) |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 34 | def handle_end_call(**kwargs): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 35 | update_call_log(kwargs, "Completed") |
| 36 | |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 37 | |
| 38 | @frappe.whitelist(allow_guest=True) |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 39 | def handle_missed_call(**kwargs): |
Subin Tom | 8d30118 | 2022-02-23 12:59:38 +0530 | [diff] [blame] | 40 | status = "" |
Subin Tom | 5b79496 | 2022-02-25 16:52:25 +0530 | [diff] [blame] | 41 | call_type = kwargs.get("CallType") |
| 42 | dial_call_status = kwargs.get("DialCallStatus") |
Subin Tom | 8d30118 | 2022-02-23 12:59:38 +0530 | [diff] [blame] | 43 | |
Subin Tom | 5b79496 | 2022-02-25 16:52:25 +0530 | [diff] [blame] | 44 | if call_type == "incomplete" and dial_call_status == "no-answer": |
Ankush Menat | 7ef5480 | 2022-03-28 19:55:39 +0530 | [diff] [blame] | 45 | status = "No Answer" |
Subin Tom | 5b79496 | 2022-02-25 16:52:25 +0530 | [diff] [blame] | 46 | elif call_type == "client-hangup" and dial_call_status == "canceled": |
Ankush Menat | 7ef5480 | 2022-03-28 19:55:39 +0530 | [diff] [blame] | 47 | status = "Canceled" |
Subin Tom | 5b79496 | 2022-02-25 16:52:25 +0530 | [diff] [blame] | 48 | elif call_type == "incomplete" and dial_call_status == "failed": |
Ankush Menat | 7ef5480 | 2022-03-28 19:55:39 +0530 | [diff] [blame] | 49 | status = "Failed" |
Subin Tom | 8d30118 | 2022-02-23 12:59:38 +0530 | [diff] [blame] | 50 | |
| 51 | update_call_log(kwargs, status) |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 52 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 53 | |
| 54 | def update_call_log(call_payload, status="Ringing", call_log=None): |
Suraj Shetty | f5dd494 | 2019-07-16 11:07:25 +0530 | [diff] [blame] | 55 | call_log = call_log or get_call_log(call_payload) |
Subin Tom | 8d30118 | 2022-02-23 12:59:38 +0530 | [diff] [blame] | 56 | |
| 57 | # for a new sid, call_log and get_call_log will be empty so create a new log |
| 58 | if not call_log: |
| 59 | call_log = create_call_log(call_payload) |
Suraj Shetty | bd03a51 | 2019-05-27 15:30:41 +0530 | [diff] [blame] | 60 | if call_log: |
Suraj Shetty | c8c1742 | 2019-06-07 10:22:50 +0530 | [diff] [blame] | 61 | call_log.status = status |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 62 | call_log.to = call_payload.get("DialWhomNumber") |
| 63 | call_log.duration = call_payload.get("DialCallDuration") or 0 |
| 64 | call_log.recording_url = call_payload.get("RecordingUrl") |
Suraj Shetty | bd03a51 | 2019-05-27 15:30:41 +0530 | [diff] [blame] | 65 | call_log.save(ignore_permissions=True) |
| 66 | frappe.db.commit() |
Suraj Shetty | c8c1742 | 2019-06-07 10:22:50 +0530 | [diff] [blame] | 67 | return call_log |
Suraj Shetty | 863b93c | 2019-05-21 07:57:06 +0530 | [diff] [blame] | 68 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 69 | |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 70 | def get_call_log(call_payload): |
Suraj Shetty | 39abfae | 2022-04-04 07:28:41 +0530 | [diff] [blame] | 71 | call_log_id = call_payload.get("CallSid") |
| 72 | if frappe.db.exists("Call Log", call_log_id): |
| 73 | return frappe.get_doc("Call Log", call_log_id) |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 74 | |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 75 | |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 76 | def create_call_log(call_payload): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 77 | call_log = frappe.new_doc("Call Log") |
| 78 | call_log.id = call_payload.get("CallSid") |
| 79 | call_log.to = call_payload.get("DialWhomNumber") |
| 80 | call_log.medium = call_payload.get("To") |
| 81 | call_log.status = "Ringing" |
| 82 | setattr(call_log, "from", call_payload.get("CallFrom")) |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 83 | call_log.save(ignore_permissions=True) |
| 84 | frappe.db.commit() |
| 85 | return call_log |
Suraj Shetty | 340ccb6 | 2019-06-17 10:16:38 +0530 | [diff] [blame] | 86 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 87 | |
Suraj Shetty | 07fe299 | 2019-05-22 15:48:57 +0530 | [diff] [blame] | 88 | @frappe.whitelist() |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 89 | def get_call_status(call_id): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 90 | endpoint = get_exotel_endpoint("Calls/{call_id}.json".format(call_id=call_id)) |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 91 | response = requests.get(endpoint) |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 92 | status = response.json().get("Call", {}).get("Status") |
Suraj Shetty | 07fe299 | 2019-05-22 15:48:57 +0530 | [diff] [blame] | 93 | return status |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 94 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 95 | |
Suraj Shetty | 07fe299 | 2019-05-22 15:48:57 +0530 | [diff] [blame] | 96 | @frappe.whitelist() |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 97 | def make_a_call(from_number, to_number, caller_id): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 98 | endpoint = get_exotel_endpoint("Calls/connect.json?details=true") |
| 99 | response = requests.post( |
| 100 | endpoint, data={"From": from_number, "To": to_number, "CallerId": caller_id} |
| 101 | ) |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 102 | |
| 103 | return response.json() |
| 104 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 105 | |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 106 | def get_exotel_settings(): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 107 | return frappe.get_single("Exotel Settings") |
| 108 | |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 109 | |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 110 | def whitelist_numbers(numbers, caller_id): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 111 | endpoint = get_exotel_endpoint("CustomerWhitelist") |
| 112 | response = requests.post( |
| 113 | endpoint, |
| 114 | data={ |
| 115 | "VirtualNumber": caller_id, |
| 116 | "Number": numbers, |
| 117 | }, |
| 118 | ) |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 119 | |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 120 | return response |
| 121 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 122 | |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 123 | def get_all_exophones(): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 124 | endpoint = get_exotel_endpoint("IncomingPhoneNumbers") |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 125 | response = requests.post(endpoint) |
| 126 | return response |
| 127 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 128 | |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 129 | def get_exotel_endpoint(action): |
| 130 | settings = get_exotel_settings() |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 131 | return "https://{api_key}:{api_token}@api.exotel.com/v1/Accounts/{sid}/{action}".format( |
| 132 | api_key=settings.api_key, api_token=settings.api_token, sid=settings.account_sid, action=action |
Suraj Shetty | af2eac4 | 2019-09-17 15:53:23 +0530 | [diff] [blame] | 133 | ) |