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): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 40 | update_call_log(kwargs, "Missed") |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 41 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 42 | |
| 43 | def update_call_log(call_payload, status="Ringing", call_log=None): |
Suraj Shetty | f5dd494 | 2019-07-16 11:07:25 +0530 | [diff] [blame] | 44 | call_log = call_log or get_call_log(call_payload) |
Suraj Shetty | bd03a51 | 2019-05-27 15:30:41 +0530 | [diff] [blame] | 45 | if call_log: |
Suraj Shetty | c8c1742 | 2019-06-07 10:22:50 +0530 | [diff] [blame] | 46 | call_log.status = status |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 47 | call_log.to = call_payload.get("DialWhomNumber") |
| 48 | call_log.duration = call_payload.get("DialCallDuration") or 0 |
| 49 | call_log.recording_url = call_payload.get("RecordingUrl") |
Suraj Shetty | bd03a51 | 2019-05-27 15:30:41 +0530 | [diff] [blame] | 50 | call_log.save(ignore_permissions=True) |
| 51 | frappe.db.commit() |
Suraj Shetty | c8c1742 | 2019-06-07 10:22:50 +0530 | [diff] [blame] | 52 | return call_log |
Suraj Shetty | 863b93c | 2019-05-21 07:57:06 +0530 | [diff] [blame] | 53 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 54 | |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 55 | def get_call_log(call_payload): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 56 | call_log = frappe.get_all( |
| 57 | "Call Log", |
| 58 | { |
| 59 | "id": call_payload.get("CallSid"), |
| 60 | }, |
| 61 | limit=1, |
| 62 | ) |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 63 | |
Suraj Shetty | 44c0e9d | 2019-06-06 11:18:16 +0530 | [diff] [blame] | 64 | if call_log: |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 65 | return frappe.get_doc("Call Log", call_log[0].name) |
| 66 | |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 67 | |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 68 | def create_call_log(call_payload): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 69 | call_log = frappe.new_doc("Call Log") |
| 70 | call_log.id = call_payload.get("CallSid") |
| 71 | call_log.to = call_payload.get("DialWhomNumber") |
| 72 | call_log.medium = call_payload.get("To") |
| 73 | call_log.status = "Ringing" |
| 74 | setattr(call_log, "from", call_payload.get("CallFrom")) |
Suraj Shetty | 502565f | 2019-07-01 14:28:59 +0530 | [diff] [blame] | 75 | call_log.save(ignore_permissions=True) |
| 76 | frappe.db.commit() |
| 77 | return call_log |
Suraj Shetty | 340ccb6 | 2019-06-17 10:16:38 +0530 | [diff] [blame] | 78 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 79 | |
Suraj Shetty | 07fe299 | 2019-05-22 15:48:57 +0530 | [diff] [blame] | 80 | @frappe.whitelist() |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 81 | def get_call_status(call_id): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 82 | 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] | 83 | response = requests.get(endpoint) |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 84 | status = response.json().get("Call", {}).get("Status") |
Suraj Shetty | 07fe299 | 2019-05-22 15:48:57 +0530 | [diff] [blame] | 85 | return status |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +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 make_a_call(from_number, to_number, caller_id): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 90 | endpoint = get_exotel_endpoint("Calls/connect.json?details=true") |
| 91 | response = requests.post( |
| 92 | endpoint, data={"From": from_number, "To": to_number, "CallerId": caller_id} |
| 93 | ) |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 94 | |
| 95 | return response.json() |
| 96 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 97 | |
Suraj Shetty | 1eeb89f | 2019-05-22 06:37:43 +0530 | [diff] [blame] | 98 | def get_exotel_settings(): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 99 | return frappe.get_single("Exotel Settings") |
| 100 | |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 101 | |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 102 | def whitelist_numbers(numbers, caller_id): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 103 | endpoint = get_exotel_endpoint("CustomerWhitelist") |
| 104 | response = requests.post( |
| 105 | endpoint, |
| 106 | data={ |
| 107 | "VirtualNumber": caller_id, |
| 108 | "Number": numbers, |
| 109 | }, |
| 110 | ) |
Suraj Shetty | e9bfecf | 2019-06-03 12:27:02 +0530 | [diff] [blame] | 111 | |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 112 | return response |
| 113 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 114 | |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 115 | def get_all_exophones(): |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 116 | endpoint = get_exotel_endpoint("IncomingPhoneNumbers") |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 117 | response = requests.post(endpoint) |
| 118 | return response |
| 119 | |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 120 | |
Suraj Shetty | 06f8034 | 2019-06-13 17:13:54 +0530 | [diff] [blame] | 121 | def get_exotel_endpoint(action): |
| 122 | settings = get_exotel_settings() |
Ankush Menat | 494bd9e | 2022-03-28 18:52:46 +0530 | [diff] [blame] | 123 | return "https://{api_key}:{api_token}@api.exotel.com/v1/Accounts/{sid}/{action}".format( |
| 124 | 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] | 125 | ) |