gitea_manager frissítés

This commit is contained in:
Roo
2026-03-10 08:27:38 +00:00
parent 0304cb8142
commit 2d8d23f469
4 changed files with 225 additions and 79 deletions

View File

@@ -1,28 +1,71 @@
# 🤖 ÉLES MUNKAFOLYAMAT (KÖTELEZŐ) # 🤖 ÉLES MUNKAFOLYAMAT (KÖTELEZŐ)
A feladataidat szigorúan a `gitea_manager.py` script segítségével kell menedzselned a `roo-helper` konténerben. A feladataidat szigorúan a `gitea_manager.py` script segítségével kell menedzselned a `roo-helper` konténerben.
Minden paramétert az alábbi parancsokkal hívj meg: A szkript most már okosabb, támogatja az automatikus lapozást, mérföldkövek kezelését és extra paramétereket.
## 1. Feladat Felvétele (Get) ## 📋 ELÉRHETŐ PARANCSOK
### 1. Listázás és Információ
- **Feladatok listázása:** `docker exec roo-helper python3 /scripts/gitea_manager.py list`
- **Lezárt feladatok:** `docker exec roo-helper python3 /scripts/gitea_manager.py list closed`
- **Mérföldkövek listázása:** `docker exec roo-helper python3 /scripts/gitea_manager.py ms list`
- **Feladat részletei:** `docker exec roo-helper python3 /scripts/gitea_manager.py get <id>`
### 2. Mérföldkövek Kezelése
- **Új mérföldkő létrehozása:** `docker exec roo-helper python3 /scripts/gitea_manager.py ms create "Mérföldkő Neve" "Leírás" --due YYYY-MM-DD`
- **Mérföldkövek listázása:** `docker exec roo-helper python3 /scripts/gitea_manager.py ms list`
### 3. Feladat Felvétele (Get)
Amikor megkapod, hogy dolgozz pl. a #3-as feladaton, ELSŐKÉNT olvasd ki a feladatot: Amikor megkapod, hogy dolgozz pl. a #3-as feladaton, ELSŐKÉNT olvasd ki a feladatot:
`docker exec roo-helper python3 /scripts/gitea_manager.py get 3` `docker exec roo-helper python3 /scripts/gitea_manager.py get 3`
Értelmezd a kapott címet és leírást. Értelmezd a kapott címet, leírást és mérföldkövet.
## 2. Munka Megkezdése (Start) ### 4. Munka Megkezdése (Start)
Mielőtt elkezdenél kódolni, mozgasd a kártyát "In Progress" állapotba: Mielőtt elkezdenél kódolni, mozgasd a kártyát "In Progress" állapotba:
`docker exec roo-helper python3 /scripts/gitea_manager.py start 3` `docker exec roo-helper python3 /scripts/gitea_manager.py start 3`
## 3. Fejlesztés és Dokumentálás ### 5. Fejlesztés és Dokumentálás
- Végezd el a kért kódolási feladatot. - Végezd el a kért kódolási feladatot.
- **KÖTELEZŐ:** Készíts vagy frissíts egy Markdown leírást (pl. `readme.md` vagy doc fájl) a működő részről. - **KÖTELEZŐ:** Készíts vagy frissíts egy Markdown leírást (pl. `readme.md` vagy doc fájl) a működő részről.
## 4. Befejezés és Lezárás (Finish) ### 6. Befejezés és Lezárás (Finish)
Ha minden kész, a kód le van tesztelve és dokumentálva, zárd le a feladatot (ez átmozgatja a Done-ba és lezárja az Issue-t is): Ha minden kész, a kód le van tesztelve és dokumentálva, zárd le a feladatot (ez átmozgatja a Done-ba és lezárja az Issue-t is):
`docker exec roo-helper python3 /scripts/gitea_manager.py finish 3` `docker exec roo-helper python3 /scripts/gitea_manager.py finish 3 "Rövid technikai összefoglaló"`
## 5. Új Feladatok Létrehozása (Create) ### 7. Új Feladatok Létrehozása (Create)
Ha auditálást végzel, és hiányzó funkciókat találsz, önállóan hozz létre ToDo kártyákat az alábbi paranccsal: Ha auditálást végzel, és hiányzó funkciókat találsz, önállóan hozz létre ToDo kártyákat:
**Alap parancs:**
`docker exec roo-helper python3 /scripts/gitea_manager.py create "Kártya Címe" "Részletes leírás Markdown formátumban"` `docker exec roo-helper python3 /scripts/gitea_manager.py create "Kártya Címe" "Részletes leírás Markdown formátumban"`
**Teljes szintaxis opciókkal:**
`docker exec roo-helper python3 /scripts/gitea_manager.py create "Cím" "Leírás" [Mérföldkő] [Címkék...] [--due YYYY-MM-DD] [--assign username]`
TILOS a folyamat lépéseit szimulálni. Ha egy API parancs hibát dob, állj meg, és jelezd a felhasználónak! **Példák:**
- `docker exec roo-helper python3 /scripts/gitea_manager.py create "API végpont hozzáadása" "Új POST /vehicles endpoint..." "DDD Refaktor" "Scope: Backend" "Type: Feature" --due 2026-03-15 --assign kincses`
- `docker exec roo-helper python3 /scripts/gitea_manager.py create "Hibajavítás" "Fix SQL injection..." "Scope: Database" "Type: Bug"`
**Címke típusok:**
- **Státusz:** `Status: To Do`, `Status: In Progress`, `Status: Done`, `Status: Blocked`
- **Hatáskör:** `Scope: Backend`, `Scope: Frontend`, `Scope: API`, `Scope: Core`, `Scope: Robot`, `Scope: Database`
- **Típus:** `Type: Script`, `Type: Model`, `Type: Database`, `Type: Bug`, `Type: Feature`, `Type: Refactor`
- **Szerepkör:** `Role: Admin`, `Role: User`
## 🎯 MUNKAFOLYAMAT ÖSSZEFOGLALÓ
1. **Feladat kiválasztása:** `list` → válassz egy nyitott feladatot
2. **Részletek:** `get <id>` → értelmezd a feladatot
3. **Megkezdés:** `start <id>` → időmérés indítása
4. **Fejlesztés:** Kódolás és dokumentálás
5. **Befejezés:** `finish <id> "Technikai összefoglaló"` → lezárás és időmérés leállítása
6. **Új feladat:** `create ...` → ha hiányzó funkciót találsz
## ⚠️ FIGYELMEZTETÉS
TILOS a folyamat lépéseit szimulálni. Ha egy API parancs hibát dob, állj meg, és jelezd a felhasználónak!
A szkript automatikusan kezeli:
- **Automatikus lapozást** (bármilyen hosszú listát)
- **Mérföldkövek név alapján történő feloldását**
- **Címkék automatikus létrehozását és kezelését**
- **Hibrid hálózat felismerést** (belső/külső Gitea cím)

