pipeline { agent any stages { stage('Restore tlw-database-tool') { steps { copyArtifacts filter: '**/tlw-database-tool-1.0.jar', fingerprintArtifacts: true, projectName: 'build tlw-database-tool', selector: lastSuccessful(), target: '.' } } stage('Execute') { steps { script { String jdkPath = tool name: 'OpenJDK18', type: 'jdk' withCredentials([usernamePassword(credentialsId: 'aws', passwordVariable: 'AWS_SECRET_KEY', usernameVariable: 'AWS_ACCESS_KEY_ID')]) { withEnv(["JAVA_HOME=${jdkPath}/jdk-18.0.1.1", "AWS_SECRET_KEY=${AWS_SECRET_KEY}", "AWS_ACCESS_KEY_ID=${AWS_ACCESS_KEY_ID}"]) { try { sh "ls build/libs" sh "java -jar build/libs/tlw-database-tool-1.0.jar --mode MatchesUpdaterFootball --season ${season} --league 1 --configFile Tippliga 2>&1 >> log.txt" sh "java -jar build/libs/tlw-database-tool-1.0.jar --mode MatchdaysUpdater --season ${season} --league 1 --configFile Tippliga 2>&1 >> log.txt" sh "java -jar build/libs/tlw-database-tool-1.0.jar --mode TeamsUpdater --season ${season} --league 1 --configFile Tippliga 2>&1 >> log.txt" sh "java -jar build/libs/tlw-database-tool-1.0.jar --mode MatchesUpdaterFootball --season ${season} --league 2 --configFile Tippliga 2>&1 >> log.txt" sh "java -jar build/libs/tlw-database-tool-1.0.jar --mode MatchdaysUpdater --season ${season} --league 2 --configFile Tippliga 2>&1 >> log.txt" sh "java -jar build/libs/tlw-database-tool-1.0.jar --mode TeamsUpdater --season ${season} --league 2 --configFile Tippliga 2>&1 >> log.txt" } catch (Exception e) { telegramSendManual("TLW-Database-Tool crashed!") } String output = readFile 'log.txt' if(output != "") { output = clean(output) output.split('\n').toList().unique().each { telegramSendManual(it) } } } } } } } } post { always { deleteDir() } failure { telegramSendManual("Build failed!\n${env.BUILD_URL}console") } } } private String clean(String orig) { orig = orig.replace("\n\n", "\n") while(orig.indexOf(" [main] INFO de.jeyp91.App - ") > 0) { int index = orig.indexOf(" [main] INFO de.jeyp91.App - ") String newString = orig.substring(0, index-12) + orig.substring(index+30, orig.size()) orig = newString } return orig } def telegramSendManual(String text) { sleep 1 if(text) { def encodedMessage = URLEncoder.encode(text, "UTF-8") println encodedMessage httpRequest( httpMode: 'GET', contentType: 'APPLICATION_JSON', responseHandle: 'NONE', url: "https://api.telegram.org/bot1298223079:AAEplcQpfzFG59qNYAYuSbJKtB9HMXCCE_U/sendMessage?text=$encodedMessage&chat_id=459231986&disable_web_page_preview=true", wrapAsMultipart: false, consoleLogResponseBody: true ) } }