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() } def resultStatus = currentBuild.result ?: 'SUCCESS' def statusEmoji = (resultStatus == 'SUCCESS') ? "✅" : "⚠️" echo "🚀 Trimitere notificare către Discord..." // Creăm un fișier JSON temporar pentru a evita problemele de shell def payload = [ content: "${statusEmoji} **Pipeline Finalizat (Build #${env.BUILD_NUMBER})**\n\n${quoteText}" ] // Scriem payload-ul într-un fișier discord_payload.json writeJSON file: 'discord_payload.json', json: payload // Trimitem fișierul folosind @ la curl - asta e metoda cea mai sigură! sh "curl -X POST -H 'Content-Type: application/json' -d @discord_payload.json '${discordUrl}'" } } } }