gitea_manager frissítés
This commit is contained in:
@@ -1,28 +1,71 @@
|
||||
# 🤖 ÉLES MUNKAFOLYAMAT (KÖTELEZŐ)
|
||||
|
||||
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 feladataidat szigorúan a `gitea_manager.py` script segítségével kell menedzselned a `roo-helper` konténerben.
|
||||
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:
|
||||
`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:
|
||||
`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.
|
||||
- **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):
|
||||
`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)
|
||||
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:
|
||||
### 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:
|
||||
|
||||
**Alap parancs:**
|
||||
`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)
|
||||
@@ -2,9 +2,12 @@
|
||||
import requests
|
||||
import sys
|
||||
import datetime
|
||||
import socket
|
||||
|
||||
# ================= KONFIGURÁCIÓ =================
|
||||
BASE_URL = "http://gitea:3000/api/v1"
|
||||
INTERNAL_HOST = "gitea"
|
||||
EXTERNAL_IP = "192.168.100.10"
|
||||
PORT = "3000"
|
||||
OWNER = "kincses"
|
||||
REPO = "service-finder"
|
||||
TOKEN = "783f58519ee0ca060491dbc07f3dde1d8e48c5dd"
|
||||
@@ -14,27 +17,54 @@ HEADERS = {
|
||||
"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 = {
|
||||
"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",
|
||||
"Type: Script": "#8b5cf6", "Type: Model": "#3b82f6", "Type: Database": "#ec4899", "Type: Bug": "#dc2626", "Type: Feature": "#16a34a",
|
||||
"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: Refactor": "#16a34a",
|
||||
"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():
|
||||
"""Lekéri a meglévő címkéket, és létrehozza a hiányzókat."""
|
||||
url = f"{BASE_URL}/repos/{OWNER}/{REPO}/labels"
|
||||
res = requests.get(url, headers=HEADERS)
|
||||
existing = {l['name']: l['id'] for l in res.json()} if res.status_code == 200 else {}
|
||||
existing_labels = fetch_all_pages(f"/repos/{OWNER}/{REPO}/labels")
|
||||
existing = {l['name']: l['id'] for l in existing_labels}
|
||||
|
||||
label_ids = {}
|
||||
for name, color in LABELS.items():
|
||||
if name in existing:
|
||||
label_ids[name] = existing[name]
|
||||
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']
|
||||
return label_ids
|
||||
|
||||
@@ -59,20 +89,64 @@ def set_issue_state(issue_num, new_state_label, category_labels=[]):
|
||||
def add_comment(issue_num, 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):
|
||||
url = f"{BASE_URL}/repos/{OWNER}/{REPO}/issues"
|
||||
# --- MÉRFÖLDKŐ (MILESTONE) KEZELÉS ---
|
||||
|
||||
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}
|
||||
if milestone_id is not None and milestone_id != "":
|
||||
try:
|
||||
payload["milestone"] = int(milestone_id)
|
||||
except ValueError:
|
||||
print(f"Figyelmeztetés: Érvénytelen milestone_id: {milestone_id}, figyelmen kívül hagyva.")
|
||||
res = requests.post(url, headers=HEADERS, json=payload)
|
||||
if ms_id:
|
||||
payload["milestone"] = ms_id
|
||||
if due_date:
|
||||
payload["due_date"] = f"{due_date}T23:59:59Z" if len(due_date) == 10 else due_date
|
||||
if assignees:
|
||||
payload["assignees"] = assignees
|
||||
|
||||
res = requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues", headers=HEADERS, json=payload)
|
||||
if res.status_code == 201:
|
||||
issue_num = res.json()['number']
|
||||
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
|
||||
print(f"❌ Hiba a kártya létrehozásakor: {res.text}")
|
||||
return False
|
||||
|
||||
def start_issue(issue_num):
|
||||
@@ -80,7 +154,7 @@ def start_issue(issue_num):
|
||||
set_issue_state(issue_num, "Status: In Progress")
|
||||
requests.post(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}/stopwatch/start", headers=HEADERS)
|
||||
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):
|
||||
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.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
|
||||
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.*"
|
||||
|
||||
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.*"
|
||||
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):
|
||||
url = f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}"
|
||||
res = requests.get(url, headers=HEADERS)
|
||||
|
||||
res = requests.get(f"{BASE_URL}/repos/{OWNER}/{REPO}/issues/{issue_num}", headers=HEADERS)
|
||||
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)
|
||||
|
||||
data = res.json()
|
||||
title = data.get('title', 'Nincs cím')
|
||||
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', '')
|
||||
|
||||
ms_title = data.get('milestone', {}).get('title', 'Nincs') if data.get('milestone') else 'Nincs'
|
||||
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(f"Cím: {title}")
|
||||
print(f"Létrehozva: {created_at}")
|
||||
print(f"Frissítve: {updated_at}")
|
||||
print(f"Cím: {data.get('title', 'Nincs cím')}")
|
||||
print("-" * 60)
|
||||
print("Leírás:")
|
||||
print(body)
|
||||
print(data.get('body', 'Nincs leírás'))
|
||||
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 len(sys.argv) < 3:
|
||||
print("Használat: python3 gitea_manager.py [start|finish|create|get] ...")
|
||||
print(" start <issue_num>")
|
||||
print(" finish <issue_num> [\"Custom summary message\"]")
|
||||
print(" get <issue_num>")
|
||||
print(" create \"<title>\" \"<body>\" [milestone_id] [category1 category2 ...]")
|
||||
raw_args = sys.argv[1:]
|
||||
if not raw_args:
|
||||
print("Használat: python3 gitea_manager.py [parancs] [argumentumok]")
|
||||
print(" list - Nyitott kártyák listázása")
|
||||
print(" list closed - Lezárt kártyák listázása")
|
||||
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)
|
||||
|
||||
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":
|
||||
start_issue(sys.argv[2])
|
||||
elif action == "finish":
|
||||
# Ha van 3. paraméter (az üzenet), adjuk át
|
||||
custom_msg = sys.argv[3] if len(sys.argv) > 3 else None
|
||||
finish_issue(sys.argv[2], custom_msg)
|
||||
elif action == "create":
|
||||
title = sys.argv[2]
|
||||
body = sys.argv[3]
|
||||
milestone_id = None
|
||||
action = args[0].lower()
|
||||
|
||||
if action == "list":
|
||||
list_issues(args[1] if len(args) > 1 else "open")
|
||||
|
||||
elif action == "ms":
|
||||
if len(args) > 1 and args[1].lower() == "create":
|
||||
create_milestone(args[2], args[3] if len(args) > 3 else "", due_date)
|
||||
else:
|
||||
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 = []
|
||||
if len(sys.argv) > 4:
|
||||
arg4 = sys.argv[4]
|
||||
if arg4.isdigit():
|
||||
milestone_id = arg4
|
||||
categories = sys.argv[5:] if len(sys.argv) > 5 else []
|
||||
|
||||
if len(args) > 3:
|
||||
arg3 = args[3]
|
||||
if any(arg3.startswith(prefix) for prefix in ["Status:", "Scope:", "Type:", "Role:"]):
|
||||
categories = args[3:]
|
||||
else:
|
||||
categories = sys.argv[4:]
|
||||
create_issue(title, body, categories, milestone_id)
|
||||
elif action == "get":
|
||||
get_issue(sys.argv[2])
|
||||
milestone_ref = arg3
|
||||
categories = args[4:]
|
||||
|
||||
create_issue(title, body, categories, milestone_ref, due_date, assignees)
|
||||
@@ -1,214 +0,0 @@
|
||||
#!/usr/bin/env python3
|
||||
"""
|
||||
Kanban kártya mozgatása a Gitea API-n keresztül.
|
||||
Ez a szkript a #2-es kártyát mozgatja "In Progress" majd "Done" oszlopba.
|
||||
"""
|
||||
|
||||
import requests
|
||||
import json
|
||||
import sys
|
||||
import time
|
||||
|
||||
# Gitea API konfiguráció
|
||||
BASE_URL = "http://192.168.100.10:3000/api/v1"
|
||||
PROJECT_OWNER = "service_finder"
|
||||
PROJECT_REPO = "service_finder"
|
||||
|
||||
def get_project_id():
|
||||
"""Lekéri a Master Book 2.0 projekt ID-ját"""
|
||||
url = f"{BASE_URL}/repos/{PROJECT_OWNER}/{PROJECT_REPO}/projects"
|
||||
try:
|
||||
response = requests.get(url, timeout=10)
|
||||
response.raise_for_status()
|
||||
projects = response.json()
|
||||
|
||||
for project in projects:
|
||||
if project.get("name") == "Master Book 2.0":
|
||||
return project["id"]
|
||||
|
||||
print("Hiba: 'Master Book 2.0' projekt nem található")
|
||||
print("Elérhető projektek:")
|
||||
for project in projects:
|
||||
print(f" - {project.get('name')} (ID: {project.get('id')})")
|
||||
return None
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba a projekt lekérdezésekor: {e}")
|
||||
return None
|
||||
|
||||
def get_project_columns(project_id):
|
||||
"""Lekéri a projekt oszlopait"""
|
||||
url = f"{BASE_URL}/projects/{project_id}/columns"
|
||||
try:
|
||||
response = requests.get(url, timeout=10)
|
||||
response.raise_for_status()
|
||||
return response.json()
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba az oszlopok lekérdezésekor: {e}")
|
||||
return []
|
||||
|
||||
def find_card_in_columns(project_id, card_number):
|
||||
"""Megkeresi a #2-es kártyát az oszlopok között"""
|
||||
columns = get_project_columns(project_id)
|
||||
|
||||
for column in columns:
|
||||
column_id = column["id"]
|
||||
column_name = column["name"]
|
||||
|
||||
url = f"{BASE_URL}/projects/columns/{column_id}/cards"
|
||||
try:
|
||||
response = requests.get(url, timeout=10)
|
||||
response.raise_for_status()
|
||||
cards = response.json()
|
||||
|
||||
for card in cards:
|
||||
if card.get("title", "").startswith(f"#{card_number}") or f"#{card_number}" in card.get("title", ""):
|
||||
return {
|
||||
"card_id": card["id"],
|
||||
"column_id": column_id,
|
||||
"column_name": column_name,
|
||||
"card_title": card.get("title", "N/A")
|
||||
}
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba a kártyák lekérdezésekor az oszlopból {column_name}: {e}")
|
||||
|
||||
return None
|
||||
|
||||
def move_card_to_column(card_id, target_column_id):
|
||||
"""Áthelyezi a kártyát a céloszlopba"""
|
||||
url = f"{BASE_URL}/projects/columns/cards/{card_id}/move"
|
||||
|
||||
payload = {
|
||||
"position": "top",
|
||||
"column_id": target_column_id
|
||||
}
|
||||
|
||||
try:
|
||||
response = requests.post(url, json=payload, timeout=10)
|
||||
if response.status_code == 201:
|
||||
print(f"Sikeresen áthelyezve a kártya (ID: {card_id})")
|
||||
return True
|
||||
else:
|
||||
print(f"Hiba a kártya mozgatásakor: {response.status_code}")
|
||||
print(f"Válasz: {response.text}")
|
||||
return False
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba a kártya mozgatásakor: {e}")
|
||||
return False
|
||||
|
||||
def find_column_by_name(project_id, column_name):
|
||||
"""Megkeresi az oszlopot név alapján"""
|
||||
columns = get_project_columns(project_id)
|
||||
|
||||
for column in columns:
|
||||
if column["name"].lower() == column_name.lower():
|
||||
return column["id"]
|
||||
|
||||
print(f"Hiba: '{column_name}' oszlop nem található")
|
||||
print("Elérhető oszlopok:")
|
||||
for column in columns:
|
||||
print(f" - {column.get('name')} (ID: {column.get('id')})")
|
||||
return None
|
||||
|
||||
def main():
|
||||
print("=== Gitea Kanban Kártya Mozgatás ===")
|
||||
print(f"API bázis URL: {BASE_URL}")
|
||||
print(f"Projekt: {PROJECT_OWNER}/{PROJECT_REPO}")
|
||||
print()
|
||||
|
||||
# 1. Projekt ID lekérése
|
||||
print("1. Projekt ID keresése...")
|
||||
project_id = get_project_id()
|
||||
if not project_id:
|
||||
print("Nem sikerült megtalálni a projektet. Kilépés.")
|
||||
return False
|
||||
|
||||
print(f" Projekt ID: {project_id}")
|
||||
|
||||
# 2. #2-es kártya keresése
|
||||
print("\n2. #2-es kártya keresése...")
|
||||
card_info = find_card_in_columns(project_id, 2)
|
||||
|
||||
if not card_info:
|
||||
print(" #2-es kártya nem található az oszlopok között")
|
||||
print(" Megpróbálom az issue #2 keresését...")
|
||||
|
||||
# Alternatív megoldás: issue keresése
|
||||
url = f"{BASE_URL}/repos/{PROJECT_OWNER}/{PROJECT_REPO}/issues/2"
|
||||
try:
|
||||
response = requests.get(url, timeout=10)
|
||||
if response.status_code == 200:
|
||||
issue = response.json()
|
||||
print(f" Issue #2 található: {issue.get('title')}")
|
||||
print(" Megjegyzés: A kártya automatikus mozgatáshoz manuális beavatkozás szükséges")
|
||||
print(" Folytatom a readme.md fájl létrehozásával...")
|
||||
return True
|
||||
else:
|
||||
print(f" Issue #2 nem található: {response.status_code}")
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f" Hiba az issue keresésekor: {e}")
|
||||
|
||||
return False
|
||||
|
||||
print(f" Kártya található: {card_info['card_title']}")
|
||||
print(f" Jelenlegi oszlop: {card_info['column_name']} (ID: {card_info['column_id']})")
|
||||
|
||||
# 3. "In Progress" oszlop keresése
|
||||
print("\n3. 'In Progress' oszlop keresése...")
|
||||
in_progress_column_id = find_column_by_name(project_id, "In Progress")
|
||||
|
||||
if not in_progress_column_id:
|
||||
# Alternatív oszlopnevek
|
||||
for alt_name in ["Doing", "In Progress", "In Development", "Active"]:
|
||||
in_progress_column_id = find_column_by_name(project_id, alt_name)
|
||||
if in_progress_column_id:
|
||||
print(f" Alternatív oszlop található: {alt_name}")
|
||||
break
|
||||
|
||||
if not in_progress_column_id:
|
||||
print(" 'In Progress' oszlop nem található. Kilépés.")
|
||||
return False
|
||||
|
||||
print(f" 'In Progress' oszlop ID: {in_progress_column_id}")
|
||||
|
||||
# 4. Kártya mozgatása "In Progress" oszlopba
|
||||
print("\n4. Kártya mozgatása 'In Progress' oszlopba...")
|
||||
if move_card_to_column(card_info["card_id"], in_progress_column_id):
|
||||
print(" ✓ Sikeresen áthelyezve 'In Progress' oszlopba")
|
||||
|
||||
# 5. Rövid várakozás
|
||||
print("\n5. Rövid várakozás a művelet között...")
|
||||
time.sleep(2)
|
||||
|
||||
# 6. "Done" oszlop keresése
|
||||
print("\n6. 'Done' oszlop keresése...")
|
||||
done_column_id = find_column_by_name(project_id, "Done")
|
||||
|
||||
if not done_column_id:
|
||||
# Alternatív oszlopnevek
|
||||
for alt_name in ["Done", "Completed", "Finished", "Closed"]:
|
||||
done_column_id = find_column_by_name(project_id, alt_name)
|
||||
if done_column_id:
|
||||
print(f" Alternatív oszlop található: {alt_name}")
|
||||
break
|
||||
|
||||
if done_column_id:
|
||||
print(f" 'Done' oszlop ID: {done_column_id}")
|
||||
|
||||
# 7. Kártya mozgatása "Done" oszlopba
|
||||
print("\n7. Kártya mozgatása 'Done' oszlopba...")
|
||||
if move_card_to_column(card_info["card_id"], done_column_id):
|
||||
print(" ✓ Sikeresen áthelyezve 'Done' oszlopba")
|
||||
return True
|
||||
else:
|
||||
print(" ✗ Hiba a 'Done' oszlopba mozgatás közben")
|
||||
return False
|
||||
else:
|
||||
print(" 'Done' oszlop nem található")
|
||||
return True # Az 'In Progress' mozgatás sikeres volt
|
||||
else:
|
||||
print(" ✗ Hiba az 'In Progress' oszlopba mozgatás közben")
|
||||
return False
|
||||
|
||||
if __name__ == "__main__":
|
||||
success = main()
|
||||
sys.exit(0 if success else 1)
|
||||
@@ -1,235 +0,0 @@
|
||||
#!/usr/bin/env python3
|
||||
"""
|
||||
Kanban kártya mozgatása a Gitea API-n keresztül a roo-helper konténerből.
|
||||
Ez a szkript a #2-es kártyát mozgatja "In Progress" majd "Done" oszlopba.
|
||||
"""
|
||||
import requests
|
||||
import json
|
||||
import sys
|
||||
import time
|
||||
import os
|
||||
# Gitea API konfiguráció
|
||||
BASE_URL = "http://192.168.100.10:3000/api/v1"
|
||||
PROJECT_OWNER = "kincses"
|
||||
PROJECT_REPO = "service-finder"
|
||||
def get_project_id():
|
||||
"""Lekéri a Master Book 2.0 projekt ID-ját"""
|
||||
url = f"{BASE_URL}/repos/{PROJECT_OWNER}/{PROJECT_REPO}/projects"
|
||||
try:
|
||||
response = requests.get(url, timeout=10)
|
||||
response.raise_for_status()
|
||||
projects = response.json()
|
||||
|
||||
for project in projects:
|
||||
if project.get("name") == "Master Book 2.0":
|
||||
return project["id"]
|
||||
|
||||
print("Hiba: 'Master Book 2.0' projekt nem található")
|
||||
print("Elérhető projektek:")
|
||||
for project in projects:
|
||||
print(f" - {project.get('name')} (ID: {project.get('id')})")
|
||||
return None
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba a projekt lekérdezésekor: {e}")
|
||||
return None
|
||||
def get_project_columns(project_id):
|
||||
"""Lekéri a projekt oszlopait"""
|
||||
url = f"{BASE_URL}/projects/{project_id}/columns"
|
||||
try:
|
||||
response = requests.get(url, timeout=10)
|
||||
response.raise_for_status()
|
||||
return response.json()
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba az oszlopok lekérdezésekor: {e}")
|
||||
return []
|
||||
def find_card_in_columns(project_id, card_number):
|
||||
"""Megkeresi a #2-es kártyát az oszlopok között"""
|
||||
columns = get_project_columns(project_id)
|
||||
|
||||
for column in columns:
|
||||
column_id = column["id"]
|
||||
column_name = column["name"]
|
||||
|
||||
url = f"{BASE_URL}/projects/columns/{column_id}/cards"
|
||||
try:
|
||||
response = requests.get(url, timeout=10)
|
||||
response.raise_for_status()
|
||||
cards = response.json()
|
||||
|
||||
for card in cards:
|
||||
card_title = card.get("title", "")
|
||||
if f"#{card_number}" in card_title or card_title.startswith(f"#{card_number}"):
|
||||
return {
|
||||
"card_id": card["id"],
|
||||
"column_id": column_id,
|
||||
"column_name": column_name,
|
||||
"card_title": card_title
|
||||
}
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba a kártyák lekérdezésekor az oszlopból {column_name}: {e}")
|
||||
|
||||
return None
|
||||
def move_card_to_column(card_id, target_column_id):
|
||||
"""Áthelyezi a kártyát a céloszlopba"""
|
||||
url = f"{BASE_URL}/projects/columns/cards/{card_id}/move"
|
||||
|
||||
payload = {
|
||||
"position": "top",
|
||||
"column_id": target_column_id
|
||||
}
|
||||
|
||||
try:
|
||||
response = requests.post(url, json=payload, timeout=10)
|
||||
if response.status_code == 201:
|
||||
print(f"Sikeresen áthelyezve a kártya (ID: {card_id})")
|
||||
return True
|
||||
else:
|
||||
print(f"Hiba a kártya mozgatásakor: {response.status_code}")
|
||||
print(f"Válasz: {response.text}")
|
||||
return False
|
||||
except requests.exceptions.RequestException as e:
|
||||
print(f"Hiba a kártya mozgatásakor: {e}")
|
||||
return False
|
||||
def find_column_by_name(project_id, column_name):
|
||||
"""Megkeresi az oszlopot név alapján"""
|
||||
columns = get_project_columns(project_id)
|
||||
|
||||
for column in columns:
|
||||
if column["name"].lower() == column_name.lower():
|
||||
return column["id"]
|
||||
|
||||
# Alternatív oszlopnevek keresése
|
||||
alt_names = {
|
||||
"in progress": ["doing", "in development", "active", "in progress"],
|
||||
"done": ["completed", "finished", "closed", "done"]
|
||||
}
|
||||
|
||||
target_alts = alt_names.get(column_name.lower(), [])
|
||||
for alt in target_alts:
|
||||
for column in columns:
|
||||
if column["name"].lower() == alt:
|
||||
print(f" Megjegyzés: '{alt}' oszlopot használom '{column_name}' helyett")
|
||||
return column["id"]
|
||||
|
||||
print(f"Hiba: '{column_name}' oszlop nem található")
|
||||
print("Elérhető oszlopok:")
|
||||
for column in columns:
|
||||
print(f" - {column.get('name')} (ID: {column.get('id')})")
|
||||
return None
|
||||
def move_card_to_in_progress():
|
||||
"""A #2-es kártya mozgatása 'In Progress' oszlopba"""
|
||||
print("=== #2-es kártya mozgatása 'In Progress' oszlopba ===")
|
||||
|
||||
# 1. Projekt ID lekérése
|
||||
print("1. Projekt ID keresése...")
|
||||
project_id = get_project_id()
|
||||
if not project_id:
|
||||
print("Nem sikerült megtalálni a projektet. Kilépés.")
|
||||
return False
|
||||
|
||||
print(f" Projekt ID: {project_id}")
|
||||
|
||||
# 2. #2-es kártya keresése
|
||||
print("\n2. #2-es kártya keresése...")
|
||||
card_info = find_card_in_columns(project_id, 2)
|
||||
|
||||
if not card_info:
|
||||
print(" #2-es kártya nem található az oszlopok között")
|
||||
return False
|
||||
|
||||
print(f" Kártya található: {card_info['card_title']}")
|
||||
print(f" Jelenlegi oszlop: {card_info['column_name']} (ID: {card_info['column_id']})")
|
||||
|
||||
# 3. "In Progress" oszlop keresése
|
||||
print("\n3. 'In Progress' oszlop keresése...")
|
||||
in_progress_column_id = find_column_by_name(project_id, "In Progress")
|
||||
|
||||
if not in_progress_column_id:
|
||||
return False
|
||||
|
||||
print(f" 'In Progress' oszlop ID: {in_progress_column_id}")
|
||||
|
||||
# 4. Ellenőrizzük, hogy már "In Progress" oszlopban van-e
|
||||
if card_info["column_id"] == in_progress_column_id:
|
||||
print(" A kártya már 'In Progress' oszlopban van")
|
||||
return True
|
||||
|
||||
# 5. Kártya mozgatása "In Progress" oszlopba
|
||||
print("\n4. Kártya mozgatása 'In Progress' oszlopba...")
|
||||
if move_card_to_column(card_info["card_id"], in_progress_column_id):
|
||||
print(" ✓ Sikeresen áthelyezve 'In Progress' oszlopba")
|
||||
return True
|
||||
else:
|
||||
print(" ✗ Hiba az 'In Progress' oszlopba mozgatás közben")
|
||||
return False
|
||||
def move_card_to_done():
|
||||
"""A #2-es kártya mozgatása 'Done' oszlopba"""
|
||||
print("\n=== #2-es kártya mozgatása 'Done' oszlopba ===")
|
||||
|
||||
# 1. Projekt ID lekérése
|
||||
print("1. Projekt ID keresése...")
|
||||
project_id = get_project_id()
|
||||
if not project_id:
|
||||
print("Nem sikerült megtalálni a projektet. Kilépés.")
|
||||
return False
|
||||
|
||||
print(f" Projekt ID: {project_id}")
|
||||
|
||||
# 2. #2-es kártya keresése
|
||||
print("\n2. #2-es kártya keresése...")
|
||||
card_info = find_card_in_columns(project_id, 2)
|
||||
|
||||
if not card_info:
|
||||
print(" #2-es kártya nem található az oszlopok között")
|
||||
return False
|
||||
|
||||
print(f" Kártya található: {card_info['card_title']}")
|
||||
print(f" Jelenlegi oszlop: {card_info['column_name']} (ID: {card_info['column_id']})")
|
||||
|
||||
# 3. "Done" oszlop keresése
|
||||
print("\n3. 'Done' oszlop keresése...")
|
||||
done_column_id = find_column_by_name(project_id, "Done")
|
||||
|
||||
if not done_column_id:
|
||||
return False
|
||||
|
||||
print(f" 'Done' oszlop ID: {done_column_id}")
|
||||
|
||||
# 4. Ellenőrizzük, hogy már "Done" oszlopban van-e
|
||||
if card_info["column_id"] == done_column_id:
|
||||
print(" A kártya már 'Done' oszlopban van")
|
||||
return True
|
||||
|
||||
# 5. Kártya mozgatása "Done" oszlopba
|
||||
print("\n4. Kártya mozgatása 'Done' oszlopba...")
|
||||
if move_card_to_column(card_info["card_id"], done_column_id):
|
||||
print(" ✓ Sikeresen áthelyezve 'Done' oszlopba")
|
||||
return True
|
||||
else:
|
||||
print(" ✗ Hiba a 'Done' oszlopba mozgatás közben")
|
||||
return False
|
||||
def main():
|
||||
"""Fő függvény - argumentum alapján végrehajtja a mozgatást"""
|
||||
if len(sys.argv) > 1:
|
||||
action = sys.argv[1].lower()
|
||||
if action == "inprogress":
|
||||
return move_card_to_in_progress()
|
||||
elif action == "done":
|
||||
return move_card_to_done()
|
||||
elif action == "both":
|
||||
success1 = move_card_to_in_progress()
|
||||
if success1:
|
||||
time.sleep(2)
|
||||
return move_card_to_done()
|
||||
return False
|
||||
else:
|
||||
print(f"Ismeretlen művelet: {action}")
|
||||
print("Használat: python3 move_card_2.py [inprogress|done|both]")
|
||||
return False
|
||||
else:
|
||||
# Alapértelmezett: csak "In Progress" mozgatás
|
||||
print("Nincs argumentum megadva, alapértelmezett: 'In Progress' mozgatás")
|
||||
return move_card_to_in_progress()
|
||||
if __name__ == "__main__":
|
||||
success = main()
|
||||
sys.exit(0 if success else 1)
|
||||
Reference in New Issue
Block a user