unifi-network-mcp 0.3.2__tar.gz → 0.3.3__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 (52) hide show
  1. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/.gitignore +1 -0
  2. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/PKG-INFO +2 -2
  3. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/pyproject.toml +12 -3
  4. unifi_network_mcp-0.3.3/src/_version.py +34 -0
  5. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/network.py +12 -1
  6. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools_manifest.json +1 -1
  7. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/.well-known/mcp-server.json +0 -0
  8. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/LICENSE +0 -0
  9. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/README.md +0 -0
  10. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/bootstrap.py +0 -0
  11. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/config/config.yaml +0 -0
  12. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/jobs.py +0 -0
  13. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/main.py +0 -0
  14. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/client_manager.py +0 -0
  15. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/connection_manager.py +0 -0
  16. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/device_manager.py +0 -0
  17. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/event_manager.py +0 -0
  18. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/firewall_manager.py +0 -0
  19. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/hotspot_manager.py +0 -0
  20. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/network_manager.py +0 -0
  21. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/qos_manager.py +0 -0
  22. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/routing_manager.py +0 -0
  23. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/stats_manager.py +0 -0
  24. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/system_manager.py +0 -0
  25. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/traffic_route_manager.py +0 -0
  26. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/usergroup_manager.py +0 -0
  27. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/managers/vpn_manager.py +0 -0
  28. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/runtime.py +0 -0
  29. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/schemas.py +0 -0
  30. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tool_index.py +0 -0
  31. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/clients.py +0 -0
  32. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/config.py +0 -0
  33. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/devices.py +0 -0
  34. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/events.py +0 -0
  35. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/firewall.py +0 -0
  36. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/hotspot.py +0 -0
  37. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/port_forwards.py +0 -0
  38. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/qos.py +0 -0
  39. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/routing.py +0 -0
  40. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/stats.py +0 -0
  41. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/system.py +0 -0
  42. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/traffic_routes.py +0 -0
  43. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/usergroups.py +0 -0
  44. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/tools/vpn.py +0 -0
  45. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/utils/confirmation.py +0 -0
  46. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/utils/diagnostics.py +0 -0
  47. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/utils/lazy_tool_loader.py +0 -0
  48. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/utils/meta_tools.py +0 -0
  49. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/utils/permissions.py +0 -0
  50. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/utils/tool_loader.py +0 -0
  51. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/validator_registry.py +0 -0
  52. {unifi_network_mcp-0.3.2 → unifi_network_mcp-0.3.3}/src/validators.py +0 -0
@@ -3,6 +3,7 @@
3
3
 
4
4
  # Python
5
5
  __pycache__/
6
+ src/_version.py
6
7
  *.py[cod]
7
8
  *$py.class
8
9
  *.so
@@ -1,11 +1,11 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: unifi-network-mcp
3
- Version: 0.3.2
3
+ Version: 0.3.3
4
4
  Summary: Unifi Network MCP Server
5
5
  License-File: LICENSE
6
6
  Requires-Python: >=3.13
7
7
  Requires-Dist: aiohttp>=3.8.5
8
- Requires-Dist: aiounifi>=87.0.0
8
+ Requires-Dist: aiounifi>=88
9
9
  Requires-Dist: jsonschema>=4.17.0
10
10
  Requires-Dist: mcp[cli]>=1.21.2
11
11
  Requires-Dist: omegaconf>=2.3.0
@@ -1,13 +1,13 @@
1
1
  [project]
2
2
  name = "unifi-network-mcp"
3
- version = "0.3.2"
3
+ dynamic = ["version"]
4
4
  description = "Unifi Network MCP Server"
5
5
  readme = "README.md"
6
6
  requires-python = ">=3.13"