View File

@@ -2,9 +2,12 @@
import requests import requests
import sys import sys
import datetime import datetime
import socket
# ================= KONFIGURÁCIÓ ================= # ================= KONFIGURÁCIÓ =================
BASE_URL = "http://gitea:3000/api/v1" INTERNAL_HOST = "gitea"
EXTERNAL_IP = "192.168.100.10"
PORT = "3000"
OWNER = "kincses" OWNER = "kincses"
REPO = "service-finder" REPO = "service-finder"
TOKEN = "783f58519ee0ca060491dbc07f3dde1d8e48c5dd" TOKEN = "783f58519ee0ca060491dbc07f3dde1d8e48c5dd"
@@ -14,27 +17,54 @@ HEADERS = {
"Content-Type": "application/json" "Content-Type": "application/json"
} }
# A teljes profi címkerendszer # Hibrid Hálózat-felismerés
def get_base_url():
try:
socket.gethostbyname(INTERNAL_HOST)
return f"http://{INTERNAL_HOST}:{PORT}/api/v1"
except socket.gaierror:
return f"http://{EXTERNAL_IP}:{PORT}/api/v1"
BASE_URL = get_base_url()
LABELS = { LABELS = {
"Status: To Do": "#ef4444", "Status: In Progress": "#f59e0b", "Status: Done": "#10b981", "Status: Blocked": "#000000", "Status: To Do": "#ef4444", "Status: In Progress": "#f59e0b", "Status: Done": "#10b981", "Status: Blocked": "#000000",
"Scope: Backend": "#0369a1", "Scope: Frontend": "#0284c7", "Scope: API": "#0ea5e9", "Scope: Core": "#38bdf8", "Scope: Robot": "#7dd3fc", "Scope: Backend": "#0369a1", "Scope: Frontend": "#0284c7", "Scope: API": "#0ea5e9", "Scope: Core": "#38bdf8", "Scope: Robot": "#7dd3fc", "Scope: Database": "#ec4899",
"Type: Script": "#8b5cf6", "Type: Model": "#3b82f6", "Type: Database": "#ec4899", "Type: Bug": "#dc2626", "Type: Feature": "#16a34a", "Type: Script": "#8b5cf6", "Type: Model": "#3b82f6", "Type: Database": "#ec4899", "Type: Bug": "#dc2626", "Type: Feature": "#16a34a", "Type: Refactor": "#16a34a",
"Role: Admin": "#fb923c", "Role: User": "#fdba74" "Role: Admin": "#fb923c", "Role: User": "#fdba74"
} }
# ================================================ # ================================================
def fetch_all_pages(endpoint):
"""Gitea API lapozás (Pagination) kezelése, hogy minden elemet visszakapjunk."""
all_data = []
page = 1
limit = 50
separator = "&" if "?" in endpoint else "?"
while True:
url = f"{BASE_URL}{endpoint}{separator}limit={limit}&page={page}"
res = requests.get(url, headers=HEADERS)
if res.status_code != 200:
break
data = res.json()
if not data:
break
all_data.extend(data)
if len(data) < limit:
break
page += 1
return all_data
def init_labels(): def init_labels():
"""Lekéri a meglévő címkéket, és létrehozza a hiányzókat.""" existing_labels = fetch_all_pages(f"/repos/{OWNER}/{REPO}/labels")
url = f"{BASE_URL}/repos/{OWNER}/{REPO}/labels" existing = {l['name']: l['id'] for l in existing_labels}
res = requests.get(url, headers=HEADERS)
existing = {l['name']: l['id'] for l in res.json()} if res.status_code == 200 else {}
label_ids = {} label_ids = {}
for name, color in LABELS.items(): for name, color in LABELS.items():
if name in existing: if name in existing:
label_ids[name] = existing[name] label_ids[name] = existing[name]
else: else:
post_res = requests.post(url, headers=HEADERS, json={"name": name, "color": color}) post_res = requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/labels", headers=HEADERS, json={"name": name, "color": color})
if post_res.status_code == 201: label_ids[name] = post_res.json()['id'] if post_res.status_code == 201: label_ids[name] = post_res.json()['id']
return label_ids return label_ids
@@ -59,20 +89,64 @@ def set_issue_state(issue_num, new_state_label, category_labels=[]):
def add_comment(issue_num, message): def add_comment(issue_num, message):
requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}/comments", headers=HEADERS, json={"body": message}) requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}/comments", headers=HEADERS, json={"body": message})
def create_issue(title, body, categories, milestone_id=None): # --- MÉRFÖLDKŐ (MILESTONE) KEZELÉS ---
url = f"{BASE_URL}/repos/{OWNER}/{REPO}/issues"
def resolve_milestone_id(name_or_id):
if not name_or_id: return None
if str(name_or_id).isdigit(): return int(name_or_id)
milestones = fetch_all_pages(f"/repos/{OWNER}/{REPO}/milestones")
for ms in milestones:
if ms['title'].lower() == str(name_or_id).lower():
return ms['id']
return None
def create_milestone(title, description="", due_date=None):
existing_id = resolve_milestone_id(title)
if existing_id:
print(f"Mérföldkő már létezik: '{title}' (ID: {existing_id})")
return existing_id
payload = {"title": title, "description": description}
if due_date:
payload["due_on"] = f"{due_date}T23:59:59Z" if len(due_date) == 10 else due_date
res = requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/milestones", headers=HEADERS, json=payload)
if res.status_code == 201:
ms_id = res.json()['id']
print(f"✅ Mérföldkő sikeresen létrehozva: '{title}' (ID: {ms_id})")
return ms_id
print(f"❌ Hiba a mérföldkő létrehozásakor: {res.text}")
return None
def list_milestones():
milestones = fetch_all_pages(f"/repos/{OWNER}/{REPO}/milestones")
print(f"\n{'ID':<5} | {'Mérföldkő Címe':<40} | {'Haladás'}")
print("-" * 65)
for ms in milestones:
print(f"#{ms['id']:<4} | {ms['title'][:40]:<40} | {ms['completeness']}%")
# --- KÁRTYA (ISSUE) KEZELÉS ---
def create_issue(title, body, categories, milestone_ref=None, due_date=None, assignees=None):
ms_id = resolve_milestone_id(milestone_ref)
payload = {"title": title, "body": body} payload = {"title": title, "body": body}
if milestone_id is not None and milestone_id != "": if ms_id:
try: payload["milestone"] = ms_id
payload["milestone"] = int(milestone_id) if due_date:
except ValueError: payload["due_date"] = f"{due_date}T23:59:59Z" if len(due_date) == 10 else due_date
print(f"Figyelmeztetés: Érvénytelen milestone_id: {milestone_id}, figyelmen kívül hagyva.") if assignees:
res = requests.post(url, headers=HEADERS, json=payload) payload["assignees"] = assignees
res = requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues", headers=HEADERS, json=payload)
if res.status_code == 201: if res.status_code == 201:
issue_num = res.json()['number'] issue_num = res.json()['number']
set_issue_state(issue_num, "Status: To Do", categories) set_issue_state(issue_num, "Status: To Do", categories)
print(f"Siker: #{issue_num} feladat létrehozva.") ms_text = f" (Milestone: {ms_id})" if ms_id else ""
print(f"✅ Siker: #{issue_num} feladat létrehozva{ms_text}.")
return True return True
print(f"❌ Hiba a kártya létrehozásakor: {res.text}")
return False return False
def start_issue(issue_num): def start_issue(issue_num):
@@ -80,7 +154,7 @@ def start_issue(issue_num):
set_issue_state(issue_num, "Status: In Progress") set_issue_state(issue_num, "Status: In Progress")
requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}/stopwatch/start", headers=HEADERS) requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}/stopwatch/start", headers=HEADERS)
add_comment(issue_num, f"▶️ **Munka megkezdve:** {now}") add_comment(issue_num, f"▶️ **Munka megkezdve:** {now}")
print(f"Siker: A #{issue_num} időmérése elindult.") print(f"Siker: A #{issue_num} időmérése elindult.")
def finish_issue(issue_num, custom_message=None): def finish_issue(issue_num, custom_message=None):
now = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S") now = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
@@ -88,70 +162,99 @@ def finish_issue(issue_num, custom_message=None):
requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}/stopwatch/stop", headers=HEADERS) requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}/stopwatch/stop", headers=HEADERS)
requests.patch(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}", headers=HEADERS, json={"state": "closed"}) requests.patch(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}", headers=HEADERS, json={"state": "closed"})
# Itt adjuk hozzá az egyedi AI összefoglalót, ha van comment_body = f"✅ **Munka befejezve:** {now}\n\n**Technikai Összefoglaló:**\n{custom_message}\n\n⏱️ *A ráfordított időt a Gitea rögzítette.*" if custom_message else f"✅ **Munka befejezve:** {now}\n⏱️ *A ráfordított időt a Gitea rögzítette.*"
if custom_message:
comment_body = f"✅ **Munka befejezve:** {now}\n\n**Technikai Összefoglaló:**\n{custom_message}\n\n⏱️ *A ráfordított időt a Gitea rögzítette.*"
else:
comment_body = f"✅ **Munka befejezve:** {now}\n⏱️ *A ráfordított időt a Gitea rögzítette.*"
add_comment(issue_num, comment_body) add_comment(issue_num, comment_body)
print(f"Siker: A #{issue_num} lezárva, időmérés megállítva. Komment mentve.") print(f"Siker: A #{issue_num} lezárva, időmérés megállítva.")
def get_issue(issue_num): def get_issue(issue_num):
url = f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}" res = requests.get(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}", headers=HEADERS)
res = requests.get(url, headers=HEADERS)
if res.status_code != 200: if res.status_code != 200:
print(f"Hiba: Nem sikerült lekérni a #{issue_num} feladatot. Státusz kód: {res.status_code}") print(f"Hiba: Nem sikerült lekérni a #{issue_num} feladatot. Státusz: {res.status_code}")
sys.exit(1) sys.exit(1)
data = res.json() data = res.json()
title = data.get('title', 'Nincs cím') ms_title = data.get('milestone', {}).get('title', 'Nincs') if data.get('milestone') else 'Nincs'
body = data.get('body', 'Nincs leírás')
state = data.get('state', 'unknown')
created_at = data.get('created_at', '')
updated_at = data.get('updated_at', '')
print("=" * 60) print("=" * 60)
print(f"Feladat #{issue_num} - {state.upper()}") print(f"Feladat #{issue_num} - {data.get('state', 'unknown').upper()} (Mérföldkő: {ms_title})")
print("=" * 60) print("=" * 60)
print(f"Cím: {title}") print(f"Cím: {data.get('title', 'Nincs cím')}")
print(f"Létrehozva: {created_at}")
print(f"Frissítve: {updated_at}")
print("-" * 60) print("-" * 60)
print("Leírás:") print(data.get('body', 'Nincs leírás'))
print(body)
print("=" * 60) print("=" * 60)
def list_issues(state="open"):
issues = fetch_all_pages(f"/repos/{OWNER}/{REPO}/issues?state={state}")
print(f"\n--- {state.upper()} FELADATOK ---")
print(f"{'ID':<4} | {'Cím':<40} | {'Mérföldkő'}")
print("-" * 70)
for i in issues:
ms = i.get('milestone', {}).get('title', '-') if i.get('milestone') else '-'
print(f"#{i['number']:<3} | {i['title'][:40]:<40} | {ms}")
# ================= FŐPROGRAM =================
if __name__ == "__main__": if __name__ == "__main__":
if len(sys.argv) < 3: raw_args = sys.argv[1:]
print("Használat: python3 gitea_manager.py [start|finish|create|get] ...") if not raw_args:
print(" start <issue_num>") print("Használat: python3 gitea_manager.py [parancs] [argumentumok]")
print(" finish <issue_num> [\"Custom summary message\"]") print(" list - Nyitott kártyák listázása")
print(" get <issue_num>") print(" list closed - Lezárt kártyák listázása")
print(" create \"<title>\" \"<body>\" [milestone_id] [category1 category2 ...]") print(" ms list - Mérföldkövek listázása")
print(" ms create \"Név\" - Új mérföldkő létrehozása")
print(" create \"Cím\" \"Leírás\" [Mérföldkő] [Címkék...] [--due YYYY-MM-DD] [--assign username]")
print(" start <id> - Munka megkezdése")
print(" finish <id> [msg] - Munka lezárása")
print(" get <id> - Kártya lekérése")
sys.exit(1) sys.exit(1)
action = sys.argv[1].lower() # Paraméterek kinyerése (--due, --assign)
args = []
due_date = None
assignees = []
i = 0
while i < len(raw_args):
if raw_args[i] == "--due" and i + 1 < len(raw_args):
due_date = raw_args[i+1]
i += 2
elif raw_args[i] == "--assign" and i + 1 < len(raw_args):
assignees.append(raw_args[i+1])
i += 2
else:
args.append(raw_args[i])
i += 1
if action == "start": action = args[0].lower()
start_issue(sys.argv[2])
elif action == "finish": if action == "list":
# Ha van 3. paraméter (az üzenet), adjuk át list_issues(args[1] if len(args) > 1 else "open")
custom_msg = sys.argv[3] if len(sys.argv) > 3 else None
finish_issue(sys.argv[2], custom_msg) elif action == "ms":
elif action == "create": if len(args) > 1 and args[1].lower() == "create":
title = sys.argv[2] create_milestone(args[2], args[3] if len(args) > 3 else "", due_date)
body = sys.argv[3] else:
milestone_id = None list_milestones()
elif action == "start" and len(args) > 1:
start_issue(args[1])
elif action == "finish" and len(args) > 1:
finish_issue(args[1], args[2] if len(args) > 2 else None)
elif action == "get" and len(args) > 1:
get_issue(args[1])
elif action == "create" and len(args) > 2:
title, body = args[1], args[2]
milestone_ref = None
categories = [] categories = []
if len(sys.argv) > 4:
arg4 = sys.argv[4] if len(args) > 3:
if arg4.isdigit(): arg3 = args[3]
milestone_id = arg4 if any(arg3.startswith(prefix) for prefix in ["Status:", "Scope:", "Type:", "Role:"]):
categories = sys.argv[5:] if len(sys.argv) > 5 else [] categories = args[3:]
else: else:
categories = sys.argv[4:] milestone_ref = arg3
create_issue(title, body, categories, milestone_id) categories = args[4:]
elif action == "get":
get_issue(sys.argv[2]) create_issue(title, body, categories, milestone_ref, due_date, assignees)