This commit is contained in:
Ionel Andrei Cataon
2026-02-12 16:42:44 +02:00
parent 2c67a10d4a
commit ddce0166aa
2 changed files with 37 additions and 34 deletions

View File

@@ -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()

View File

@@ -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}'"
}
}
}