pipeline { agent any stages { stage('Build & Lint') { steps { script { dir('project2') { sh "docker build -t quotes-app ." echo "🔍 Verificăm sintaxa codului..." sh "docker run --rm quotes-app python -m py_compile famousquotes.py" } } } } stage('Run & Extract') { steps { script { dir('project2') { // Curățăm preventiv containerul dacă a rămas blocat de la un build anterior sh "docker rm -f quotes-worker || true" try { sh "docker run --name quotes-worker --dns 8.8.8.8 quotes-app" sh "docker cp quotes-worker:/app/quote.txt ." } catch (e) { echo "⚠️ Eroare la rulare, dar încercăm notificarea." } finally { sh "docker rm -f quotes-worker || true" } } } } } } post { always { script { def discordUrl = "https://discord.com/api/webhooks/1471492658336891013/T5s6ZKZjJjDMHXc3k3jjZdk6m5EV12bKF1wda9d5I_gZJrsDZQ1m1m078IiLJWK38mqa" def quoteText = "Nu am putut citi fișierul." if (fileExists('project2/quote.txt')) { quoteText = readFile('project2/quote.txt').trim() // Scoatem ghilimelele duble din citat ca să nu strice JSON-ul quoteText = quoteText.replace('"', "'") } def resultStatus = currentBuild.result ?: 'SUCCESS' def statusEmoji = (resultStatus == 'SUCCESS') ? "✅" : "⚠️" echo "🚀 Trimitere notificare către Discord..." // REPARARE: Definim payload-ul separat pentru claritate def payload = """{"content": "${statusEmoji} **Pipeline Finalizat (Build #${env.BUILD_NUMBER})**\\n\\n${quoteText}"}""" // Folosim ghilimele simple pentru URL în comanda shell sh "curl -X POST -H 'Content-Type: application/json' -d '${payload}' '${discordUrl}'" } } } }