utils.py 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import json
  2. import uuid
  3. from open_webui.utils.redis import get_redis_connection
  4. class RedisLock:
  5. def __init__(self, redis_url, lock_name, timeout_secs, redis_sentinels=[]):
  6. self.lock_name = lock_name
  7. self.lock_id = str(uuid.uuid4())
  8. self.timeout_secs = timeout_secs
  9. self.lock_obtained = False
  10. self.redis = get_redis_connection(
  11. redis_url, redis_sentinels, decode_responses=True
  12. )
  13. def aquire_lock(self):
  14. # nx=True will only set this key if it _hasn't_ already been set
  15. self.lock_obtained = self.redis.set(
  16. self.lock_name, self.lock_id, nx=True, ex=self.timeout_secs
  17. )
  18. return self.lock_obtained
  19. def renew_lock(self):
  20. # xx=True will only set this key if it _has_ already been set
  21. return self.redis.set(
  22. self.lock_name, self.lock_id, xx=True, ex=self.timeout_secs
  23. )
  24. def release_lock(self):
  25. lock_value = self.redis.get(self.lock_name)
  26. if lock_value and lock_value == self.lock_id:
  27. self.redis.delete(self.lock_name)
  28. class RedisDict:
  29. def __init__(self, name, redis_url, redis_sentinels=[]):
  30. self.name = name
  31. self.redis = get_redis_connection(
  32. redis_url, redis_sentinels, decode_responses=True
  33. )
  34. def __setitem__(self, key, value):
  35. serialized_value = json.dumps(value)
  36. self.redis.hset(self.name, key, serialized_value)
  37. def __getitem__(self, key):
  38. value = self.redis.hget(self.name, key)
  39. if value is None:
  40. raise KeyError(key)
  41. return json.loads(value)
  42. def __delitem__(self, key):
  43. result = self.redis.hdel(self.name, key)
  44. if result == 0:
  45. raise KeyError(key)
  46. def __contains__(self, key):
  47. return self.redis.hexists(self.name, key)
  48. def __len__(self):
  49. return self.redis.hlen(self.name)
  50. def keys(self):
  51. return self.redis.hkeys(self.name)
  52. def values(self):
  53. return [json.loads(v) for v in self.redis.hvals(self.name)]
  54. def items(self):
  55. return [(k, json.loads(v)) for k, v in self.redis.hgetall(self.name).items()]
  56. def get(self, key, default=None):
  57. try:
  58. return self[key]
  59. except KeyError:
  60. return default
  61. def clear(self):
  62. self.redis.delete(self.name)
  63. def update(self, other=None, **kwargs):
  64. if other is not None:
  65. for k, v in other.items() if hasattr(other, "items") else other:
  66. self[k] = v
  67. for k, v in kwargs.items():
  68. self[k] = v
  69. def setdefault(self, key, default=None):
  70. if key not in self:
  71. self[key] = default
  72. return self[key]