You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

azure_sas_conn.py 2.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. import logging
  2. import os
  3. import time
  4. from io import BytesIO
  5. from rag import settings
  6. from rag.utils import singleton
  7. from azure.storage.blob import ContainerClient
  8. @singleton
  9. class RAGFlowAzureSasBlob(object):
  10. def __init__(self):
  11. self.conn = None
  12. self.container_url = os.getenv('CONTAINER_URL', settings.AZURE["container_url"])
  13. self.sas_token = os.getenv('SAS_TOKEN', settings.AZURE["sas_token"])
  14. self.__open__()
  15. def __open__(self):
  16. try:
  17. if self.conn:
  18. self.__close__()
  19. except Exception:
  20. pass
  21. try:
  22. self.conn = ContainerClient.from_container_url(self.container_url + "?" + self.sas_token)
  23. except Exception:
  24. logging.exception("Fail to connect %s " % self.container_url)
  25. def __close__(self):
  26. del self.conn
  27. self.conn = None
  28. def health(self):
  29. _bucket, fnm, binary = "txtxtxtxt1", "txtxtxtxt1", b"_t@@@1"
  30. return self.conn.upload_blob(name=fnm, data=BytesIO(binary), length=len(binary))
  31. def put(self, bucket, fnm, binary):
  32. for _ in range(3):
  33. try:
  34. return self.conn.upload_blob(name=fnm, data=BytesIO(binary), length=len(binary))
  35. except Exception:
  36. logging.exception(f"Fail put {bucket}/{fnm}")
  37. self.__open__()
  38. time.sleep(1)
  39. def rm(self, bucket, fnm):
  40. try:
  41. self.conn.delete_blob(fnm)
  42. except Exception:
  43. logging.exception(f"Fail rm {bucket}/{fnm}")
  44. def get(self, bucket, fnm):
  45. for _ in range(1):
  46. try:
  47. r = self.conn.download_blob(fnm)
  48. return r.read()
  49. except Exception:
  50. logging.exception(f"fail get {bucket}/{fnm}")
  51. self.__open__()
  52. time.sleep(1)
  53. return
  54. def obj_exist(self, bucket, fnm):
  55. try:
  56. return self.conn.get_blob_client(fnm).exists()
  57. except Exception:
  58. logging.exception(f"Fail put {bucket}/{fnm}")
  59. return False
  60. def get_presigned_url(self, bucket, fnm, expires):
  61. for _ in range(10):
  62. try:
  63. return self.conn.get_presigned_url("GET", bucket, fnm, expires)
  64. except Exception:
  65. logging.exception(f"fail get {bucket}/{fnm}")
  66. self.__open__()
  67. time.sleep(1)
  68. return