Jenkinsfile 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. pipeline {
  2. agent any
  3. environment {
  4. APP_NAME = 'Polizia'
  5. APP_ENV = 'testing'
  6. APP_KEY = 'base64:1YsMWZ+cIDVa5NIePkjsXVheT9rbykHDs/CnGPUQdqU='
  7. APP_DEBUG = 'false'
  8. APP_URL = 'https://frascati.dev.webmagistri.biz'
  9. LOG_CHANNEL = 'stack'
  10. LOG_DEPRECATIONS_CHANNEL = 'null'
  11. LOG_LEVEL = 'debug'
  12. DB_CONNECTION = 'mysql'
  13. DB_HOST = '127.0.0.1'
  14. DB_PORT = '3306'
  15. DB_DATABASE = 'polizia_online'
  16. DB_USERNAME = 'admin'
  17. DB_PASSWORD = 'admin'
  18. MCTC_URL = 'https://www.ilportaledellautomobilista.it/Info-ws/services'
  19. MCTC_USER = 'CMRM001301'
  20. MCTC_PASSWORD = '2PMPM*86'
  21. STORAGE_PATH = 'app/public/'
  22. REMOTE_HOST = '10.2.0.10'
  23. REMOTE_USER = 'fratini'
  24. REMOTE_DIR = '/var/www/html/polizia'
  25. // Store the SSH password as an environment variable
  26. // You need to set this in Jenkins as a secret text credential
  27. SSH_PASS = credentials('fratini-ssh-password')
  28. ADMIN_EMAIL = 'f.fratini@webmagistri.it'
  29. }
  30. stages {
  31. stage('Verify Host') {
  32. steps {
  33. sh 'hostname'
  34. sh 'hostname -I'
  35. sh 'whoami'
  36. }
  37. }
  38. stage('Check Dependencies') {
  39. steps {
  40. sh 'php --version || echo "PHP not available locally"'
  41. sh 'composer --version || echo "Composer not available locally"'
  42. sh 'node --version || echo "Node not available locally"'
  43. sh 'npm --version || echo "NPM not available locally"'
  44. // Check if sshpass is installed
  45. sh 'sshpass -V || echo "sshpass not available, please install it on Jenkins server"'
  46. }
  47. }
  48. stage('Get Code') {
  49. steps {
  50. checkout scm
  51. }
  52. }
  53. stage('Debug Branch Info') {
  54. steps {
  55. sh 'git branch -v || echo "Could not get branch info"'
  56. sh 'git status || echo "Could not get status"'
  57. sh 'echo "BRANCH_NAME: ${BRANCH_NAME:-not set}"'
  58. sh 'echo "GIT_BRANCH: ${GIT_BRANCH:-not set}"'
  59. script {
  60. // Store the branch info for later use
  61. env.CURRENT_BRANCH = sh(script: 'git rev-parse --abbrev-ref HEAD || echo "HEAD"', returnStdout: true).trim()
  62. echo "Current branch detected as: ${env.CURRENT_BRANCH}"
  63. }
  64. }
  65. }
  66. stage('Deploy to Server') {
  67. when {
  68. expression {
  69. // Always deploy from develop branch
  70. return env.CURRENT_BRANCH == 'HEAD' || env.CURRENT_BRANCH == 'develop' ||
  71. env.GIT_BRANCH == 'origin/develop' || env.BRANCH_NAME == 'develop'
  72. }
  73. }
  74. steps {
  75. echo "Starting deployment to ${REMOTE_HOST} as user ${REMOTE_USER}"
  76. // Create remote directory
  77. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'mkdir -p ${REMOTE_DIR}'"
  78. // Sync files
  79. sh "sshpass -p \"\${SSH_PASS}\" rsync -avz -e \"ssh -o StrictHostKeyChecking=no\" --exclude '.git' --exclude 'node_modules' --exclude 'vendor' ./ ${REMOTE_USER}@${REMOTE_HOST}:${REMOTE_DIR}/"
  80. // Run composer install
  81. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'cd ${REMOTE_DIR} && composer install --no-interaction --no-dev --prefer-dist'"
  82. // Run npm install and build
  83. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'cd ${REMOTE_DIR} && npm install && npm run build'"
  84. // Run Laravel artisan commands
  85. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'cd ${REMOTE_DIR} && php artisan migrate --force && php artisan config:cache && php artisan route:cache && php artisan view:cache && php artisan optimize && php artisan storage:link'"
  86. // Set permissions
  87. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'cd ${REMOTE_DIR} && chmod -R 775 storage bootstrap/cache && sudo chown -R www-data:www-data .'"
  88. // Restart services
  89. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'sudo systemctl restart php8.1-fpm || sudo systemctl restart php-fpm || echo \"PHP service restart failed, may need manual intervention\"'"
  90. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'sudo systemctl restart nginx || echo \"Nginx restart failed, may need manual intervention\"'"
  91. // Clear cache
  92. sh "sshpass -p \"\${SSH_PASS}\" ssh -o StrictHostKeyChecking=no ${REMOTE_USER}@${REMOTE_HOST} 'cd ${REMOTE_DIR} && php artisan cache:clear'"
  93. }
  94. }
  95. }
  96. post {
  97. always {
  98. script {
  99. cleanWs()
  100. }
  101. }
  102. success {
  103. echo 'Build successful! The Polizia application is now deployed to 10.2.0.10'
  104. script {
  105. mail to: env.ADMIN_EMAIL,
  106. subject: 'Polizia - Build Successful',
  107. body: 'The build was successful and the Polizia application has been deployed to the server at 10.2.0.10'
  108. }
  109. }
  110. failure {
  111. echo 'Build failed! Please check the console output to fix the issues.'
  112. script {
  113. mail to: env.ADMIN_EMAIL,
  114. subject: 'Polizia - Build Failed',
  115. body: 'The build has failed. Please check Jenkins for details.'
  116. }
  117. }
  118. }
  119. }