7
7
  dependencies = [
8
8
  "mcp[cli]>=1.21.2",
9
9
  "aiohttp>=3.8.5",
10
- "aiounifi>=87.0.0",
10
+ "aiounifi>=88",
11
11
  "pyyaml>=6.0",
12
12
  "python-dotenv>=1.0.0",
13
13
  "omegaconf>=2.3.0",
@@ -16,9 +16,15 @@ dependencies = [
16
16
  ]
17
17
 
18
18
  [build-system]
19
- requires = ["hatchling"]
19
+ requires = ["hatchling", "hatch-vcs"]
20
20
  build-backend = "hatchling.build"
21
21
 
22
+ [tool.hatch.version]
23
+ source = "vcs"
24
+
25
+ [tool.hatch.build.hooks.vcs]
26
+ version-file = "src/_version.py"
27
+
22
28
  [tool.hatch.build.targets.wheel]
23
29
  packages = ["src"]
24
30
 
@@ -44,6 +50,7 @@ dev = [
44
50
  "pytest-asyncio>=0.21.0",
45
51
  "aioresponses>=0.7.0",
46
52
  "pytest-cov>=4.0.0",
53
+ "ruff>=0.8.0",
47
54
  ]
48
55
 
49
56
  [tool.rye]
@@ -53,6 +60,7 @@ dev-dependencies = [
53
60
  "pytest-asyncio>=0.21.0",
54
61
  "aioresponses>=0.7.0",
55
62
  "pytest-cov>=4.0.0",
63
+ "ruff>=0.8.0",
56
64
  ]
57
65
 
58
66
  [project.scripts]
@@ -61,6 +69,7 @@ unifi-network-mcp = "src.main:main"
61
69
 
62
70
  [tool.ruff]
63
71
  line-length = 120
72
+ exclude = ["src/_version.py"] # Auto-generated by hatch-vcs
64
73
 
65
74
  [tool.ruff.lint]
66
75
  select = ["E", "F", "I"]
@@ -0,0 +1,34 @@
1
+ # file generated by setuptools-scm
2
+ # don't change, don't track in version control
3
+
4
+ __all__ = [
5
+ "__version__",
6
+ "__version_tuple__",
7
+ "version",
8
+ "version_tuple",
9
+ "__commit_id__",
10
+ "commit_id",
11
+ ]
12
+
13
+ TYPE_CHECKING = False
14
+ if TYPE_CHECKING:
15
+ from typing import Tuple
16
+ from typing import Union
17
+
18
+ VERSION_TUPLE = Tuple[Union[int, str], ...]
19
+ COMMIT_ID = Union[str, None]
20
+ else:
21
+ VERSION_TUPLE = object
22
+ COMMIT_ID = object
23
+
24
+ version: str
25
+ __version__: str
26
+ __version_tuple__: VERSION_TUPLE
27
+ version_tuple: VERSION_TUPLE
28
+ commit_id: COMMIT_ID
29
+ __commit_id__: COMMIT_ID
30
+
31
+ __version__ = version = '0.3.3'
32
+ __version_tuple__ = version_tuple = (0, 3, 3)
33
+
34
+ __commit_id__ = commit_id = None
@@ -170,7 +170,7 @@ async def get_network_details(network_id: str) -> Dict[str, Any]:
170
170
 
171
171
  @server.tool(
172
172
  name="unifi_update_network",
173
- description="Update specific fields of an existing network (LAN/VLAN). Requires confirmation.",
173
+ description="Update specific fields of an existing network (LAN/VLAN). Requires confirmation. Note: Network isolation is only supported on 'corporate' networks, not 'guest' networks.",
174
174
  permission_category="networks",
175
175
  permission_action="update",
176
176
  )
@@ -193,9 +193,15 @@ async def update_network(network_id: str, update_data: Dict[str, Any], confirm:
193
193
  - dhcp_start (string): New DHCP start IP.
194
194
  - dhcp_stop (string): New DHCP stop IP.
195
195
  - enabled (boolean): Enable/disable the entire network.
196
+ - network_isolation_enabled (boolean): Enable network isolation (IMPORTANT: Only works on networks with purpose="corporate").
196
197
  # Add other relevant fields from NetworkSchema here if needed
197
198
  confirm (bool): Must be set to `True` to execute. Defaults to `False`.
198
199
 
200
+ Important Constraints:
201
+ - Network isolation (network_isolation_enabled) is ONLY supported on networks with purpose="corporate".
202
+ - Attempting to enable isolation on "guest" or other network types will fail with an API error.
203
+ - To isolate a guest network: (1) Change its purpose from "guest" to "corporate", then (2) enable network_isolation_enabled.
204
+
199
205
  Returns:
200
206
  Dict: Success status, ID, updated fields, details, or error message.
201
207
  Example (success):
@@ -317,6 +323,11 @@ async def create_network(network_data: Dict[str, Any], confirm: bool = False) ->
317
323
  - vlan (integer): VLAN ID (required if vlan_enabled is true)
318
324
  - dhcp_enabled (boolean): Whether DHCP is enabled (default: true)
319
325
  - enabled (boolean): Whether the network is enabled (default: true)
326
+ - network_isolation_enabled (boolean): Enable network isolation (IMPORTANT: Only works on networks with purpose="corporate")
327
+
328
+ Important Constraints:
329
+ - Network isolation (network_isolation_enabled) is ONLY supported on networks with purpose="corporate".
330
+ - It cannot be enabled on "guest" networks.
320
331
 
321
332
  Example:
322
333
  {
@@ -1239,7 +1239,7 @@
1239
1239
  }
1240
1240
  },
1241
1241
  {
1242
- "description": "Update specific fields of an existing network (LAN/VLAN). Requires confirmation.",
1242
+ "description": "Update specific fields of an existing network (LAN/VLAN). Requires confirmation. Note: Network isolation is only supported on 'corporate' networks, not 'guest' networks.",
1243
1243
  "name": "unifi_update_network",
1244
1244
  "schema": {
1245
1245
  "input": {