send_sms.py 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. import os
  2. import logging
  3. import time
  4. import requests
  5. from .KdeConnect import KDEConnect
  6. from app.schemas.responses import AccessTokenResponse, SMSResponse
  7. def send_sms_from_api(url: str, login: str, pwd: str, device_name: str):
  8. """Connect to sms-server API to retreieve sms to be send and send them using kdeconnect-cli"""
  9. # Log in to API get access token
  10. response = requests.post(
  11. url + "/auth/access-token",
  12. data={"grant_type": "password", "username": login, "password": pwd},
  13. )
  14. authentication = AccessTokenResponse.parse_raw(response.content)
  15. headers = {"Authorization": "Bearer " + authentication.access_token}
  16. # List SMS to be send
  17. response = requests.get(url + "/sms/to-send", headers=headers)
  18. sms_list: list[SMSResponse] = [SMSResponse.parse_obj(obj) for obj in response.json()]
  19. logging.info(f"{len(sms_list):5} SMS a envoyer")
  20. # Init KDE Connect
  21. kde = KDEConnect(device_name=device_name)
  22. # send sms & update database
  23. for sms in sms_list:
  24. try:
  25. kde.send_sms(sms.phone_number, sms.content)
  26. requests.post(url + "/sms/send-now/" + sms.id, headers=headers)
  27. except Exception as exc:
  28. logging.warning(f"Echec lors de l'envoie du sms {sms.id}\n{str(exc)}")
  29. time.sleep(2)
  30. class InvalidEnvironnementVariable(Exception):
  31. pass
  32. def get_env(key: str) -> str:
  33. """Get a variable from the environnement or raise an InvalidEnvironnementVariable"""
  34. value = os.environ.get(key)
  35. if value is None:
  36. raise InvalidEnvironnementVariable(key)
  37. return value
  38. def main():
  39. API_URL = get_env("API_URL")
  40. API_LOGIN = get_env("API_LOGIN")
  41. API_PASSWORD = get_env("API_PASSWORD")
  42. DEVICE_NAME = get_env("DEVICE_NAME")
  43. send_sms_from_api(API_URL, API_LOGIN, API_PASSWORD, DEVICE_NAME)
  44. if __name__ == "__main__":
  45. logging.basicConfig(
  46. format="%(asctime)s %(levelname)s - %(message)s",
  47. level=logging.INFO,
  48. filemode="a",
  49. filename="log.txt",
  50. )
  51. while True:
  52. starting_time = time.time()
  53. try:
  54. main()
  55. except Exception:
  56. logging.exception("An error as occured : ")
  57. elapsed_time = time.time() - starting_time
  58. time.sleep(180 - elapsed_time)