app-MAIL-temp/app/phone/views/provider2_callback.py

61 lines
1.9 KiB
Python

import jwt
from flask import request
from jwt import InvalidSignatureError, DecodeError
from app.config import (
PHONE_PROVIDER_2_HEADER,
PHONE_PROVIDER_2_SECRET,
)
from app.log import LOG
from app.models import PhoneNumber, PhoneMessage
from app.phone.base import phone_bp
@phone_bp.route("/provider2/sms", methods=["GET", "POST"])
def provider2_sms():
encoded = request.headers.get(PHONE_PROVIDER_2_HEADER)
try:
jwt.decode(encoded, key=PHONE_PROVIDER_2_SECRET, algorithms="HS256")
except (InvalidSignatureError, DecodeError):
LOG.e(
"Unauthenticated callback %s %s %s %s",
request.headers,
request.method,
request.args,
request.json,
)
return "not ok", 400
# request.json should be a dict where
# msisdn is the sender
# receiver is the receiver
# For ex:
# {'id': 2042489247, 'msisdn': 33612345678, 'country_code': 'FR', 'country_prefix': 33, 'receiver': 33687654321,
# 'message': 'Test 1', 'senttime': 1641401781, 'webhook_label': 'Hagekar', 'sender': None,
# 'mcc': None, 'mnc': None, 'validity_period': None, 'encoding': 'UTF8', 'udh': None, 'payload': None}
to_number: str = str(request.json.get("receiver"))
if not to_number.startswith("+"):
to_number = "+" + to_number
from_number = str(request.json.get("msisdn"))
if not from_number.startswith("+"):
from_number = "+" + from_number
body = request.json.get("message")
LOG.d("%s->%s:%s", from_number, to_number, body)
phone_number = PhoneNumber.get_by(number=to_number)
if phone_number:
PhoneMessage.create(
number_id=phone_number.id,
from_number=from_number,
body=body,
commit=True,
)
else:
LOG.e("Unknown phone number %s %s", to_number, request.json)
return "not ok", 200
return "ok", 200