v2: Forge Console + Open WebUI artifacts + Docker
- web/: Local chat UI (Express + WS → Codex bridge) - openwebui/: Preset, pipelines, knowledge manifest - Dockerfile + docker-compose.yml - Updated README with 3 frontend options - CLI-agnostic: works with Codex, Claude Code, Kiro, Gemini
This commit is contained in:
87
openwebui/pipelines/aha_pipeline.py
Normal file
87
openwebui/pipelines/aha_pipeline.py
Normal file
@@ -0,0 +1,87 @@
|
||||
"""
|
||||
title: Aha! Pipeline
|
||||
author: PM Factory
|
||||
version: 0.1.0
|
||||
description: Create epics and features in Aha! via the MCP server.
|
||||
requirements: subprocess
|
||||
"""
|
||||
|
||||
import subprocess
|
||||
import json
|
||||
import os
|
||||
from typing import Optional
|
||||
|
||||
MCPORTER_CONFIG = os.environ.get("MCPORTER_CONFIG", "config/mcporter.json")
|
||||
|
||||
|
||||
class Tools:
|
||||
def __init__(self):
|
||||
self.valves = self.Valves()
|
||||
|
||||
class Valves:
|
||||
MCPORTER_CONFIG: str = MCPORTER_CONFIG
|
||||
AHA_DOMAIN: str = os.environ.get("AHA_DOMAIN", "")
|
||||
AHA_API_KEY: str = os.environ.get("AHA_API_KEY", "")
|
||||
|
||||
def aha_create_epic(self, product: str, name: str, description: str, workflow_status: str = "New", __user__: dict = {}) -> str:
|
||||
"""
|
||||
Create an epic in Aha!
|
||||
|
||||
:param product: Aha! product key (e.g. 'PLAT')
|
||||
:param name: Epic name
|
||||
:param description: Epic description (supports HTML)
|
||||
:param workflow_status: Initial status. Default: New
|
||||
:return: Created epic reference and URL
|
||||
"""
|
||||
env = os.environ.copy()
|
||||
env["AHA_DOMAIN"] = self.valves.AHA_DOMAIN
|
||||
env["AHA_API_TOKEN"] = self.valves.AHA_API_KEY
|
||||
|
||||
params = {
|
||||
"product": product,
|
||||
"name": name,
|
||||
"description": description,
|
||||
"workflow_status": workflow_status
|
||||
}
|
||||
try:
|
||||
result = subprocess.run(
|
||||
[
|
||||
"mcporter",
|
||||
"--config", self.valves.MCPORTER_CONFIG,
|
||||
"call", "aha", "create_epic",
|
||||
"--params", json.dumps(params)
|
||||
],
|
||||
capture_output=True, text=True, timeout=30, env=env
|
||||
)
|
||||
if result.returncode != 0:
|
||||
return f"Error: {result.stderr.strip()}"
|
||||
return result.stdout.strip()
|
||||
except Exception as e:
|
||||
return f"Error: {str(e)}"
|
||||
|
||||
def aha_list_features(self, product: str, __user__: dict = {}) -> str:
|
||||
"""
|
||||
List features for an Aha! product.
|
||||
|
||||
:param product: Aha! product key
|
||||
:return: JSON list of features
|
||||
"""
|
||||
env = os.environ.copy()
|
||||
env["AHA_DOMAIN"] = self.valves.AHA_DOMAIN
|
||||
env["AHA_API_TOKEN"] = self.valves.AHA_API_KEY
|
||||
|
||||
try:
|
||||
result = subprocess.run(
|
||||
[
|
||||
"mcporter",
|
||||
"--config", self.valves.MCPORTER_CONFIG,
|
||||
"call", "aha", "list_features",
|
||||
"--params", json.dumps({"product": product})
|
||||
],
|
||||
capture_output=True, text=True, timeout=30, env=env
|
||||
)
|
||||
if result.returncode != 0:
|
||||
return f"Error: {result.stderr.strip()}"
|
||||
return result.stdout.strip()
|
||||
except Exception as e:
|
||||
return f"Error: {str(e)}"
|
||||
Reference in New Issue
Block a user