| import javax.imageio.ImageIO |
| import javax.swing.* |
| import java.awt.* |
| import java.awt.event.ActionEvent |
| import java.awt.event.ActionListener |
| import java.util.List |
| import java.util.concurrent.Callable |
| import java.util.concurrent.Executors |
| import java.util.concurrent.atomic.AtomicBoolean |
| |
| import static ServiceControl.* |
| import static Services.* |
| |
| group 'com.att.ecomp' |
| version '1.01-SNAPSHOT' |
| |
| apply plugin: 'groovy' |
| apply plugin: 'java' |
| apply plugin: "org.hidetake.ssh" |
| apply plugin: 'java-gradle-plugin' |
| apply plugin: 'idea' |
| |
| sourceCompatibility = 1.8 |
| |
| buildscript { |
| repositories { |
| jcenter() |
| mavenCentral() |
| } |
| dependencies { |
| classpath 'org.codehaus.groovy:groovy-all:2.4.12' |
| classpath "org.hidetake:gradle-ssh-plugin:2.9.0" |
| } |
| } |
| |
| enum Services { |
| BACKEND , //be |
| FRONTEND , //fe |
| DB , //cassandra |
| CACHING , //elawsrticsearch |
| SECURITY , //webseal |
| ALL //all services |
| } |
| enum ServiceControl { |
| HEALTH , |
| START , |
| RESTART , |
| STOP , |
| KILL |
| } |
| //env variables |
| //fill YOUR_WINDOWS_USER_HOME |
| project.ext.set("NEW_VAG",Boolean.FALSE) //flags to use new vagrant configuration |
| project.ext.set("IS_HOTSWAP",Boolean.FALSE) //flags to use new vagrant configuration |
| project.ext.set("PROJECT_PATH", System.getenv("SDC")) //ex. 'C:\\GIT_WORK\\asdc\\sdc') |
| project.ext.set("VAGRANT_HOME", NEW_VAG ? System.getenv("NEW_VAG") : System.getenv("VAG")) //ex. 'C:\\GIT_WORK\\vagrant-asdc-all-in-one') |
| project.ext.set("USER_HOME", "${System.getenv("USERPROFILE")}\\.ssh") |
| project.ext.set("BE_REMOTE", NEW_VAG ? '/opt/app/jetty/base/be' : '/home/vagrant/catalog-be' ) |
| project.ext.set("FE_REMOTE", NEW_VAG ? '/opt/app/jetty/base/fe' : '/home/vagrant/catalog-fe' ) |
| project.ext.set("VAGRANT_USER", NEW_VAG ? 'm11981' : 'vagrant' ) |
| project.ext.set("RSA_PRIVATE_KEY_PATH", NEW_VAG ? "$VAGRANT_HOME/id_rsa" : '' ) |
| project.ext.set("VAGRANT_PASSWORD", NEW_VAG ? 'Aa123456' : 'vagrant' ) |
| project.ext.set("X_FOLDER",'/xFolder' ) |
| project.ext.set("BE_DEPENDENCIES", 'common-be,common-app-api,catalog-dao,catalog-model,security-utils' ) |
| project.ext.set("command", [ (ALL) : [ (HEALTH) : { NEW_VAG ? 'sudo curl -i http://localhost:8181/sdc1/rest/healthCheck' : 'curl -i localhost:8080/sdc2/rest/healthCheck' } , |
| (KILL) : { NEW_VAG ? 'sudo pkill java' : 'pkill java'} ] , // TODO: refine kill only for services |
| (BACKEND) : [ (START) : { NEW_VAG ? 'sudo service jettyBE start' : 'service catalog-be start'} , |
| (STOP) : { NEW_VAG ? 'sudo service jettyBE stop' : 'service catalog-be stop'} , |
| (RESTART) : { NEW_VAG ? 'sudo service jettyBE restart' : 'service catalog-be restart'}] , |
| (DB) : [ (START) : { NEW_VAG ? 'sudo service cassandra start' : 'start-asdc-storage.sh' } , |
| (STOP) : { NEW_VAG ? 'sudo service cassandra stop' : 'service cassandra stop'} , |
| (RESTART) : { NEW_VAG ? 'sudo service cassandra restart' : 'service cassandra restart'} ] , |
| (FRONTEND): [ (START) : { NEW_VAG ? 'sudo service jettyFE start' : 'service catalog-fe start' } , |
| (STOP) : { NEW_VAG ? 'sudo service jettyFE stop' : 'service catalog-fe stop'} , |
| (RESTART) : { NEW_VAG ? 'sudo service jettyFE restart' : 'service catalog-fe restart' } ] , |
| (CACHING): [ (START) : { NEW_VAG ? 'sudo service elasticsearch start' : 'echo "starting es is not yet supported"' } ], |
| (SECURITY): [ (START) : { NEW_VAG ? 'sudo docker start sdc-WebSeal-Simulator' : 'service webseal-simulator start' } , |
| (STOP) : { NEW_VAG ? 'sudo docker stop sdc-WebSeal-Simulator' : 'service webseal-simulator stop'} , |
| (RESTART) : { NEW_VAG ? 'sudo docker restart sdc-WebSeal-Simulator' : 'service webseal-simulator restart'}] |
| ] ) //abstraction level to shell scripts , support old and new vagrant bash commands |
| |
| //icons |
| project.ext.set("warnImg",'') |
| project.ext.set("okImg1",'') |
| project.ext.set("okImg2" , '') |
| project.ext.set("errorImg" , '') |
| project.ext.set("unavailableImg" , '') |
| |
| |
| //health params |
| project.ext.set("trayIcon", null) |
| project.ext.set("lastStatus", null) |
| project.ext.set("isStopHealthCheck", false) |
| project.ext.set("isHaltHealth", new AtomicBoolean(false) ) |
| project.ext.set("startedAwait", Long.MAX_VALUE) |
| project.ext.set("logFile", 'C:/ProgramData/all.log') |
| project.ext.set("pomList" , ["${System?.getenv('SDC')}/catalog-fe/pom.xml" ,"${System?.getenv('SDC')}/catalog-be/pom.xml" ] ) //empty list will scan all openecomp poms |
| project.ext.set("pomChangesMap" , [:] ) |
| project.ext.set("beConfigFilesToCopyMapping" , [ 'src/main/resources/config/*.yaml' : 'config/catalog-be/' , |
| 'src/main/resources/config/*.properties' : 'config/catalog-be/'] ) |
| |
| //menu item strings |
| project.ext.set("toggleHealthString" , "Halt Health" ) |
| //menu item |
| project.ext.set("toggleHealthItemView" , null ) |
| |
| //other |
| project.ext.set("IS_MVN_INSTALL",false) |
| project.ext.set("executor" , null ) |
| project.ext.set("lockObj" , new Object() ) |
| /*compile?.doLast { |
| println "2. hello compile2" |
| }*/ |
| |
| /*def post(String host , String serviceName,String msg){ |
| // POST |
| def post = new URL("$host/$serviceName").openConnection(); |
| def message = '{"message":"this is a message"}' |
| post.setRequestMethod("POST") |
| post.setDoOutput(true) |
| post.setRequestProperty("Content-Type", "application/json") |
| post.getOutputStream().write(message.getBytes("UTF-8")); |
| def postRC = post.getResponseCode(); |
| println(postRC); |
| if( postRC.equals(200)) { |
| println(post.getInputStream().getText()); |
| } |
| } |
| |
| def postStat( long operationTime, String user , String meta ){ |
| def host = 'http://135.76.123.70:8888' |
| def params = "user=$user&meta=$meta" |
| post host , "UserStats" , params |
| }*/ |
| |
| |
| def hash( List list ){ |
| def map = list?.collectEntries { File file -> [(file?.absolutePath) : file?.text?.hashCode() ]} |
| |
| map |
| } |
| |
| def pomChanges(){ |
| long started = System.currentTimeMillis() |
| if ( !pomList ) |
| listPom() |
| //find hash changes |
| def changes = pomList?.findAll { |
| def File file = new File(it); |
| pomChangesMap[it] != file?.text?.hashCode() |
| } |
| println "\n\n[MasterD][POM]--> detected changes for -> $changes" |
| //update changes in map |
| changes?.each { pomChangesMap[it] = new File(it)?.text?.hashCode() } |
| println "\n\n[MasterD][POM]--> pom map -> $pomChangesMap" |
| |
| println """ |
| ****** POM changes detection finished after -> ${System.currentTimeMillis()- started}ms ****** |
| """ |
| |
| changes |
| } |
| //list pom with updated file hashes |
| def listPom(){ |
| long started = System.currentTimeMillis() |
| if (!pomList) { |
| def tree = fileTree( PROJECT_PATH ).include '**/pom.xml'//.filter { it.isFile() && it?.toString()?.toLowerCase()?.endsWith('pom.xml') } |
| //println "$PROJECT_PATH list is ->${ list?.collect { it?.absolutePath } }" |
| //flatten and filter openecomp poms |
| pomList = tree?.flatten()?.findAll { File file -> file?.text?.contains('org.openecomp.sdc') }?.collect {File file -> file?.absolutePath } |
| } |
| pomChangesMap = pomList.collectEntries { absolutePath ->[ ( absolutePath ) : new File(absolutePath)?.text?.hashCode() ] } |
| |
| println """ [MasterD][Init] intializing POM detector |
| |
| ********* POM listing finished after -> ${System.currentTimeMillis()- started}ms ********* |
| """ |
| return pomList |
| } |
| |
| |
| task initialization(){ |
| listPom() |
| executor = Executors.newCachedThreadPool(); |
| } |
| |
| def parallel( closure ){ |
| executor?.submit(new Callable<Object>(){ |
| @Override |
| public Object call() { |
| closure(); |
| return null; |
| } |
| }) |
| } |
| /*class Preferences { |
| def String Username |
| def String IsNewVagrant |
| def String IsRapidMode |
| } |
| |
| def initXFolder(){ |
| def folder = new File(X_FOLDER); |
| folder?.exists() ?: folder?.mkdirs() |
| |
| new File("${folder?.absolutePath}/$PREFERENCES_FILENAME") |
| }*/ |
| |
| task tester{ |
| /*doLast{ |
| //postStat(10000, "shay" , "report/index") |
| listPom() |
| new File('catalog-be\\pom.xml') << "#hello" |
| pomChanges() |
| }*/ |
| } |
| |
| |
| def fetchFilesByExtention(remote, local , ext ){ |
| ssh.run { |
| def started = System.currentTimeMillis() |
| println "folder diff" |
| session(remotes.vagrant) { |
| //execute "cd /home/vagrant/catalog-be/tmp ; ls -lt | grep catalog-be" //todo- use my dates to filter |
| get from: remote , into: local , filter: { it?.absolutePath =~ /jetty.*catalog-be.*\.dir.*\.$ext/ } // { it?.absolutePath =~ /.*catalog-be.*dir.*classes.*/ } |
| } |
| println "fetched files in ${System.currentTimeMillis() - started} ms" |
| } |
| } |
| |
| def updateRemoteFile(String remote , String local){ |
| ssh.run { |
| def to = "$BE_REMOTE${remote[remote?.indexOf("tmp\\")..remote.size()-1].replaceAll("\\\\","/")}" |
| println "copying $local \nto\n $to" |
| session(remotes.vagrant) { |
| put from: local , into: to } |
| } |
| } |
| |
| def compareAndSwap(){ |
| def final LIMIT = 10 |
| def newClasses = new File("$PROJECT_PATH\\catalog-be\\target\\classes") |
| def File jettyClasses ; |
| //locate classes |
| println "traversing.." |
| new File("build/hotswap").traverse { if (it?.directory && it?.name?.equals("classes")){ |
| jettyClasses = it |
| return; |
| } } |
| def jettyClassesList = [] |
| jettyClasses?.traverse { jettyClassesList << it } |
| |
| println "$jettyClasses" |
| //Sort compiled classes |
| def files = [] |
| newClasses?.traverse { files << it } |
| def result = files.sort{ a,b -> b.lastModified() <=> a.lastModified() } |
| println "show only last $LIMIT changes" |
| result[0..LIMIT]?.each{ println it?.lastModified() +" | "+ it?.name + (it?.directory ? "[Directory]" : "") } //show only last 10 changes |
| |
| //update |
| def changesMap = [ : ] //<old,new> |
| println "updating changes" |
| result[0..LIMIT]?.each { File f -> def File other = jettyClassesList.find{ File other-> other?.absolutePath?.endsWith(f?.name) }; |
| if ( !(f.directory) && f?.text?.hashCode() != other?.text?.hashCode() ) |
| updateRemoteFile( other?.getAbsolutePath() , f?.getAbsolutePath() ) |
| } //use hashing |
| } |
| |
| task hotswap(){ |
| doLast { |
| new File("build/hotswap")?.deleteDir() |
| new File("build/hotswap")?.mkdirs() |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| fetchFilesByExtention( "$BE_REMOTE/tmp/" , 'build/hotswap' , "class") |
| compareAndSwap() |
| } |
| } |
| |
| remotes { |
| vagrant { |
| host = '127.0.0.1' |
| port = 2222 |
| user = VAGRANT_USER |
| password = VAGRANT_PASSWORD |
| identity = NEW_VAG ? new File(RSA_PRIVATE_KEY_PATH) : null |
| } |
| |
| } |
| |
| def gitLatest(){ |
| |
| } |
| |
| def newEcoSystem(){ |
| //cleanTitan() |
| backupDB() //and clean all |
| //restoreDB() //restore latest |
| createSchema() |
| fillSchema() |
| postCreate() |
| startAll() |
| //todo- conside updating from git |
| updaterBEFull() |
| updaterFE() |
| } |
| def importHeatTypes(){ |
| //todo- impl |
| } |
| def postCreate(){ |
| importNormative() |
| importHeatTypes() |
| } |
| def fillSchema(){ |
| // add conformence level |
| } |
| def createSchemaPreStep(){ |
| //todo- DB up |
| } |
| def createSchemaPostStep(){ |
| ////todo- impl create amdocs dox |
| } |
| def createSchema(){ |
| createSchemaPreStep() |
| //todo- create schema |
| //todo- create titan |
| createSchemaPostStep() |
| } |
| |
| def cleanTitan(){ |
| execSafe{ |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| execute "cqlsh -e 'DROP KEYSPACE titan;'" |
| println "[MasterD][DB_DROP]-> Dropped 'titan' KEYSPACE." |
| } |
| } |
| } |
| } |
| task cleanTitan { |
| doLast{ |
| cleanTitan() |
| } |
| } |
| |
| task fetchE2EDB(){ |
| doLast{ |
| fetchE2EDB() |
| } |
| } |
| def fetchE2EDB(){ |
| execSafe{ |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| def tmp = '$CASSANDRA_HOME/backup/e2e' |
| //execute 'mkdir $CASSANDRA_HOME/backup/e2e/' |
| //execute 'wget http://135.76.210.202:8080/ETE_backup_files/latest_ETE_backup_file.zip -P /vagrant/db' |
| println "[MasterD] download finished, unzipping.." |
| execute "unzip -u $tmp/latest_ETE_backup_file.zip" //execute 'unzip -u /vagrant/db/latest_ETE_backup_file.zip'//' |
| def folder = execute "cd $tmp; ls -d -- */" |
| println "[MasterD] unzipping finished into -> $folder , untaring.." |
| execute "tar zxf $tmp/$folder/* --strip 3 -C" +'$CASSANDRA_HOME/data | pv -l >/dev/null' |
| println "[MasterD][E2E_DB]-> Downloaded & unzipped e2e data successfully." |
| } |
| } |
| } |
| } |
| def copyExplodedBE() { |
| execSafe{ |
| println "[MasterD][BackEnd] copying exploded war." |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| long started = System.currentTimeMillis() |
| def dirPath = "${PROJECT_PATH}/catalog-be/target/catalog-be-1.1.0-SNAPSHOT" |
| def dir = new File(dirPath); |
| println "[MasterD][BackEnd] copying ${dir?.directorySize()/(1024*1024)} MB, from ${dir?.name} to $BE_REMOTE/webapps" |
| ssh.run { |
| session(remotes.vagrant) { |
| execute "rm -R $BE_REMOTE/webapps/catalog-be-1.1.0-SNAPSHOT" |
| put from: dir?.absolutePath , into: "$BE_REMOTE/webapps" |
| } |
| } |
| println "[MasterD][BackEnd] Successfully copied exploded war in ${System.currentTimeMillis()-started}ms." |
| } |
| } |
| task copyExplodedBE(){ |
| doLast{ |
| copyExplodedBE() |
| } |
| } |
| def backupDB() { |
| execSafe{ |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| execute 'mkdir -p $CASSANDRA_HOME/backup' |
| def res = execute 'mv $CASSANDRA_HOME/data $CASSANDRA_HOME/backup/data_$(date +\'%Y_%m_%d__%H:%M:%S\')' |
| println "[MasterD][DB_BACKUP]-> snapshot DB finished. $res" |
| } |
| } |
| } |
| } |
| task backupDB{ |
| doLast{ |
| backupDB() |
| } |
| } |
| |
| def restoreDB(){ |
| execSafe{ |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| println "[MasterD]-> restoring DB" |
| execute 'mkdir -p $CASSANDRA_HOME/data' |
| def res = execute 'mv $CASSANDRA_HOME/backup/data_*/* $CASSANDRA_HOME/data' |
| println "[MasterD]-> DB restore FINISHED!! $res" |
| } |
| } |
| } |
| } |
| task restoreDB() { |
| doLast { |
| restoreDB() |
| } |
| } |
| |
| def vm( ){ |
| exec{ |
| if (VAGRANT_HOME){ |
| workingDir VAGRANT_HOME //vagrant path |
| println "*****************\nworking dir -> $VAGRANT_HOME" |
| commandLine "cmd","/c", "vagrant up" |
| //args = [ ] |
| } else { |
| println "[MasterD]--> please define windows enviroment variable VAG pointing to vagrant project" |
| } |
| } |
| } |
| |
| task vm{ |
| doLast{ |
| vm() |
| } |
| } |
| |
| def copyFE() { |
| println "[MasterD][FrontEnd] starting war copy." |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| long started = System.currentTimeMillis() |
| def target = "${PROJECT_PATH}/catalog-fe/target/" |
| def files = GFileUtils.listFiles( new File(target) , ["war"] as String[] , false); |
| files?.each{ File file -> |
| if (!file?.name?.contains('classes')){ |
| println "[MasterD][FrontEnd] copying ${file.length()/(1024*1024)} MB, from ${file?.name} to $FE_REMOTE/webapps" |
| ssh.run { |
| session(remotes.vagrant) { |
| put from: file?.absolutePath , into: "$FE_REMOTE/webapps" |
| } |
| } |
| } |
| |
| } |
| println "[MasterD][FrontEnd] Successfully copied war in ${System.currentTimeMillis()-started}ms." |
| } |
| |
| task deployFE{ |
| doLast { |
| copyFE() |
| } |
| } |
| |
| |
| def copyBE(){ |
| println "[MasterD][BackEnd] starting war copy." |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| def target = "${PROJECT_PATH}/catalog-be/target/" |
| def files = GFileUtils.listFiles( new File(target) , ["war"] as String[] , false); |
| long started = System.currentTimeMillis() |
| files?.each{ File file -> |
| if (!file?.name?.contains('classes')){ |
| println "[MasterD][BackEnd] copying ${file.length()/(1024*1024)} MB, from ${file?.name} to $BE_REMOTE/webapps" |
| ssh.run { |
| session(remotes.vagrant) { |
| put from: file?.absolutePath , into: "$BE_REMOTE/webapps" |
| } |
| } |
| } |
| } |
| println "[MasterD][BackEnd] SUCCESSFULY copied be war in ${System.currentTimeMillis()-started}ms." |
| } |
| |
| task deployBE { |
| doLast { |
| copyBE() |
| } |
| } |
| def compileFE(){ |
| exec{ |
| println "[MasterD][FE]--> compiling project at -> ${PROJECT_PATH}\\catalog-fe" |
| workingDir "${PROJECT_PATH}" //vagrant path |
| commandLine 'cmd','/c','mvn -T 2 compile -pl catalog-fe,catalog-ui -am -Pcatalog -Dmaven.test.skip' |
| } |
| } |
| task compileFE(){ |
| doLast{ |
| compileFE() |
| } |
| } |
| def compileBE(){ |
| exec{ |
| println "[MasterD][BE]--> compiling project at -> ${PROJECT_PATH}\\catalog-be" |
| workingDir "${PROJECT_PATH}" //vagrant path |
| commandLine 'cmd','/c','mvn -T 2 compile -pl catalog-be -Pcatalog -Dmaven.test.skip' |
| } |
| } |
| task compileBE{ |
| doLast{ |
| compileBE() |
| } |
| } |
| |
| def compile(){ |
| exec{ |
| println "[MasterD]--> compiling project at -> ${PROJECT_PATH}" |
| workingDir "${PROJECT_PATH}" //vagrant path |
| commandLine 'cmd','/c','mvn -T 2 compile -am -Pcatalog -Dmaven.test.skip' |
| } |
| } |
| |
| task compile{ |
| doLast{ |
| compile() |
| } |
| } |
| def compileDependencies(){ |
| def cmd = IS_MVN_INSTALL ? 'install' : 'compile' |
| exec{ |
| println "[MasterD]--> compiling BE dependencies -> $BE_DEPENDENCIES [ SKIPPING TESTS!! ]" |
| workingDir "${PROJECT_PATH}" //vagrant path |
| commandLine 'cmd','/c',"mvn $cmd -pl $BE_DEPENDENCIES -Pcatalog -Dmaven.test.skip" //commandLine 'cmd', '/c','mvn -T 1C package -pl catalog-model,catalog-dao,catalog-be -P catalog -Dmaven.test.skip' |
| } |
| } |
| task compileDependencies { |
| doLast{ |
| compileDependencies() |
| } |
| } |
| def compileWar(){ |
| def cmd = IS_MVN_INSTALL ? 'install' : 'compile' |
| exec{ |
| println "--> compiling project at -> ${PROJECT_PATH}\\catalog-be" |
| workingDir "${PROJECT_PATH}" //vagrant path |
| commandLine 'cmd','/c',"mvn -T 1 $cmd war:war -pl catalog-be -Pcatalog -Dmaven.test.skip" //commandLine 'cmd', '/c','mvn -T 1C package -pl catalog-model,catalog-dao,catalog-be -P catalog -Dmaven.test.skip' |
| } |
| } |
| task compileWar(){ |
| doLast{ |
| compileWar() |
| } |
| } |
| |
| //deprecated - use deployBE() |
| task be() { |
| doLast{ |
| def started = System.currentTimeMillis(); |
| exec{ |
| println "[MasterD]--> copying be... [from $VAGRANT_HOME]" |
| workingDir VAGRANT_HOME //vagrant path |
| commandLine 'cmd','/c', 'copy_war_be.bat','localhost' , "$PROJECT_PATH\\catalog-be\\target\\catalog-be*.war" , "$BE_REMOTE/webapps" |
| //args = [ ] |
| } |
| println """ |
| **** copying finished in -> ${System.currentTimeMillis() - started}ms **** |
| """ |
| } |
| } |
| |
| task beConfig( ) { |
| doLast{ |
| exec{ |
| workingDir "${System.env.VAG}" //vagrant path |
| commandLine 'cmd','/c','copy_war_be_with_configuration','localhost' , "$PROJECT_PATH\\catalog-be\\target\\catalog-be*.war" , "$BE_REMOTE/webapps" |
| //args = [ ] |
| } |
| } |
| |
| } |
| task feConfig( ) { |
| doLast{ |
| exec{ |
| workingDir "${System.env.VAG}" //vagrant path |
| commandLine 'cmd','/c','copy_war_fe_with_configuration','localhost' , "$PROJECT_PATH\\catalog-fe\\target\\catalog-fe*.war" , "$FE_REMOTE/webapps" |
| //args = [ ] |
| } |
| } |
| |
| } |
| |
| task fe() { |
| doLast{ |
| exec { |
| workingDir "${System.env.VAG}" //vagrant path |
| commandLine 'cmd','/c', 'copy_war_fe.bat', 'localhost', "$PROJECT_PATH\\catalog-fe\\target\\catalog-fe*.war", "$FE_REMOTE/webapps" |
| //args = [ ] |
| } |
| } |
| } |
| |
| def installAllProject(){ |
| exec{ |
| println "[MasterD]--> Compiling&Installing project at -> ${PROJECT_PATH}" |
| workingDir "${PROJECT_PATH}" //vagrant path |
| commandLine 'cmd','/c','mvn -T 2 clean install -U -Pcatalog -Dmaven.test.skip' |
| } |
| } |
| task installAllProject { |
| doLast { |
| installAllProject() |
| } |
| } |
| |
| task installAll { |
| doLast{ |
| println '[MasterD]--> Finished!!' |
| } |
| } |
| installAll.dependsOn { tasks.findAll { task -> task.name.startsWith('install_') } } |
| |
| def install_BE(){ |
| exec { |
| println '[MasterD][Install]--> Installing BE!!' |
| workingDir "${PROJECT_PATH}" |
| commandLine 'cmd','/c', 'mvn clean install -pl catalog-be -am -Pcatalog -Dmaven.test.skip' |
| //args = [ ] |
| } |
| } |
| |
| task install_BE() { |
| doLast{ |
| install_BE() |
| } |
| } |
| |
| def install_FE() { |
| exec { |
| workingDir "${PROJECT_PATH}" |
| commandLine 'cmd','/c', 'mvn clean install -pl catalog-ui,catalog-fe -am -Pcatalog -Dmaven.test.skip' |
| } |
| } |
| task install_FE() { |
| doLast { |
| install_FE() |
| } |
| } |
| |
| def updaterBERapid(){ |
| /* if ( ticket() > PREVIOUS_BUILD_VAR ){ |
| PREVIOUS_BUILD_VAR = ticket()*/ |
| def started = System.currentTimeMillis(); |
| println "[MasterD][Rapid]--> compiling changes using maven" |
| compileWar() |
| println "[MasterD][Rapid]--> copying war" |
| copyBE() //use this if you want to deploy entire war //hotswap.execute() |
| restartBackend() |
| println msg(" redeploy finished in -> ${System.currentTimeMillis() - started}ms ") |
| } |
| task updaterBERapid(){ |
| doLast { |
| updaterBERapid() |
| } |
| } |
| def updaterBE(){ |
| def started = System.currentTimeMillis(); |
| IS_MVN_INSTALL = pomChanges() ? true : false |
| println "[MasterD]--> compiling changes using maven" |
| compileDependencies() |
| compileWar() |
| println "[MasterD]--> copying war" |
| IS_HOTSWAP ? copyExplodedBE() : copyBE() //execute() //use this if you want to deploy entire war //hotswap.execute() |
| restartBackend() |
| println msg("redeploy finished in -> ${System.currentTimeMillis() - started}ms ") |
| } |
| task updaterBE(){ |
| doLast { |
| updaterBE() |
| } |
| } |
| def copyBEConfiguration(){ |
| /* execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| println msg("Stopping BackEnd Server") |
| execute command[BACKEND][STOP]() |
| } |
| } |
| }*/ |
| } |
| def updaterBEFull(){ |
| def started = System.currentTimeMillis(); |
| compile() |
| println "[MasterD]--> copying war" |
| copyBE() //use this if you want to deploy entire war //hotswap.execute() |
| copyBEConfiguration() |
| println msg("redeploy finished in -> ${System.currentTimeMillis() - started}ms ") |
| } |
| task updaterBEFull(){ |
| doLast { |
| updaterBEFull() |
| } |
| } |
| def copyFEConfiguration(){ |
| //todo- implement |
| } |
| def updaterFE(){ |
| def started = System.currentTimeMillis(); |
| println "[MasterD]--> compiling changes using maven" |
| compileFE() |
| println "[MasterD]--> copying war" |
| copyFE() //.execute() //use this if you want to deploy entire war //hotswap.execute() |
| copyFEConfiguration() |
| println msg("redeploy finished in -> ${System.currentTimeMillis() - started}ms ") |
| } |
| task updaterFE(){ |
| doLast { |
| updaterFE() |
| } |
| } |
| def stopBackend(){ |
| execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| println msg("Stopping BackEnd Server") |
| execute command[BACKEND][STOP]() |
| } |
| } |
| } |
| } |
| task stopBackend(){ |
| doLast { |
| stopBackend() |
| } |
| } |
| |
| def startBackend(){ |
| execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| println msg("[MasterD] starting backend sever") |
| |
| execute command[BACKEND][START]() |
| } |
| } |
| } |
| println """[MasterD]-> finished !! |
| """ |
| } |
| task startBackend(){ |
| doLast{ |
| startBackend() |
| } |
| } |
| |
| def restartBackend(){ |
| execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| println msg("[MasterD] restarting backend sever") |
| |
| execute command[BACKEND][RESTART]() |
| } |
| } |
| } |
| println """[MasterD]-> finished !! |
| """ |
| } |
| //todo- remove this if you want to auto-deploy on every file save |
| /* |
| compileJava.doFirst{ |
| updater?.execute() |
| }*/ |
| |
| enum STATUS { UP, DOWN , UNKNOWN , UNAVAILABLE } |
| |
| task health(){ |
| doLast { |
| prepareTray() |
| } |
| } |
| |
| def execSafe( closure){ |
| if (!lockObj) { |
| [0..4].forEach( {println "Critical ERROR : lock object is not initialized\n\nCritical ERROR : cannot run tasks\n"}() ) |
| return; |
| } |
| synchronized (lockObj){ |
| boolean prev = isHaltHealth.get() |
| try { |
| isHaltHealth.set(true) |
| closure() |
| } catch (Exception e) { |
| println e |
| } finally { |
| isHaltHealth.set(prev) |
| } |
| } |
| } |
| |
| def fetchFiles( remote, local ){ |
| ssh.run { |
| session(remotes.vagrant) { |
| //execute "cd /home/vagrant/catalog-be/tmp ; ls -lt | grep catalog-be" //todo- use my dates to filter |
| def f = get from: remote , into: local |
| println f?.name |
| //return f |
| } |
| //println "fetched files in ${System.currentTimeMillis() - started} ms" |
| } |
| |
| //return null |
| } |
| |
| |
| def killJava(){ |
| execSafe { |
| def res |
| ssh.run { |
| session( remotes.vagrant ) { |
| println """ *-*-****************************-*-* |
| killing all java proccesses |
| *-*-****************************-*-* |
| """ |
| res = execute command[ALL][KILL]() |
| } |
| } |
| println res?.toString() |
| } |
| } |
| |
| def importNormative(){ |
| execSafe { |
| ssh.run { |
| session(remotes.vagrant) { |
| println """ *-*-************************************-*-* |
| importNormative |
| *-*-************************************-*-* |
| """ |
| execute "python -v $BE_REMOTE/scripts/import/tosca/importNormativeAll.py" |
| } |
| } |
| } |
| } |
| |
| def startAll(){ |
| def startCassandra = """ |
| #!/bin/bash |
| |
| cassandra& |
| elasticsearch -d |
| |
| #Wait until ES is up |
| until curl localhost:9200/_cluster/health; |
| do |
| printf "." |
| sleep 3 |
| done |
| |
| # Create Elastic Mapping if not exist in ES |
| createESMapping.sh |
| """ |
| execSafe { |
| ssh.run { |
| session(remotes.vagrant) { |
| println """ *-*-************************************-*-* |
| starting all SDC services(DB,BE,FE,Webseal) |
| *-*-************************************-*-* |
| """ |
| if ( NEW_VAG ){ |
| execute command[DB][START]() |
| Thread.sleep(5000) |
| execute command[CACHING][START]() |
| } |
| else |
| execute startCassandra |
| //[0..4]?.forEach( Thread?.sleep(2000) ) |
| Thread?.sleep(10000) |
| Thread?.sleep(10000) |
| execute command[BACKEND][START]() |
| execute command[FRONTEND][START]() |
| execute command[SECURITY][START]() |
| } |
| } |
| } |
| } |
| |
| |
| /*def clearLog(type: Delete){ |
| delete{ |
| delete 'C:/ProgramData/all.log' |
| followSymlinks = true |
| } |
| }*/ |
| task clearLog(type: Delete){ |
| doLast{ |
| delete 'C:/ProgramData/all.log' |
| followSymlinks = true |
| } |
| } |
| def logBE(){ |
| try{ |
| println "\n*** logging BE all.log ***\n" |
| |
| ssh.run { |
| session( remotes.vagrant ) { |
| //String now = execute 'echo \"\$(date +\'%Y_%m_%d\')\"' |
| //println "\n\n*******************************************************\n\n"+now?.toString() |
| clearLog?.execute() //todo- remove this .execute() |
| fetchFiles( '/home/vagrant/catalog-be/logs/SDC/SDC-BE/all.log' , 'C:/ProgramData') //"%USERPROFILE%\AppData\Local\") |
| //project.ext.set( "logFile" , 'C:/ProgramData/all.log' ) |
| |
| // -f /home/vagrant/catalog-fe/logs/*$now.stderrout.log -f /home/vagrant/catalog-be/logs/*$now.stderrout.log -f /home/vagrant/catalog-be/logs/ASDC/ASDC-BE/debug.log*' |
| } |
| } |
| |
| parallel { |
| exec { |
| //if ( logFile ){ |
| String notepad = 'C:\\Program Files (x86)\\Notepad++\\notepad++.exe' |
| println "logging $logFile to notepad++ [$notepad]" |
| commandLine 'cmd','/c' , notepad ,logFile |
| } |
| } |
| }catch(Exception e){ |
| println "cannot open logs!!!" |
| e.printStackTrace() |
| } |
| } |
| task logBE(){ |
| doLast{ |
| logBE() |
| } |
| } |
| |
| def toggleHealthPolling(){ |
| isHaltHealth.set(!isHaltHealth.get()) |
| } |
| //converts predefined icon to Image |
| def Image convert( imageName ){ |
| String encodedimage = project.ext.get(imageName); |
| byte[] byteImage = encodedimage?.split(',')[1]?.decodeBase64() |
| Image image = ImageIO.read(new ByteArrayInputStream(byteImage)); |
| } |
| |
| def refreshMenu(String imageName){ |
| switch( imageName ) { |
| case 'unavailableImg' : toggleHealthString = "Resume Health"; break; |
| default : toggleHealthString = "Halt Health"; |
| } |
| if (((MenuItem)toggleHealthItemView).getLabel() != toggleHealthString) |
| ((MenuItem)toggleHealthItemView).setLabel(toggleHealthString); |
| } |
| def startDB(){ |
| println "[MasterD] Starting database.." |
| execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| execute command[DB][START]() |
| } |
| } |
| } |
| } |
| task startDB(){ |
| doLast { |
| startDB() |
| } |
| } |
| def stopDB(){ |
| execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| execute command[DB][STOP]() |
| } |
| } |
| } |
| } |
| task stopDB(){ |
| doLast { |
| stopDB() |
| } |
| } |
| def startFE(){ |
| execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| execute command[FRONTEND][START]() |
| } |
| } |
| } |
| } |
| task startFE(){ |
| doLast { |
| startFE() |
| } |
| } |
| def stopFE(){ |
| execSafe { |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| ssh.run { |
| session(remotes.vagrant) { |
| execute command[FRONTEND][STOP]() |
| } |
| } |
| } |
| } |
| task stopFE(){ |
| doLast { |
| stopFE() |
| } |
| } |
| |
| def ActionListener newListener( closure ){ |
| ActionListener listener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| closure() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| } |
| |
| listener |
| } |
| |
| ext.updateTray = { STATUS status -> |
| lastStatus = status |
| if (SystemTray.isSupported()) { |
| // get the SystemTray instance |
| SystemTray tray = SystemTray.getSystemTray(); |
| // load an image |
| String imageName = status==STATUS.UP ? (Math.random()>0.5 ?'okImg1':'okImg2') : status==STATUS.UNAVAILABLE ? 'unavailableImg' : status==STATUS.DOWN ? 'errorImg' : 'warnImg' |
| Image image = convert imageName |
| if (trayIcon != null) { |
| trayIcon.setImage(image) |
| refreshMenu(imageName); |
| return ; |
| } |
| //region -> Menu UI |
| // create a popup menu |
| PopupMenu popup = new PopupMenu(); |
| // create menu item for the default action |
| |
| MenuItem hotswapItem = new MenuItem("===> WAR <==="); |
| hotswapItem.setFont(new Font("MONOSPACED" , Font.BOLD ,15f )) |
| |
| //region Multilevel Menus |
| Menu deployMasterMenu = new Menu("DeployMaster"); |
| Menu backendMenu = new Menu("Backend"); |
| Menu frontendMenu = new Menu("Frontend"); |
| Menu dbMenu = new Menu("Database"); |
| try{ |
| deployMasterMenu.setFont(new Font("Cooper Black" ,Font.BOLD ,14f )) |
| backendMenu.setFont(new Font("Cooper Black" ,Font.PLAIN ,13f )) |
| frontendMenu.setFont(new Font("Cooper Black" ,Font.PLAIN ,13f )) |
| dbMenu.setFont(new Font("Cooper Black" ,Font.PLAIN ,13f )) |
| }catch(Exception e){ |
| println e |
| } |
| |
| //DeployMaster Menu |
| MenuItem updaterBeWithDependenciesItem = new MenuItem("[BE] Quick Compile -> Deploy"); |
| MenuItem updaterFullBeItem = new MenuItem("[BE] Full Install -> Deploy"); |
| MenuItem updaterFeItem = new MenuItem("[FE] Quick Compile -> Deploy"); |
| MenuItem updaterFullFeItem = new MenuItem("[FE] Full Install -> Deploy"); |
| |
| //Menu UI build |
| |
| deployMasterMenu.add(updaterFullBeItem); |
| deployMasterMenu.add(updaterBeWithDependenciesItem); |
| |
| deployMasterMenu.addSeparator(); |
| deployMasterMenu.add(updaterFullFeItem); |
| deployMasterMenu.add(updaterFeItem); |
| |
| |
| //BE menu |
| MenuItem startItem = new MenuItem("[BE] Start"); |
| MenuItem stopItem = new MenuItem("[BE] Stop BackEnd"); |
| MenuItem copyBeWarItem = new MenuItem("[BE] Copy War"); |
| backendMenu.add(startItem); |
| backendMenu.add(stopItem); |
| backendMenu.add(copyBeWarItem); |
| |
| //FE menu |
| MenuItem startFEItem = new MenuItem("[FE] Start"); |
| MenuItem stopFEItem = new MenuItem("[FE] Stop"); |
| MenuItem copyFeWarItem = new MenuItem("[FE] Copy War"); |
| frontendMenu.add(startFEItem); |
| frontendMenu.add(stopFEItem); |
| frontendMenu.add(copyFeWarItem); |
| |
| //DB menu |
| MenuItem startDBItem = new MenuItem("[DB] Start"); |
| MenuItem stopDBItem = new MenuItem("[DB] Stop"); |
| MenuItem backupDBItem = new MenuItem("[DB] Backup"); |
| MenuItem restoreDBItem = new MenuItem("[DB] Restore"); |
| dbMenu.add(startDBItem); |
| dbMenu.add(stopDBItem); |
| dbMenu.add(backupDBItem); |
| dbMenu.add(restoreDBItem); |
| //endregion |
| |
| |
| MenuItem killItem = new MenuItem("Kill All"); |
| MenuItem startAllItem = new MenuItem("Start All"); |
| MenuItem importItem = new MenuItem("Import Normative"); |
| MenuItem healthInfoItem = new MenuItem("[Info] Health"); |
| MenuItem toggleHealthItem = new MenuItem(toggleHealthString); |
| MenuItem logsItem = new MenuItem("Logs [Beta]"); |
| MenuItem exitItem = new MenuItem("Exit"); |
| |
| toggleHealthItemView = toggleHealthItem; |
| |
| popup.add(hotswapItem); |
| popup?.addSeparator(); |
| popup.add(deployMasterMenu); |
| popup?.addSeparator(); |
| popup.add(backendMenu) |
| popup.add(frontendMenu) |
| popup.add(dbMenu) |
| popup?.addSeparator(); |
| popup.add(startAllItem); |
| popup.add(killItem); |
| popup?.addSeparator(); |
| popup.add(toggleHealthItem); |
| popup.add(healthInfoItem); |
| popup?.addSeparator(); |
| popup.add(importItem); |
| popup.add(logsItem); |
| popup?.addSeparator(); |
| popup.add(exitItem); |
| //endregion UI |
| // construct a TrayIcon |
| trayIcon = new TrayIcon(image, "HealthTray", popup); |
| |
| //region -> Button actions |
| def listenerHotswap = newListener { project.ext.set("IS_HOTSWAP", !IS_HOTSWAP); hotswapItem?.setLabel( IS_HOTSWAP ? "==> HotSwap <==" : "===> WAR <===") } |
| // create a action listener to listen for default action executed on the tray icon |
| def listenerFullBE = newListener { parallel { install_BE(); IS_HOTSWAP ? copyExplodedBE() : copyBE(); restartBackend() } } |
| def listenerFullFE = newListener { parallel { install_FE(); copyFE() } } |
| ActionListener listenerFE = newListener { parallel { updaterFE() } } |
| ActionListener listenerBE = newListener { parallel { updaterBE() } } |
| ActionListener exitListener = newListener { |
| executor?.isShutdown() ?: executor?.shutdown() |
| tray.remove(trayIcon); |
| project.ext.set("isStopHealthCheck", true) |
| println "Shutting down.. bye bye.." |
| } |
| ActionListener stopBackendListener = newListener { stopBackend() } |
| ActionListener startBEListener = newListener { parallel { startBackend() } } |
| ActionListener killJavaListener = newListener { killJava() } |
| |
| ActionListener startAllListener = newListener { parallel { startAll() } } |
| |
| ActionListener listener5 = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| parallel { importNormative() } |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| }; |
| |
| ActionListener listener6 = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| parallel { healthPopup() } |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| }; |
| |
| ActionListener listener7 = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| logBE()//tasks.logger.execute() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| }; |
| ActionListener listener8 = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| toggleHealthPolling()//tasks.logger.execute() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| }; |
| ActionListener copyBeWarListener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| parallel { copyBE() }//.execute()//tasks.logger.execute() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| }; |
| |
| ActionListener startDBListener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| parallel { |
| startDB() |
| }//tasks.logger.execute() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| } |
| |
| ActionListener stopDBListener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| stopDB()//tasks.logger.execute() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| } |
| |
| ActionListener dbBackupListener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| parallel { |
| backupDB()//tasks.logger.execute() |
| } |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| } |
| |
| ActionListener feStartListener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| parallel { |
| startFE() |
| }//tasks.logger.execute() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| } |
| |
| ActionListener feStopListener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| stopFE()//tasks.logger.execute() |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| } |
| |
| ActionListener feCopyListener = new ActionListener() { |
| public void actionPerformed(ActionEvent e) { |
| try { |
| parallel { |
| copyFE() //.execute()//tasks.logger.execute() |
| } |
| } catch (AWTException e1) { |
| System.err.println(e1); |
| } |
| } |
| } |
| |
| |
| //def listenerFullModules = newListener { parallel { installAllProject() } } |
| //region -> Button<=Listener |
| hotswapItem.addActionListener(listenerHotswap) |
| updaterFeItem.addActionListener(listenerFE) |
| updaterFullBeItem.addActionListener( listenerFullBE ) |
| updaterBeWithDependenciesItem.addActionListener( listenerBE ) |
| updaterFullFeItem.addActionListener( listenerFullFE ) |
| stopItem.addActionListener(stopBackendListener) |
| startItem.addActionListener(startBEListener) |
| copyBeWarItem.addActionListener(copyBeWarListener); |
| killItem.addActionListener(killJavaListener) |
| startAllItem.addActionListener(startAllListener) |
| importItem.addActionListener(listener5) |
| healthInfoItem.addActionListener(listener6) |
| toggleHealthItem.addActionListener(listener8) |
| logsItem.addActionListener(listener7) |
| exitItem.addActionListener(exitListener) |
| |
| startDBItem.addActionListener( startDBListener ) |
| stopDBItem.addActionListener( stopDBListener ) |
| backupDBItem.addActionListener( dbBackupListener ) |
| copyFeWarItem.addActionListener( feCopyListener ) |
| startFEItem.addActionListener( feStartListener ) |
| stopFEItem.addActionListener( feStopListener ) |
| //endregion |
| //endregion |
| // set the TrayIcon properties |
| |
| // ... |
| // add the tray image |
| try { |
| tray.add(trayIcon); |
| |
| } catch (AWTException e) { |
| System.err.println(e); |
| } |
| // ... |
| } else { |
| println "Java TrayIcon Option is not supported in your System, try enabling it. Bye Bye" |
| } |
| |
| } |
| |
| def prepareTray(){ |
| long UPDATE_THRESHOLD = 3500 |
| float SCALAR = 1 |
| ssh.settings { |
| knownHosts = allowAnyHosts |
| } |
| while(!isStopHealthCheck) { |
| if (!isHaltHealth.get()) { //if await or await is more then 60 second return health check |
| ssh.run { |
| session(remotes.vagrant) { |
| try { |
| def healthOutput = execute command[ALL][HEALTH]() |
| if (healthOutput?.contains("Failed command .* with status 7") || healthOutput?.contains("Problem accessing /sdc2/rest/healthCheck")) |
| updateTray(STATUS.DOWN) |
| def statusCollecion = healthOutput?.findAll "\"healthCheckStatus\": \".*\"" |
| def upCount = statusCollecion?.count { it?.contains("UP") } |
| def downCount = statusCollecion?.count { it?.contains("DOWN") } |
| def uknownCount = (statusCollecion?.size() - upCount) - downCount |
| println " UP -> $upCount | downCount=$downCount | uknownCount=$uknownCount " |
| (uknownCount > 0 || (downCount > 0 && upCount > 0)) ? updateTray(STATUS.UNKNOWN) : ((upCount > 0) ? updateTray(STATUS.UP) : updateTray(STATUS.DOWN)) |
| SCALAR = 1 |
| } catch (Exception e) { |
| updateTray(STATUS.DOWN) |
| println e |
| SCALAR = Math.min(SCALAR * 1.1, 5) //slow down on errors |
| } |
| //green color effects |
| if (lastStatus && lastStatus == STATUS.UP) { |
| trayIcon.setImage(convert(Math.random() > 0.5 ? 'okImg1' : 'okImg2')) |
| //randomly green change color |
| } |
| Thread.yield() |
| Thread?.sleep((long) (UPDATE_THRESHOLD * SCALAR)) |
| } |
| } |
| }else{ |
| updateTray(STATUS.UNAVAILABLE) |
| Thread.yield() |
| } |
| } |
| } |
| |
| def healthPopup(){ |
| ssh.run { |
| session(remotes.vagrant) { |
| def healthOutput = execute command[ALL][HEALTH]() |
| JOptionPane.showMessageDialog(null, |
| healthOutput, |
| "HEALTH", |
| JOptionPane.INFORMATION_MESSAGE); |
| } |
| } |
| } |
| |
| project.ext.set("msg", { content -> """ |
| ************************************************************************************************ |
| ************************************************************************************************ |
| ******* ********* |
| ************** **************** |
| $content |
| |
| ************************************************************************************************ |
| ************************************************************************************************ |
| """} ) |