From ddce0166aaf52dee672b78beb304427ef8694fec Mon Sep 17 00:00:00 2001 From: Ionel Andrei Cataon Date: Thu, 12 Feb 2026 16:42:44 +0200 Subject: [PATCH] p2 --- project2/famousquotes.py | 28 ++++++++++++++------------ project2/jenkinsfile | 43 ++++++++++++++++++++-------------------- 2 files changed, 37 insertions(+), 34 deletions(-) diff --git a/project2/famousquotes.py b/project2/famousquotes.py index e7121d0..8d77a23 100644 --- a/project2/famousquotes.py +++ b/project2/famousquotes.py @@ -2,34 +2,36 @@ import requests import os import sys +# Folosim variabila de mediu sau un fallback API_URL = os.getenv("QUOTE_API_URL", "https://api.quotable.io/random") def get_quote(): try: - # Folosim verify=False doar dacă avem în continuare erori de SSL pe serverul Jenkins + # Timeout de 10 secunde ca să nu stea Jenkins blocat dacă API-ul nu răspunde response = requests.get(API_URL, timeout=10) response.raise_for_status() data = response.json() - if isinstance(data, list): data = data[0] + if isinstance(data, list): + data = data[0] - quote = data.get('content') or data.get('advice') or data.get('q') or "No quote found." - author = data.get('author') or data.get('a') or "Unknown Author" + quote = data.get('content') or data.get('advice') or data.get('q') or "No quote today." + author = data.get('author') or data.get('a') or "Unknown" # Mesaj formatat pentru Discord - full_message = f"📜 *\"{quote}\"* \n\n✍️ **{author}**" + message = f"📜 *\"{quote}\"* \n\n✍️ **{author}**" - # Salvăm în folderul /app (care este mapat cu volumul Jenkins) - with open("/app/quote.txt", "w", encoding="utf-8") as f: - f.write(full_message) + with open("quote.txt", "w", encoding="utf-8") as f: + f.write(message) - print(f"Succes! Citat salvat: {author}") + print(f"Citat salvat cu succes!") except Exception as e: - print(f"Eroare: {e}") - with open("/app/quote.txt", "w", encoding="utf-8") as f: - f.write("⚠️ Nu am putut prelua citatul, dar aplicația a rulat.") - sys.exit(1) + print(f"Eroare API: {e}") + with open("quote.txt", "w", encoding="utf-8") as f: + f.write("⚠️ Nu am putut prelua citatul din cauza unei erori de rețea.") + # Ieșim cu 0 ca să lăsăm Jenkins să trimită notificarea chiar dacă API-ul a dat fail + sys.exit(0) if __name__ == "__main__": get_quote() \ No newline at end of file diff --git a/project2/jenkinsfile b/project2/jenkinsfile index 0df5f5b..3da576b 100644 --- a/project2/jenkinsfile +++ b/project2/jenkinsfile @@ -8,15 +8,16 @@ pipeline { dir('project2') { sh "docker build -t quotes-app ." - // 1. Rulăm containerul și îi dăm un nume pentru a putea copia din el - // Nu folosim -v aici pentru a evita eroarea "No such file" - sh "docker run --name temp-container --network host -e QUOTE_API_URL='https://api.quotable.io/random' quotes-app" - - // 2. Copiem fișierul generat din container în workspace-ul Jenkins - sh "docker cp temp-container:/app/quote.txt ." - - // 3. Ștergem containerul temporar - sh "docker rm temp-container" + try { + // Rulăm containerul și dăm un nume pentru a putea copia fișierul afară + sh "docker run --name quotes-container --network host quotes-app" + sh "docker cp quotes-container:/app/quote.txt ." + } catch (e) { + echo "Eroare la execuție, trecem la notificare." + } finally { + // Curățăm containerul ca să nu dea eroare de 'name already in use' la următorul build + sh "docker rm -f quotes-container || true" + } } } } @@ -26,24 +27,24 @@ pipeline { post { always { script { - def discordUrl = "WEBHOOK_TAU_AICI" - def status = currentBuild.result ?: 'SUCCESS' + // !!! PUNE WEBHOOK-UL TĂU AICI !!! + def discordUrl = "https://discord.com/api/webhooks/1471492658336891013/T5s6ZKZjJjDMHXc3k3jjZdk6m5EV12bKF1wda9d5I_gZJrsDZQ1m1m078IiLJWK38mqa" - // Citim citatul (dacă există) sau punem un mesaj de eroare - def quoteText = "" + def quoteText = "Fișierul cu citate nu a fost găsit." try { quoteText = readFile('project2/quote.txt').trim() - } catch (e) { - quoteText = "Nu am putut citi citatul din fișier." + } catch (err) { + echo "Eroare la citirea fișierului." } - def payload = """ - { - "content": "✅ **Build #${env.BUILD_NUMBER} Finalizat**\\n\\n${quoteText}" - } + def statusEmoji = (currentBuild.result == 'SUCCESS') ? "✅" : "⚠️" + + // Trimitem notificarea + sh """ + curl -X POST -H 'Content-Type: application/json' \ + -d '{"content": "${statusEmoji} **Pipeline Finalizat (Build #${env.BUILD_NUMBER})**\\n\\n${quoteText}"}' \ + '${discordUrl}' """ - - sh "curl -X POST -H 'Content-Type: application/json' -d '${payload}' '${discordUrl}'" } } }