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') { 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() // CURĂȚARE TEXT: Prevenim stricarea JSON-ului manual quoteText = quoteText.replace('\\', '\\\\').replace('"', '\\"').replace('\n', '\\n') } def resultStatus = currentBuild.result ?: 'SUCCESS' def statusEmoji = (resultStatus == 'SUCCESS') ? "✅" : "⚠️" def buildHeader = "${statusEmoji} **Pipeline Finalizat (Build #${env.BUILD_NUMBER})**" echo "🚀 Generăm payload-ul și trimitem către Discord..." // MODIFICARE CRITICĂ: Înlocuim writeJSON cu 'cat' (Linux native) sh """ cat << 'EOF' > discord_payload.json { "content": "${buildHeader}\\n\\n${quoteText}" } EOF """ // Trimitem fișierul JSON brut către Discord // Folosim --data-binary pentru a păstra formatarea corectă sh "curl -X POST -H 'Content-Type: application/json' --data-binary @discord_payload.json '${discordUrl}'" } } } }