111 lines
3.2 KiB
Python
Raw Normal View History

2019-05-21 07:57:06 +05:30
import frappe
import requests
from frappe import _
# api/method/erpnext.erpnext_integrations.exotel_integration.handle_incoming_call
# api/method/erpnext.erpnext_integrations.exotel_integration.handle_end_call
# api/method/erpnext.erpnext_integrations.exotel_integration.handle_missed_call
2019-05-21 07:57:06 +05:30
@frappe.whitelist(allow_guest=True)
2019-07-01 14:28:59 +05:30
def handle_incoming_call(**kwargs):
try:
exotel_settings = get_exotel_settings()
if not exotel_settings.enabled: return
call_payload = kwargs
status = call_payload.get('Status')
if status == 'free':
return
call_log = get_call_log(call_payload)
if not call_log:
create_call_log(call_payload)
else:
update_call_log(call_payload, call_log=call_log)
except Exception as e:
frappe.db.rollback()
frappe.log_error(title=_('Error in Exotel incoming call'))
frappe.db.commit()
2019-05-21 07:57:06 +05:30
2019-05-27 15:30:41 +05:30
@frappe.whitelist(allow_guest=True)
2019-07-01 14:28:59 +05:30
def handle_end_call(**kwargs):
2019-06-17 10:16:38 +05:30
update_call_log(kwargs, 'Completed')
2019-06-03 12:27:02 +05:30
@frappe.whitelist(allow_guest=True)
2019-07-01 14:28:59 +05:30
def handle_missed_call(**kwargs):
2019-06-17 10:16:38 +05:30
update_call_log(kwargs, 'Missed')
2019-06-03 12:27:02 +05:30
def update_call_log(call_payload, status='Ringing', call_log=None):
call_log = call_log or get_call_log(call_payload)
2019-05-27 15:30:41 +05:30
if call_log:
call_log.status = status
call_log.to = call_payload.get('DialWhomNumber')
call_log.duration = call_payload.get('DialCallDuration') or 0
call_log.recording_url = call_payload.get('RecordingUrl')
2019-05-27 15:30:41 +05:30
call_log.save(ignore_permissions=True)
frappe.db.commit()
return call_log
2019-05-27 15:30:41 +05:30
2019-07-01 14:28:59 +05:30
def get_call_log(call_payload):
call_log = frappe.get_all('Call Log', {
'id': call_payload.get('CallSid'),
}, limit=1)
if call_log:
return frappe.get_doc('Call Log', call_log[0].name)
2019-07-01 14:28:59 +05:30
def create_call_log(call_payload):
call_log = frappe.new_doc('Call Log')
call_log.id = call_payload.get('CallSid')
call_log.to = call_payload.get('DialWhomNumber')
2019-07-01 14:28:59 +05:30
call_log.medium = call_payload.get('To')
call_log.status = 'Ringing'
setattr(call_log, 'from', call_payload.get('CallFrom'))
call_log.save(ignore_permissions=True)
frappe.db.commit()
return call_log
2019-06-17 10:16:38 +05:30
@frappe.whitelist()
def get_call_status(call_id):
2019-06-13 17:13:54 +05:30
endpoint = get_exotel_endpoint('Calls/{call_id}.json'.format(call_id=call_id))
response = requests.get(endpoint)
status = response.json().get('Call', {}).get('Status')
return status
@frappe.whitelist()
def make_a_call(from_number, to_number, caller_id):
2019-06-13 17:13:54 +05:30
endpoint = get_exotel_endpoint('Calls/connect.json?details=true')
response = requests.post(endpoint, data={
'From': from_number,
'To': to_number,
'CallerId': caller_id
})
return response.json()
def get_exotel_settings():
2019-06-03 12:27:02 +05:30
return frappe.get_single('Exotel Settings')
def whitelist_numbers(numbers, caller_id):
2019-06-13 17:13:54 +05:30
endpoint = get_exotel_endpoint('CustomerWhitelist')
response = requests.post(endpoint, data={
2019-06-03 12:27:02 +05:30
'VirtualNumber': caller_id,
'Number': numbers,
})
2019-06-13 17:13:54 +05:30
return response
def get_all_exophones():
endpoint = get_exotel_endpoint('IncomingPhoneNumbers')
response = requests.post(endpoint)
return response
def get_exotel_endpoint(action):
settings = get_exotel_settings()
return 'https://{api_key}:{api_token}@api.exotel.com/v1/Accounts/{sid}/{action}'.format(
api_key=settings.api_key,
api_token=settings.api_token,
sid=settings.account_sid,
action=action
)