fenix-mcp 1.7.0__tar.gz → 1.8.0__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 (34) hide show
  1. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/PKG-INFO +1 -1
  2. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/__init__.py +1 -1
  3. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tools/knowledge.py +9 -3
  4. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp.egg-info/PKG-INFO +1 -1
  5. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/README.md +0 -0
  6. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/presenters.py +0 -0
  7. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tool_base.py +0 -0
  8. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tool_registry.py +0 -0
  9. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tools/__init__.py +0 -0
  10. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tools/health.py +0 -0
  11. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tools/initialize.py +0 -0
  12. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tools/intelligence.py +0 -0
  13. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tools/productivity.py +0 -0
  14. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/application/tools/user_config.py +0 -0
  15. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/domain/initialization.py +0 -0
  16. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/domain/intelligence.py +0 -0
  17. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/domain/knowledge.py +0 -0
  18. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/domain/productivity.py +0 -0
  19. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/domain/user_config.py +0 -0
  20. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/infrastructure/config.py +0 -0
  21. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/infrastructure/context.py +0 -0
  22. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/infrastructure/fenix_api/client.py +0 -0
  23. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/infrastructure/http_client.py +0 -0
  24. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/infrastructure/logging.py +0 -0
  25. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/interface/mcp_server.py +0 -0
  26. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/interface/transports.py +0 -0
  27. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp/main.py +0 -0
  28. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp.egg-info/SOURCES.txt +0 -0
  29. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp.egg-info/dependency_links.txt +0 -0
  30. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp.egg-info/entry_points.txt +0 -0
  31. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp.egg-info/requires.txt +0 -0
  32. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/fenix_mcp.egg-info/top_level.txt +0 -0
  33. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/pyproject.toml +0 -0
  34. {fenix_mcp-1.7.0 → fenix_mcp-1.8.0}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: fenix-mcp
3
- Version: 1.7.0
3
+ Version: 1.8.0
4
4
  Summary: Fênix Cloud MCP server implemented in Python
5
5
  Author: Fenix Inc
6
6
  Requires-Python: >=3.10
@@ -8,4 +8,4 @@ Fênix Cloud MCP Server (Python edition).
8
8
  __all__ = ["__version__"]
9
9
 
10
10
 
11
- __version__ = "1.7.0"
11
+ __version__ = "1.8.0"
@@ -80,7 +80,7 @@ class KnowledgeAction(str, Enum):
80
80
  )
81
81
  WORK_BULK_CREATE = (
82
82
  "work_bulk_create",
83
- "Creates multiple work items atomically with hierarchy. Use temp_id as temporary identifier and parent_temp_id to reference parent. Example: [{temp_id:'epic-1', title:'My Epic', item_type:'epic', work_category:'backend'}, {temp_id:'task-1', parent_temp_id:'epic-1', title:'My Task', item_type:'task', work_category:'backend'}]",
83
+ "Creates multiple work items atomically with hierarchy. Use temp_id as temporary identifier and parent_temp_id to reference parent in the same batch, or parent_key to reference an existing work item (e.g., TEMA-0056). Cannot use both parent_temp_id and parent_key on the same item. Example: [{temp_id:'epic-1', title:'My Epic', item_type:'epic', work_category:'backend'}, {temp_id:'task-1', parent_temp_id:'epic-1', title:'My Task', item_type:'task', work_category:'backend'}] or [{temp_id:'task-1', parent_key:'TEMA-0056', title:'My Task', item_type:'task', work_category:'backend'}]",
84
84
  )
85
85
 
86
86
  # Boards
@@ -269,7 +269,9 @@ class KnowledgeRequest(ToolRequest):
269
269
  description=(
270
270
  "List of work items for bulk create (max 50). Each item requires: "
271
271
  "temp_id (your temporary ID like 'epic-1', 'task-a'), title, item_type, work_category. "
272
- "Use parent_temp_id to set parent (e.g., parent_temp_id:'epic-1' makes it child of epic-1). "
272
+ "Use parent_temp_id to set parent from same batch (e.g., parent_temp_id:'epic-1'), "
273
+ "OR parent_key to set parent from existing work item (e.g., parent_key:'TEMA-0056'). "
274
+ "Cannot use both parent_temp_id and parent_key on the same item. "
273
275
  "Optional: description, priority (low/medium/high/critical), story_points, tags, due_date. "
274
276
  'Example: [{"temp_id":"e1", "title":"Epic", "item_type":"epic", "work_category":"backend"}, '
275
277
  '{"temp_id":"t1", "parent_temp_id":"e1", "title":"Task", "item_type":"task", "work_category":"backend"}]'
@@ -598,7 +600,7 @@ class KnowledgeTool(Tool):
598
600
  if not payload.work_items:
599
601
  return text(
600
602
  "❌ Provide work_items array. Each item requires: temp_id, title, item_type, work_category. "
601
- "Optional: parent_temp_id, description, priority, story_points, tags, due_date."
603
+ "Optional: parent_temp_id OR parent_key (not both), description, priority, story_points, tags, due_date."
602
604
  )
603
605
  if len(payload.work_items) > 50:
604
606
  return text("❌ Maximum 50 items per bulk create.")
@@ -613,6 +615,10 @@ class KnowledgeTool(Tool):
613
615
  return text(f"❌ Item {i}: missing item_type.")
614
616
  if not item.get("work_category"):
615
617
  return text(f"❌ Item {i}: missing work_category.")
618
+ if item.get("parent_temp_id") and item.get("parent_key"):
619
+ return text(
620
+ f"❌ Item {i}: cannot have both parent_temp_id and parent_key. Use one or the other."
621
+ )
616
622
 
617
623
  items = await self._service.work_bulk_create({"items": payload.work_items})
618
624
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: fenix-mcp
3
- Version: 1.7.0
3
+ Version: 1.8.0
4
4
  Summary: Fênix Cloud MCP server implemented in Python
5
5
  Author: Fenix Inc
6
6
  Requires-Python: >=3.10
File without changes
File without changes
File without changes
File without changes