fix(users): skip sms delivery when api key is unset

This commit is contained in:
2026-04-29 20:19:13 +03:30
parent ec199a0e99
commit a2de2a133c

View File

@@ -9,35 +9,46 @@ logger = logging.getLogger(__name__)
def _send_sms(receptor, pattern_code, variables: list = None): def _send_sms(receptor, pattern_code, variables: list = None):
""" """
Send OTP SMS using SMS.ir pattern-based API Send OTP SMS using SMS.ir verify API
""" """
SMS_ENDPOINT = "https://api.sms.ir/v1/send/verify" SMS_ENDPOINT = "https://api.sms.ir/v1/send/verify"
variables = variables or [] variables = variables or []
headers = {"Content-Type": "application/json", "Accept": "text/plain", "x-api-key": settings.SMS_APIKEY}
headers = {
"Content-Type": "application/json",
"Accept": "application/json",
"x-api-key": settings.SMS_APIKEY,
}
payload = { payload = {
"mobile": receptor, "mobile": receptor,
"templateId": str(pattern_code), "templateId": int(pattern_code),
"parameters": variables, "parameters": variables,
} }
logger.info(f"Sending SMS to {receptor} with payload: {payload}") logger.info("Sending SMS to %s with payload: %s", receptor, payload)
try: try:
response = requests.post(SMS_ENDPOINT, data=payload, headers=headers, timeout=10) response = requests.post(
SMS_ENDPOINT,
json=payload,
headers=headers,
timeout=10,
)
logger.info(f"Response status: {response.status_code}") logger.info("Response status: %s", response.status_code)
logger.info(f"Response text: {response.text}") logger.info("Response text: %s", response.text)
if response.status_code == 200: if response.status_code == 200:
result = response.json() result = response.json()
if str(result.get("status", "")) == "1": if str(result.get("status", "")) == "1":
logger.info(f"SMS sent successfully to {receptor}") logger.info("SMS sent successfully to %s", receptor)
else: else:
logger.error(f"SMS.ir API error: {result}") logger.error("SMS.ir API error: %s", result)
else: else:
logger.error(f"HTTP error sending SMS: {response.status_code} - {response.text}") logger.error("HTTP error sending SMS: %s - %s", response.status_code, response.text)
return response return response