nvidia-nat-redis 1.4.0a20251105__py3-none-any.whl → 1.4.0a20251107__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- nat/plugins/redis/object_store.py +10 -1
- nat/plugins/redis/redis_object_store.py +15 -4
- {nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/METADATA +2 -2
- {nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/RECORD +9 -9
- {nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/WHEEL +0 -0
- {nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/entry_points.txt +0 -0
- {nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/licenses/LICENSE-3rd-party.txt +0 -0
- {nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/licenses/LICENSE.md +0 -0
- {nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/top_level.txt +0 -0
|
@@ -14,6 +14,7 @@
|
|
|
14
14
|
# limitations under the License.
|
|
15
15
|
|
|
16
16
|
from pydantic import Field
|
|
17
|
+
from pydantic import field_validator
|
|
17
18
|
|
|
18
19
|
from nat.builder.builder import Builder
|
|
19
20
|
from nat.cli.register_workflow import register_object_store
|
|
@@ -23,7 +24,7 @@ from nat.data_models.object_store import ObjectStoreBaseConfig
|
|
|
23
24
|
|
|
24
25
|
class RedisObjectStoreClientConfig(ObjectStoreBaseConfig, name="redis"):
|
|
25
26
|
"""
|
|
26
|
-
Object store that stores objects in a Redis database.
|
|
27
|
+
Object store that stores objects in a Redis database with optional TTL.
|
|
27
28
|
"""
|
|
28
29
|
|
|
29
30
|
host: str = Field(default="localhost", description="The host of the Redis server")
|
|
@@ -31,6 +32,14 @@ class RedisObjectStoreClientConfig(ObjectStoreBaseConfig, name="redis"):
|
|
|
31
32
|
port: int = Field(default=6379, description="The port of the Redis server")
|
|
32
33
|
bucket_name: str = Field(description="The name of the bucket to use for the object store")
|
|
33
34
|
password: OptionalSecretStr = Field(default=None, description="The password for the Redis server")
|
|
35
|
+
ttl: int | None = Field(default=None, description="TTL in seconds for objects (None = no expiration)")
|
|
36
|
+
|
|
37
|
+
@field_validator("ttl")
|
|
38
|
+
@classmethod
|
|
39
|
+
def validate_ttl(cls, v: int | None) -> int | None:
|
|
40
|
+
if v is not None and v <= 0:
|
|
41
|
+
raise ValueError("TTL must be a positive integer greater than 0")
|
|
42
|
+
return v
|
|
34
43
|
|
|
35
44
|
|
|
36
45
|
@register_object_store(config_type=RedisObjectStoreClientConfig)
|
|
@@ -28,12 +28,22 @@ logger = logging.getLogger(__name__)
|
|
|
28
28
|
|
|
29
29
|
class RedisObjectStore(ObjectStore):
|
|
30
30
|
"""
|
|
31
|
-
Implementation of ObjectStore that stores objects in Redis.
|
|
31
|
+
Implementation of ObjectStore that stores objects in Redis with optional TTL.
|
|
32
32
|
|
|
33
33
|
Each object is stored as a single binary value at key "nat/object_store/{bucket_name}/{object_key}".
|
|
34
|
+
When TTL is configured, keys will automatically expire after the specified duration in seconds.
|
|
34
35
|
"""
|
|
35
36
|
|
|
36
|
-
def __init__(
|
|
37
|
+
def __init__(
|
|
38
|
+
self,
|
|
39
|
+
*,
|
|
40
|
+
bucket_name: str,
|
|
41
|
+
host: str,
|
|
42
|
+
port: int,
|
|
43
|
+
db: int,
|
|
44
|
+
password: str | None = None,
|
|
45
|
+
ttl: int | None = None,
|
|
46
|
+
):
|
|
37
47
|
|
|
38
48
|
super().__init__()
|
|
39
49
|
|
|
@@ -42,6 +52,7 @@ class RedisObjectStore(ObjectStore):
|
|
|
42
52
|
self._port = port
|
|
43
53
|
self._db = db
|
|
44
54
|
self._password = password
|
|
55
|
+
self._ttl = ttl
|
|
45
56
|
self._client: redis.Redis | None = None
|
|
46
57
|
|
|
47
58
|
async def __aenter__(self) -> "RedisObjectStore":
|
|
@@ -88,7 +99,7 @@ class RedisObjectStore(ObjectStore):
|
|
|
88
99
|
|
|
89
100
|
item_json = item.model_dump_json()
|
|
90
101
|
# Redis SET with NX ensures we do not overwrite existing keys
|
|
91
|
-
if not await self._client.set(full_key, item_json, nx=True):
|
|
102
|
+
if not await self._client.set(full_key, item_json, nx=True, ex=self._ttl):
|
|
92
103
|
raise KeyAlreadyExistsError(key=key,
|
|
93
104
|
additional_message=f"Redis bucket {self._bucket_name} already has key {key}")
|
|
94
105
|
|
|
@@ -100,7 +111,7 @@ class RedisObjectStore(ObjectStore):
|
|
|
100
111
|
|
|
101
112
|
full_key = self._make_key(key)
|
|
102
113
|
item_json = item.model_dump_json()
|
|
103
|
-
await self._client.set(full_key, item_json)
|
|
114
|
+
await self._client.set(full_key, item_json, ex=self._ttl)
|
|
104
115
|
|
|
105
116
|
@override
|
|
106
117
|
async def get_object(self, key: str) -> ObjectStoreItem:
|
{nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/METADATA
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: nvidia-nat-redis
|
|
3
|
-
Version: 1.4.
|
|
3
|
+
Version: 1.4.0a20251107
|
|
4
4
|
Summary: Subpackage for Redis integration in NeMo Agent toolkit
|
|
5
5
|
Author: NVIDIA Corporation
|
|
6
6
|
Maintainer: NVIDIA Corporation
|
|
@@ -16,7 +16,7 @@ Requires-Python: <3.14,>=3.11
|
|
|
16
16
|
Description-Content-Type: text/markdown
|
|
17
17
|
License-File: LICENSE-3rd-party.txt
|
|
18
18
|
License-File: LICENSE.md
|
|
19
|
-
Requires-Dist: nvidia-nat==v1.4.
|
|
19
|
+
Requires-Dist: nvidia-nat==v1.4.0a20251107
|
|
20
20
|
Requires-Dist: redis~=4.3.4
|
|
21
21
|
Dynamic: license-file
|
|
22
22
|
|
{nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/RECORD
RENAMED
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
nat/meta/pypi.md,sha256=TpeNbVZJxzvEf0Gh3BGvLHPYsKnXjgM_KQVCayBPXso,1090
|
|
2
2
|
nat/plugins/redis/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
3
3
|
nat/plugins/redis/memory.py,sha256=up25g7p7EXUcwAvMgCJjzyeGxH0454y9rE6QPPPYjK4,2825
|
|
4
|
-
nat/plugins/redis/object_store.py,sha256=
|
|
4
|
+
nat/plugins/redis/object_store.py,sha256=cRmZfyKJB2yhrbhsbFEaJ8UMjX2E5ca_eT9o41dBK7o,2233
|
|
5
5
|
nat/plugins/redis/redis_editor.py,sha256=nkSIWi1HUPald088fXTuF0rmZ0uS_3V65Vxy20vLSgk,9746
|
|
6
|
-
nat/plugins/redis/redis_object_store.py,sha256=
|
|
6
|
+
nat/plugins/redis/redis_object_store.py,sha256=AvVWCnAO6QMePE8twB03dFSe1VHLq_AOcqCcvDZscbE,4667
|
|
7
7
|
nat/plugins/redis/register.py,sha256=dJBKi-7W72ipkmZTOIo1E3ETffmJIlYhQTOlrkiFH3A,834
|
|
8
8
|
nat/plugins/redis/schema.py,sha256=Zcas3hIIqG7wuR94baYRFycmnccB3CuGmTs4p8Vv4mA,5589
|
|
9
|
-
nvidia_nat_redis-1.4.
|
|
10
|
-
nvidia_nat_redis-1.4.
|
|
11
|
-
nvidia_nat_redis-1.4.
|
|
12
|
-
nvidia_nat_redis-1.4.
|
|
13
|
-
nvidia_nat_redis-1.4.
|
|
14
|
-
nvidia_nat_redis-1.4.
|
|
15
|
-
nvidia_nat_redis-1.4.
|
|
9
|
+
nvidia_nat_redis-1.4.0a20251107.dist-info/licenses/LICENSE-3rd-party.txt,sha256=fOk5jMmCX9YoKWyYzTtfgl-SUy477audFC5hNY4oP7Q,284609
|
|
10
|
+
nvidia_nat_redis-1.4.0a20251107.dist-info/licenses/LICENSE.md,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
|
|
11
|
+
nvidia_nat_redis-1.4.0a20251107.dist-info/METADATA,sha256=xmluwY3xsXLl46lGjsE4ybL5PlmS7rTwzlecSpK_xVc,1894
|
|
12
|
+
nvidia_nat_redis-1.4.0a20251107.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
|
13
|
+
nvidia_nat_redis-1.4.0a20251107.dist-info/entry_points.txt,sha256=nyS8t8L9CbRFIMlE70RQBtJXrflBP4Ltl5zAkIl44So,56
|
|
14
|
+
nvidia_nat_redis-1.4.0a20251107.dist-info/top_level.txt,sha256=8-CJ2cP6-f0ZReXe5Hzqp-5pvzzHz-5Ds5H2bGqh1-U,4
|
|
15
|
+
nvidia_nat_redis-1.4.0a20251107.dist-info/RECORD,,
|
{nvidia_nat_redis-1.4.0a20251105.dist-info → nvidia_nat_redis-1.4.0a20251107.dist-info}/WHEEL
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|