nvidia-nat-redis 1.3.0a20250928__py3-none-any.whl → 1.4.0a20251111__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.
Potentially problematic release.
This version of nvidia-nat-redis might be problematic. Click here for more details.
- nat/plugins/redis/memory.py +4 -0
- nat/plugins/redis/object_store.py +12 -1
- nat/plugins/redis/redis_object_store.py +17 -4
- {nvidia_nat_redis-1.3.0a20250928.dist-info → nvidia_nat_redis-1.4.0a20251111.dist-info}/METADATA +10 -2
- nvidia_nat_redis-1.4.0a20251111.dist-info/RECORD +15 -0
- nvidia_nat_redis-1.4.0a20251111.dist-info/licenses/LICENSE-3rd-party.txt +5478 -0
- nvidia_nat_redis-1.4.0a20251111.dist-info/licenses/LICENSE.md +201 -0
- nvidia_nat_redis-1.3.0a20250928.dist-info/RECORD +0 -13
- {nvidia_nat_redis-1.3.0a20250928.dist-info → nvidia_nat_redis-1.4.0a20251111.dist-info}/WHEEL +0 -0
- {nvidia_nat_redis-1.3.0a20250928.dist-info → nvidia_nat_redis-1.4.0a20251111.dist-info}/entry_points.txt +0 -0
- {nvidia_nat_redis-1.3.0a20250928.dist-info → nvidia_nat_redis-1.4.0a20251111.dist-info}/top_level.txt +0 -0
nat/plugins/redis/memory.py
CHANGED
|
@@ -17,6 +17,8 @@ from pydantic import Field
|
|
|
17
17
|
|
|
18
18
|
from nat.builder.builder import Builder
|
|
19
19
|
from nat.cli.register_workflow import register_memory
|
|
20
|
+
from nat.data_models.common import OptionalSecretStr
|
|
21
|
+
from nat.data_models.common import get_secret_value
|
|
20
22
|
from nat.data_models.component_ref import EmbedderRef
|
|
21
23
|
from nat.data_models.memory import MemoryBaseConfig
|
|
22
24
|
|
|
@@ -25,6 +27,7 @@ class RedisMemoryClientConfig(MemoryBaseConfig, name="redis_memory"):
|
|
|
25
27
|
host: str = Field(default="localhost", description="Redis server host")
|
|
26
28
|
db: int = Field(default=0, description="Redis DB")
|
|
27
29
|
port: int = Field(default=6379, description="Redis server port")
|
|
30
|
+
password: OptionalSecretStr = Field(default=None, description="Password for the Redis server")
|
|
28
31
|
key_prefix: str = Field(default="nat", description="Key prefix to use for redis keys")
|
|
29
32
|
embedder: EmbedderRef = Field(description=("Instance name of the memory client instance from the workflow "
|
|
30
33
|
"configuration object."))
|
|
@@ -43,6 +46,7 @@ async def redis_memory_client(config: RedisMemoryClientConfig, builder: Builder)
|
|
|
43
46
|
redis_client = redis.Redis(host=config.host,
|
|
44
47
|
port=config.port,
|
|
45
48
|
db=config.db,
|
|
49
|
+
password=get_secret_value(config.password),
|
|
46
50
|
decode_responses=True,
|
|
47
51
|
socket_timeout=5.0,
|
|
48
52
|
socket_connect_timeout=5.0)
|
|
@@ -14,21 +14,32 @@
|
|
|
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
|
|
21
|
+
from nat.data_models.common import OptionalSecretStr
|
|
20
22
|
from nat.data_models.object_store import ObjectStoreBaseConfig
|
|
21
23
|
|
|
22
24
|
|
|
23
25
|
class RedisObjectStoreClientConfig(ObjectStoreBaseConfig, name="redis"):
|
|
24
26
|
"""
|
|
25
|
-
Object store that stores objects in a Redis database.
|
|
27
|
+
Object store that stores objects in a Redis database with optional TTL.
|
|
26
28
|
"""
|
|
27
29
|
|
|
28
30
|
host: str = Field(default="localhost", description="The host of the Redis server")
|
|
29
31
|
db: int = Field(default=0, description="The Redis logical database number")
|
|
30
32
|
port: int = Field(default=6379, description="The port of the Redis server")
|
|
31
33
|
bucket_name: str = Field(description="The name of the bucket to use for the object store")
|
|
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
|
|
32
43
|
|
|
33
44
|
|
|
34
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
|
|
|
@@ -41,6 +51,8 @@ class RedisObjectStore(ObjectStore):
|
|
|
41
51
|
self._host = host
|
|
42
52
|
self._port = port
|
|
43
53
|
self._db = db
|
|
54
|
+
self._password = password
|
|
55
|
+
self._ttl = ttl
|
|
44
56
|
self._client: redis.Redis | None = None
|
|
45
57
|
|
|
46
58
|
async def __aenter__(self) -> "RedisObjectStore":
|
|
@@ -52,6 +64,7 @@ class RedisObjectStore(ObjectStore):
|
|
|
52
64
|
host=self._host,
|
|
53
65
|
port=self._port,
|
|
54
66
|
db=self._db,
|
|
67
|
+
password=self._password,
|
|
55
68
|
socket_timeout=5.0,
|
|
56
69
|
socket_connect_timeout=5.0,
|
|
57
70
|
)
|
|
@@ -86,7 +99,7 @@ class RedisObjectStore(ObjectStore):
|
|
|
86
99
|
|
|
87
100
|
item_json = item.model_dump_json()
|
|
88
101
|
# Redis SET with NX ensures we do not overwrite existing keys
|
|
89
|
-
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):
|
|
90
103
|
raise KeyAlreadyExistsError(key=key,
|
|
91
104
|
additional_message=f"Redis bucket {self._bucket_name} already has key {key}")
|
|
92
105
|
|
|
@@ -98,7 +111,7 @@ class RedisObjectStore(ObjectStore):
|
|
|
98
111
|
|
|
99
112
|
full_key = self._make_key(key)
|
|
100
113
|
item_json = item.model_dump_json()
|
|
101
|
-
await self._client.set(full_key, item_json)
|
|
114
|
+
await self._client.set(full_key, item_json, ex=self._ttl)
|
|
102
115
|
|
|
103
116
|
@override
|
|
104
117
|
async def get_object(self, key: str) -> ObjectStoreItem:
|
{nvidia_nat_redis-1.3.0a20250928.dist-info → nvidia_nat_redis-1.4.0a20251111.dist-info}/METADATA
RENAMED
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: nvidia-nat-redis
|
|
3
|
-
Version: 1.
|
|
3
|
+
Version: 1.4.0a20251111
|
|
4
4
|
Summary: Subpackage for Redis integration in NeMo Agent toolkit
|
|
5
|
+
Author: NVIDIA Corporation
|
|
6
|
+
Maintainer: NVIDIA Corporation
|
|
7
|
+
License: Apache-2.0
|
|
8
|
+
Project-URL: documentation, https://docs.nvidia.com/nemo/agent-toolkit/latest/
|
|
9
|
+
Project-URL: source, https://github.com/NVIDIA/NeMo-Agent-Toolkit
|
|
5
10
|
Keywords: ai,agents,memory
|
|
6
11
|
Classifier: Programming Language :: Python
|
|
7
12
|
Classifier: Programming Language :: Python :: 3.11
|
|
@@ -9,8 +14,11 @@ Classifier: Programming Language :: Python :: 3.12
|
|
|
9
14
|
Classifier: Programming Language :: Python :: 3.13
|
|
10
15
|
Requires-Python: <3.14,>=3.11
|
|
11
16
|
Description-Content-Type: text/markdown
|
|
12
|
-
|
|
17
|
+
License-File: LICENSE-3rd-party.txt
|
|
18
|
+
License-File: LICENSE.md
|
|
19
|
+
Requires-Dist: nvidia-nat==v1.4.0a20251111
|
|
13
20
|
Requires-Dist: redis~=4.3.4
|
|
21
|
+
Dynamic: license-file
|
|
14
22
|
|
|
15
23
|
<!--
|
|
16
24
|
SPDX-FileCopyrightText: Copyright (c) 2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
nat/meta/pypi.md,sha256=TpeNbVZJxzvEf0Gh3BGvLHPYsKnXjgM_KQVCayBPXso,1090
|
|
2
|
+
nat/plugins/redis/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
3
|
+
nat/plugins/redis/memory.py,sha256=up25g7p7EXUcwAvMgCJjzyeGxH0454y9rE6QPPPYjK4,2825
|
|
4
|
+
nat/plugins/redis/object_store.py,sha256=cRmZfyKJB2yhrbhsbFEaJ8UMjX2E5ca_eT9o41dBK7o,2233
|
|
5
|
+
nat/plugins/redis/redis_editor.py,sha256=nkSIWi1HUPald088fXTuF0rmZ0uS_3V65Vxy20vLSgk,9746
|
|
6
|
+
nat/plugins/redis/redis_object_store.py,sha256=AvVWCnAO6QMePE8twB03dFSe1VHLq_AOcqCcvDZscbE,4667
|
|
7
|
+
nat/plugins/redis/register.py,sha256=dJBKi-7W72ipkmZTOIo1E3ETffmJIlYhQTOlrkiFH3A,834
|
|
8
|
+
nat/plugins/redis/schema.py,sha256=Zcas3hIIqG7wuR94baYRFycmnccB3CuGmTs4p8Vv4mA,5589
|
|
9
|
+
nvidia_nat_redis-1.4.0a20251111.dist-info/licenses/LICENSE-3rd-party.txt,sha256=fOk5jMmCX9YoKWyYzTtfgl-SUy477audFC5hNY4oP7Q,284609
|
|
10
|
+
nvidia_nat_redis-1.4.0a20251111.dist-info/licenses/LICENSE.md,sha256=QwcOLU5TJoTeUhuIXzhdCEEDDvorGiC6-3YTOl4TecE,11356
|
|
11
|
+
nvidia_nat_redis-1.4.0a20251111.dist-info/METADATA,sha256=nobgaoa3267c99TAk-6bs2C_Myrzs6ycWKdUnArPTew,1894
|
|
12
|
+
nvidia_nat_redis-1.4.0a20251111.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
|
13
|
+
nvidia_nat_redis-1.4.0a20251111.dist-info/entry_points.txt,sha256=nyS8t8L9CbRFIMlE70RQBtJXrflBP4Ltl5zAkIl44So,56
|
|
14
|
+
nvidia_nat_redis-1.4.0a20251111.dist-info/top_level.txt,sha256=8-CJ2cP6-f0ZReXe5Hzqp-5pvzzHz-5Ds5H2bGqh1-U,4
|
|
15
|
+
nvidia_nat_redis-1.4.0a20251111.dist-info/RECORD,,
|