send_sms.py 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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 api
  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. class InvalidEnvironnementVariable(Exception):
  30. pass
  31. def get_env(key: str) -> str:
  32. """Get a variable from the environnement or raise an InvalidEnvironnementVariable"""
  33. value = os.environ.get(key)
  34. if value is None:
  35. raise InvalidEnvironnementVariable(key)
  36. return value
  37. def main():
  38. API_URL = get_env("API_URL")
  39. API_LOGIN = get_env("API_LOGIN")
  40. API_PASSWORD = get_env("API_PASSWORD")
  41. DEVICE_NAME = get_env("DEVICE_NAME")
  42. send_sms_from_api(API_URL, API_LOGIN, API_PASSWORD, DEVICE_NAME)
  43. if __name__ == "__main__":
  44. logging.basicConfig(
  45. format="%(asctime)s %(levelname)s - %(message)s",
  46. level=logging.DEBUG,
  47. filemode="a",
  48. filename="log.txt",
  49. )
  50. while True:
  51. starting_time = time.time()
  52. try:
  53. main()
  54. except Exception as e:
  55. logging.exception("An error as occured : ")
  56. elapsed_time = time.time() - starting_time
  57. time.sleep(300 - elapsed_time)