blob: 5f290f21256f1be02bd578cdb8d84d7f5a410b05 [file] [log] [blame]
Michael Lando5b593492018-07-29 16:13:45 +03001import javax.imageio.ImageIO
2import javax.swing.*
3import java.awt.*
4import java.awt.event.ActionEvent
5import java.awt.event.ActionListener
6import java.util.List
Michael Landoa5445102018-03-04 14:53:33 +02007import java.util.concurrent.Callable
8import java.util.concurrent.Executors
9import java.util.concurrent.atomic.AtomicBoolean
10
Michael Landoa5445102018-03-04 14:53:33 +020011import static ServiceControl.*
Michael Lando5b593492018-07-29 16:13:45 +030012import static Services.*
Michael Landoa5445102018-03-04 14:53:33 +020013
14group 'com.att.ecomp'
15version '1.01-SNAPSHOT'
16
17apply plugin: 'groovy'
18apply plugin: 'java'
19apply plugin: "org.hidetake.ssh"
20apply plugin: 'java-gradle-plugin'
21apply plugin: 'idea'
22
23sourceCompatibility = 1.8
24
25buildscript {
26 repositories {
27 jcenter()
28 mavenCentral()
29 }
30 dependencies {
31 classpath 'org.codehaus.groovy:groovy-all:2.4.12'
32 classpath "org.hidetake:gradle-ssh-plugin:2.9.0"
33 }
34}
35
36enum Services {
37 BACKEND , //be
38 FRONTEND , //fe
39 DB , //cassandra
40 CACHING , //elawsrticsearch
41 SECURITY , //webseal
42 ALL //all services
43}
44enum ServiceControl {
45 HEALTH ,
46 START ,
47 RESTART ,
48 STOP ,
49 KILL
50}
51//env variables
52//fill YOUR_WINDOWS_USER_HOME
53project.ext.set("NEW_VAG",Boolean.FALSE) //flags to use new vagrant configuration
54project.ext.set("IS_HOTSWAP",Boolean.FALSE) //flags to use new vagrant configuration
55project.ext.set("PROJECT_PATH", System.getenv("SDC")) //ex. 'C:\\GIT_WORK\\asdc\\sdc')
56project.ext.set("VAGRANT_HOME", NEW_VAG ? System.getenv("NEW_VAG") : System.getenv("VAG")) //ex. 'C:\\GIT_WORK\\vagrant-asdc-all-in-one')
57project.ext.set("USER_HOME", "${System.getenv("USERPROFILE")}\\.ssh")
58project.ext.set("BE_REMOTE", NEW_VAG ? '/opt/app/jetty/base/be' : '/home/vagrant/catalog-be' )
59project.ext.set("FE_REMOTE", NEW_VAG ? '/opt/app/jetty/base/fe' : '/home/vagrant/catalog-fe' )
60project.ext.set("VAGRANT_USER", NEW_VAG ? 'm11981' : 'vagrant' )
61project.ext.set("RSA_PRIVATE_KEY_PATH", NEW_VAG ? "$VAGRANT_HOME/id_rsa" : '' )
62project.ext.set("VAGRANT_PASSWORD", NEW_VAG ? 'Aa123456' : 'vagrant' )
63project.ext.set("X_FOLDER",'/xFolder' )
64project.ext.set("BE_DEPENDENCIES", 'common-be,common-app-api,catalog-dao,catalog-model,security-utils' )
65project.ext.set("command", [ (ALL) : [ (HEALTH) : { NEW_VAG ? 'sudo curl -i http://localhost:8181/sdc1/rest/healthCheck' : 'curl -i localhost:8080/sdc2/rest/healthCheck' } ,
66 (KILL) : { NEW_VAG ? 'sudo pkill java' : 'pkill java'} ] , // TODO: refine kill only for services
67 (BACKEND) : [ (START) : { NEW_VAG ? 'sudo service jettyBE start' : 'service catalog-be start'} ,
68 (STOP) : { NEW_VAG ? 'sudo service jettyBE stop' : 'service catalog-be stop'} ,
69 (RESTART) : { NEW_VAG ? 'sudo service jettyBE restart' : 'service catalog-be restart'}] ,
70 (DB) : [ (START) : { NEW_VAG ? 'sudo service cassandra start' : 'start-asdc-storage.sh' } ,
71 (STOP) : { NEW_VAG ? 'sudo service cassandra stop' : 'service cassandra stop'} ,
72 (RESTART) : { NEW_VAG ? 'sudo service cassandra restart' : 'service cassandra restart'} ] ,
73 (FRONTEND): [ (START) : { NEW_VAG ? 'sudo service jettyFE start' : 'service catalog-fe start' } ,
74 (STOP) : { NEW_VAG ? 'sudo service jettyFE stop' : 'service catalog-fe stop'} ,
75 (RESTART) : { NEW_VAG ? 'sudo service jettyFE restart' : 'service catalog-fe restart' } ] ,
76 (CACHING): [ (START) : { NEW_VAG ? 'sudo service elasticsearch start' : 'echo "starting es is not yet supported"' } ],
77 (SECURITY): [ (START) : { NEW_VAG ? 'sudo docker start sdc-WebSeal-Simulator' : 'service webseal-simulator start' } ,
78 (STOP) : { NEW_VAG ? 'sudo docker stop sdc-WebSeal-Simulator' : 'service webseal-simulator stop'} ,
79 (RESTART) : { NEW_VAG ? 'sudo docker restart sdc-WebSeal-Simulator' : 'service webseal-simulator restart'}]
80 ] ) //abstraction level to shell scripts , support old and new vagrant bash commands
81
82//icons
83project.ext.set("warnImg",'')
84project.ext.set("okImg1",'')
85project.ext.set("okImg2" , '')
86project.ext.set("errorImg" , '')
87project.ext.set("unavailableImg" , '')
88
89
90//health params
91project.ext.set("trayIcon", null)
92project.ext.set("lastStatus", null)
93project.ext.set("isStopHealthCheck", false)
94project.ext.set("isHaltHealth", new AtomicBoolean(false) )
95project.ext.set("startedAwait", Long.MAX_VALUE)
96project.ext.set("logFile", 'C:/ProgramData/all.log')
97project.ext.set("pomList" , ["${System?.getenv('SDC')}/catalog-fe/pom.xml" ,"${System?.getenv('SDC')}/catalog-be/pom.xml" ] ) //empty list will scan all openecomp poms
98project.ext.set("pomChangesMap" , [:] )
99project.ext.set("beConfigFilesToCopyMapping" , [ 'src/main/resources/config/*.yaml' : 'config/catalog-be/' ,
100 'src/main/resources/config/*.properties' : 'config/catalog-be/'] )
101
102//menu item strings
103project.ext.set("toggleHealthString" , "Halt Health" )
104//menu item
105project.ext.set("toggleHealthItemView" , null )
106
107//other
108project.ext.set("IS_MVN_INSTALL",false)
109project.ext.set("executor" , null )
110project.ext.set("lockObj" , new Object() )
111/*compile?.doLast {
112 println "2. hello compile2"
113}*/
114
115/*def post(String host , String serviceName,String msg){
116 // POST
117 def post = new URL("$host/$serviceName").openConnection();
118 def message = '{"message":"this is a message"}'
119 post.setRequestMethod("POST")
120 post.setDoOutput(true)
121 post.setRequestProperty("Content-Type", "application/json")
122 post.getOutputStream().write(message.getBytes("UTF-8"));
123 def postRC = post.getResponseCode();
124 println(postRC);
125 if( postRC.equals(200)) {
126 println(post.getInputStream().getText());
127 }
128}
129
130def postStat( long operationTime, String user , String meta ){
131 def host = 'http://135.76.123.70:8888'
132 def params = "user=$user&meta=$meta"
133 post host , "UserStats" , params
134}*/
135
136
137def hash( List list ){
138 def map = list?.collectEntries { File file -> [(file?.absolutePath) : file?.text?.hashCode() ]}
139
140 map
141}
142
143def pomChanges(){
144 long started = System.currentTimeMillis()
145 if ( !pomList )
146 listPom()
147 //find hash changes
148 def changes = pomList?.findAll {
149 def File file = new File(it);
150 pomChangesMap[it] != file?.text?.hashCode()
151 }
152 println "\n\n[MasterD][POM]--> detected changes for -> $changes"
153 //update changes in map
154 changes?.each { pomChangesMap[it] = new File(it)?.text?.hashCode() }
155 println "\n\n[MasterD][POM]--> pom map -> $pomChangesMap"
156
157 println """
158 ****** POM changes detection finished after -> ${System.currentTimeMillis()- started}ms ******
159 """
160
161 changes
162}
163//list pom with updated file hashes
164def listPom(){
165 long started = System.currentTimeMillis()
166 if (!pomList) {
167 def tree = fileTree( PROJECT_PATH ).include '**/pom.xml'//.filter { it.isFile() && it?.toString()?.toLowerCase()?.endsWith('pom.xml') }
168 //println "$PROJECT_PATH list is ->${ list?.collect { it?.absolutePath } }"
169 //flatten and filter openecomp poms
170 pomList = tree?.flatten()?.findAll { File file -> file?.text?.contains('org.openecomp.sdc') }?.collect {File file -> file?.absolutePath }
171 }
172 pomChangesMap = pomList.collectEntries { absolutePath ->[ ( absolutePath ) : new File(absolutePath)?.text?.hashCode() ] }
173
174 println """ [MasterD][Init] intializing POM detector
175
176 ********* POM listing finished after -> ${System.currentTimeMillis()- started}ms *********
177 """
178 return pomList
179}
180
181
182task initialization(){
183 listPom()
184 executor = Executors.newCachedThreadPool();
185}
186
187def parallel( closure ){
188 executor?.submit(new Callable<Object>(){
189 @Override
190 public Object call() {
191 closure();
192 return null;
193 }
194 })
195}
196/*class Preferences {
197 def String Username
198 def String IsNewVagrant
199 def String IsRapidMode
200}
201
202def initXFolder(){
203 def folder = new File(X_FOLDER);
204 folder?.exists() ?: folder?.mkdirs()
205
206 new File("${folder?.absolutePath}/$PREFERENCES_FILENAME")
207}*/
208
209task tester{
210 /*doLast{
211 //postStat(10000, "shay" , "report/index")
212 listPom()
213 new File('catalog-be\\pom.xml') << "#hello"
214 pomChanges()
215 }*/
216}
217
218
219def fetchFilesByExtention(remote, local , ext ){
220 ssh.run {
221 def started = System.currentTimeMillis()
222 println "folder diff"
223 session(remotes.vagrant) {
224 //execute "cd /home/vagrant/catalog-be/tmp ; ls -lt | grep catalog-be" //todo- use my dates to filter
225 get from: remote , into: local , filter: { it?.absolutePath =~ /jetty.*catalog-be.*\.dir.*\.$ext/ } // { it?.absolutePath =~ /.*catalog-be.*dir.*classes.*/ }
226 }
227 println "fetched files in ${System.currentTimeMillis() - started} ms"
228 }
229}
230
231def updateRemoteFile(String remote , String local){
232 ssh.run {
233 def to = "$BE_REMOTE${remote[remote?.indexOf("tmp\\")..remote.size()-1].replaceAll("\\\\","/")}"
234 println "copying $local \nto\n $to"
235 session(remotes.vagrant) {
236 put from: local , into: to }
237 }
238}
239
240def compareAndSwap(){
241 def final LIMIT = 10
242 def newClasses = new File("$PROJECT_PATH\\catalog-be\\target\\classes")
243 def File jettyClasses ;
244 //locate classes
245 println "traversing.."
246 new File("build/hotswap").traverse { if (it?.directory && it?.name?.equals("classes")){
247 jettyClasses = it
248 return;
249 } }
250 def jettyClassesList = []
251 jettyClasses?.traverse { jettyClassesList << it }
252
253 println "$jettyClasses"
254 //Sort compiled classes
255 def files = []
256 newClasses?.traverse { files << it }
257 def result = files.sort{ a,b -> b.lastModified() <=> a.lastModified() }
258 println "show only last $LIMIT changes"
259 result[0..LIMIT]?.each{ println it?.lastModified() +" | "+ it?.name + (it?.directory ? "[Directory]" : "") } //show only last 10 changes
260
261 //update
262 def changesMap = [ : ] //<old,new>
263 println "updating changes"
264 result[0..LIMIT]?.each { File f -> def File other = jettyClassesList.find{ File other-> other?.absolutePath?.endsWith(f?.name) };
265 if ( !(f.directory) && f?.text?.hashCode() != other?.text?.hashCode() )
266 updateRemoteFile( other?.getAbsolutePath() , f?.getAbsolutePath() )
267 } //use hashing
268}
269
270task hotswap(){
271 doLast {
272 new File("build/hotswap")?.deleteDir()
273 new File("build/hotswap")?.mkdirs()
274 ssh.settings {
275 knownHosts = allowAnyHosts
276 }
277 fetchFilesByExtention( "$BE_REMOTE/tmp/" , 'build/hotswap' , "class")
278 compareAndSwap()
279 }
280}
281
282remotes {
283 vagrant {
284 host = '127.0.0.1'
285 port = 2222
286 user = VAGRANT_USER
287 password = VAGRANT_PASSWORD
288 identity = NEW_VAG ? new File(RSA_PRIVATE_KEY_PATH) : null
289 }
290
291}
292
293def gitLatest(){
294
295}
296
297def newEcoSystem(){
298 //cleanTitan()
299 backupDB() //and clean all
300 //restoreDB() //restore latest
301 createSchema()
302 fillSchema()
303 postCreate()
304 startAll()
305 //todo- conside updating from git
306 updaterBEFull()
307 updaterFE()
308}
309def importHeatTypes(){
310 //todo- impl
311}
312def postCreate(){
313 importNormative()
314 importHeatTypes()
315}
316def fillSchema(){
317 // add conformence level
318}
319def createSchemaPreStep(){
320 //todo- DB up
321}
322def createSchemaPostStep(){
323 ////todo- impl create amdocs dox
324}
325def createSchema(){
326 createSchemaPreStep()
327 //todo- create schema
328 //todo- create titan
329 createSchemaPostStep()
330}
331
332def cleanTitan(){
333 execSafe{
334 ssh.settings {
335 knownHosts = allowAnyHosts
336 }
337 ssh.run {
338 session(remotes.vagrant) {
339 execute "cqlsh -e 'DROP KEYSPACE titan;'"
340 println "[MasterD][DB_DROP]-> Dropped 'titan' KEYSPACE."
341 }
342 }
343 }
344}
345task cleanTitan {
346 doLast{
347 cleanTitan()
348 }
349}
350
351task fetchE2EDB(){
352 doLast{
353 fetchE2EDB()
354 }
355}
356def fetchE2EDB(){
357 execSafe{
358 ssh.settings {
359 knownHosts = allowAnyHosts
360 }
361 ssh.run {
362 session(remotes.vagrant) {
363 def tmp = '$CASSANDRA_HOME/backup/e2e'
364 //execute 'mkdir $CASSANDRA_HOME/backup/e2e/'
365 //execute 'wget http://135.76.210.202:8080/ETE_backup_files/latest_ETE_backup_file.zip -P /vagrant/db'
366 println "[MasterD] download finished, unzipping.."
367 execute "unzip -u $tmp/latest_ETE_backup_file.zip" //execute 'unzip -u /vagrant/db/latest_ETE_backup_file.zip'//'
368 def folder = execute "cd $tmp; ls -d -- */"
369 println "[MasterD] unzipping finished into -> $folder , untaring.."
370 execute "tar zxf $tmp/$folder/* --strip 3 -C" +'$CASSANDRA_HOME/data | pv -l >/dev/null'
371 println "[MasterD][E2E_DB]-> Downloaded & unzipped e2e data successfully."
372 }
373 }
374 }
375}
376def copyExplodedBE() {
377 execSafe{
378 println "[MasterD][BackEnd] copying exploded war."
379 ssh.settings {
380 knownHosts = allowAnyHosts
381 }
382 long started = System.currentTimeMillis()
383 def dirPath = "${PROJECT_PATH}/catalog-be/target/catalog-be-1.1.0-SNAPSHOT"
384 def dir = new File(dirPath);
385 println "[MasterD][BackEnd] copying ${dir?.directorySize()/(1024*1024)} MB, from ${dir?.name} to $BE_REMOTE/webapps"
386 ssh.run {
387 session(remotes.vagrant) {
388 execute "rm -R $BE_REMOTE/webapps/catalog-be-1.1.0-SNAPSHOT"
389 put from: dir?.absolutePath , into: "$BE_REMOTE/webapps"
390 }
391 }
392 println "[MasterD][BackEnd] Successfully copied exploded war in ${System.currentTimeMillis()-started}ms."
393 }
394}
395task copyExplodedBE(){
396 doLast{
397 copyExplodedBE()
398 }
399}
400def backupDB() {
401 execSafe{
402 ssh.settings {
403 knownHosts = allowAnyHosts
404 }
405 ssh.run {
406 session(remotes.vagrant) {
407 execute 'mkdir -p $CASSANDRA_HOME/backup'
408 def res = execute 'mv $CASSANDRA_HOME/data $CASSANDRA_HOME/backup/data_$(date +\'%Y_%m_%d__%H:%M:%S\')'
409 println "[MasterD][DB_BACKUP]-> snapshot DB finished. $res"
410 }
411 }
412 }
413}
414task backupDB{
415 doLast{
416 backupDB()
417 }
418}
419
420def restoreDB(){
421 execSafe{
422 ssh.settings {
423 knownHosts = allowAnyHosts
424 }
425 ssh.run {
426 session(remotes.vagrant) {
427 println "[MasterD]-> restoring DB"
428 execute 'mkdir -p $CASSANDRA_HOME/data'
429 def res = execute 'mv $CASSANDRA_HOME/backup/data_*/* $CASSANDRA_HOME/data'
430 println "[MasterD]-> DB restore FINISHED!! $res"
431 }
432 }
433 }
434}
435task restoreDB() {
436 doLast {
437 restoreDB()
438 }
439}
440
441def vm( ){
442 exec{
443 if (VAGRANT_HOME){
444 workingDir VAGRANT_HOME //vagrant path
445 println "*****************\nworking dir -> $VAGRANT_HOME"
446 commandLine "cmd","/c", "vagrant up"
447 //args = [ ]
448 } else {
449 println "[MasterD]--> please define windows enviroment variable VAG pointing to vagrant project"
450 }
451 }
452}
453
454task vm{
455 doLast{
456 vm()
457 }
458}
459
460def copyFE() {
461 println "[MasterD][FrontEnd] starting war copy."
462 ssh.settings {
463 knownHosts = allowAnyHosts
464 }
465 long started = System.currentTimeMillis()
466 def target = "${PROJECT_PATH}/catalog-fe/target/"
467 def files = GFileUtils.listFiles( new File(target) , ["war"] as String[] , false);
468 files?.each{ File file ->
469 if (!file?.name?.contains('classes')){
470 println "[MasterD][FrontEnd] copying ${file.length()/(1024*1024)} MB, from ${file?.name} to $FE_REMOTE/webapps"
471 ssh.run {
472 session(remotes.vagrant) {
473 put from: file?.absolutePath , into: "$FE_REMOTE/webapps"
474 }
475 }
476 }
477
478 }
479 println "[MasterD][FrontEnd] Successfully copied war in ${System.currentTimeMillis()-started}ms."
480}
481
482task deployFE{
483 doLast {
484 copyFE()
485 }
486}
487
488
489def copyBE(){
490 println "[MasterD][BackEnd] starting war copy."
491 ssh.settings {
492 knownHosts = allowAnyHosts
493 }
494 def target = "${PROJECT_PATH}/catalog-be/target/"
495 def files = GFileUtils.listFiles( new File(target) , ["war"] as String[] , false);
496 long started = System.currentTimeMillis()
497 files?.each{ File file ->
498 if (!file?.name?.contains('classes')){
499 println "[MasterD][BackEnd] copying ${file.length()/(1024*1024)} MB, from ${file?.name} to $BE_REMOTE/webapps"
500 ssh.run {
501 session(remotes.vagrant) {
502 put from: file?.absolutePath , into: "$BE_REMOTE/webapps"
503 }
504 }
505 }
506 }
507 println "[MasterD][BackEnd] SUCCESSFULY copied be war in ${System.currentTimeMillis()-started}ms."
508}
509
510task deployBE {
511 doLast {
512 copyBE()
513 }
514}
515def compileFE(){
516 exec{
517 println "[MasterD][FE]--> compiling project at -> ${PROJECT_PATH}\\catalog-fe"
518 workingDir "${PROJECT_PATH}" //vagrant path
519 commandLine 'cmd','/c','mvn -T 2 compile -pl catalog-fe,catalog-ui -am -Pcatalog -Dmaven.test.skip'
520 }
521}
522task compileFE(){
523 doLast{
524 compileFE()
525 }
526}
527def compileBE(){
528 exec{
529 println "[MasterD][BE]--> compiling project at -> ${PROJECT_PATH}\\catalog-be"
530 workingDir "${PROJECT_PATH}" //vagrant path
531 commandLine 'cmd','/c','mvn -T 2 compile -pl catalog-be -Pcatalog -Dmaven.test.skip'
532 }
533}
534task compileBE{
535 doLast{
536 compileBE()
537 }
538}
539
540def compile(){
541 exec{
542 println "[MasterD]--> compiling project at -> ${PROJECT_PATH}"
543 workingDir "${PROJECT_PATH}" //vagrant path
544 commandLine 'cmd','/c','mvn -T 2 compile -am -Pcatalog -Dmaven.test.skip'
545 }
546}
547
548task compile{
549 doLast{
550 compile()
551 }
552}
553def compileDependencies(){
554 def cmd = IS_MVN_INSTALL ? 'install' : 'compile'
555 exec{
556 println "[MasterD]--> compiling BE dependencies -> $BE_DEPENDENCIES [ SKIPPING TESTS!! ]"
557 workingDir "${PROJECT_PATH}" //vagrant path
558 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'
559 }
560}
561task compileDependencies {
562 doLast{
563 compileDependencies()
564 }
565}
566def compileWar(){
567 def cmd = IS_MVN_INSTALL ? 'install' : 'compile'
568 exec{
569 println "--> compiling project at -> ${PROJECT_PATH}\\catalog-be"
570 workingDir "${PROJECT_PATH}" //vagrant path
571 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'
572 }
573}
574task compileWar(){
575 doLast{
576 compileWar()
577 }
578}
579
580//deprecated - use deployBE()
581task be() {
582 doLast{
583 def started = System.currentTimeMillis();
584 exec{
585 println "[MasterD]--> copying be... [from $VAGRANT_HOME]"
586 workingDir VAGRANT_HOME //vagrant path
587 commandLine 'cmd','/c', 'copy_war_be.bat','localhost' , "$PROJECT_PATH\\catalog-be\\target\\catalog-be*.war" , "$BE_REMOTE/webapps"
588 //args = [ ]
589 }
590 println """
591 **** copying finished in -> ${System.currentTimeMillis() - started}ms ****
592 """
593 }
594}
595
596task beConfig( ) {
597 doLast{
598 exec{
599 workingDir "${System.env.VAG}" //vagrant path
600 commandLine 'cmd','/c','copy_war_be_with_configuration','localhost' , "$PROJECT_PATH\\catalog-be\\target\\catalog-be*.war" , "$BE_REMOTE/webapps"
601 //args = [ ]
602 }
603 }
604
605}
606task feConfig( ) {
607 doLast{
608 exec{
609 workingDir "${System.env.VAG}" //vagrant path
610 commandLine 'cmd','/c','copy_war_fe_with_configuration','localhost' , "$PROJECT_PATH\\catalog-fe\\target\\catalog-fe*.war" , "$FE_REMOTE/webapps"
611 //args = [ ]
612 }
613 }
614
615}
616
617task fe() {
618 doLast{
619 exec {
620 workingDir "${System.env.VAG}" //vagrant path
621 commandLine 'cmd','/c', 'copy_war_fe.bat', 'localhost', "$PROJECT_PATH\\catalog-fe\\target\\catalog-fe*.war", "$FE_REMOTE/webapps"
622 //args = [ ]
623 }
624 }
625}
626
627def installAllProject(){
628 exec{
629 println "[MasterD]--> Compiling&Installing project at -> ${PROJECT_PATH}"
630 workingDir "${PROJECT_PATH}" //vagrant path
631 commandLine 'cmd','/c','mvn -T 2 clean install -U -Pcatalog -Dmaven.test.skip'
632 }
633}
634task installAllProject {
635 doLast {
636 installAllProject()
637 }
638}
639
640task installAll {
641 doLast{
642 println '[MasterD]--> Finished!!'
643 }
644}
645installAll.dependsOn { tasks.findAll { task -> task.name.startsWith('install_') } }
646
647def install_BE(){
648 exec {
649 println '[MasterD][Install]--> Installing BE!!'
650 workingDir "${PROJECT_PATH}"
651 commandLine 'cmd','/c', 'mvn clean install -pl catalog-be -am -Pcatalog -Dmaven.test.skip'
652 //args = [ ]
653 }
654}
655
656task install_BE() {
657 doLast{
658 install_BE()
659 }
660}
661
662def install_FE() {
663 exec {
664 workingDir "${PROJECT_PATH}"
665 commandLine 'cmd','/c', 'mvn clean install -pl catalog-ui,catalog-fe -am -Pcatalog -Dmaven.test.skip'
666 }
667}
668task install_FE() {
669 doLast {
670 install_FE()
671 }
672}
673
674def updaterBERapid(){
675 /* if ( ticket() > PREVIOUS_BUILD_VAR ){
676 PREVIOUS_BUILD_VAR = ticket()*/
677 def started = System.currentTimeMillis();
678 println "[MasterD][Rapid]--> compiling changes using maven"
679 compileWar()
680 println "[MasterD][Rapid]--> copying war"
681 copyBE() //use this if you want to deploy entire war //hotswap.execute()
682 restartBackend()
683 println msg(" redeploy finished in -> ${System.currentTimeMillis() - started}ms ")
684}
685task updaterBERapid(){
686 doLast {
687 updaterBERapid()
688 }
689}
690def updaterBE(){
691 def started = System.currentTimeMillis();
692 IS_MVN_INSTALL = pomChanges() ? true : false
693 println "[MasterD]--> compiling changes using maven"
694 compileDependencies()
695 compileWar()
696 println "[MasterD]--> copying war"
697 IS_HOTSWAP ? copyExplodedBE() : copyBE() //execute() //use this if you want to deploy entire war //hotswap.execute()
698 restartBackend()
699 println msg("redeploy finished in -> ${System.currentTimeMillis() - started}ms ")
700}
701task updaterBE(){
702 doLast {
703 updaterBE()
704 }
705}
706def copyBEConfiguration(){
707/* execSafe {
708 ssh.settings {
709 knownHosts = allowAnyHosts
710 }
711 ssh.run {
712 session(remotes.vagrant) {
713 println msg("Stopping BackEnd Server")
714 execute command[BACKEND][STOP]()
715 }
716 }
717 }*/
718}
719def updaterBEFull(){
720 def started = System.currentTimeMillis();
721 compile()
722 println "[MasterD]--> copying war"
723 copyBE() //use this if you want to deploy entire war //hotswap.execute()
724 copyBEConfiguration()
725 println msg("redeploy finished in -> ${System.currentTimeMillis() - started}ms ")
726}
727task updaterBEFull(){
728 doLast {
729 updaterBEFull()
730 }
731}
732def copyFEConfiguration(){
733 //todo- implement
734}
735def updaterFE(){
736 def started = System.currentTimeMillis();
737 println "[MasterD]--> compiling changes using maven"
738 compileFE()
739 println "[MasterD]--> copying war"
740 copyFE() //.execute() //use this if you want to deploy entire war //hotswap.execute()
741 copyFEConfiguration()
742 println msg("redeploy finished in -> ${System.currentTimeMillis() - started}ms ")
743}
744task updaterFE(){
745 doLast {
746 updaterFE()
747 }
748}
749def stopBackend(){
750 execSafe {
751 ssh.settings {
752 knownHosts = allowAnyHosts
753 }
754 ssh.run {
755 session(remotes.vagrant) {
756 println msg("Stopping BackEnd Server")
757 execute command[BACKEND][STOP]()
758 }
759 }
760 }
761}
762task stopBackend(){
763 doLast {
764 stopBackend()
765 }
766}
767
768def startBackend(){
769 execSafe {
770 ssh.settings {
771 knownHosts = allowAnyHosts
772 }
773 ssh.run {
774 session(remotes.vagrant) {
775 println msg("[MasterD] starting backend sever")
776
777 execute command[BACKEND][START]()
778 }
779 }
780 }
781 println """[MasterD]-> finished !!
782 """
783}
784task startBackend(){
785 doLast{
786 startBackend()
787 }
788}
789
790def restartBackend(){
791 execSafe {
792 ssh.settings {
793 knownHosts = allowAnyHosts
794 }
795 ssh.run {
796 session(remotes.vagrant) {
797 println msg("[MasterD] restarting backend sever")
798
799 execute command[BACKEND][RESTART]()
800 }
801 }
802 }
803 println """[MasterD]-> finished !!
804 """
805}
806//todo- remove this if you want to auto-deploy on every file save
807/*
808compileJava.doFirst{
809 updater?.execute()
810}*/
811
812enum STATUS { UP, DOWN , UNKNOWN , UNAVAILABLE }
813
814task health(){
815 doLast {
816 prepareTray()
817 }
818}
819
820def execSafe( closure){
821 if (!lockObj) {
822 [0..4].forEach( {println "Critical ERROR : lock object is not initialized\n\nCritical ERROR : cannot run tasks\n"}() )
823 return;
824 }
825 synchronized (lockObj){
826 boolean prev = isHaltHealth.get()
827 try {
828 isHaltHealth.set(true)
829 closure()
830 } catch (Exception e) {
831 println e
832 } finally {
833 isHaltHealth.set(prev)
834 }
835 }
836}
837
838def fetchFiles( remote, local ){
839 ssh.run {
840 session(remotes.vagrant) {
841 //execute "cd /home/vagrant/catalog-be/tmp ; ls -lt | grep catalog-be" //todo- use my dates to filter
842 def f = get from: remote , into: local
843 println f?.name
844 //return f
845 }
846 //println "fetched files in ${System.currentTimeMillis() - started} ms"
847 }
848
849 //return null
850}
851
852
853def killJava(){
854 execSafe {
855 def res
856 ssh.run {
857 session( remotes.vagrant ) {
858 println """ *-*-****************************-*-*
859 killing all java proccesses
860 *-*-****************************-*-*
861 """
862 res = execute command[ALL][KILL]()
863 }
864 }
865 println res?.toString()
866 }
867}
868
869def importNormative(){
870 execSafe {
871 ssh.run {
872 session(remotes.vagrant) {
873 println """ *-*-************************************-*-*
874 importNormative
875 *-*-************************************-*-*
876 """
877 execute "python -v $BE_REMOTE/scripts/import/tosca/importNormativeAll.py"
878 }
879 }
880 }
881}
882
883def startAll(){
884 def startCassandra = """
885 #!/bin/bash
886
887 cassandra&
888 elasticsearch -d
889
890 #Wait until ES is up
891 until curl localhost:9200/_cluster/health;
892 do
893 printf "."
894 sleep 3
895 done
896
897 # Create Elastic Mapping if not exist in ES
898 createESMapping.sh
899 """
900 execSafe {
901 ssh.run {
902 session(remotes.vagrant) {
903 println """ *-*-************************************-*-*
904 starting all SDC services(DB,BE,FE,Webseal)
905 *-*-************************************-*-*
906 """
907 if ( NEW_VAG ){
908 execute command[DB][START]()
909 Thread.sleep(5000)
910 execute command[CACHING][START]()
911 }
912 else
913 execute startCassandra
914 //[0..4]?.forEach( Thread?.sleep(2000) )
915 Thread?.sleep(10000)
916 Thread?.sleep(10000)
917 execute command[BACKEND][START]()
918 execute command[FRONTEND][START]()
919 execute command[SECURITY][START]()
920 }
921 }
922 }
923}
924
925
926/*def clearLog(type: Delete){
927 delete{
928 delete 'C:/ProgramData/all.log'
929 followSymlinks = true
930 }
931}*/
932task clearLog(type: Delete){
933 doLast{
934 delete 'C:/ProgramData/all.log'
935 followSymlinks = true
936 }
937}
938def logBE(){
939 try{
940 println "\n*** logging BE all.log ***\n"
941
942 ssh.run {
943 session( remotes.vagrant ) {
944 //String now = execute 'echo \"\$(date +\'%Y_%m_%d\')\"'
945 //println "\n\n*******************************************************\n\n"+now?.toString()
946 clearLog?.execute() //todo- remove this .execute()
947 fetchFiles( '/home/vagrant/catalog-be/logs/SDC/SDC-BE/all.log' , 'C:/ProgramData') //"%USERPROFILE%\AppData\Local\")
948 //project.ext.set( "logFile" , 'C:/ProgramData/all.log' )
949
950 // -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*'
951 }
952 }
953
954 parallel {
955 exec {
956 //if ( logFile ){
957 String notepad = 'C:\\Program Files (x86)\\Notepad++\\notepad++.exe'
958 println "logging $logFile to notepad++ [$notepad]"
959 commandLine 'cmd','/c' , notepad ,logFile
960 }
961 }
962 }catch(Exception e){
963 println "cannot open logs!!!"
964 e.printStackTrace()
965 }
966}
967task logBE(){
968 doLast{
969 logBE()
970 }
971}
972
973def toggleHealthPolling(){
974 isHaltHealth.set(!isHaltHealth.get())
975}
976//converts predefined icon to Image
977def Image convert( imageName ){
978 String encodedimage = project.ext.get(imageName);
979 byte[] byteImage = encodedimage?.split(',')[1]?.decodeBase64()
980 Image image = ImageIO.read(new ByteArrayInputStream(byteImage));
981}
982
983def refreshMenu(String imageName){
984 switch( imageName ) {
985 case 'unavailableImg' : toggleHealthString = "Resume Health"; break;
986 default : toggleHealthString = "Halt Health";
987 }
988 if (((MenuItem)toggleHealthItemView).getLabel() != toggleHealthString)
989 ((MenuItem)toggleHealthItemView).setLabel(toggleHealthString);
990}
991def startDB(){
992 println "[MasterD] Starting database.."
993 execSafe {
994 ssh.settings {
995 knownHosts = allowAnyHosts
996 }
997 ssh.run {
998 session(remotes.vagrant) {
999 execute command[DB][START]()
1000 }
1001 }
1002 }
1003}
1004task startDB(){
1005 doLast {
1006 startDB()
1007 }
1008}
1009def stopDB(){
1010 execSafe {
1011 ssh.settings {
1012 knownHosts = allowAnyHosts
1013 }
1014 ssh.run {
1015 session(remotes.vagrant) {
1016 execute command[DB][STOP]()
1017 }
1018 }
1019 }
1020}
1021task stopDB(){
1022 doLast {
1023 stopDB()
1024 }
1025}
1026def startFE(){
1027 execSafe {
1028 ssh.settings {
1029 knownHosts = allowAnyHosts
1030 }
1031 ssh.run {
1032 session(remotes.vagrant) {
1033 execute command[FRONTEND][START]()
1034 }
1035 }
1036 }
1037}
1038task startFE(){
1039 doLast {
1040 startFE()
1041 }
1042}
1043def stopFE(){
1044 execSafe {
1045 ssh.settings {
1046 knownHosts = allowAnyHosts
1047 }
1048 ssh.run {
1049 session(remotes.vagrant) {
1050 execute command[FRONTEND][STOP]()
1051 }
1052 }
1053 }
1054}
1055task stopFE(){
1056 doLast {
1057 stopFE()
1058 }
1059}
1060
1061def ActionListener newListener( closure ){
1062 ActionListener listener = new ActionListener() {
1063 public void actionPerformed(ActionEvent e) {
1064 try {
1065 closure()
1066 } catch (AWTException e1) {
1067 System.err.println(e1);
1068 }
1069 }
1070 }
1071
1072 listener
1073}
1074
1075ext.updateTray = { STATUS status ->
1076 lastStatus = status
1077 if (SystemTray.isSupported()) {
1078 // get the SystemTray instance
1079 SystemTray tray = SystemTray.getSystemTray();
1080 // load an image
1081 String imageName = status==STATUS.UP ? (Math.random()>0.5 ?'okImg1':'okImg2') : status==STATUS.UNAVAILABLE ? 'unavailableImg' : status==STATUS.DOWN ? 'errorImg' : 'warnImg'
1082 Image image = convert imageName
1083 if (trayIcon != null) {
1084 trayIcon.setImage(image)
1085 refreshMenu(imageName);
1086 return ;
1087 }
1088 //region -> Menu UI
1089 // create a popup menu
1090 PopupMenu popup = new PopupMenu();
1091 // create menu item for the default action
1092
1093 MenuItem hotswapItem = new MenuItem("===> WAR <===");
1094 hotswapItem.setFont(new Font("MONOSPACED" , Font.BOLD ,15f ))
1095
1096 //region Multilevel Menus
1097 Menu deployMasterMenu = new Menu("DeployMaster");
1098 Menu backendMenu = new Menu("Backend");
1099 Menu frontendMenu = new Menu("Frontend");
1100 Menu dbMenu = new Menu("Database");
1101 try{
1102 deployMasterMenu.setFont(new Font("Cooper Black" ,Font.BOLD ,14f ))
1103 backendMenu.setFont(new Font("Cooper Black" ,Font.PLAIN ,13f ))
1104 frontendMenu.setFont(new Font("Cooper Black" ,Font.PLAIN ,13f ))
1105 dbMenu.setFont(new Font("Cooper Black" ,Font.PLAIN ,13f ))
1106 }catch(Exception e){
1107 println e
1108 }
1109
1110 //DeployMaster Menu
1111 MenuItem updaterBeWithDependenciesItem = new MenuItem("[BE] Quick Compile -> Deploy");
1112 MenuItem updaterFullBeItem = new MenuItem("[BE] Full Install -> Deploy");
1113 MenuItem updaterFeItem = new MenuItem("[FE] Quick Compile -> Deploy");
1114 MenuItem updaterFullFeItem = new MenuItem("[FE] Full Install -> Deploy");
1115
1116 //Menu UI build
1117
1118 deployMasterMenu.add(updaterFullBeItem);
1119 deployMasterMenu.add(updaterBeWithDependenciesItem);
1120
1121 deployMasterMenu.addSeparator();
1122 deployMasterMenu.add(updaterFullFeItem);
1123 deployMasterMenu.add(updaterFeItem);
1124
1125
1126 //BE menu
1127 MenuItem startItem = new MenuItem("[BE] Start");
1128 MenuItem stopItem = new MenuItem("[BE] Stop BackEnd");
1129 MenuItem copyBeWarItem = new MenuItem("[BE] Copy War");
1130 backendMenu.add(startItem);
1131 backendMenu.add(stopItem);
1132 backendMenu.add(copyBeWarItem);
1133
1134 //FE menu
1135 MenuItem startFEItem = new MenuItem("[FE] Start");
1136 MenuItem stopFEItem = new MenuItem("[FE] Stop");
1137 MenuItem copyFeWarItem = new MenuItem("[FE] Copy War");
1138 frontendMenu.add(startFEItem);
1139 frontendMenu.add(stopFEItem);
1140 frontendMenu.add(copyFeWarItem);
1141
1142 //DB menu
1143 MenuItem startDBItem = new MenuItem("[DB] Start");
1144 MenuItem stopDBItem = new MenuItem("[DB] Stop");
1145 MenuItem backupDBItem = new MenuItem("[DB] Backup");
1146 MenuItem restoreDBItem = new MenuItem("[DB] Restore");
1147 dbMenu.add(startDBItem);
1148 dbMenu.add(stopDBItem);
1149 dbMenu.add(backupDBItem);
1150 dbMenu.add(restoreDBItem);
1151 //endregion
1152
1153
1154 MenuItem killItem = new MenuItem("Kill All");
1155 MenuItem startAllItem = new MenuItem("Start All");
1156 MenuItem importItem = new MenuItem("Import Normative");
1157 MenuItem healthInfoItem = new MenuItem("[Info] Health");
1158 MenuItem toggleHealthItem = new MenuItem(toggleHealthString);
1159 MenuItem logsItem = new MenuItem("Logs [Beta]");
1160 MenuItem exitItem = new MenuItem("Exit");
1161
1162 toggleHealthItemView = toggleHealthItem;
1163
1164 popup.add(hotswapItem);
1165 popup?.addSeparator();
1166 popup.add(deployMasterMenu);
1167 popup?.addSeparator();
1168 popup.add(backendMenu)
1169 popup.add(frontendMenu)
1170 popup.add(dbMenu)
1171 popup?.addSeparator();
1172 popup.add(startAllItem);
1173 popup.add(killItem);
1174 popup?.addSeparator();
1175 popup.add(toggleHealthItem);
1176 popup.add(healthInfoItem);
1177 popup?.addSeparator();
1178 popup.add(importItem);
1179 popup.add(logsItem);
1180 popup?.addSeparator();
1181 popup.add(exitItem);
1182 //endregion UI
1183 // construct a TrayIcon
1184 trayIcon = new TrayIcon(image, "HealthTray", popup);
1185
1186 //region -> Button actions
1187 def listenerHotswap = newListener { project.ext.set("IS_HOTSWAP", !IS_HOTSWAP); hotswapItem?.setLabel( IS_HOTSWAP ? "==> HotSwap <==" : "===> WAR <===") }
1188 // create a action listener to listen for default action executed on the tray icon
1189 def listenerFullBE = newListener { parallel { install_BE(); IS_HOTSWAP ? copyExplodedBE() : copyBE(); restartBackend() } }
1190 def listenerFullFE = newListener { parallel { install_FE(); copyFE() } }
1191 ActionListener listenerFE = newListener { parallel { updaterFE() } }
1192 ActionListener listenerBE = newListener { parallel { updaterBE() } }
1193 ActionListener exitListener = newListener {
1194 executor?.isShutdown() ?: executor?.shutdown()
1195 tray.remove(trayIcon);
1196 project.ext.set("isStopHealthCheck", true)
1197 println "Shutting down.. bye bye.."
1198 }
1199 ActionListener stopBackendListener = newListener { stopBackend() }
1200 ActionListener startBEListener = newListener { parallel { startBackend() } }
1201 ActionListener killJavaListener = newListener { killJava() }
1202
1203 ActionListener startAllListener = newListener { parallel { startAll() } }
1204
1205 ActionListener listener5 = new ActionListener() {
1206 public void actionPerformed(ActionEvent e) {
1207 try {
1208 parallel { importNormative() }
1209 } catch (AWTException e1) {
1210 System.err.println(e1);
1211 }
1212 }
1213 };
1214
1215 ActionListener listener6 = new ActionListener() {
1216 public void actionPerformed(ActionEvent e) {
1217 try {
1218 parallel { healthPopup() }
1219 } catch (AWTException e1) {
1220 System.err.println(e1);
1221 }
1222 }
1223 };
1224
1225 ActionListener listener7 = new ActionListener() {
1226 public void actionPerformed(ActionEvent e) {
1227 try {
1228 logBE()//tasks.logger.execute()
1229 } catch (AWTException e1) {
1230 System.err.println(e1);
1231 }
1232 }
1233 };
1234 ActionListener listener8 = new ActionListener() {
1235 public void actionPerformed(ActionEvent e) {
1236 try {
1237 toggleHealthPolling()//tasks.logger.execute()
1238 } catch (AWTException e1) {
1239 System.err.println(e1);
1240 }
1241 }
1242 };
1243 ActionListener copyBeWarListener = new ActionListener() {
1244 public void actionPerformed(ActionEvent e) {
1245 try {
1246 parallel { copyBE() }//.execute()//tasks.logger.execute()
1247 } catch (AWTException e1) {
1248 System.err.println(e1);
1249 }
1250 }
1251 };
1252
1253 ActionListener startDBListener = new ActionListener() {
1254 public void actionPerformed(ActionEvent e) {
1255 try {
1256 parallel {
1257 startDB()
1258 }//tasks.logger.execute()
1259 } catch (AWTException e1) {
1260 System.err.println(e1);
1261 }
1262 }
1263 }
1264
1265 ActionListener stopDBListener = new ActionListener() {
1266 public void actionPerformed(ActionEvent e) {
1267 try {
1268 stopDB()//tasks.logger.execute()
1269 } catch (AWTException e1) {
1270 System.err.println(e1);
1271 }
1272 }
1273 }
1274
1275 ActionListener dbBackupListener = new ActionListener() {
1276 public void actionPerformed(ActionEvent e) {
1277 try {
1278 parallel {
1279 backupDB()//tasks.logger.execute()
1280 }
1281 } catch (AWTException e1) {
1282 System.err.println(e1);
1283 }
1284 }
1285 }
1286
1287 ActionListener feStartListener = new ActionListener() {
1288 public void actionPerformed(ActionEvent e) {
1289 try {
1290 parallel {
1291 startFE()
1292 }//tasks.logger.execute()
1293 } catch (AWTException e1) {
1294 System.err.println(e1);
1295 }
1296 }
1297 }
1298
1299 ActionListener feStopListener = new ActionListener() {
1300 public void actionPerformed(ActionEvent e) {
1301 try {
1302 stopFE()//tasks.logger.execute()
1303 } catch (AWTException e1) {
1304 System.err.println(e1);
1305 }
1306 }
1307 }
1308
1309 ActionListener feCopyListener = new ActionListener() {
1310 public void actionPerformed(ActionEvent e) {
1311 try {
1312 parallel {
1313 copyFE() //.execute()//tasks.logger.execute()
1314 }
1315 } catch (AWTException e1) {
1316 System.err.println(e1);
1317 }
1318 }
1319 }
1320
1321
1322 //def listenerFullModules = newListener { parallel { installAllProject() } }
1323 //region -> Button<=Listener
1324 hotswapItem.addActionListener(listenerHotswap)
1325 updaterFeItem.addActionListener(listenerFE)
1326 updaterFullBeItem.addActionListener( listenerFullBE )
1327 updaterBeWithDependenciesItem.addActionListener( listenerBE )
1328 updaterFullFeItem.addActionListener( listenerFullFE )
1329 stopItem.addActionListener(stopBackendListener)
1330 startItem.addActionListener(startBEListener)
1331 copyBeWarItem.addActionListener(copyBeWarListener);
1332 killItem.addActionListener(killJavaListener)
1333 startAllItem.addActionListener(startAllListener)
1334 importItem.addActionListener(listener5)
1335 healthInfoItem.addActionListener(listener6)
1336 toggleHealthItem.addActionListener(listener8)
1337 logsItem.addActionListener(listener7)
1338 exitItem.addActionListener(exitListener)
1339
1340 startDBItem.addActionListener( startDBListener )
1341 stopDBItem.addActionListener( stopDBListener )
1342 backupDBItem.addActionListener( dbBackupListener )
1343 copyFeWarItem.addActionListener( feCopyListener )
1344 startFEItem.addActionListener( feStartListener )
1345 stopFEItem.addActionListener( feStopListener )
1346 //endregion
1347 //endregion
1348 // set the TrayIcon properties
1349
1350 // ...
1351 // add the tray image
1352 try {
1353 tray.add(trayIcon);
1354
1355 } catch (AWTException e) {
1356 System.err.println(e);
1357 }
1358 // ...
1359 } else {
1360 println "Java TrayIcon Option is not supported in your System, try enabling it. Bye Bye"
1361 }
1362
1363}
1364
1365def prepareTray(){
1366 long UPDATE_THRESHOLD = 3500
1367 float SCALAR = 1
1368 ssh.settings {
1369 knownHosts = allowAnyHosts
1370 }
1371 while(!isStopHealthCheck) {
1372 if (!isHaltHealth.get()) { //if await or await is more then 60 second return health check
1373 ssh.run {
1374 session(remotes.vagrant) {
1375 try {
1376 def healthOutput = execute command[ALL][HEALTH]()
1377 if (healthOutput?.contains("Failed command .* with status 7") || healthOutput?.contains("Problem accessing /sdc2/rest/healthCheck"))
1378 updateTray(STATUS.DOWN)
1379 def statusCollecion = healthOutput?.findAll "\"healthCheckStatus\": \".*\""
1380 def upCount = statusCollecion?.count { it?.contains("UP") }
1381 def downCount = statusCollecion?.count { it?.contains("DOWN") }
1382 def uknownCount = (statusCollecion?.size() - upCount) - downCount
1383 println " UP -> $upCount | downCount=$downCount | uknownCount=$uknownCount "
1384 (uknownCount > 0 || (downCount > 0 && upCount > 0)) ? updateTray(STATUS.UNKNOWN) : ((upCount > 0) ? updateTray(STATUS.UP) : updateTray(STATUS.DOWN))
1385 SCALAR = 1
1386 } catch (Exception e) {
1387 updateTray(STATUS.DOWN)
1388 println e
1389 SCALAR = Math.min(SCALAR * 1.1, 5) //slow down on errors
1390 }
1391 //green color effects
1392 if (lastStatus && lastStatus == STATUS.UP) {
1393 trayIcon.setImage(convert(Math.random() > 0.5 ? 'okImg1' : 'okImg2'))
1394 //randomly green change color
1395 }
1396 Thread.yield()
1397 Thread?.sleep((long) (UPDATE_THRESHOLD * SCALAR))
1398 }
1399 }
1400 }else{
1401 updateTray(STATUS.UNAVAILABLE)
1402 Thread.yield()
1403 }
1404 }
1405}
1406
1407def healthPopup(){
1408 ssh.run {
1409 session(remotes.vagrant) {
1410 def healthOutput = execute command[ALL][HEALTH]()
1411 JOptionPane.showMessageDialog(null,
1412 healthOutput,
1413 "HEALTH",
1414 JOptionPane.INFORMATION_MESSAGE);
1415 }
1416 }
1417}
1418
1419project.ext.set("msg", { content -> """
1420 ************************************************************************************************
1421 ************************************************************************************************
1422 ******* *********
1423 ************** ****************
1424 $content
1425
1426 ************************************************************************************************
1427 ************************************************************************************************
1428 """} )