better-mem0-mcp 1.1.0b17__tar.gz → 1.1.0b19__tar.gz

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.
Files changed (31) hide show
  1. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.pre-commit-config.yaml +1 -1
  2. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/CHANGELOG.md +14 -0
  3. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/PKG-INFO +4 -4
  4. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/README.md +3 -3
  5. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/pyproject.toml +1 -1
  6. better_mem0_mcp-1.1.0b19/src/better_mem0_mcp/__main__.py +6 -0
  7. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/src/better_mem0_mcp/server.py +16 -9
  8. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/uv.lock +1 -1
  9. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.dockerignore +0 -0
  10. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.editorconfig +0 -0
  11. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.github/scripts/check-ci-cd-status.sh +0 -0
  12. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.github/scripts/merge-with-auto-resolve.sh +0 -0
  13. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.github/workflows/cd.yml +0 -0
  14. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.github/workflows/ci.yml +0 -0
  15. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.gitignore +0 -0
  16. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.mise.toml +0 -0
  17. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.python-version +0 -0
  18. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.releaserc.json +0 -0
  19. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/.vscode/better-mem0-mcp.code-workspace +0 -0
  20. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/CONTRIBUTING.md +0 -0
  21. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/Dockerfile +0 -0
  22. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/LICENSE +0 -0
  23. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/SECURITY.md +0 -0
  24. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/package-lock.json +0 -0
  25. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/package.json +0 -0
  26. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/scripts/clean-venv.mjs +0 -0
  27. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/src/better_mem0_mcp/__init__.py +0 -0
  28. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/src/better_mem0_mcp/config.py +0 -0
  29. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/src/better_mem0_mcp/docs/memory.md +0 -0
  30. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/src/better_mem0_mcp/graph.py +0 -0
  31. {better_mem0_mcp-1.1.0b17 → better_mem0_mcp-1.1.0b19}/src/better_mem0_mcp/py.typed +0 -0
@@ -30,7 +30,7 @@ repos:
30
30
  hooks:
31
31
  - id: ty
32
32
  name: ty type check
33
- entry: uv run ty check
33
+ entry: mise exec -- uv run ty check
34
34
  language: system
35
35
  types: [python]
36
36
  pass_filenames: false
