mirror of
https://github.com/bringout/oca-ocb-mail.git
synced 2026-04-21 05:42:09 +02:00
19.0 vanilla
This commit is contained in:
parent
5df8c07b59
commit
daa394e8b0
2114 changed files with 564841 additions and 299642 deletions
49
odoo-bringout-oca-ocb-sms/sms/controllers/main.py
Normal file
49
odoo-bringout-oca-ocb-sms/sms/controllers/main.py
Normal file
|
|
@ -0,0 +1,49 @@
|
|||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
import logging
|
||||
import re
|
||||
|
||||
from odoo import _
|
||||
from odoo.exceptions import UserError
|
||||
from odoo.http import Controller, request, route
|
||||
|
||||
_logger = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class SmsController(Controller):
|
||||
|
||||
@route('/sms/status', type='jsonrpc', auth='public')
|
||||
def update_sms_status(self, message_statuses):
|
||||
"""Receive a batch of delivery reports from IAP
|
||||
|
||||
:param message_statuses:
|
||||
[
|
||||
{
|
||||
'sms_status': status0,
|
||||
'uuids': [uuid00, uuid01, ...],
|
||||
}, {
|
||||
'sms_status': status1,
|
||||
'uuids': [uuid10, uuid11, ...],
|
||||
},
|
||||
...
|
||||
]
|
||||
"""
|
||||
all_uuids = []
|
||||
for uuids, iap_status in ((status['uuids'], status['sms_status']) for status in message_statuses):
|
||||
self._check_status_values(uuids, iap_status, message_statuses)
|
||||
if sms_trackers_sudo := request.env['sms.tracker'].sudo().search([('sms_uuid', 'in', uuids)]):
|
||||
if state := request.env['sms.sms'].IAP_TO_SMS_STATE_SUCCESS.get(iap_status):
|
||||
sms_trackers_sudo._action_update_from_sms_state(state)
|
||||
else:
|
||||
sms_trackers_sudo._action_update_from_provider_error(iap_status)
|
||||
all_uuids += uuids
|
||||
request.env['sms.sms'].sudo().search([('uuid', 'in', all_uuids), ('to_delete', '=', False)]).to_delete = True
|
||||
return 'OK'
|
||||
|
||||
@staticmethod
|
||||
def _check_status_values(uuids, iap_status, message_statuses):
|
||||
"""Basic checks to avoid unnecessary queries and allow debugging."""
|
||||
if (not uuids or not iap_status or not re.match(r'^\w+$', iap_status)
|
||||
or any(not re.match(r'^[0-9a-f]{32}$', uuid) for uuid in uuids)):
|
||||
_logger.warning('Received ill-formatted SMS delivery report event: \n%s', message_statuses)
|
||||
raise UserError(_("Bad parameters"), status=400)
|
||||
Loading…
Add table
Add a link
Reference in a new issue