@@ -1,3 +1,17 @@
1
+ # [1.1.0-beta.19](https://github.com/n24q02m/better-mem0-mcp/compare/v1.1.0-beta.18...v1.1.0-beta.19) (2026-01-05)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * correct Mem0 API response parsing for search and get_all ([8a612b1](https://github.com/n24q02m/better-mem0-mcp/commit/8a612b1443c59c229e7583ffedced6d38f1b13d1))
7
+
8
+ # [1.1.0-beta.18](https://github.com/n24q02m/better-mem0-mcp/compare/v1.1.0-beta.17...v1.1.0-beta.18) (2026-01-05)
9
+
10
+
11
+ ### Bug Fixes
12
+
13
+ * Add `__main__.py` entry point and update README with `better-mem0` server configuration. ([5c44f58](https://github.com/n24q02m/better-mem0-mcp/commit/5c44f58a5357c90c586009f75ddd876c45ef6f66))
14
+
1
15
  # [1.1.0-beta.17](https://github.com/n24q02m/better-mem0-mcp/compare/v1.1.0-beta.16...v1.1.0-beta.17) (2026-01-05)
2
16
 
3
17
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: better-mem0-mcp
3
- Version: 1.1.0b17
3
+ Version: 1.1.0b19
4
4
  Summary: Zero-setup MCP Server for AI memory - works with Neon/Supabase
5
5
  Project-URL: Homepage, https://github.com/n24q02m/better-mem0-mcp
6
6
  Project-URL: Repository, https://github.com/n24q02m/better-mem0-mcp.git
@@ -47,9 +47,9 @@ Description-Content-Type: text/markdown
47
47
  ```json
48
48
  {
49
49
  "mcpServers": {
50
- "memory": {
50
+ "better-mem0": {
51
51
  "command": "uvx",
52
- "args": ["better-mem0-mcp"],
52
+ "args": ["better-mem0-mcp@latest"],
53
53
  "env": {
54
54
  "DATABASE_URL": "postgresql://user:pass@xxx.neon.tech/neondb?sslmode=require",
55
55
  "API_KEYS": "gemini:AIza..."
@@ -64,7 +64,7 @@ Description-Content-Type: text/markdown
64
64
  ```json
65
65
  {
66
66
  "mcpServers": {
67
- "memory": {
67
+ "better-mem0": {
68
68
  "command": "docker",
69
69
  "args": ["run", "-i", "--rm", "-e", "DATABASE_URL", "-e", "API_KEYS", "n24q02m/better-mem0-mcp:latest"],
70
70
  "env": {
@@ -18,9 +18,9 @@
18
18
  ```json
19
19
  {
20
20
  "mcpServers": {
21
- "memory": {
21
+ "better-mem0": {
22
22
  "command": "uvx",
23
- "args": ["better-mem0-mcp"],
23
+ "args": ["better-mem0-mcp@latest"],
24
24
  "env": {
25
25
  "DATABASE_URL": "postgresql://user:pass@xxx.neon.tech/neondb?sslmode=require",
26
26
  "API_KEYS": "gemini:AIza..."
@@ -35,7 +35,7 @@
35
35
  ```json
36
36
  {
37
37
  "mcpServers": {
38
- "memory": {
38
+ "better-mem0": {
39
39
  "command": "docker",
40
40
  "args": ["run", "-i", "--rm", "-e", "DATABASE_URL", "-e", "API_KEYS", "n24q02m/better-mem0-mcp:latest"],
41
41
  "env": {
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "better-mem0-mcp"
3
- version = "1.1.0-beta.17"
3
+ version = "1.1.0-beta.19"
4
4
  description = "Zero-setup MCP Server for AI memory - works with Neon/Supabase"
5
5
  readme = "README.md"
6
6
  license = { text = "MIT" }
@@ -0,0 +1,6 @@
1
+ """Entry point for `python -m better_mem0_mcp`."""
2
+
3
+ from .server import main
4
+
5
+ if __name__ == "__main__":
6
+ main()
@@ -108,21 +108,24 @@ async def memory(
108
108
  if not query:
109
109
  return "Error: 'query' required for search action"
110
110
 
111
- # Vector search
112
- results = _memory.search(query, user_id=user_id, limit=limit)
111
+ # Vector search - returns {"memories": [...]}
112
+ response = _memory.search(query, user_id=user_id, limit=limit)
113
+ memories = (
114
+ response.get("memories", []) if isinstance(response, dict) else response
115
+ )
113
116
 
114
117
  # Add graph context
115
118
  graph_context = ""
116
119
  if _graph:
117
120
  graph_context = _graph.get_context(query, user_id)
118
121
 
119
- if not results and not graph_context:
122
+ if not memories and not graph_context:
120
123
  return "No memories found."
121
124
 
122
125
  output = ""
123
- if results:
126
+ if memories:
124
127
  output = "Memories:\n" + "\n".join(
125
- [f"- {r.get('memory', str(r))}" for r in results]
128
+ [f"- {m.get('memory', str(m))}" for m in memories]
126
129
  )
127
130
  if graph_context:
128
131
  output += f"\n\n{graph_context}"
@@ -130,13 +133,17 @@ async def memory(
130
133
  return output
131
134
 
132
135
  elif action == "list":
133
- results = _memory.get_all(user_id=user_id)
136
+ # get_all returns {"results": [...]} or list directly
137
+ response = _memory.get_all(user_id=user_id)
138
+ memories = (
139
+ response.get("results", []) if isinstance(response, dict) else response
140
+ )
134
141
 
135
- if not results:
142
+ if not memories:
136
143
  return "No memories stored."
137
144
 
138
- lines = [f"- [{r['id'][:8]}] {r['memory']}" for r in results]
139
- return f"Memories ({len(results)}):\n" + "\n".join(lines)
145
+ lines = [f"- [{m['id'][:8]}] {m['memory']}" for m in memories]
146
+ return f"Memories ({len(memories)}):\n" + "\n".join(lines)
140
147
 
141
148
  elif action == "delete":
142
149
  if not memory_id:
@@ -136,7 +136,7 @@ wheels = [
136
136
 
137
137
  [[package]]
138
138
  name = "better-mem0-mcp"
139
- version = "1.1.0b15"
139
+ version = "1.1.0b18"
140
140
  source = { editable = "." }
141
141
  dependencies = [
142
142
  { name = "google-genai" },