WsDeployService.cpp 249 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445
  1. /*##############################################################################
  2. HPCC SYSTEMS software Copyright (C) 2012 HPCC Systems.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. ############################################################################## */
  13. #pragma warning (disable : 4786)
  14. #include "WsDeployService.hpp"
  15. #include "WsDeployEngine.hpp"
  16. #include "jwrapper.hpp"
  17. #include "daclient.hpp"
  18. #include "dadfs.hpp"
  19. #include "jencrypt.hpp"
  20. #ifdef _WINDOWS
  21. #include <winsock2.h>
  22. #define strlwr _strlwr
  23. #endif
  24. #define STANDARD_CONFIG_BACKUPDIR CONFIG_DIR"/backup"
  25. #define STANDARD_CONFIG_SOURCEDIR CONFIG_DIR
  26. #define STANDARD_CONFIG_BUILDSETFILE "buildset.xml"
  27. #define STANDARD_CONFIG_CONFIGXML_DIR "/componentfiles/configxml/"
  28. #define STANDARD_CONFIG_STAGED_PATH "/etc/HPCCSystems/environment.xml"
  29. #define DEFAULT_DIRECTORIES "<Directories name=\""DIR_NAME"\">\
  30. <Category dir=\""EXEC_PREFIX"/log/[NAME]/[INST]\" name=\"log\"/>\
  31. <Category dir=\""EXEC_PREFIX"/lib/[NAME]/[INST]\" name=\"run\"/>\
  32. <Category dir=\""CONFIG_PREFIX"/[NAME]/[INST]\" name=\"conf\"/>\
  33. <Category dir=\""EXEC_PREFIX"/lib/[NAME]/[INST]/temp\" name=\"temp\"/> \
  34. <Category dir=\""EXEC_PREFIX"/lib/[NAME]/hpcc-data/[COMPONENT]\" name=\"data\"/> \
  35. <Category dir=\""EXEC_PREFIX"/lib/[NAME]/hpcc-data2/[COMPONENT]\" name=\"data2\"/> \
  36. <Category dir=\""EXEC_PREFIX"/lib/[NAME]/hpcc-data3/[COMPONENT]\" name=\"data3\"/> \
  37. <Category dir=\""EXEC_PREFIX"/lib/[NAME]/hpcc-mirror/[COMPONENT]\" name=\"mirror\"/> \
  38. <Category dir=\""EXEC_PREFIX"/lib/[NAME]/queries/[INST]\" name=\"query\"/> \
  39. <Category dir=\""EXEC_PREFIX"/lock/[NAME]/[INST]\" name=\"lock\"/> \
  40. </Directories>"
  41. #include <vector>
  42. using namespace std;
  43. typedef vector<IPropertyTree*> IPropertyTreePtrArray;
  44. bool CCloudTaskThread::s_abort = false;
  45. bool supportedInEEOnly()
  46. {
  47. throw MakeStringException(-1, "This operation is supported in Enterprise and above editions only. Please contact HPCC Systems at http://www.hpccsystems.com/contactus");
  48. }
  49. void substituteParameters(const IPropertyTree* pEnv, const char *xpath, IPropertyTree* pNode, StringBuffer& result)
  50. {
  51. const char* xpathorig = xpath;
  52. while (*xpath)
  53. {
  54. if (*xpath=='$')
  55. {
  56. if (strncmp(xpath, "$build", 6)==0)
  57. {
  58. result.append('\"');
  59. result.append(pNode->queryProp(XML_ATTR_BUILD));
  60. result.append('\"');
  61. xpath+=6;
  62. }
  63. else if (strncmp(xpath, "$model", 6)==0)
  64. {
  65. result.append("Model");
  66. const char *datamodel = pNode->queryProp("@dataModel");
  67. if (datamodel)
  68. {
  69. result.append("[@name=\"");
  70. result.append(datamodel);
  71. result.append("\"]");
  72. }
  73. xpath+=6;
  74. }
  75. else if (strncmp(xpath, "$parentmodel", 12)==0)
  76. {
  77. // Find the model that I am in - HACK
  78. result.append( "Model");
  79. const char *datamodel = NULL;
  80. const IPropertyTree *root = pEnv;
  81. IPropertyTree *current = pNode;
  82. Owned<IPropertyTreeIterator> allModels = root->getElements("Data/Model");
  83. ForEach(*allModels)
  84. {
  85. IPropertyTree &model = allModels->query();
  86. Owned<IPropertyTreeIterator> children = model.getElements("*");
  87. ForEach(*children)
  88. {
  89. if (&children->query()==current)
  90. {
  91. datamodel = model.queryProp("@name");
  92. break;
  93. }
  94. }
  95. if (datamodel)
  96. break;
  97. }
  98. if (datamodel)
  99. {
  100. result.append("[@name=\"");
  101. result.append(datamodel);
  102. result.append("\"]");
  103. }
  104. xpath+=12;
  105. }
  106. else if (strncmp(xpath, "$./*", 4) == 0)
  107. {
  108. String xpath2(xpath+4);
  109. StringBuffer sb(xpath2);
  110. String xpath3(xpathorig);
  111. String* pstr = xpath3.substring(xpath3.lastIndexOf('[', xpath3.indexOf("$./*")) + 1, xpath3.indexOf("$./*"));
  112. int pos1 = xpath2.indexOf(']');
  113. int pos2 = xpath2.lastIndexOf('/');
  114. if (pos1 != -1 && pos2 != -1)
  115. sb.clear().append(xpath2.substring(0, pos2)->toCharArray());
  116. else if (pos1 != -1)
  117. sb.clear().append(xpath2.substring(0, pos1)->toCharArray());
  118. Owned<IPropertyTreeIterator> elems = pNode->getElements(sb.str());
  119. if (pos2 != -1)
  120. sb.clear().append(xpath2.substring(pos2+ 1, pos1)->toCharArray());
  121. ForEach(*elems)
  122. {
  123. IPropertyTree* elem = &elems->query();
  124. result.append('\"');
  125. result.append(elem->queryProp(sb.str()));
  126. result.append("\"").append("][").append(pstr->toCharArray());
  127. }
  128. result.setLength(result.length() - pstr->length() - 2);
  129. delete pstr;
  130. xpath+=pos1+4;
  131. }
  132. else if (strncmp(xpath, "$./", 3) == 0)
  133. {
  134. String xpath2(xpath+3);
  135. StringBuffer sb(xpath2);
  136. int pos = xpath2.indexOf(']');
  137. if (pos != -1)
  138. sb.clear().append(xpath2.substring(0, pos)->toCharArray());
  139. result.append('\"');
  140. result.append(pNode->queryProp(sb.str()));
  141. result.append('\"');
  142. xpath+=pos+3; //skip past $./ and xpath2
  143. }
  144. else
  145. result.append(*xpath++);
  146. }
  147. else
  148. result.append(*xpath++);
  149. }
  150. }
  151. void expandRange(IPropertyTree* pComputers)
  152. {
  153. if (pComputers && pComputers->hasProp("@hasrange"))
  154. {
  155. if(!strcmp(pComputers->queryProp("@hasrange"), "true"))
  156. {
  157. Owned<IPropertyTreeIterator> rangeIter = pComputers->getElements("ComputerRange");
  158. ForEach(*rangeIter)
  159. {
  160. StringArray ipList;
  161. IPropertyTree* pEachComp = &rangeIter->query();
  162. formIPList(pEachComp->queryProp(XML_ATTR_NETADDRESS), ipList);
  163. for(unsigned i = 0 ; i < ipList.ordinality(); i++)
  164. {
  165. IPropertyTree* pElem = pComputers->addPropTree(XML_TAG_COMPUTER,createPTree());
  166. pElem->addProp(XML_ATTR_NETADDRESS,ipList.item(i));
  167. }
  168. pComputers->removeTree(pEachComp);
  169. }
  170. pComputers->removeProp("@hasrange");
  171. }
  172. }
  173. }
  174. CConfigHelper::CConfigHelper()
  175. {
  176. }
  177. CConfigHelper::~CConfigHelper()
  178. {
  179. }
  180. void CConfigHelper::init(const IPropertyTree *cfg, const char* esp_name)
  181. {
  182. StringBuffer xpath;
  183. xpath.clear().appendf("%s/%s/%s[%s='%s']/%s",XML_TAG_SOFTWARE, XML_TAG_ESPPROCESS, XML_TAG_ESPSERVICE, XML_ATTR_NAME, esp_name, XML_TAG_LOCALCONFFILE);
  184. m_strConfFile = cfg->queryProp(xpath.str());
  185. xpath.clear().appendf("%s/%s/%s[%s='%s']/%s",XML_TAG_SOFTWARE, XML_TAG_ESPPROCESS, XML_TAG_ESPSERVICE, XML_ATTR_NAME, esp_name, XML_TAG_LOCALENVCONFFILE);
  186. m_strEnvConfFile = cfg->queryProp(xpath.str());
  187. if (m_strConfFile.length() > 0 && m_strEnvConfFile.length() > 0)
  188. {
  189. Owned<IProperties> pParams = createProperties(m_strConfFile);
  190. Owned<IProperties> pEnvParams = createProperties(m_strEnvConfFile);
  191. m_strConfigXMLDir = pEnvParams->queryProp(TAG_PATH);
  192. if ( m_strConfigXMLDir.length() == 0)
  193. {
  194. m_strConfigXMLDir = INSTALL_DIR;
  195. }
  196. m_strBuildSetFileName = pParams->queryProp(TAG_BUILDSET);
  197. m_strBuildSetFilePath.append(m_strConfigXMLDir).append(STANDARD_CONFIG_CONFIGXML_DIR).append( m_strBuildSetFileName.length() > 0 ? m_strBuildSetFileName : STANDARD_CONFIG_BUILDSETFILE);
  198. m_pDefBldSet.set(createPTreeFromXMLFile(m_strBuildSetFilePath.str()));
  199. }
  200. }
  201. bool CConfigHelper::isInBuildSet(const char* comp_process_name, const char* comp_name) const
  202. {
  203. StringBuffer xpath;
  204. xpath.appendf("./%s/%s/%s[%s=\"%s\"][%s=\"%s\"]", XML_TAG_PROGRAMS, XML_TAG_BUILD, XML_TAG_BUILDSET, XML_ATTR_PROCESS_NAME, comp_process_name, XML_ATTR_NAME, comp_name);
  205. if (strcmp(XML_TAG_DIRECTORIES,comp_name) != 0 && m_pDefBldSet->queryPropTree(xpath.str()) == NULL)
  206. {
  207. return false;
  208. }
  209. else
  210. {
  211. return true;
  212. }
  213. }
  214. CWsDeployExCE::~CWsDeployExCE()
  215. {
  216. m_pCfg.clear();
  217. closeEnvironment();
  218. closedownClientProcess();
  219. HashIterator iter(m_fileInfos);
  220. ForEach(iter)
  221. {
  222. IMapping &cur = iter.query();
  223. CWsDeployFileInfo* pInfo = m_fileInfos.mapToValue(&cur);
  224. pInfo->Release();
  225. }
  226. m_fileInfos.kill();
  227. }
  228. IPropertyTree* CWsDeployFileInfo::getEnvTree(IEspContext &context, IConstWsDeployReqInfo *reqInfo)
  229. {
  230. StringBuffer sbName, sbUserIp;
  231. if (reqInfo)
  232. sbName.clear().append(reqInfo->getUserId());
  233. context.getPeer(sbUserIp);
  234. if (m_userWithLock.length() && !strcmp(sbName.str(), m_userWithLock.str()) && !strcmp(sbUserIp.str(), m_userIp.str()) && m_Environment != NULL)
  235. return &m_Environment->getPTree();
  236. else
  237. return &m_constEnvRdOnly->getPTree();
  238. }
  239. void CWsDeployFileInfo::activeUserNotResponding()
  240. {
  241. m_activeUserNotResp = true;
  242. }
  243. void CWsDeployExCE::init(IPropertyTree *cfg, const char *process, const char *service)
  244. {
  245. if (m_lastStarted.isNull())
  246. m_lastStarted.setNow();
  247. if (m_pCfg.get() == NULL)
  248. m_pCfg.setown(createPTreeFromIPT(cfg));
  249. if (m_process.length() == 0)
  250. m_process.append(process);
  251. if (m_service.length() == 0)
  252. m_service.append(service);
  253. m_bCloud = false;
  254. StringBuffer xpath;
  255. m_envFile.clear();
  256. m_configHelper.init(cfg,service);
  257. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalEnvConfFile", service);
  258. const char* tmp = cfg->queryProp(xpath.str());
  259. if (tmp && *tmp)
  260. {
  261. Owned<IProperties> pParams = createProperties(tmp);
  262. m_sourceDir.clear().append(pParams->queryProp("sourcedir"));
  263. if (!m_sourceDir.length())
  264. m_sourceDir.clear().append(STANDARD_CONFIG_SOURCEDIR);
  265. m_backupDir.clear().append(m_sourceDir).append(PATHSEPSTR"backup");
  266. }
  267. if (m_backupDir.length() == 0)
  268. m_backupDir.clear().append(STANDARD_CONFIG_BACKUPDIR);
  269. if (!m_sourceDir.length())
  270. m_sourceDir.clear().append(STANDARD_CONFIG_SOURCEDIR);
  271. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalEnvFile", service);
  272. const char* pEnvFile = cfg->queryProp(xpath.str());
  273. if (pEnvFile && *pEnvFile)
  274. {
  275. CWsDeployFileInfo* fi = m_fileInfos.getValue(pEnvFile);
  276. StringBuffer sb;
  277. if (!fi)
  278. {
  279. synchronized block(m_mutexSrv);
  280. StringBuffer filePath(pEnvFile);
  281. if (strstr(pEnvFile, m_sourceDir.str()) != pEnvFile)
  282. {
  283. filePath.clear().append(m_sourceDir);
  284. filePath.append(PATHSEPCHAR);
  285. filePath.append(pEnvFile);
  286. }
  287. fi = new CWsDeployFileInfo(this, filePath.str(), m_bCloud);
  288. const char* psz = strrchr(pEnvFile, PATHSEPCHAR);
  289. if (!psz)
  290. psz = strrchr(pEnvFile, PATHSEPCHAR == '\\' ? '/' : '\\');
  291. if (!psz)
  292. sb.append(pEnvFile);
  293. else
  294. sb.append(psz + 1);
  295. m_fileInfos.setValue(sb.str(), fi);
  296. }
  297. try
  298. {
  299. fi->initFileInfo(false);
  300. }
  301. catch (IException* e)
  302. {
  303. m_fileInfos.remove(sb.str());
  304. delete fi;
  305. e->Release();
  306. }
  307. m_envFile.append(pEnvFile);
  308. }
  309. }
  310. bool CWsDeployFileInfo::navMenuEvent(IEspContext &context,
  311. IEspNavMenuEventRequest &req,
  312. IEspNavMenuEventResponse &resp)
  313. {
  314. synchronized block(m_mutex);
  315. checkForRefresh(context, &req.getReqInfo(), false);
  316. const char* cmd = req.getCmd();
  317. const char* xmlArg = req.getXmlArgs();
  318. if (!cmd || !*cmd)
  319. throw ::MakeStringException(-1, "Invalid command specified!");
  320. if (!strcmp(cmd, "LockEnvironment"))
  321. {
  322. StringBuffer sbName, sbUserIp;
  323. sbName.clear().append(req.getReqInfo().getUserId());
  324. context.getPeer(sbUserIp);
  325. if (!strcmp(sbName.str(), m_userWithLock.str()) && !strcmp(sbUserIp.str(), m_userIp.str()))
  326. throw MakeStringException(-1, "Another browser window already has write access on machine '%s'. Please use that window.", sbUserIp.str());
  327. }
  328. else if (strcmp(cmd, "SaveEnvironmentAs"))
  329. checkForRefresh(context, &req.getReqInfo(), true);
  330. if (!stricmp(cmd, "Deploy"))
  331. {
  332. /* xmlArg for is of the form:
  333. <EspNavigationData>
  334. <Folder name="Environment">
  335. <Folder name="Software">
  336. <Folder name="EspProcesses">
  337. <Link name="ESP Process - esp1" selected="true"/>
  338. <Link name="ESP Process - esp2" selected="true"/>
  339. </Folder>
  340. <Folder name="EclServerProcess - eclserver" selected="true"/>
  341. </Folder>
  342. </Folder>
  343. </EspNavigationData>
  344. There are one or more attributes and modules marked as @selected
  345. so enumerate these selected nodes and produce xml of the form:
  346. <Deploy>
  347. <SelectedComponents>
  348. <EspProcess name="esp1"/>//deploy all instances
  349. <EspProcess name="esp2"/>
  350. <Instance name="s1" computer="2wd20"/> //deploy selected instances only
  351. </EspProcess>
  352. </SelectedComponents>
  353. </Deploy>
  354. */
  355. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  356. IPropertyTree* pEnvSoftware = pEnvRoot->queryPropTree(XML_TAG_SOFTWARE);
  357. Owned<IPropertyTree> pDeploy = createPTree("Deploy");
  358. IPropertyTree* pComponents = pDeploy->addPropTree("Components", createPTree());
  359. if (pEnvSoftware)
  360. {
  361. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  362. IPropertyTree* pSoftwareFolder = pSrcTree->queryPropTree("Folder[@name='Environment']/Folder[@name='Software']");
  363. if (pSoftwareFolder)
  364. {
  365. bool bSelected = pSoftwareFolder->getPropBool("@selected", false);
  366. if (bSelected)
  367. {
  368. Owned<IPropertyTreeIterator> iComp = pEnvSoftware->getElements("*", iptiter_sort );
  369. ForEach(*iComp)
  370. addDeployableComponentAndInstances(pEnvRoot, &iComp->query(), pComponents, NULL, NULL);
  371. }
  372. else
  373. {
  374. Owned<IPropertyTreeIterator> iFolder = pSoftwareFolder->getElements( "*" );
  375. ForEach (*iFolder)
  376. {
  377. IPropertyTree* pFolder = &iFolder->query();
  378. bool bSelected = pFolder->getPropBool("@selected", false);
  379. const char* szFolderName = pFolder->queryProp(XML_ATTR_NAME);
  380. if (strstr(szFolderName, " - ") != NULL)
  381. {
  382. IPropertyTree* pCompInEnv = findComponentForFolder(pFolder, pEnvSoftware);
  383. if (pCompInEnv)
  384. addDeployableComponentAndInstances(pEnvRoot, pCompInEnv, pComponents, pFolder, NULL);
  385. }
  386. else if (!strcmp(szFolderName, "ECL Servers"))
  387. {
  388. Owned<IPropertyTreeIterator> iSubFolder = pFolder->getElements( "*" );
  389. ForEach (*iSubFolder)
  390. {
  391. IPropertyTree* pSubFolder = &iSubFolder->query();
  392. IPropertyTree* pCompInEnv = findComponentForFolder(pSubFolder, pEnvSoftware);
  393. if (pCompInEnv)
  394. addDeployableComponentAndInstances(pEnvRoot, pCompInEnv, pComponents, pSubFolder, NULL);
  395. }
  396. }
  397. else
  398. {
  399. //this folder bundles multiple components and has name like "ESP Servers"
  400. //
  401. if (bSelected)
  402. {
  403. //if selected, deploy all its components like deploy all ESP servers
  404. //
  405. const char* params = pFolder->queryProp("@params");
  406. if (params)
  407. {
  408. // pFolder's @params has string of the form: "comp=EspProcess"
  409. //
  410. Owned<IProperties> pParams = createProperties();
  411. pParams->loadProps(params);
  412. const char* comp = pParams->queryProp("comp");
  413. if (comp && *comp)
  414. {
  415. Owned<IPropertyTreeIterator> iComp = pEnvSoftware->getElements(comp);
  416. ForEach(*iComp)
  417. addDeployableComponentAndInstances(pEnvRoot, &iComp->query(), pComponents, NULL, szFolderName);
  418. }
  419. }
  420. }
  421. else
  422. {
  423. //deploy only selected components under this folder
  424. //
  425. Owned<IPropertyTreeIterator> iFolder = pFolder->getElements("*[@selected='true']");
  426. ForEach(*iFolder)
  427. {
  428. IPropertyTree* pFolder = &iFolder->query();
  429. IPropertyTree* pCompInEnv = findComponentForFolder(pFolder, pEnvSoftware);
  430. if (pCompInEnv)
  431. addDeployableComponentAndInstances(pEnvRoot, pCompInEnv, pComponents, pFolder, szFolderName);
  432. }
  433. }
  434. }
  435. }
  436. }//software folder is not selected
  437. }//pSoftwareFolder
  438. }//pEnvSoftware
  439. StringBuffer xml;
  440. toXML(pDeploy, xml, false);
  441. resp.setComponent( "WsDeploy" );
  442. resp.setCommand ( "Deploy" );
  443. resp.setXmlArgs( xml.str() );
  444. }//deploy
  445. else
  446. if (!stricmp(cmd, "Dependencies"))
  447. {
  448. /* xmlArg for is of the form:
  449. <EspNavigationData>
  450. <Folder name="Environment">
  451. <Folder name="Hardware">
  452. <Folder name="Computers">
  453. <Link name="machine1"/>
  454. <Link name="machine2"/>
  455. </Folder>
  456. </Folder>
  457. </Folder>
  458. </EspNavigationData>
  459. There are one or more attributes and modules marked as @selected
  460. so enumerate these selected nodes and produce xml of the form:
  461. <Deploy>
  462. <SelectedComponents>
  463. <EspProcess name="esp1"/>//deploy all instances
  464. <EspProcess name="esp2"/>
  465. <Instance name="s1" computer="2wd20"/> //deploy selected instances only
  466. </EspProcess>
  467. </SelectedComponents>
  468. </Deploy>
  469. */
  470. Owned<IPropertyTree> pDeploy = createPTree("Deploy");
  471. IPropertyTree* pComponents = pDeploy->addPropTree("Components", createPTree());
  472. if (xmlArg && *xmlArg)
  473. {
  474. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString( xmlArg);
  475. IPropertyTree* pComputersFolder = pSrcTree->queryPropTree("Folder[@name='Environment']/Folder[@name='Hardware']/Folder[@name='Computers']");
  476. if (pComputersFolder)
  477. {
  478. Owned<IPropertyTreeIterator> iLink = pComputersFolder->getElements( "Link" );
  479. ForEach (*iLink)
  480. {
  481. IPropertyTree* pLink = &iLink->query();
  482. const bool bSelected = pLink->getPropBool("@selected", false);
  483. const char* szComputerName = pLink->queryProp(XML_ATTR_NAME);
  484. //this folder bundles multiple components and has name like "ESP Servers"
  485. //
  486. if (bSelected)
  487. {
  488. //deploy all its components like deploy all ESP servers
  489. //addDeployableComponentAndInstances(pEnvRoot, pCompInEnv, pComponents, pFolder, szFolderName);
  490. }
  491. }
  492. }//pSoftwareFolder
  493. }//pEnvSoftware
  494. StringBuffer xml;
  495. toXML(pDeploy, xml, false);
  496. resp.setComponent( "WsDeploy" );
  497. resp.setCommand ( "Deploy" );
  498. resp.setXmlArgs( xml.str() );
  499. }//dependencies
  500. else if (!stricmp(cmd, "LockEnvironment"))
  501. {
  502. StringBuffer xml;
  503. try
  504. {
  505. if (m_userWithLock.length() == 0 || m_activeUserNotResp)
  506. {
  507. StringBuffer sbName, sbUserIp;
  508. sbName.clear().append(req.getReqInfo().getUserId());
  509. context.getPeer(sbUserIp);
  510. if (m_pFile.get() && m_pFile->isReadOnly())
  511. {
  512. xml.appendf("Write access to the Environment cannot be provided as %s is Read Only.", m_envFile.str());
  513. resp.setXmlArgs(xml.str());
  514. return true;
  515. }
  516. if (m_bCloud)
  517. {
  518. StringBuffer sbMsg;
  519. Owned<IPropertyTree> pComputers = createPTreeFromXMLString(xmlArg);
  520. CCloudActionHandler lockCloud(this, CLOUD_LOCK_ENV, CLOUD_UNLOCK_ENV, sbName.str(), "8015", pComputers);
  521. bool ret = lockCloud.start(sbMsg);
  522. if (!ret || sbMsg.length())
  523. {
  524. xml.appendf("Write access to the Environment cannot be provided. Reason(s):\n%s", sbMsg.str());
  525. resp.setXmlArgs(xml.str());
  526. return true;
  527. }
  528. else if (pComputers && pComputers->numChildren())
  529. m_lockedNodesBeforeEnv.set(pComputers);
  530. }
  531. StringBuffer sb;
  532. if (m_userWithLock.length() == 0)
  533. sb.append(sbName).append(sbUserIp);
  534. else
  535. {
  536. sb.append(m_userWithLock).append(m_userIp);
  537. m_userWithLock.clear();
  538. m_userIp.clear();
  539. m_Environment.clear();
  540. m_activeUserNotResp = false;
  541. }
  542. CClientAliveThread* th = m_keepAliveHTable.getValue(sb.str());
  543. if (th)
  544. {
  545. th->Release();
  546. m_keepAliveHTable.remove(sb.str());
  547. }
  548. StringBuffer sbxml;
  549. if (m_pFileIO.get())
  550. {
  551. Owned <IPropertyTree> pTree = createPTree(*m_pFileIO);
  552. toXML(pTree, sbxml);
  553. }
  554. else
  555. toXML(&m_constEnvRdOnly->getPTree(), sbxml);
  556. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  557. m_Environment.setown(factory->loadLocalEnvironment(sbxml.str()));
  558. m_userWithLock.clear().append(req.getReqInfo().getUserId());
  559. context.getPeer(m_userIp.clear());
  560. Owned<IPropertyTree> pEnvRoot = &m_Environment->getPTree();
  561. unsigned timeout = pEnvRoot->getPropInt(XML_TAG_ENVSETTINGS"/brokenconntimeout", 60);
  562. th = new CClientAliveThread(this, timeout * 60 * 1000);
  563. m_keepAliveHTable.setValue(sb.str(), th);
  564. th->init();
  565. StringBuffer tmp;
  566. m_lastSaved.getString(tmp);
  567. resp.setLastSaved(tmp.str());
  568. resp.setComponent( "WsDeploy" );
  569. resp.setCommand ( "LockEnvironment" );
  570. }
  571. else
  572. {
  573. StringBuffer sbName, sbUserIp;
  574. sbName.clear().append(req.getReqInfo().getUserId());
  575. context.getPeer(sbUserIp);
  576. if (strcmp(sbName.str(), m_userWithLock.str()) || strcmp(sbUserIp.str(), m_userIp.str()))
  577. {
  578. xml.appendf("Write access to the Environment cannot be provided as it is currently being used on machine %s.", m_userIp.str());
  579. resp.setXmlArgs(xml.str());
  580. }
  581. }
  582. }
  583. catch (IException* e)
  584. {
  585. StringBuffer sErrMsg;
  586. e->errorMessage(sErrMsg);
  587. e->Release();
  588. if (m_envFile.length())
  589. {
  590. char achHost[128] = "";
  591. const char* p = strstr(sErrMsg.str(), "\n\n");
  592. if (p && *(p+=2))
  593. {
  594. const char* q = strchr(p, ':');
  595. if (q)
  596. {
  597. const int len = q-p;
  598. strncpy(achHost, p, len);
  599. achHost[len] = '\0';
  600. }
  601. }
  602. //resolve hostname for this IP address
  603. unsigned int addr = inet_addr(achHost);
  604. struct hostent* hp = gethostbyaddr((const char*)&addr, sizeof(addr), AF_INET);
  605. if (hp)
  606. {
  607. strcpy(achHost, hp->h_name);
  608. //strlwr(achHost);
  609. }
  610. StringBuffer sMsg;
  611. sMsg.appendf("Error accessing the environment definition");
  612. if (achHost[0])
  613. sMsg.appendf(" \nbecause it is locked by computer '%s'.", achHost);
  614. else
  615. sMsg.append(":\n\n").append(sErrMsg);
  616. throw MakeStringException(0, "%s", sMsg.str());
  617. }
  618. else
  619. {
  620. StringBuffer sMsg;
  621. sMsg.append("Error locking environment. ").append(sErrMsg.str());
  622. throw MakeStringException(-1, "%s", sMsg.str());
  623. }
  624. }
  625. }
  626. else if (!stricmp(cmd, "UnlockEnvironment"))
  627. {
  628. StringBuffer xml;
  629. try
  630. {
  631. StringBuffer sbUser, sbUserIp, errMsg;
  632. context.getUserID(sbUser);
  633. sbUser.clear().append(req.getReqInfo().getUserId());
  634. context.getPeer(sbUserIp);
  635. if (!stricmp(m_userWithLock.str(), sbUser.str()) && !stricmp(sbUserIp.str(), m_userIp.str()))
  636. {
  637. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  638. IPropertyTree* pSaveEnv = pSrcTree->queryPropTree("SaveEnv[@flag='true']");
  639. StringBuffer sbErrMsg;
  640. if (pSaveEnv)
  641. {
  642. StringBuffer sb;
  643. m_skipEnvUpdateFromNotification = true;
  644. saveEnvironment(&context, &req.getReqInfo(), sb);
  645. if (sb.length())
  646. sbErrMsg.appendf("<Warning>%s</Warning>", sb.str());
  647. }
  648. unlockEnvironment(&context, &req.getReqInfo(), xmlArg, sbErrMsg, pSaveEnv != NULL);
  649. if (sbErrMsg.length())
  650. {
  651. resp.setXmlArgs(sbErrMsg.str());
  652. return true;
  653. }
  654. m_skipEnvUpdateFromNotification = false;
  655. StringBuffer tmp;
  656. m_lastSaved.getString(tmp);
  657. resp.setLastSaved(tmp.str());
  658. resp.setComponent( "WsDeploy" );
  659. resp.setCommand ( "UnlockEnvironment" );
  660. }
  661. else
  662. {
  663. xml.appendf("The environment has been locked on machine '%s'", m_userIp.str());
  664. resp.setComponent( "WsDeploy" );
  665. resp.setCommand ( "UnlockEnvironment" );
  666. resp.setXmlArgs( xml.str() );
  667. }
  668. }
  669. catch (IException* e)
  670. {
  671. StringBuffer sErrMsg;
  672. e->errorMessage(sErrMsg);
  673. e->Release();
  674. if (m_envFile.length() == 0)
  675. {
  676. char achHost[128] = "";
  677. const char* p = strstr(sErrMsg.str(), "\n\n");
  678. if (p && *(p+=2))
  679. {
  680. const char* q = strchr(p, ':');
  681. if (q)
  682. {
  683. const int len = q-p;
  684. strncpy(achHost, p, len);
  685. achHost[len] = '\0';
  686. }
  687. }
  688. //resolve hostname for this IP address
  689. unsigned int addr = inet_addr(achHost);
  690. struct hostent* hp = gethostbyaddr((const char*)&addr, sizeof(addr), AF_INET);
  691. if (hp)
  692. {
  693. strcpy(achHost, hp->h_name);
  694. }
  695. StringBuffer sMsg;
  696. sMsg.appendf("The environment definition in dali server "
  697. "could not be opened for write access");
  698. if (achHost[0])
  699. sMsg.appendf(" \nbecause it is locked by computer '%s'.", achHost);
  700. else
  701. sMsg.append(":\n\n").append(sErrMsg);
  702. throw MakeStringException(0, "%s", sMsg.str());
  703. }
  704. else
  705. {
  706. StringBuffer sMsg;
  707. sMsg.append("Error unlocking environment. ").append(sErrMsg.str());
  708. throw MakeStringException(-1, "%s", sMsg.str());
  709. }
  710. }
  711. }
  712. else if (!stricmp(cmd, "SaveEnvironment"))
  713. {
  714. StringBuffer xml;
  715. StringBuffer sbUser, sbIp, sbErrMsg;
  716. sbUser.clear().append(req.getReqInfo().getUserId());
  717. context.getPeer(sbIp);
  718. if (m_userWithLock.length() != 0 && m_userIp.length() != 0 &&
  719. !strcmp(m_userWithLock.str(), sbUser.str()) && !strcmp(m_userIp.str(), sbIp.str()) &&
  720. m_Environment != NULL)
  721. {
  722. saveEnvironment(&context, &req.getReqInfo(), sbErrMsg);
  723. if (sbErrMsg.length())
  724. resp.setXmlArgs(sbErrMsg.str());
  725. StringBuffer tmp;
  726. m_lastSaved.getString(tmp);
  727. resp.setLastSaved(tmp.str());
  728. resp.setComponent( "WsDeploy" );
  729. resp.setCommand ( "SaveEnvironment" );
  730. }
  731. else
  732. {
  733. xml.appendf("The environment has been locked on machine '%s'", m_userIp.str());
  734. resp.setComponent( "WsDeploy" );
  735. resp.setCommand ( "SaveEnvironment" );
  736. resp.setXmlArgs( xml.str() );
  737. }
  738. }
  739. else if (!stricmp(cmd, "SaveEnvironmentAs"))
  740. {
  741. StringBuffer xml;
  742. StringBuffer sbUser, sbIp;
  743. sbUser.clear().append(req.getReqInfo().getUserId());
  744. context.getPeer(sbIp);
  745. const char* xmlArg = req.getXmlArgs();
  746. Owned<IPropertyTree> pParamTree = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  747. const char* envSaveAs = pParamTree->queryProp("@envSaveAs");
  748. if (envSaveAs && *envSaveAs)
  749. {
  750. StringBuffer filePath(m_pService->getSourceDir());
  751. StringBuffer sbErrMsg;
  752. if (filePath.charAt(filePath.length() - 1) != PATHSEPCHAR)
  753. filePath.append(PATHSEPCHAR);
  754. filePath.append(envSaveAs);
  755. if (!strcmp(filePath.str(), m_envFile.str()))
  756. {
  757. if (m_userWithLock.length() != 0 && m_userIp.length() != 0 &&
  758. !strcmp(m_userWithLock.str(), sbUser.str()) && !strcmp(m_userIp.str(), sbIp.str()) &&
  759. m_Environment != NULL)
  760. {
  761. saveEnvironment(&context, &req.getReqInfo(), sbErrMsg);
  762. unlockEnvironment(&context, &req.getReqInfo(), "", sbErrMsg);
  763. if (sbErrMsg.length())
  764. {
  765. resp.setXmlArgs(sbErrMsg.str());
  766. return true;
  767. }
  768. StringBuffer tmp;
  769. m_lastSaved.getString(tmp);
  770. resp.setLastSaved(tmp.str());
  771. resp.setComponent("WsDeploy");
  772. resp.setCommand ("SaveEnvironmentAs");
  773. }
  774. else if (m_userWithLock.length() == 0 && m_userIp.length() == 0)
  775. {
  776. saveEnvironment(&context, &req.getReqInfo(), sbErrMsg, true);
  777. if (sbErrMsg.length())
  778. resp.setXmlArgs(sbErrMsg.str());
  779. StringBuffer tmp;
  780. m_lastSaved.getString(tmp);
  781. resp.setLastSaved(tmp.str());
  782. resp.setComponent("WsDeploy");
  783. resp.setCommand("SaveEnvironmentAs");
  784. }
  785. }
  786. else
  787. {
  788. CWsDeployFileInfo* fi = m_pService->getFileInfo(envSaveAs, true);
  789. StringBuffer sbUser, sbIp, sbXml;
  790. if ( fi->isLocked(sbUser, sbIp) == true)
  791. throw MakeStringException(-1, "%s is locked by another user. File not saved.", envSaveAs);
  792. if (isLocked(sbUser,sbIp) == true) // if we are in write only mode then save the working environment
  793. toXML(&m_Environment->getPTree(), sbXml);
  794. else
  795. toXML(&m_constEnvRdOnly->getPTree(), sbXml);
  796. if (fi->updateEnvironment(sbXml))
  797. fi->saveEnvironment(NULL, &req.getReqInfo(), sbErrMsg, true);
  798. else
  799. throw MakeStringException(-1, "Environment Save as operation has failed");
  800. if (m_userWithLock.length() != 0 && m_userIp.length() != 0)
  801. {
  802. if (sbErrMsg.length())
  803. {
  804. resp.setXmlArgs(sbErrMsg.str());
  805. return true;
  806. }
  807. }
  808. if (sbErrMsg.length())
  809. resp.setXmlArgs(sbErrMsg.str());
  810. StringBuffer tmp;
  811. fi->getLastSaved(tmp);
  812. resp.setLastSaved(tmp.str());
  813. resp.setComponent("WsDeploy");
  814. resp.setCommand("SaveEnvironmentAs");
  815. }
  816. }
  817. else
  818. throw MakeStringException(-1, "File name to save environment as cannot be empty");
  819. }
  820. else if (!stricmp(cmd, "ValidateEnvironment"))
  821. {
  822. StringBuffer xml;
  823. StringBuffer sbUser, sbIp;
  824. sbUser.clear().append(req.getReqInfo().getUserId());
  825. context.getPeer(sbIp);
  826. if (m_userWithLock.length() != 0 && m_userIp.length() != 0 &&
  827. !strcmp(m_userWithLock.str(), sbUser.str()) && !strcmp(m_userIp.str(), sbIp.str()) &&
  828. m_Environment != NULL)
  829. {
  830. if (m_envFile.length())
  831. validateEnv((IConstEnvironment*)m_Environment, false);
  832. resp.setComponent( "WsDeploy" );
  833. resp.setCommand ( "ValidateEnvironment" );
  834. }
  835. else
  836. {
  837. xml.appendf("The environment has been locked on machine '%s'", m_userIp.str());
  838. resp.setComponent( "WsDeploy" );
  839. resp.setCommand ( "SaveEnvironment" );
  840. resp.setXmlArgs( xml.str() );
  841. }
  842. }
  843. else
  844. {
  845. StringBuffer url;
  846. url.append("/WsDeploy/").append(cmd).append("?form");
  847. resp.setRedirectUrl(url.str());
  848. }
  849. return true;
  850. }//onNavMenuEvent
  851. bool CWsDeployFileInfo::isAlphaNumeric(const char *pstr) const
  852. {
  853. RegExpr expr("[A-Za-z0-9-_]+");
  854. return (expr.find(pstr) && expr.findlen(0) == strlen(pstr));
  855. }
  856. bool CWsDeployFileInfo::saveSetting(IEspContext &context, IEspSaveSettingRequest &req, IEspSaveSettingResponse &resp)
  857. {
  858. synchronized block(m_mutex);
  859. checkForRefresh(context, &req.getReqInfo(), true);
  860. const char* xmlArg = req.getXmlArgs();
  861. Owned<IPropertyTree> pEnvRoot = &m_Environment->getPTree();
  862. IPropertyTree* pEnvSoftware = pEnvRoot->queryPropTree(XML_TAG_SOFTWARE);
  863. IPropertyTree* pEnvHardware = pEnvRoot->queryPropTree(XML_TAG_HARDWARE);
  864. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  865. IPropertyTree* pSoftwareFolder = pSrcTree->queryPropTree("Setting[@category='Software']");
  866. IPropertyTree* pTopologyFolder = pSrcTree->queryPropTree("Setting[@category='Topology']");
  867. IPropertyTree* pHardwareFolder = pSrcTree->queryPropTree("Setting[@category='Hardware']");
  868. IPropertyTree* pEnvFolder = pSrcTree->queryPropTree("Setting[@category='Environment']");
  869. if (pSoftwareFolder)
  870. {
  871. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements("Setting[@category='Software']");
  872. ForEach (*iter)
  873. {
  874. IPropertyTree* pSetting = &iter->query();
  875. StringBuffer decodedParams( pSetting->queryProp("@params") );
  876. decodedParams.replaceString("::", "\n");
  877. Owned<IProperties> pParams = createProperties();
  878. pParams->loadProps(decodedParams.str());
  879. const char* pszCompType = pParams->queryProp("pcType");
  880. const char* pszCompName = pParams->queryProp("pcName");
  881. const char* pszSubType = pParams->queryProp("subType");
  882. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  883. const char* pszAttrName = pSetting->queryProp("@attrName");
  884. const char* rowIndex = pSetting->queryProp("@rowIndex");
  885. const char* pszOldValue = pSetting->queryProp("@oldValue");
  886. const char* pszNewValue = pSetting->queryProp("@newValue");
  887. const char* pszOnChange = pSetting->queryProp("@onChange");
  888. const char* pszViewType = pSetting->queryProp("@viewType");
  889. StringBuffer xpath;
  890. xpath.clear().appendf("%s[@name='%s']", pszCompType, pszCompName);
  891. if (pszSubType && pszSubTypeKey && strlen(pszSubTypeKey) > 0)
  892. {
  893. if (pszSubTypeKey[0] == '[' && pszSubTypeKey[strlen(pszSubTypeKey) - 1] == ']')
  894. xpath.appendf("/%s%s", pszSubType, pszSubTypeKey);
  895. else
  896. xpath.appendf("/%s[@name='%s']", pszSubType, pszSubTypeKey);
  897. }
  898. else if (!strcmp(pszCompType, "Topology"))
  899. xpath.appendf("[@name='%s']", pszSubTypeKey);
  900. else if (pszSubType && strlen(rowIndex) > 0)
  901. xpath.appendf("/%s[%s]", pszSubType, rowIndex);
  902. IPropertyTree* pComp = pEnvSoftware->queryPropTree(xpath.str());
  903. if (!pComp)
  904. {
  905. //read any updates to rows that have not been posted to the tree
  906. const char* pszUpdate = NULL;
  907. const char* key = NULL;
  908. int idx = 1;
  909. StringBuffer sbUpdate;
  910. StringBuffer xpath2;
  911. while (true)
  912. {
  913. sbUpdate.clear().appendf("Update%dKey", idx);
  914. key = pParams->queryProp(sbUpdate.str());
  915. if (!key)
  916. break;
  917. else
  918. {
  919. sbUpdate.clear().appendf("Update%dValue", idx);
  920. pszUpdate = pParams->queryProp(sbUpdate.str());
  921. break;
  922. }
  923. idx++;
  924. }
  925. xpath2.clear().appendf("*[@name='%s']", pszCompName);
  926. Owned<IPropertyTreeIterator> iter = pEnvSoftware->getElements(xpath2);
  927. ForEach (*iter)
  928. {
  929. IPropertyTree* pTmpComp = &iter->query();
  930. const char* pProcessName = pTmpComp->queryName();
  931. if (pProcessName && !strcmp(pProcessName, pszCompType))
  932. {
  933. if (pszSubType && pszSubTypeKey && strlen(pszSubTypeKey) > 0)
  934. {
  935. if (pszSubTypeKey[0] == '[' && pszSubTypeKey[strlen(pszSubTypeKey) - 1] == ']')
  936. xpath2.clear().appendf("%s%s", pszSubType, pszSubTypeKey);
  937. else
  938. xpath2.clear().appendf("%s[@name='%s']", pszSubType, pszSubTypeKey);
  939. pComp = pTmpComp->queryPropTree(xpath2.str());
  940. if (!pComp)
  941. {
  942. if (pszUpdate && pszSubType && key)
  943. xpath2.clear().appendf("%s[@%s='%s']", pszSubType, key, pszUpdate);
  944. pComp = pTmpComp->queryPropTree(xpath2.str());
  945. }
  946. }
  947. else if (pszSubType)
  948. {
  949. StringBuffer tmppath;
  950. tmppath.clear().appendf("%s", pszSubType);
  951. pComp = pTmpComp->queryPropTree(tmppath.str());
  952. if (!pComp)
  953. {
  954. if (pszUpdate && key)
  955. {
  956. StringBuffer sbtmp(pszSubType);
  957. StringBuffer sb;
  958. const char* psz = strrchr(pszSubType, '/');
  959. const char* ptmp = pszSubType;
  960. if (psz)
  961. sbtmp.clear().append(psz + 1);
  962. psz = sbtmp.str();
  963. if (strchr(pszSubType, '[') && strchr(pszSubType, ']'))
  964. {
  965. char ch;
  966. bool copy = true;
  967. bool flag = false;
  968. while ((ch = *ptmp++) != '\0')
  969. {
  970. if (ch == '/')
  971. {
  972. flag = true;
  973. break;
  974. }
  975. else if (ch == '[')
  976. copy = false;
  977. else if (ch == ']')
  978. copy = true;
  979. else if (copy)
  980. sb.append(ch);
  981. }
  982. sb.appendf("[@%s='%s']/%s", key, pszUpdate, psz);
  983. }
  984. xpath2.clear().append(sb);
  985. }
  986. pComp = pTmpComp->queryPropTree(xpath2.str());
  987. }
  988. if (!pComp)
  989. {
  990. if (!strcmp(pszCompName, "Directories"))
  991. tmppath.clear().append(pszCompName);
  992. else
  993. tmppath.clear().appendf("%s[@name='%s']", pszCompType, pszCompName);
  994. IPropertyTree* pTmpComp = pEnvSoftware->queryPropTree(tmppath.str());
  995. if (!pTmpComp)
  996. continue;
  997. if (!strcmp(pszCompType, XML_TAG_ESPSERVICE) || !strcmp(pszCompType, XML_TAG_PLUGINPROCESS))
  998. tmppath.clear().appendf("./Programs/Build/BuildSet[@name=\"%s\"]", pTmpComp->queryProp(XML_ATTR_BUILDSET));
  999. else
  1000. tmppath.clear().appendf("./Programs/Build/BuildSet[@processName=\"%s\"]", pszCompType);
  1001. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(tmppath.str());
  1002. buildSetIter->first();
  1003. IPropertyTree* pBuildSet;
  1004. if (buildSetIter->isValid())
  1005. pBuildSet = &buildSetIter->query();
  1006. else if (!strcmp(pszCompType, "Directories"))
  1007. {
  1008. pBuildSet = createPTree(XML_TAG_BUILDSET);
  1009. pBuildSet->addProp(XML_ATTR_NAME, pszCompName);
  1010. pBuildSet->addProp(XML_ATTR_SCHEMA, "directories.xsd");
  1011. pBuildSet->addProp(XML_ATTR_PROCESS_NAME, "Directories");
  1012. }
  1013. const char* buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  1014. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  1015. StringBuffer buildSetPath;
  1016. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  1017. Owned<IPropertyTree> pNewCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName());
  1018. StringBuffer sbtmp(pszSubType);
  1019. StringBuffer sb;
  1020. const char* psz = strrchr(pszSubType, '/');
  1021. if (psz)
  1022. sbtmp.clear().append(psz + 1);
  1023. psz = sbtmp.str();
  1024. if (strchr(psz, '[') && strchr(psz, ']'))
  1025. {
  1026. char ch;
  1027. while ((ch = *psz++) != '\0')
  1028. {
  1029. if (ch != '[')
  1030. sb.append(ch);
  1031. else
  1032. break;
  1033. }
  1034. while ((ch = *psz++) != '\0')
  1035. {
  1036. if (ch == ']')
  1037. break;
  1038. }
  1039. sb.append(psz);
  1040. sbtmp.clear().append(sb);
  1041. }
  1042. Owned<IPropertyTreeIterator> iterElems = pNewCompTree->getElements(sbtmp.str());
  1043. ForEach (*iterElems)
  1044. {
  1045. IPropertyTree* pElem = &iterElems->query();
  1046. if (pElem)
  1047. pComp = pTmpComp->addPropTree(pszSubType, createPTreeFromIPT(pElem));
  1048. else
  1049. pComp = pTmpComp->addPropTree(pszSubType, createPTree());
  1050. break;
  1051. }
  1052. if (!pComp)
  1053. pComp = pTmpComp->addPropTree(pszSubType, createPTree());
  1054. if (pComp && !strcmp(pszAttrName, "name"))
  1055. pComp->setProp(XML_ATTR_NAME, pszNewValue);
  1056. }
  1057. }
  1058. else
  1059. pComp = &iter->query();
  1060. break;
  1061. }
  1062. const char* pBuildSet = pTmpComp->queryProp(XML_ATTR_BUILDSET);
  1063. if (pBuildSet && !strcmp(pBuildSet, pszCompType))
  1064. {
  1065. if (pszSubType && pszSubTypeKey && strlen(pszSubTypeKey) > 0)
  1066. {
  1067. if (pszSubTypeKey[0] == '[' && pszSubTypeKey[strlen(pszSubTypeKey) - 1] == ']')
  1068. xpath2.clear().appendf("%s%s", pszSubType, pszSubTypeKey);
  1069. else
  1070. xpath2.clear().appendf("%s[@name='%s']", pszSubType, pszSubTypeKey);
  1071. pComp = pTmpComp->queryPropTree(xpath2.str());
  1072. if (!pComp)
  1073. {
  1074. if (pszUpdate && pszSubType && key)
  1075. xpath2.clear().appendf("%s[@%s='%s']", pszSubType, key, pszUpdate);
  1076. pComp = pTmpComp->queryPropTree(xpath2.str());
  1077. }
  1078. }
  1079. else if (pszSubType && strlen(rowIndex) > 0)
  1080. {
  1081. xpath2.clear().appendf("%s[%s]", pszSubType, rowIndex);
  1082. pComp = pTmpComp->queryPropTree(xpath2.str());
  1083. }
  1084. else if (pszSubType)
  1085. {
  1086. xpath2.clear().appendf("%s", pszSubType);
  1087. pComp = pTmpComp->queryPropTree(xpath2.str());
  1088. }
  1089. else
  1090. pComp = &iter->query();
  1091. break;
  1092. }
  1093. }
  1094. }
  1095. if (!pComp)
  1096. throw MakeStringException(-1, "No such component in environment: '%s' named '%s'.", pszCompType, pszCompName);
  1097. else
  1098. {
  1099. if (pszOnChange && !strcmp(pszOnChange, "2"))
  1100. {
  1101. StringBuffer xpathBSet;
  1102. //get the onChange xslt and apply it.
  1103. if (!strcmp(pszCompType, XML_TAG_ESPSERVICE) || !strcmp(pszCompType, XML_TAG_PLUGINPROCESS))
  1104. xpathBSet.clear().appendf("./Programs/Build/BuildSet[@name=\"%s\"]", pComp->queryProp(XML_ATTR_BUILDSET));
  1105. else
  1106. xpathBSet.clear().appendf("./Programs/Build/BuildSet[@processName=\"%s\"]", pszCompType);
  1107. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(xpathBSet.str());
  1108. buildSetIter->first();
  1109. IPropertyTree* pBuildSet;
  1110. if (!buildSetIter->isValid())
  1111. {
  1112. xpathBSet.clear().appendf("./Programs/Build/BuildSet[@name=\"%s\"]", pszCompType);
  1113. buildSetIter.setown(pEnvRoot->getElements(xpathBSet.str()));
  1114. buildSetIter->first();
  1115. }
  1116. if (buildSetIter->isValid())
  1117. {
  1118. pBuildSet = &buildSetIter->query();
  1119. const char* buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  1120. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  1121. StringBuffer buildSetPath;
  1122. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  1123. StringBuffer xpathOnChg;
  1124. xpathOnChg.append(".//xs:attribute[@name=\"").append(pszAttrName).append("\"]//onchange");
  1125. IPropertyTree* pAttr = pSchema->queryPropTree(xpathOnChg.str());
  1126. xpathOnChg.clear().append(".//onchange");
  1127. IPropertyTree* pOnChange = pAttr? pAttr->queryPropTree(xpathOnChg.str()) : NULL;
  1128. if (pAttr)
  1129. {
  1130. const char* onChangeXslt = pAttr->queryProp("xslt");
  1131. if (onChangeXslt && *onChangeXslt)
  1132. {
  1133. StringBuffer sbAttrName("@");
  1134. sbAttrName.append(pszAttrName);
  1135. pComp->setProp(sbAttrName.str(), pszNewValue);
  1136. if (onChangeAttribute(pEnvRoot, m_Environment, pszAttrName, pAttr, pComp, pComp /*TBD Calc parent nodeGetParentNode()*/, 0, pszNewValue, pszOldValue, pszCompType))
  1137. {
  1138. bool bRefresh = pAttr->getPropBool("refresh", true);
  1139. if (bRefresh)
  1140. {
  1141. resp.setRefresh("true");
  1142. resp.setUpdateValue(pszNewValue);
  1143. return true;
  1144. }
  1145. }
  1146. else
  1147. {
  1148. pComp->setProp(sbAttrName.str(), pszOldValue);
  1149. resp.setUpdateValue(pszOldValue);
  1150. return true;
  1151. }
  1152. }
  1153. }
  1154. }
  1155. }
  1156. //perform checks
  1157. if (!strcmp(pszAttrName, "name"))
  1158. {
  1159. ensureUniqueName(pEnvRoot, pComp, pszNewValue);
  1160. if (isAlphaNumeric(pszNewValue) == false)
  1161. {
  1162. throw MakeStringException(-1, "Invalid Character in name '%s'.", pszNewValue);
  1163. }
  1164. }
  1165. //Store prev settings for use further down for esp service bindings
  1166. const char* sPrevDefaultPort = NULL;
  1167. const char* sPrevPort = NULL;
  1168. const char* sPrevResBasedn = NULL;
  1169. const char* sPrevDefaultSecurePort = NULL;
  1170. const char* sPrevDefaultResBasedn = NULL;
  1171. if (pszSubType && !strcmp(pszSubType, XML_TAG_ESPBINDING) &&
  1172. (!strcmp(pszAttrName, "service") || !strcmp(pszAttrName, "protocol")))
  1173. {
  1174. const char* szServiceName = xpath.clear().append("Software/EspService[@name=\"");
  1175. xpath.append(pComp->queryProp(XML_ATTR_SERVICE));
  1176. xpath.append("\"]/Properties");
  1177. IPropertyTree* pPrevSvcProps = pEnvRoot->queryPropTree(xpath);
  1178. if (pPrevSvcProps)
  1179. {
  1180. sPrevDefaultPort = pPrevSvcProps->queryProp("@defaultPort");
  1181. sPrevDefaultSecurePort= pPrevSvcProps->queryProp("@defaultSecurePort");
  1182. sPrevDefaultResBasedn = pPrevSvcProps->queryProp("@defaultResourcesBasedn");
  1183. }
  1184. sPrevPort = pComp->queryProp("@port");
  1185. sPrevResBasedn = pComp->queryProp("@resourcesBasedn");
  1186. }
  1187. bool isSet = false;
  1188. if (pszSubType && strstr(pszSubType, "Notes") == pszSubType && !strcmp(pszAttrName, "Note"))
  1189. {
  1190. pComp->setProp(".", pszNewValue);
  1191. isSet = true;
  1192. }
  1193. else if (pszCompType && !strcmp(pszCompType, XML_TAG_ESPPROCESS))
  1194. {
  1195. String strXPath(xpath);
  1196. if (strXPath.indexOf("CSR") != -1 || strXPath.indexOf("Certificate") != -1 || strXPath.indexOf("PrivateKey") != -1)
  1197. {
  1198. StringBuffer sbNewVal(pszNewValue);
  1199. pEnvSoftware->setProp(xpath, sbNewVal.str());
  1200. isSet = true;
  1201. }
  1202. }
  1203. StringBuffer encryptedText;
  1204. if (!isSet)
  1205. {
  1206. xpath.clear().appendf("@%s", pszAttrName);
  1207. if (pszViewType && *pszViewType && !strcmp(pszViewType, "password"))
  1208. {
  1209. encrypt(encryptedText, pszNewValue);
  1210. pszNewValue = encryptedText.str();
  1211. }
  1212. pComp->setProp(xpath, pszNewValue);
  1213. }
  1214. resp.setUpdateValue(pszNewValue);
  1215. if (!strcmp(pszAttrName, "name"))
  1216. {
  1217. if (!pszSubType || !*pszSubType)
  1218. {
  1219. StringBuffer rundir;
  1220. if (!getConfigurationDirectory(pEnvRoot->queryPropTree("Software/Directories"), "run", pszCompType, pszNewValue, rundir))
  1221. rundir.clear().appendf(RUNTIME_DIR"/%s", pszNewValue);
  1222. Owned<IPropertyTreeIterator> iterInsts = pComp->getElements(XML_TAG_INSTANCE);
  1223. ForEach (*iterInsts)
  1224. iterInsts->query().setProp(XML_ATTR_DIRECTORY, rundir.str());
  1225. if (!strcmp(pszCompType, XML_TAG_ROXIECLUSTER))
  1226. pComp->setProp(XML_ATTR_DIRECTORY, rundir);
  1227. }
  1228. StringBuffer sbold, sbnew, sbMsg;
  1229. bool ret = false;
  1230. if (pszSubType && !strcmp(pszSubType, "EspBinding"))
  1231. {
  1232. sbold.append(pszCompName).append('/').append(pszOldValue);
  1233. sbnew.append(pszCompName).append('/').append(pszNewValue);
  1234. ret = checkComponentReferences(pEnvRoot, pComp, sbold.str(), sbMsg, sbnew.str());
  1235. }
  1236. else
  1237. ret = checkComponentReferences(pEnvRoot, pComp, pszOldValue, sbMsg, pszNewValue);
  1238. if (ret)
  1239. resp.setRefresh("true");
  1240. }
  1241. if (pszCompType && *pszCompType && pszSubType && *pszSubType &&
  1242. !strcmp(pszCompType, XML_TAG_ROXIECLUSTER) && !strcmp(pszSubType, XML_TAG_ROXIE_FARM)
  1243. && pszAttrName && *pszAttrName)
  1244. {
  1245. Owned<IPropertyTreeIterator> iter = pComp->getElements(XML_TAG_ROXIE_SERVER);
  1246. ForEach (*iter)
  1247. {
  1248. IPropertyTree* pSrv = &iter->query();
  1249. const char* pszName = pSrv->queryProp(XML_ATTR_NAME);
  1250. xpath.clear().appendf(XML_TAG_ROXIECLUSTER"[@name='%s']/"XML_TAG_ROXIE_SERVER"[@name='%s']/", pszCompName, pszName);
  1251. IPropertyTree* pServer = pEnvSoftware->queryPropTree(xpath.str());
  1252. if (pServer)
  1253. {
  1254. StringBuffer sbattr("@");
  1255. sbattr.append(pszAttrName);
  1256. pServer->setProp(sbattr.str(), pszNewValue);
  1257. }
  1258. }
  1259. }
  1260. //if dataDirectory for a roxie farm is being changed, also change baseDataDir for roxie
  1261. if(!strcmp(pszCompType, "Directories") && !strcmp(pszSubType, "Category"))
  1262. {
  1263. StringBuffer sbNewValue;
  1264. bool bdata = strstr(pszSubTypeKey, "[@name='data']") || strstr(pszSubTypeKey, "[@name=\"data\"]");\
  1265. bool bdata2 = strstr(pszSubTypeKey, "[@name='data2']") || strstr(pszSubTypeKey, "[@name=\"data2\"]");
  1266. bool bdata3 = strstr(pszSubTypeKey, "[@name='data3']") || strstr(pszSubTypeKey, "[@name=\"data3\"]");
  1267. if (bdata || bdata2 || bdata3)
  1268. {
  1269. Owned<IPropertyTreeIterator> iterRoxies = pEnvSoftware->getElements("RoxieCluster");
  1270. ForEach (*iterRoxies)
  1271. {
  1272. IPropertyTree* pRoxie = &iterRoxies->query();
  1273. if (bdata)
  1274. {
  1275. getCommonDir(pEnvRoot, "data", "roxie", pRoxie->queryProp(XML_ATTR_NAME), sbNewValue.clear());
  1276. pRoxie->setProp("@baseDataDir", sbNewValue.str());
  1277. //change all farms
  1278. Owned<IPropertyTreeIterator> iterFarms = pRoxie->getElements(XML_TAG_ROXIE_FARM);
  1279. ForEach (*iterFarms)
  1280. {
  1281. IPropertyTree* pTmpComp = &iterFarms->query();
  1282. if (strcmp(pTmpComp->queryProp(XML_ATTR_DATADIRECTORY), sbNewValue.str()))
  1283. pTmpComp->setProp(XML_ATTR_DATADIRECTORY, sbNewValue.str());
  1284. }
  1285. //change all legacy Roxie servers
  1286. Owned<IPropertyTreeIterator> iterRoxieServers = pRoxie->getElements(XML_TAG_ROXIE_SERVER);
  1287. ForEach (*iterRoxieServers)
  1288. {
  1289. IPropertyTree* pTmpComp = &iterRoxieServers->query();
  1290. if (strcmp(pTmpComp->queryProp(XML_ATTR_DATADIRECTORY), sbNewValue.str()))
  1291. pTmpComp->setProp(XML_ATTR_DATADIRECTORY, sbNewValue.str());
  1292. }
  1293. //also change roxie slave primary data directory for all RoxieSlave and RoxieSlaveProcess
  1294. Owned<IPropertyTreeIterator> iterSlvs = pRoxie->getElements(XML_TAG_ROXIE_ONLY_SLAVE);
  1295. ForEach (*iterSlvs)
  1296. {
  1297. IPropertyTree* pTmpComp = &iterSlvs->query();
  1298. const char* pRoxieComputer = pTmpComp->queryProp(XML_ATTR_COMPUTER);
  1299. IPropertyTree* pChannel = pTmpComp->queryPropTree(XML_TAG_ROXIE_CHANNEL"[1]");
  1300. if (pChannel)
  1301. {
  1302. pChannel->setProp(XML_ATTR_DATADIRECTORY, sbNewValue.str());
  1303. const char* number = pChannel->queryProp("@number");
  1304. xpath.clear().appendf(XML_TAG_ROXIE_SLAVE"[@channel='%s'][@computer='%s']", number, pRoxieComputer);
  1305. IPropertyTree* pSlvProc = pRoxie->queryPropTree(xpath.str());
  1306. if (pSlvProc)
  1307. pSlvProc->setProp(XML_ATTR_DATADIRECTORY, sbNewValue.str());
  1308. }
  1309. }
  1310. }
  1311. else if (bdata2 || bdata3)
  1312. {
  1313. getCommonDir(pEnvRoot, bdata2 ? "data2" : "data3" , "roxie", pRoxie->queryProp(XML_ATTR_NAME), sbNewValue.clear());
  1314. Owned<IPropertyTreeIterator> iterSlvs = pRoxie->getElements(XML_TAG_ROXIE_ONLY_SLAVE);
  1315. StringBuffer sb(XML_TAG_ROXIE_CHANNEL);
  1316. sb.appendf("%s", bdata2?"[2]":"[3]");
  1317. ForEach (*iterSlvs)
  1318. {
  1319. IPropertyTree* pTmpComp = &iterSlvs->query();
  1320. const char* pRoxieComputer = pTmpComp->queryProp(XML_ATTR_COMPUTER);
  1321. IPropertyTree* pChannel = pTmpComp->queryPropTree(sb.str());
  1322. if (pChannel)
  1323. {
  1324. pChannel->setProp(XML_ATTR_DATADIRECTORY, sbNewValue.str());
  1325. const char* number = pChannel->queryProp("@number");
  1326. xpath.clear().appendf(XML_TAG_ROXIE_SLAVE"[@channel='%s'][@computer='%s']", number, pRoxieComputer);
  1327. IPropertyTree* pSlvProc = pRoxie->queryPropTree(xpath.str());
  1328. if (pSlvProc)
  1329. pSlvProc->setProp(XML_ATTR_DATADIRECTORY, sbNewValue.str());
  1330. }
  1331. }
  1332. }
  1333. }
  1334. }
  1335. }
  1336. //if we are changing the eclServer field of wsattributes, set the following
  1337. //extra params from that eclserver. dbPassword, dbUser, mySQL, repository
  1338. if (!strcmp(pszCompType, "WsAttributes") && !strcmp(pszAttrName, "eclServer"))
  1339. {
  1340. xpath.clear().appendf("Software/EclServerProcess[@name='%s']", pszNewValue);
  1341. IPropertyTree* pEclServer = pEnvRoot->queryPropTree(xpath.str());
  1342. if (pEclServer)
  1343. {
  1344. pComp->setProp("@dbPassword", pEclServer->queryProp("@dbPassword"));
  1345. pComp->setProp("@dbUser", pEclServer->queryProp("@dbUser"));
  1346. pComp->setProp("@mySQL", pEclServer->queryProp("@MySQL"));
  1347. pComp->setProp("@repository", pEclServer->queryProp("@repository"));
  1348. }
  1349. }
  1350. else if (!strcmp(pszCompType, "EclServerProcess") && (!strcmp(pszAttrName, "dbPassword") ||
  1351. !strcmp(pszAttrName, "dbUser") || !strcmp(pszAttrName, "MySQL") ||
  1352. !strcmp(pszAttrName, "repository")))
  1353. {
  1354. xpath.clear().append("Software/EspService[@buildSet='WsAttributes']");
  1355. Owned<IPropertyTreeIterator> pWsAttrsIter = pEnvRoot->getElements(xpath.str());
  1356. ForEach(*pWsAttrsIter)
  1357. {
  1358. IPropertyTree* wsAttr = &pWsAttrsIter->query();
  1359. if (!strcmp(wsAttr->queryProp("@eclServer"), pszCompName))
  1360. {
  1361. wsAttr->setProp("@dbPassword", pComp->queryProp("@dbPassword"));
  1362. wsAttr->setProp("@dbUser", pComp->queryProp("@dbUser"));
  1363. wsAttr->setProp("@mySQL", pComp->queryProp("@MySQL"));
  1364. wsAttr->setProp("@repository", pComp->queryProp("@repository"));
  1365. }
  1366. }
  1367. }
  1368. if (pszSubType && !strcmp(pszSubType, XML_TAG_INSTANCE) && !strcmp(pszAttrName, TAG_COMPUTER))
  1369. {
  1370. xpath.clear().appendf("Hardware/Computer[@name='%s']", pszNewValue);
  1371. IPropertyTree* pEnvComputer = pEnvRoot->queryPropTree(xpath);
  1372. if (pEnvComputer)
  1373. {
  1374. const char* pszNetAddr = pEnvComputer->queryProp(XML_ATTR_NETADDRESS);
  1375. if (pszNetAddr)
  1376. {
  1377. StringBuffer prevValue;
  1378. pComp->getProp(XML_ATTR_NETADDRESS, prevValue);
  1379. resp.setPrevValue(prevValue.str());
  1380. pComp->setProp(XML_ATTR_NETADDRESS, pszNetAddr);
  1381. resp.setUpdateValue(pszNetAddr);
  1382. resp.setUpdateAttr("netAddress");
  1383. }
  1384. const char* name = pComp->queryProp(XML_ATTR_NAME);
  1385. if (!name || !*name)
  1386. {
  1387. pComp->setProp(XML_ATTR_NAME, "s1");
  1388. StringBuffer sb;
  1389. StringBuffer rundir;
  1390. if (!getConfigurationDirectory(pEnvRoot->queryPropTree("Software/Directories"), "run", pszCompType, pszCompName, rundir))
  1391. sb.clear().appendf(RUNTIME_DIR"/%s", pszCompName);
  1392. else
  1393. sb.clear().append(rundir);
  1394. pComp->setProp(XML_ATTR_DIRECTORY, sb.str());
  1395. }
  1396. }
  1397. }
  1398. if (pszSubType && !strcmp(pszSubType, XML_TAG_ESPBINDING) &&
  1399. (!strcmp(pszAttrName, "service") || !strcmp(pszAttrName, "protocol")))
  1400. {
  1401. bool bEspServiceChanged = !strcmp(pszAttrName, "service");
  1402. const char* szSrvName = pComp->queryProp(XML_ATTR_SERVICE);
  1403. xpath.clear().append("Software/EspService[@name=\"");
  1404. xpath.append(bEspServiceChanged ? pszNewValue : szSrvName ? szSrvName : "");
  1405. xpath.append("\"]/Properties");
  1406. IPropertyTree* pSvcProps = pEnvRoot->queryPropTree(xpath.str());
  1407. if (bEspServiceChanged)
  1408. {
  1409. IPropertyTree* pChild;
  1410. while ((pChild = pComp->queryPropTree("Authenticate[1]")) != NULL)
  1411. if (pChild)
  1412. pComp->removeTree( pChild );
  1413. while ((pChild = pComp->queryPropTree("AuthenticateFeature[1]")) != NULL)
  1414. if (pChild)
  1415. pComp->removeTree( pChild );
  1416. while ((pChild = pComp->queryPropTree("AuthenticateSetting[1]")) != NULL)
  1417. if (pChild)
  1418. pComp->removeTree( pChild );
  1419. }
  1420. if (pSvcProps)
  1421. {
  1422. if (bEspServiceChanged)
  1423. {
  1424. xpath.clear().append("./Programs/Build/BuildSet[@processName=\"EspProcess\"]");
  1425. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(xpath.str());
  1426. buildSetIter->first();
  1427. IPropertyTree* pBuildSet = &buildSetIter->query();
  1428. const char* buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  1429. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  1430. StringBuffer buildSetPath;
  1431. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  1432. Owned<IPropertyTree> pCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName());
  1433. Owned<IPropertyTreeIterator> i = pSvcProps->getElements("Authenticate");
  1434. ForEach(*i)
  1435. {
  1436. IPropertyTree* pAuthCopy = createPTreeFromIPT(&i->query());
  1437. mergeAttributes(pAuthCopy, pCompTree->queryPropTree("Authenticate"));
  1438. IPropertyTree* pNewNode = pComp->addPropTree("Authenticate", pAuthCopy);
  1439. }
  1440. i.setown( pSvcProps->getElements("AuthenticateFeature") );
  1441. ForEach(*i)
  1442. {
  1443. IPropertyTree* pAuthCopy = createPTreeFromIPT(&i->query());
  1444. mergeAttributes(pAuthCopy, pCompTree->queryPropTree("AuthenticateFeature"));
  1445. IPropertyTree* pNewNode = pComp->addPropTree("AuthenticateFeature", pAuthCopy);
  1446. }
  1447. i.setown( pSvcProps->getElements("AuthenticateSetting") );
  1448. ForEach(*i)
  1449. {
  1450. IPropertyTree* pAuthCopy = createPTreeFromIPT(&i->query());
  1451. mergeAttributes(pAuthCopy, pCompTree->queryPropTree("AuthenticateSetting"));
  1452. IPropertyTree* pNewNode = pComp->addPropTree("AuthenticateSetting", pAuthCopy);
  1453. }
  1454. }
  1455. const char* szProtocol = pComp->queryProp("@protocol");
  1456. bool bHttps = szProtocol && !strcmp(szProtocol, "https");
  1457. const char* szDefaultPort = pSvcProps->queryProp(bHttps ? "@defaultSecurePort" : "@defaultPort");
  1458. if (!bEspServiceChanged)//@protocol was just changed so use last one
  1459. bHttps = !bHttps;
  1460. const char* szPrevDefaultPort = bHttps ? sPrevDefaultSecurePort : sPrevDefaultPort;
  1461. if (szDefaultPort &&
  1462. ((!sPrevPort || (sPrevPort && !*sPrevPort)) || (szPrevDefaultPort && !strcmp(sPrevPort, szPrevDefaultPort))))
  1463. pComp->setProp(XML_ATTR_PORT, szDefaultPort);
  1464. if (bEspServiceChanged)
  1465. {
  1466. const char* szDefault = pSvcProps->queryProp("@defaultResourcesBasedn");
  1467. if (szDefault &&
  1468. ((!sPrevResBasedn || (sPrevResBasedn && !*sPrevResBasedn )) || (sPrevDefaultResBasedn && !strcmp(sPrevResBasedn, sPrevDefaultResBasedn))))
  1469. pComp->setProp("@resourcesBasedn", szDefault);
  1470. }
  1471. }
  1472. resp.setRefresh("true");
  1473. }
  1474. }
  1475. resp.setIsSaved("true");
  1476. }
  1477. }
  1478. else if (pTopologyFolder)
  1479. {
  1480. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements("Setting[@category='Topology']");
  1481. ForEach (*iter)
  1482. {
  1483. IPropertyTree* pSetting = &iter->query();
  1484. StringBuffer decodedParams( pSetting->queryProp("@params") );
  1485. decodedParams.replaceString("::", "\n");
  1486. Owned<IProperties> pParams = createProperties();
  1487. pParams->loadProps(decodedParams.str());
  1488. const char* pszCompType = pParams->queryProp("pcType");
  1489. const char* pszCompName = pParams->queryProp("pcName");
  1490. const char* pszSubType = pParams->queryProp("subType");
  1491. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  1492. const char* pszAttrName = pSetting->queryProp("@attrName");
  1493. const char* rowIndex = pSetting->queryProp("@rowIndex");
  1494. const char* pszOldValue = pSetting->queryProp("@oldValue");
  1495. const char* pszNewValue = pSetting->queryProp("@newValue");
  1496. StringBuffer xpath_key;
  1497. if (strcmp(pszAttrName,TAG_NAME) == 0)
  1498. {
  1499. xpath_key.appendf("%s/%s/%s[%s='%s']", XML_TAG_SOFTWARE, XML_TAG_TOPOLOGY, XML_TAG_CLUSTER, XML_ATTR_NAME, pszNewValue);
  1500. //Check to see if the cluster name is already in use
  1501. IPropertyTree* pEnvCluster = pEnvRoot->queryPropTree(xpath_key);
  1502. if (pEnvCluster != NULL)
  1503. throw MakeStringException(-1, "Cluster - %s is already in use. Please enter a unique name for the Cluster.", pszNewValue);
  1504. }
  1505. StringBuffer buf("Topology");
  1506. for (int i = 3; i >= 0; i--)
  1507. {
  1508. StringBuffer sb;
  1509. sb.appendf("inner%d_name", i);
  1510. const char* sbName = pParams->queryProp(sb.str());
  1511. if (sbName)
  1512. {
  1513. if (strstr(sbName, "EclCCServerProcess") == sbName ||
  1514. strstr(sbName, "EclServerProcess") == sbName ||
  1515. strstr(sbName, "EclAgentProcess") == sbName ||
  1516. strstr(sbName, "EclSchedulerProcess") == sbName)
  1517. {
  1518. StringBuffer sbEcl(sbName);
  1519. if (strstr(sbName, " - "))
  1520. sbEcl.replaceString(" - ", "[@process='").append("']");
  1521. else if (strstr(sbName, " -"))
  1522. sbEcl.replaceString(" -", "[@process='").append("']");
  1523. buf.append("/").append(sbEcl);
  1524. }
  1525. else if (strstr(sbName, "Cluster") == sbName)
  1526. {
  1527. StringBuffer sbCl(sbName);
  1528. if (strstr(sbName, " - "))
  1529. sbCl.replaceString(" - ", "[@name='").append("']");
  1530. else if (strstr(sbName, " -"))
  1531. sbCl.replaceString(" -", "[@name='").append("']");
  1532. buf.append("/").append(sbCl);
  1533. }
  1534. else if (strstr(sbName, XML_TAG_THORCLUSTER) == sbName)
  1535. buf.append("/ThorCluster");
  1536. else if (strstr(sbName, XML_TAG_ROXIECLUSTER) == sbName)
  1537. buf.append("/RoxieCluster");
  1538. else if (buf.str()[buf.length() - 1] != ']')
  1539. buf.appendf("[@%s='%s']", sbName, pParams->queryProp(sb.replaceString("_name", "_value").str()));
  1540. }
  1541. }
  1542. StringBuffer xpath;
  1543. xpath.appendf("%s[@name='%s']", pszCompType, pszCompName);
  1544. IPropertyTree* pComp = pEnvSoftware->queryPropTree(buf.str());
  1545. if (!pComp)
  1546. {
  1547. xpath.clear().appendf("*[@name='%s']", pszCompName);
  1548. Owned<IPropertyTreeIterator> iter = pEnvSoftware->getElements(xpath);
  1549. ForEach (*iter)
  1550. {
  1551. IPropertyTree* pTmpComp = &iter->query();
  1552. const char* pBldSet = pTmpComp->queryProp(XML_ATTR_BUILDSET);
  1553. if (pBldSet && !strcmp(pBldSet, pszCompType))
  1554. {
  1555. pComp = &iter->query();
  1556. break;
  1557. }
  1558. }
  1559. }
  1560. if (!pComp)
  1561. throw MakeStringException(-1, "No such component in environment: '%s' named '%s'.", pszCompType, pszCompName);
  1562. else
  1563. {
  1564. xpath.clear().appendf("@%s", pszAttrName);
  1565. pComp->setProp(xpath, pszNewValue);
  1566. resp.setUpdateValue(pszNewValue);
  1567. if (pszSubType && !strcmp(pszSubType, XML_TAG_INSTANCE) && !strcmp(pszAttrName, TAG_COMPUTER))
  1568. {
  1569. xpath.clear().appendf("Hardware/Computer[@name='%s']", pszNewValue);
  1570. IPropertyTree* pEnvComputer = pEnvRoot->queryPropTree(xpath);
  1571. if (pEnvComputer)
  1572. {
  1573. const char* pszNetAddr = pEnvComputer->queryProp(XML_ATTR_NETADDRESS);
  1574. if (pszNetAddr)
  1575. pComp->setProp(XML_ATTR_NETADDRESS, pszNetAddr);
  1576. }
  1577. }
  1578. }
  1579. resp.setIsSaved("true");
  1580. }
  1581. }
  1582. else if (pHardwareFolder)
  1583. {
  1584. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements("Setting[@category='Hardware']");
  1585. ForEach (*iter)
  1586. {
  1587. IPropertyTree* pSetting = &iter->query();
  1588. StringBuffer decodedParams( pSetting->queryProp("@params") );
  1589. decodedParams.replaceString("::", "\n");
  1590. Owned<IProperties> pParams = createProperties();
  1591. pParams->loadProps(decodedParams.str());
  1592. const char* pszCompType = pParams->queryProp("pcType");
  1593. const char* pszCompName = pParams->queryProp("pcName");
  1594. const char* pszSubType = pParams->queryProp("subType");
  1595. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  1596. const char* pszAttrName = pSetting->queryProp("@attrName");
  1597. const char* rowIndex = pSetting->queryProp("@rowIndex");
  1598. const char* pszOldValue = pSetting->queryProp("@oldValue");
  1599. const char* pszNewValue = pSetting->queryProp("@newValue");
  1600. //read anyupdates to rows that have not been updated
  1601. const char* pszUpdate = NULL;
  1602. int idx = 1;
  1603. StringBuffer sbUpdate;
  1604. while (true)
  1605. {
  1606. sbUpdate.clear().appendf("Update%dKey", idx);
  1607. const char* key = pParams->queryProp(sbUpdate.str());
  1608. if (!key)
  1609. break;
  1610. else if (!strcmp(key, "name") || !strcmp(key, "Name"))
  1611. {
  1612. sbUpdate.clear().appendf("Update%dValue", idx);
  1613. pszUpdate = pParams->queryProp(sbUpdate.str());
  1614. break;
  1615. }
  1616. idx++;
  1617. }
  1618. StringBuffer xpath;
  1619. if (pszSubType && pszSubTypeKey && strlen(pszSubTypeKey) > 0/* && !strcmp(pszSubType, "Instance")*/)
  1620. {
  1621. if (pszSubTypeKey[0] == '[' && pszSubTypeKey[strlen(pszSubTypeKey) - 1] == ']')
  1622. xpath.appendf("%s%s", pszSubType, pszSubTypeKey);
  1623. else
  1624. xpath.clear().appendf("%s[@name='%s']", pszSubType, pszSubTypeKey);
  1625. }
  1626. else if (pszSubType && strlen(rowIndex) > 0/* && !strcmp(pszSubType, "Instance")*/)
  1627. xpath.clear().appendf("%s[%s]", pszSubType, rowIndex);
  1628. IPropertyTree* pComp = pEnvHardware->queryPropTree(xpath.str());
  1629. if (!pComp)
  1630. {
  1631. //check for any updates first
  1632. if (pszUpdate && pszSubType)
  1633. xpath.clear().appendf("%s[@name='%s']", pszSubType, pszUpdate);
  1634. pComp = pEnvHardware->queryPropTree(xpath.str());
  1635. if (!pComp)
  1636. {
  1637. xpath.clear().appendf("*[@name='%s']", pszCompName);
  1638. Owned<IPropertyTreeIterator> iter = pEnvHardware->getElements(xpath);
  1639. ForEach (*iter)
  1640. {
  1641. IPropertyTree* pTmpComp = &iter->query();
  1642. const char* pBldSet = pTmpComp->queryProp(XML_ATTR_BUILDSET);
  1643. if (pBldSet && !strcmp(pBldSet, pszCompType))
  1644. {
  1645. pComp = &iter->query();
  1646. break;
  1647. }
  1648. }
  1649. }
  1650. }
  1651. if (!pComp)
  1652. throw MakeStringException(-1, "No such component in environment: '%s' named '%s'.", pszCompType, pszCompName);
  1653. else
  1654. {
  1655. if (!strcmp(pszAttrName, "name"))
  1656. {
  1657. xpath.clear().appendf("%s["XML_ATTR_NAME"='%s']", pszSubType, pszNewValue);
  1658. if (pEnvHardware->queryPropTree(xpath.str()))
  1659. throw MakeStringException(-1, "Another item exists with the same name '%s'! Please specify a unique name.", pszNewValue);
  1660. }
  1661. xpath.clear().appendf("@%s", pszAttrName);
  1662. String strAttrName(pszAttrName);
  1663. StringBuffer encryptedText;
  1664. if (strAttrName.toLowerCase()->endsWith("password"))
  1665. {
  1666. encrypt(encryptedText, pszNewValue);
  1667. pszNewValue = encryptedText.str();
  1668. }
  1669. if (m_bCloud && !strcmp(pszAttrName, "netAddress"))
  1670. {
  1671. StringBuffer sb, sbMsg;
  1672. {
  1673. sb.clear().appendf("<Computers><Computer netAddress='%s'/></Computers>", pszNewValue);
  1674. Owned<IPropertyTree> pComputer = createPTreeFromXMLString(sb.str());
  1675. CCloudActionHandler lockCloud(this, CLOUD_LOCK_ENV, CLOUD_NONE, m_userWithLock.str(), "8015", pComputer);
  1676. bool ret = lockCloud.start(sbMsg.clear());
  1677. if (!ret || sbMsg.length())
  1678. throw MakeStringException(-1, "Cannot set netAddress as environment lock could not be obtained. Reason(s):\n%s", sbMsg.str());
  1679. }
  1680. if (pszOldValue && *pszOldValue)
  1681. {
  1682. sb.clear().appendf("<Computers><Computer netAddress='%s'/></Computers>", pszOldValue);
  1683. Owned<IPropertyTree> pComputer = createPTreeFromXMLString(sb.str());
  1684. CCloudActionHandler unlockCloud(this, CLOUD_UNLOCK_ENV, CLOUD_NONE, m_userWithLock.str(), "8015", pComputer);
  1685. bool ret = unlockCloud.start(sbMsg.clear());
  1686. if (!ret || sbMsg.length())
  1687. {
  1688. //Unlock the new node.
  1689. {
  1690. sb.clear().appendf("<Computers><Computer netAddress='%s'/></Computers>", pszNewValue);
  1691. Owned<IPropertyTree> pComputer = createPTreeFromXMLString(sb.str());
  1692. CCloudActionHandler unlockPrevCloud(this, CLOUD_UNLOCK_ENV, CLOUD_NONE, m_userWithLock.str(), "8015", pComputer);
  1693. ret = unlockPrevCloud.start(sbMsg.clear());
  1694. }
  1695. throw MakeStringException(-1, "Cannot set netAddress as some targets could not be unlocked. Reason(s):\n%s", sbMsg.str());
  1696. }
  1697. }
  1698. }
  1699. pComp->setProp(xpath, pszNewValue);
  1700. resp.setUpdateValue(pszNewValue);
  1701. //update references
  1702. if (!strcmp(pszAttrName, "name"))
  1703. {
  1704. if (!strcmp(pszSubType, XML_TAG_COMPUTER))
  1705. {
  1706. UpdateRefAttributes(pEnvRoot, XML_TAG_SOFTWARE"//*", XML_ATTR_COMPUTER, pszOldValue, pszNewValue);
  1707. UpdateRefAttributes(pEnvRoot, XML_TAG_SOFTWARE"/"XML_TAG_DALISERVERPROCESS, XML_ATTR_BACKUPCOMPUTER, pszOldValue, pszNewValue);
  1708. }
  1709. else if (!strcmp(pszSubType, XML_TAG_DOMAIN))
  1710. UpdateRefAttributes(pEnvRoot, XML_TAG_HARDWARE"/"XML_TAG_COMPUTER, XML_ATTR_DOMAIN, pszOldValue, pszNewValue);
  1711. else if (!strcmp(pszSubType, XML_TAG_SWITCH))
  1712. UpdateRefAttributes(pEnvRoot, XML_TAG_HARDWARE"/"XML_TAG_COMPUTER, XML_ATTR_SWITCH, pszOldValue, pszNewValue);
  1713. else if (!strcmp(pszSubType, XML_TAG_COMPUTERTYPE))
  1714. UpdateRefAttributes(pEnvRoot, XML_TAG_HARDWARE"/"XML_TAG_COMPUTER, XML_ATTR_COMPUTERTYPE, pszOldValue, pszNewValue);
  1715. }
  1716. else if (!strcmp(pszAttrName, "netAddress"))
  1717. {
  1718. Owned<IPropertyTreeIterator> iter = pEnvRoot->getElements(XML_TAG_SOFTWARE"//*");
  1719. for (iter->first(); iter->isValid(); iter->next())
  1720. {
  1721. IPropertyTree& node = iter->query();
  1722. const char* szVal = node.queryProp(XML_ATTR_COMPUTER);
  1723. const char* szComputer = pComp->queryProp(XML_ATTR_NAME);
  1724. if (szVal && strcmp(szVal, szComputer)==0)
  1725. {
  1726. if (node.hasProp(XML_ATTR_NETADDRESS))
  1727. node.setProp(XML_ATTR_NETADDRESS, pszNewValue);
  1728. }
  1729. }
  1730. }
  1731. if (pszSubType && !strcmp(pszSubType, XML_TAG_INSTANCE) && !strcmp(pszAttrName, TAG_COMPUTER))
  1732. {
  1733. xpath.clear().appendf("Hardware/Computer[@name='%s']", pszNewValue);
  1734. IPropertyTree* pEnvComputer = pEnvRoot->queryPropTree(xpath);
  1735. if (pEnvComputer)
  1736. {
  1737. const char* pszNetAddr = pEnvComputer->queryProp(XML_ATTR_NETADDRESS);
  1738. if (pszNetAddr)
  1739. pComp->setProp(XML_ATTR_NETADDRESS, pszNetAddr);
  1740. }
  1741. }
  1742. }
  1743. resp.setIsSaved("true");
  1744. }
  1745. }
  1746. else if (pEnvFolder)
  1747. {
  1748. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements("Setting[@category='Environment']");
  1749. ForEach (*iter)
  1750. {
  1751. IPropertyTree* pSetting = &iter->query();
  1752. StringBuffer decodedParams( pSetting->queryProp("@params") );
  1753. decodedParams.replaceString("::", "\n");
  1754. Owned<IProperties> pParams = createProperties();
  1755. pParams->loadProps(decodedParams.str());
  1756. const char* pszAttrName = pSetting->queryProp("@attrName");
  1757. const char* pszOldValue = pSetting->queryProp("@oldValue");
  1758. const char* pszNewValue = pSetting->queryProp("@newValue");
  1759. StringBuffer xpath;
  1760. const char* pszUpdate = NULL;
  1761. int idx = 1;
  1762. StringBuffer sbUpdate;
  1763. while (true)
  1764. {
  1765. sbUpdate.clear().appendf("Update%dKey", idx);
  1766. const char* key = pParams->queryProp(sbUpdate.str());
  1767. if (!key)
  1768. break;
  1769. else if (!strcmp(key, "name") || !strcmp(key, "Name"))
  1770. {
  1771. sbUpdate.clear().appendf("Update%dValue", idx);
  1772. pszUpdate = pParams->queryProp(sbUpdate.str());
  1773. break;
  1774. }
  1775. idx++;
  1776. }
  1777. const char* pszParams = NULL;
  1778. idx = 2;
  1779. StringBuffer sbParams;
  1780. StringBuffer sb;
  1781. bool flag = false;
  1782. const char* isAttr = pParams->queryProp("isAttr");
  1783. while (true)
  1784. {
  1785. sbParams.clear().appendf("parentParams%d", idx);
  1786. const char* val = pParams->queryProp(sbParams.str());
  1787. if (!val || !*val)
  1788. {
  1789. if (!flag)
  1790. flag = true;
  1791. else
  1792. {
  1793. if (pszUpdate)
  1794. {
  1795. sbParams.clear().appendf("parentParams%d", idx-2);
  1796. const char* val = pParams->queryProp(sbParams.str());
  1797. String st(val);
  1798. if (st.indexOf("pcName=") != -1)
  1799. sbParams.clear().append("[@name='").append(*st.substring(st.indexOf("pcName=") + 7)).append("']");
  1800. String str(xpath.str());
  1801. sb.clear().append(*str.substring(0, str.indexOf(sbParams.str())));
  1802. sb.appendf("[@name='%s']", pszUpdate);
  1803. xpath.clear().append(sb.str());
  1804. }
  1805. break;
  1806. }
  1807. idx++;
  1808. continue;
  1809. }
  1810. else
  1811. {
  1812. flag = false;
  1813. sb.clear();
  1814. StringBuffer params(val);
  1815. params.replaceString(":", "\n");
  1816. Owned<IProperties> pSubParams = createProperties();
  1817. pSubParams->loadProps(params.str());
  1818. sb.append(pSubParams->queryProp("pcType"));
  1819. if (sb.length())
  1820. xpath.append(xpath.length()?"/":"").append(sb.str());
  1821. sb.clear().append(pSubParams->queryProp("pcName"));
  1822. if (sb.length())
  1823. xpath.appendf("[@name='%s']", sb.str());
  1824. }
  1825. idx++;
  1826. }
  1827. IPropertyTree* pComp = pEnvRoot->queryPropTree(xpath.str());
  1828. if (pComp)
  1829. {
  1830. sb.clear();
  1831. if (!isAttr)
  1832. sb.append("@");
  1833. sb.append(pszAttrName);
  1834. pComp->setProp(sb.str(), pszNewValue);
  1835. resp.setUpdateValue(pszNewValue);
  1836. }
  1837. else
  1838. throw MakeStringException(-1, "Cannot find component/attribute in environment: '%s'.", pszAttrName);
  1839. }
  1840. }
  1841. return true;
  1842. }
  1843. bool CWsDeployFileInfo::getNavTreeDefn(IEspContext &context, IEspGetNavTreeDefnRequest &req, IEspGetNavTreeDefnResponse &resp)
  1844. {
  1845. synchronized block(m_mutex);
  1846. const char* xmlArg = req.getXmlArgs();
  1847. StringBuffer sbDefn, sb;
  1848. resp.setReadOnly("false");
  1849. bool doreload = true;
  1850. StringBuffer decodedParams(xmlArg);
  1851. decodedParams.replaceString("::", "\n");
  1852. Owned<IProperties> pParams = createProperties();
  1853. pParams->loadProps(decodedParams.str());
  1854. const char* reload = pParams->queryProp("reloadEnv");
  1855. StringBuffer sbName, sbUserIp;
  1856. sbName.clear().append(req.getReqInfo().getUserId());
  1857. context.getPeer(sbUserIp);
  1858. if (!strcmp(sbName.str(), m_userWithLock.str()) && !strcmp(sbUserIp.str(), m_userIp.str()) && reload && !strcmp(reload, "true"))
  1859. throw MakeStringException(-1, "Another browser window already has write access on machine '%s'. Please use that window.", sbUserIp.str());
  1860. if (m_pNavTree.get() == NULL)
  1861. m_pNavTree.setown(getEnvTree(context, &req.getReqInfo()));
  1862. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  1863. generateHeadersFromEnv(pEnvRoot, sbDefn);
  1864. resp.setCompDefn(sbDefn.str());
  1865. m_lastSaved.getString(sb.clear());
  1866. resp.setLastSaved(sb.str());
  1867. m_pService->getLastStarted(sb.clear());
  1868. resp.setLastStarted(sb.str());
  1869. return true;
  1870. }
  1871. bool CWsDeployFileInfo::lockEnvironmentForCloud(IEspContext &context, IEspLockEnvironmentForCloudRequest &req, IEspLockEnvironmentForCloudResponse &resp)
  1872. {
  1873. synchronized block(m_mutex);
  1874. const char* user = req.getUserName();
  1875. const char* ip = req.getIp();
  1876. if (!user || !*user || !ip || !*ip)
  1877. {
  1878. resp.setReturnCode(0);
  1879. resp.setMsg("User name or ip cannot be empty");
  1880. }
  1881. StringBuffer xml;
  1882. try
  1883. {
  1884. if (m_userWithLock.length() == 0)
  1885. {
  1886. StringBuffer sb;
  1887. StringBuffer sbUserIp;
  1888. context.getPeer(sbUserIp);
  1889. m_userWithLock.clear().append(user);
  1890. m_userIp.clear().append(sbUserIp);
  1891. Owned<IPropertyTree> pEnvRoot = &m_constEnvRdOnly->getPTree();
  1892. unsigned timeout = 60;
  1893. if (pEnvRoot)
  1894. timeout = pEnvRoot->getPropInt(XML_TAG_ENVSETTINGS"/brokenconntimeout", 60);
  1895. if (m_cloudLockerAliveThread && m_cloudLockerAliveThread.get() != NULL)
  1896. m_cloudLockerAliveThread.clear();
  1897. m_cloudLockerAliveThread.setown(new CLockerAliveThread(this, timeout * 60 * 1000, user, sbUserIp.str()));
  1898. m_cloudLockerAliveThread->init();
  1899. resp.setReturnCode(1);
  1900. resp.setMsg("");
  1901. }
  1902. else
  1903. {
  1904. xml.appendf("Write access to the Environment cannot be provided as it is currently being used on machine %s.", m_userIp.str());
  1905. resp.setMsg(xml.str());
  1906. resp.setReturnCode(0);
  1907. }
  1908. }
  1909. catch (IException* e)
  1910. {
  1911. StringBuffer sErrMsg;
  1912. e->errorMessage(sErrMsg);
  1913. e->Release();
  1914. char achHost[128] = "";
  1915. const char* p = strstr(sErrMsg.str(), "\n\n");
  1916. if (p && *(p+=2))
  1917. {
  1918. const char* q = strchr(p, ':');
  1919. if (q)
  1920. {
  1921. const int len = q-p;
  1922. strncpy(achHost, p, len);
  1923. achHost[len] = '\0';
  1924. }
  1925. }
  1926. unsigned int addr = inet_addr(achHost);
  1927. struct hostent* hp = gethostbyaddr((const char*)&addr, sizeof(addr), AF_INET);
  1928. if (hp)
  1929. strcpy(achHost, hp->h_name);
  1930. StringBuffer sMsg;
  1931. sMsg.appendf("Error accessing the environment definition");
  1932. if (achHost[0])
  1933. sMsg.appendf(" \nbecause it is locked by computer '%s'.", achHost);
  1934. else
  1935. sMsg.append(":\n\n").append(sErrMsg);
  1936. //throw MakeStringException(0, sMsg);
  1937. resp.setMsg(sMsg.str());
  1938. resp.setReturnCode(0);
  1939. }
  1940. return true;
  1941. }
  1942. bool CWsDeployFileInfo::unlockEnvironmentForCloud(IEspContext &context, IEspUnlockEnvironmentForCloudRequest &req, IEspUnlockEnvironmentForCloudResponse &resp)
  1943. {
  1944. synchronized block(m_mutex);
  1945. const char* user = req.getUserName();
  1946. const char* ip = req.getIp();
  1947. const char* newEnv = req.getNewEnvXml();
  1948. if (!user || !*user || !ip || !*ip)
  1949. {
  1950. resp.setReturnCode(0);
  1951. resp.setMsg("User name or ip cannot be empty");
  1952. }
  1953. StringBuffer xml, sbMsg;
  1954. int ret = 0;
  1955. try
  1956. {
  1957. if (!stricmp(m_userWithLock.str(), user) && !stricmp(m_userIp.str(), ip))
  1958. {
  1959. m_Environment.clear();
  1960. m_userWithLock.clear();
  1961. m_userIp.clear();
  1962. if (m_cloudLockerAliveThread)
  1963. {
  1964. m_cloudLockerAliveThread->signal();
  1965. m_cloudLockerAliveThread.clear();
  1966. }
  1967. Owned<IPropertyTree> pNavTree(getEnvTree(context, &req.getReqInfo()));
  1968. if (!areMatchingPTrees(pNavTree, m_pNavTree))
  1969. {
  1970. m_pEnvXml.clear();
  1971. m_pGraphXml.clear();
  1972. m_pNavTree.clear();
  1973. m_pNavTree.setown(getEnvTree(context, &req.getReqInfo()));
  1974. }
  1975. resp.setReturnCode(1);
  1976. resp.setMsg("");
  1977. }
  1978. else
  1979. {
  1980. xml.appendf("The environment has been locked on machine '%s'", m_userIp.str());
  1981. resp.setReturnCode(0);
  1982. resp.setMsg(xml.str());
  1983. }
  1984. }
  1985. catch (IException* e)
  1986. {
  1987. StringBuffer sErrMsg;
  1988. e->errorMessage(sErrMsg);
  1989. e->Release();
  1990. char achHost[128] = "";
  1991. const char* p = strstr(sErrMsg.str(), "\n\n");
  1992. if (p && *(p+=2))
  1993. {
  1994. const char* q = strchr(p, ':');
  1995. if (q)
  1996. {
  1997. const int len = q-p;
  1998. strncpy(achHost, p, len);
  1999. achHost[len] = '\0';
  2000. }
  2001. }
  2002. unsigned int addr = inet_addr(achHost);
  2003. struct hostent* hp = gethostbyaddr((const char*)&addr, sizeof(addr), AF_INET);
  2004. if (hp)
  2005. strcpy(achHost, hp->h_name);
  2006. StringBuffer sMsg;
  2007. sMsg.appendf("The environment definition in dali server "
  2008. "could not be opened for write access");
  2009. if (achHost[0])
  2010. sMsg.appendf(" \nbecause it is locked by computer '%s'.", achHost);
  2011. else
  2012. sMsg.append(":\n\n").append(sErrMsg);
  2013. resp.setReturnCode(0);
  2014. resp.setMsg(sMsg.str());
  2015. }
  2016. return true;
  2017. }
  2018. bool CWsDeployFileInfo::saveEnvironmentForCloud(IEspContext &context, IEspSaveEnvironmentForCloudRequest &req, IEspSaveEnvironmentForCloudResponse &resp)
  2019. {
  2020. synchronized block(m_mutex);
  2021. const char* user = req.getUserName();
  2022. const char* ip = req.getIp();
  2023. if (!user || !*user || !ip || !*ip)
  2024. {
  2025. resp.setReturnCode(0);
  2026. resp.setMsg("User name or ip cannot be empty");
  2027. }
  2028. StringBuffer xml;
  2029. try
  2030. {
  2031. if (m_userWithLock.length() == 0)
  2032. {
  2033. xml.appendf("Environment cannot be saved as it is not locked.");
  2034. resp.setMsg(xml.str());
  2035. resp.setReturnCode(0);
  2036. return false;
  2037. }
  2038. else if (stricmp(m_userWithLock.str(), user) || stricmp(m_userIp.str(), ip))
  2039. {
  2040. xml.appendf("The environment has been locked on machine '%s'", m_userIp.str());
  2041. resp.setReturnCode(0);
  2042. resp.setMsg(xml.str());
  2043. return false;
  2044. }
  2045. else
  2046. {
  2047. const char* newEnv = req.getNewEnv();
  2048. const char* newEnvId = req.getId();
  2049. m_cloudEnvId.clear().append(newEnvId);
  2050. if (!newEnv || !*newEnv)
  2051. {
  2052. resp.setReturnCode(0);
  2053. resp.setMsg("Input xml cannot be empty");
  2054. return false;
  2055. }
  2056. StringBuffer sbBackup;
  2057. setEnvironment(context, &req.getReqInfo(), newEnv, "SaveEnvironmentForCloud", sbBackup, false, false);
  2058. m_cloudEnvBkupFileName.clear().append(sbBackup);
  2059. resp.setReturnCode(1);
  2060. resp.setMsg("");
  2061. }
  2062. }
  2063. catch (IException* e)
  2064. {
  2065. StringBuffer sErrMsg;
  2066. e->errorMessage(sErrMsg);
  2067. e->Release();
  2068. resp.setMsg(sErrMsg.str());
  2069. resp.setReturnCode(0);
  2070. }
  2071. return true;
  2072. }
  2073. bool CWsDeployFileInfo::rollbackEnvironmentForCloud(IEspContext &context, IEspRollbackEnvironmentForCloudRequest &req, IEspRollbackEnvironmentForCloudResponse &resp)
  2074. {
  2075. synchronized block(m_mutex);
  2076. const char* user = req.getUserName();
  2077. const char* ip = req.getIp();
  2078. if (!user || !*user || !ip || !*ip)
  2079. {
  2080. resp.setReturnCode(0);
  2081. resp.setMsg("User name or ip cannot be empty");
  2082. }
  2083. StringBuffer xml;
  2084. try
  2085. {
  2086. if (m_userWithLock.length() == 0)
  2087. {
  2088. xml.appendf("Cannot rollback environment as it is not locked.");
  2089. resp.setMsg(xml.str());
  2090. resp.setReturnCode(0);
  2091. return false;
  2092. }
  2093. else if (stricmp(m_userWithLock.str(), user) || stricmp(m_userIp.str(), ip))
  2094. {
  2095. xml.appendf("The environment has been locked on machine '%s'", m_userIp.str());
  2096. resp.setReturnCode(0);
  2097. resp.setMsg(xml.str());
  2098. return false;
  2099. }
  2100. else
  2101. {
  2102. const char* newEnvId = req.getId();
  2103. if (newEnvId && *newEnvId && !strcmp(newEnvId, m_cloudEnvId.str()))
  2104. {
  2105. StringBuffer sbBackup;
  2106. Owned<IFile> pFile = createIFile(m_cloudEnvBkupFileName.str());
  2107. Owned<IFileIO> pFileIO = pFile->open(IFOreadwrite);
  2108. StringBuffer sbxml;
  2109. {
  2110. Owned <IPropertyTree> pTree = createPTree(*pFileIO);
  2111. toXML(pTree, sbxml);
  2112. setEnvironment(context, &req.getReqInfo(), sbxml, "RollbackEnvironmentForCloud", sbBackup);
  2113. }
  2114. resp.setReturnCode(1);
  2115. resp.setMsg("");
  2116. }
  2117. else
  2118. {
  2119. resp.setReturnCode(0);
  2120. resp.setMsg("Cannot rollback Environment as rollback id does not match");
  2121. return false;
  2122. }
  2123. }
  2124. }
  2125. catch (IException* e)
  2126. {
  2127. StringBuffer sErrMsg;
  2128. e->errorMessage(sErrMsg);
  2129. e->Release();
  2130. resp.setMsg(sErrMsg.str());
  2131. resp.setReturnCode(0);
  2132. }
  2133. return true;
  2134. }
  2135. bool CWsDeployFileInfo::notifyInitSystemSaveEnvForCloud(IEspContext &context, IEspNotifyInitSystemSaveEnvForCloudRequest &req, IEspNotifyInitSystemSaveEnvForCloudResponse &resp)
  2136. {
  2137. synchronized block(m_mutex);
  2138. const char* user = req.getUserName();
  2139. const char* ip = req.getIp();
  2140. if (!user || !*user || !ip || !*ip)
  2141. {
  2142. resp.setReturnCode(0);
  2143. resp.setMsg("User name or ip cannot be empty");
  2144. }
  2145. StringBuffer xml;
  2146. try
  2147. {
  2148. if (m_userWithLock.length() == 0)
  2149. {
  2150. xml.appendf("Cannot notify init system as the environment as it is not locked.");
  2151. resp.setMsg(xml.str());
  2152. resp.setReturnCode(0);
  2153. return false;
  2154. }
  2155. else if (stricmp(m_userWithLock.str(), user) || stricmp(m_userIp.str(), ip))
  2156. {
  2157. xml.appendf("The environment has been locked on machine '%s'", m_userIp.str());
  2158. resp.setReturnCode(0);
  2159. resp.setMsg(xml.str());
  2160. return false;
  2161. }
  2162. else
  2163. {
  2164. StringBuffer xpath;
  2165. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalConfFile", m_pService->getName());
  2166. const char* pConfFile = m_pService->getCfg()->queryProp(xpath.str());
  2167. if( pConfFile && *pConfFile)
  2168. {
  2169. Owned<IProperties> pParams = createProperties(pConfFile);
  2170. Owned<IPropertyIterator> iter = pParams->getIterator();
  2171. StringBuffer prop, out, err;
  2172. pParams->getProp("initSystemNotifyScript", prop);
  2173. if(prop.length())
  2174. runScript(out, err, prop.str());
  2175. resp.setMsg("");
  2176. resp.setReturnCode(1);
  2177. }
  2178. }
  2179. }
  2180. catch(IException* e)
  2181. {
  2182. throw e;
  2183. }
  2184. return true;
  2185. }
  2186. bool CWsDeployFileInfo::getValue(IEspContext &context, IEspGetValueRequest &req, IEspGetValueResponse &resp)
  2187. {
  2188. synchronized block(m_mutex);
  2189. StringBuffer decodedParams(req.getParams());
  2190. decodedParams.replaceString("::", "\n");
  2191. Owned<IProperties> pParams = createProperties();
  2192. pParams->loadProps(decodedParams.str());
  2193. const char* pszCategory = pParams->queryProp("category");
  2194. const char* pszBldSet = pParams->queryProp(TAG_BUILDSET);
  2195. const char* pszCompName = pParams->queryProp("compName");
  2196. const char* pszSubType = pParams->queryProp("subType");
  2197. const char* pszSubTypeName = pParams->queryProp("subTypeName");
  2198. const char* pszAttrName = pParams->queryProp("attrName");
  2199. const char* pszQueryType = pParams->queryProp("queryType");
  2200. const char* pszExcludePath = pParams->queryProp("excludePath");
  2201. const char* pszExcludeAttr = pParams->queryProp("excludeAttr");
  2202. const char* pszXpath = pParams->queryProp("xpath");
  2203. const char* pszparams = pParams->queryProp("params");
  2204. const char* pszAttrValue = pParams->queryProp("attrValue");
  2205. if (!pszCompName)
  2206. pszCompName = pParams->queryProp("pcName");
  2207. if (!pszBldSet)
  2208. pszBldSet = pParams->queryProp("pcType");
  2209. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  2210. StringBuffer xpath;
  2211. const char* pszValue;
  2212. StringBuffer sbMultiple;
  2213. if (pszQueryType && !strcmp(pszQueryType, "multiple"))
  2214. {
  2215. StringBuffer excludes;
  2216. //prepare exclude list
  2217. if (pszExcludePath && *pszExcludePath && pszExcludeAttr && *pszExcludeAttr)
  2218. {
  2219. if (pszCategory)
  2220. xpath.clear().append(pszCategory).append("/");
  2221. xpath.append(pszExcludePath);
  2222. Owned<IPropertyTreeIterator> pExcludes = pEnvRoot->getElements(xpath.str());
  2223. ForEach(*pExcludes)
  2224. {
  2225. IPropertyTree* pExclude = &pExcludes->query();
  2226. excludes.append(":").append(pExclude->queryProp(pszExcludeAttr)).append(":");
  2227. }
  2228. }
  2229. xpath.clear().append(pszCategory).append("/*");
  2230. if (pszBldSet)
  2231. xpath.appendf("[@buildSet='%s']", pszBldSet);
  2232. if (pszCompName)
  2233. xpath.appendf("[@name='%s']", pszCompName);
  2234. if (pszSubType)
  2235. xpath.appendf("/%s", pszSubType);
  2236. Owned<IPropertyTreeIterator> pComps = pEnvRoot->getElements(xpath.str());
  2237. xpath.clear().appendf("@%s", pszAttrName);
  2238. ForEach(*pComps)
  2239. {
  2240. IPropertyTree* pComp = &pComps->query();
  2241. String excl(excludes.str());
  2242. StringBuffer sb(":");
  2243. sb.append(pComp->queryProp(xpath.str())).append(":");
  2244. if (excl.indexOf(sb.str()) == -1)
  2245. sbMultiple.append(pComp->queryProp(xpath.str())).append(",");
  2246. }
  2247. if (sbMultiple.length())
  2248. sbMultiple.setLength(sbMultiple.length() - 1);
  2249. pszValue = sbMultiple.str();
  2250. }
  2251. else if (pszQueryType && !strcmp(pszQueryType, "xpathType") && pszXpath && *pszXpath)
  2252. {
  2253. StringBuffer sb;
  2254. sbMultiple.clear().append("");
  2255. xpath.clear().appendf("./Software/%s[@name=\"%s\"]", pszBldSet, pszCompName);
  2256. IPropertyTree* pNode = pEnvRoot->queryPropTree(xpath.str());
  2257. if (!pNode)
  2258. {
  2259. xpath.clear().appendf("./Software/*[@buildSet=\"%s\"][@name=\"%s\"]", pszBldSet, pszCompName);
  2260. pNode = pEnvRoot->queryPropTree(xpath.str());
  2261. }
  2262. if (pNode)
  2263. {
  2264. substituteParameters(pEnvRoot, pszXpath, pNode, sb);
  2265. const char* szPath = sb.str();
  2266. const char* buildSet = NULL;
  2267. if (!strncmp(szPath, "$process", 8))
  2268. {
  2269. if (!pNode)
  2270. return false;
  2271. szPath += strlen("$process");
  2272. if (*szPath == '\0')
  2273. {
  2274. const char* szName = pNode->queryProp("@name");
  2275. if (szName && *szName)
  2276. sbMultiple.append(",").append(szName);
  2277. pszValue = sbMultiple.str();
  2278. return true;
  2279. }
  2280. szPath++; //skip over '/'
  2281. }
  2282. else
  2283. {
  2284. if (pNode && !strcmp(szPath, "Programs/Build"))
  2285. buildSet = pNode->queryProp("@buildSet");
  2286. if (!pNode)
  2287. pNode = pEnvRoot;
  2288. }
  2289. String str(szPath);
  2290. Owned<IPropertyTreeIterator> iter;
  2291. if (str.startsWith(XML_TAG_SOFTWARE) ||
  2292. str.startsWith(XML_TAG_HARDWARE) ||
  2293. str.startsWith(XML_TAG_PROGRAMS))
  2294. iter.setown(pEnvRoot->getElements(szPath));
  2295. else
  2296. iter.setown(pNode->getElements(szPath));
  2297. ForEach(*iter)
  2298. {
  2299. IPropertyTree* pChildNode = &iter->query();
  2300. const char* szName = pChildNode->queryProp(XML_ATTR_NAME);
  2301. if (szName)
  2302. {
  2303. bool bAdd;
  2304. if (buildSet)
  2305. {
  2306. StringBuffer xpath;
  2307. xpath.appendf("BuildSet[@name='%s']", buildSet);
  2308. bAdd = pChildNode->queryPropTree(xpath.str()) != NULL;
  2309. }
  2310. else
  2311. bAdd = true;
  2312. if (bAdd)
  2313. sbMultiple.append(",").append(szName);
  2314. }
  2315. }
  2316. }
  2317. pszValue = sbMultiple.str();
  2318. }
  2319. else if(pszQueryType && !strcmp(pszQueryType, "customType"))
  2320. {
  2321. sbMultiple.clear();
  2322. if(pszparams && *pszparams)
  2323. {
  2324. StringArray sArray;
  2325. sArray.appendList(pszparams, ",");
  2326. for(unsigned i = 0; i < sArray.ordinality() ; i++)
  2327. {
  2328. if(!strcmp(sArray.item(i), "checklock"))
  2329. {
  2330. StringBuffer sbName, sbUserIp, msg;
  2331. sbName.clear().append(req.getReqInfo().getUserId());
  2332. context.getPeer(sbUserIp);
  2333. if(m_userWithLock.length())
  2334. {
  2335. if (strcmp(sbName.str(), m_userWithLock.str()) || strcmp(sbUserIp.str(), m_userIp.str()))
  2336. sbMultiple.append(sArray.item(i)).append("=").append("Cannot get access to Wizard mode as Environment is currently being configured in wizard mode on machine ").append(m_userIp.str());
  2337. else if(!strcmp(sbName.str(), m_userWithLock.str()) && !strcmp(sbUserIp.str(),m_userIp.str()))
  2338. sbMultiple.append(sArray.item(i)).append("=").append("Another browser window already has write access on machine ").append(m_userIp.str()).append(".Please use that window.");
  2339. else
  2340. sbMultiple.append(sArray.item(i)).append("=''");
  2341. if(sbMultiple.length())
  2342. sbMultiple.append(",");
  2343. }
  2344. }
  2345. else if(!strcmp(sArray.item(i), "lastsaved"))
  2346. {
  2347. StringBuffer lastSaved;
  2348. m_lastSaved.getString(lastSaved);
  2349. if(lastSaved.length())
  2350. sbMultiple.append(sArray.item(i)).append("=").append(lastSaved);
  2351. else
  2352. sbMultiple.append(sArray.item(i)).append("=''");
  2353. if(sbMultiple.length())
  2354. sbMultiple.append(",");
  2355. }
  2356. }
  2357. }
  2358. pszValue = sbMultiple.str();
  2359. }
  2360. else if(pszQueryType && !strcmp(pszQueryType, "DomainsAndComputerTypes"))
  2361. {
  2362. xpath.clear().append(XML_TAG_HARDWARE"/"XML_TAG_DOMAIN);
  2363. sbMultiple.append("<Domains>");
  2364. bool flag = false;
  2365. Owned<IPropertyTreeIterator> pDomains = pEnvRoot->getElements(xpath.str());
  2366. ForEach(*pDomains)
  2367. {
  2368. IPropertyTree* pDomain = &pDomains->query();
  2369. sbMultiple.append(pDomain->queryProp(XML_ATTR_NAME)).append(",");
  2370. flag = true;
  2371. }
  2372. if (flag)
  2373. sbMultiple.setLength(sbMultiple.length() - 1);
  2374. sbMultiple.append("</Domains>");
  2375. flag = false;
  2376. xpath.clear().append(XML_TAG_HARDWARE"/"XML_TAG_COMPUTERTYPE);
  2377. sbMultiple.append("<ComputerTypes>");
  2378. Owned<IPropertyTreeIterator> pCTypes = pEnvRoot->getElements(xpath.str());
  2379. ForEach(*pCTypes)
  2380. {
  2381. IPropertyTree* pCType = &pCTypes->query();
  2382. sbMultiple.append(pCType->queryProp(XML_ATTR_NAME)).append(",");
  2383. flag = true;
  2384. }
  2385. if (flag)
  2386. sbMultiple.setLength(sbMultiple.length() - 1);
  2387. sbMultiple.append("</ComputerTypes>");
  2388. pszValue = sbMultiple.str();
  2389. }
  2390. else
  2391. {
  2392. if (pszCategory)
  2393. xpath.append(pszCategory);
  2394. if (pszBldSet)
  2395. xpath.append("/").append(pszBldSet);
  2396. if (pszCompName)
  2397. xpath.appendf("["XML_ATTR_NAME"='%s']", pszCompName);
  2398. if (pszSubType)
  2399. xpath.append("/").append(pszSubType);
  2400. if (pszSubTypeName)
  2401. xpath.appendf("["XML_ATTR_NAME"='%s']", pszSubTypeName);
  2402. if (pszAttrName)
  2403. xpath.appendf("/@%s", pszAttrName);
  2404. pszValue = pEnvRoot->queryProp(xpath.str());
  2405. }
  2406. resp.setReqValue(pszValue);
  2407. resp.setStatus("true");
  2408. return true;
  2409. }
  2410. bool CWsDeployFileInfo::unlockUser(IEspContext &context, IEspUnlockUserRequest &req, IEspUnlockUserResponse &resp)
  2411. {
  2412. synchronized block(m_mutex);
  2413. resp.setStatus("false");
  2414. StringBuffer sbName, sbUserIp;
  2415. sbName.clear().append(req.getReqInfo().getUserId());
  2416. context.getPeer(sbUserIp);
  2417. if (!strcmp(sbName.str(), m_userWithLock.str()) && !strcmp(sbUserIp.str(), m_userIp.str()))
  2418. {
  2419. m_userWithLock.clear();
  2420. m_userIp.clear();
  2421. resp.setStatus("true");
  2422. }
  2423. else
  2424. return false;
  2425. return true;
  2426. }
  2427. bool CWsDeployFileInfo::clientAlive(IEspContext &context, IEspClientAliveRequest &req, IEspClientAliveResponse &resp)
  2428. {
  2429. StringBuffer sbName, sbUserIp;
  2430. sbName.clear().append(req.getReqInfo().getUserId());
  2431. context.getPeer(sbUserIp);
  2432. StringBuffer sb(sbName);
  2433. sb.append(sbUserIp);
  2434. if (getConfigChanged() == true)
  2435. {
  2436. updateConfigFromFile();
  2437. setConfigChanged(false);
  2438. }
  2439. if (!strcmp(sbName.str(), m_userWithLock.str()) && !strcmp(sbUserIp.str(), m_userIp.str()))
  2440. {
  2441. CClientAliveThread* pClientAliveThread = m_keepAliveHTable.getValue(sb.str());
  2442. if (pClientAliveThread)
  2443. pClientAliveThread->signal();
  2444. }
  2445. m_lastSaved.getString(sb.clear());
  2446. resp.setLastSaved(sb.str());
  2447. m_pService->getLastStarted(sb.clear());
  2448. resp.setLastStarted(sb.str());
  2449. return true;
  2450. }
  2451. bool CWsDeployFileInfo::getEnvironment(IEspContext &context, IEspGetEnvironmentRequest &req, IEspGetEnvironmentResponse &resp)
  2452. {
  2453. synchronized block(m_mutex);
  2454. StringBuffer sb;
  2455. if (m_pFileIO.get())
  2456. {
  2457. Owned <IPropertyTree> pTree = createPTree(*m_pFileIO);
  2458. toXML(pTree, sb);
  2459. resp.setEnvXml(sb.str());
  2460. }
  2461. return true;
  2462. }
  2463. bool CWsDeployFileInfo::setEnvironment(IEspContext &context, IEspSetEnvironmentRequest &req, IEspSetEnvironmentResponse &resp)
  2464. {
  2465. synchronized block(m_mutex);
  2466. const char* pszEnv = req.getEnvXml();
  2467. if (!pszEnv || !*pszEnv)
  2468. {
  2469. resp.setReturnCode(1);
  2470. resp.setErrorMsg("Input xml cannot be empty");
  2471. return false;
  2472. }
  2473. try
  2474. {
  2475. StringBuffer sbBackup;
  2476. setEnvironment(context, NULL, pszEnv, "SetEnvironment", sbBackup);
  2477. }
  2478. catch(IException* e)
  2479. {
  2480. resp.setReturnCode(2);
  2481. StringBuffer sb;
  2482. e->errorMessage(sb);
  2483. resp.setErrorMsg(sb.str());
  2484. throw e;
  2485. }
  2486. resp.setReturnCode(0);
  2487. return true;
  2488. }
  2489. void CWsDeployFileInfo::setEnvironment(IEspContext &context, IConstWsDeployReqInfo *reqInfo, const char* pszEnv, const char* fnName, StringBuffer& sbBackupName, bool validate, bool updateDali)
  2490. {
  2491. if (!pszEnv)
  2492. return;
  2493. try
  2494. {
  2495. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  2496. Owned<IConstEnvironment> constEnv = factory->loadLocalEnvironment(pszEnv);
  2497. Owned<IPropertyTree> pEnvRoot = createPTreeFromXMLString(pszEnv);
  2498. Owned<IPropertyTreeIterator> dalis = pEnvRoot->getElements("Software/DaliServerProcess/Instance");
  2499. if (validate)
  2500. validateEnv(constEnv);
  2501. if (updateDali && dalis && dalis->first())
  2502. updateDaliEnv(pEnvRoot);
  2503. //save and write to backup
  2504. StringBuffer sXML;
  2505. StringBuffer tmp;
  2506. StringBuffer dtStr;
  2507. CDateTime dt;
  2508. try
  2509. {
  2510. if (m_pFile.get())
  2511. {
  2512. StringBuffer sb;
  2513. if (!checkDirExists(m_pService->getBackupDir()))
  2514. recursiveCreateDirectory(m_pService->getBackupDir());
  2515. while(true)
  2516. {
  2517. String strEnvFile(m_envFile);
  2518. int idx = strEnvFile.lastIndexOf('/');
  2519. if (idx <= 0)
  2520. idx = strEnvFile.lastIndexOf('\\');
  2521. String* tmpstr = strEnvFile.substring(idx+1);
  2522. sb.clear().append(m_pService->getBackupDir()).append(PATHSEPCHAR).append(*tmpstr);
  2523. delete tmpstr;
  2524. dt.setNow();
  2525. tmp.clear();
  2526. dtStr.clear();
  2527. dt.getDateString(tmp, true);
  2528. tmp.append("_");
  2529. dt.getTimeString(tmp, true);
  2530. dtStr.append(".").append(tmp);
  2531. dtStr.replaceString("-","_");
  2532. dtStr.replaceString(":","_");
  2533. String ext(sb);
  2534. idx = ext.lastIndexOf(PATHSEPCHAR);
  2535. if(ext.indexOf('.', idx > 0 ? idx : 0) != -1)
  2536. sb.insert(ext.lastIndexOf('.'), dtStr.str());
  2537. else
  2538. sb.append(dtStr.str());
  2539. if (checkFileExists(sb))
  2540. continue;
  2541. else
  2542. {
  2543. Owned<IFile> pFile(createIFile(sb.str()));
  2544. copyFile(pFile, m_pFile, 0x100000);
  2545. sbBackupName.clear().append(sb);
  2546. break;
  2547. }
  2548. }
  2549. }
  2550. }
  2551. catch(IException* e)
  2552. {
  2553. //ignore any attempts to create the backup
  2554. e->Release();
  2555. }
  2556. if (!m_pFile.get())
  2557. m_pFile.setown(createIFile(m_envFile));
  2558. m_pFileIO.clear();
  2559. m_pFileIO.setown(m_pFile->open(IFOcreaterw));
  2560. dt.setNow();
  2561. dt.getString(tmp.clear());
  2562. StringBuffer sbUserWithLock, sbUserIp;
  2563. if (reqInfo)
  2564. sbUserWithLock.clear().append(reqInfo->getUserId());
  2565. context.getPeer(sbUserIp);
  2566. sXML.appendf("<"XML_HEADER">\n<!-- Set via %s call by %s from ip %s on %s -->\n", fnName, sbUserWithLock.str(), sbUserIp.str(), tmp.str());
  2567. toXML(pEnvRoot, sXML, 0, XML_SortTags | XML_Format);
  2568. m_pFileIO->write(0, sXML.length(), sXML.str());
  2569. m_lastSaved.clear();
  2570. m_lastSaved.setNow();
  2571. m_lastSaved.getString(tmp.clear());
  2572. initFileInfo(false);
  2573. m_pNavTree.setown(getEnvTree(context, reqInfo));
  2574. //reset the readonly tree
  2575. m_constEnvRdOnly.setown(factory->loadLocalEnvironment(sXML.str()));
  2576. }
  2577. catch(IException* e)
  2578. {
  2579. throw e;
  2580. }
  2581. }
  2582. bool CWsDeployFileInfo::displaySettings(IEspContext &context, IEspDisplaySettingsRequest &req, IEspDisplaySettingsResponse &resp)
  2583. {
  2584. synchronized block(m_mutex);
  2585. if (m_pNavTree.get() == NULL)
  2586. {
  2587. resp.setComponent("Refresh");
  2588. resp.setXmlArgs("<Refresh flag=\"true\"/>");
  2589. return false;
  2590. }
  2591. const char* cmd = req.getCmd();
  2592. const char* xmlArg = req.getXmlArgs();
  2593. StringBuffer sbDefn, sbViewChildNodes, sbMultiRowNodes;
  2594. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  2595. Owned<IPropertyTree> pSettings = createPTree("Settings");
  2596. Owned<IPropertyTree> pParamTree = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  2597. IPropertyTree* pSoftwareFolder = pParamTree->queryPropTree("Component[@parent='Software']");
  2598. IPropertyTree* pBuildFolder = pParamTree->queryPropTree("Component[@name='Programs']");
  2599. IPropertyTree* pHardwareFolder = pParamTree->queryPropTree("Component[@name='Hardware']");
  2600. IPropertyTree* pBuildSet = pParamTree->queryPropTree(XML_TAG_BUILDSET);
  2601. IPropertyTree* pEnvSettings = pParamTree->queryPropTree("Component[@name='EnvSettings']");
  2602. IPropertyTree* pEnvironment = pParamTree->queryPropTree("Component[@name='Environment']");
  2603. if (pSoftwareFolder)
  2604. {
  2605. IPropertyTree* pEnvSoftware = pEnvRoot->queryPropTree(XML_TAG_SOFTWARE);
  2606. Owned<IPropertyTreeIterator> iter = pParamTree->getElements("Component[@parent='Software']", iptiter_sort);
  2607. ForEach (*iter)
  2608. {
  2609. IPropertyTree* pFolder = &iter->query();
  2610. const char* pszCompType = pFolder->queryProp("@compType");
  2611. const char* pszCompName = pFolder->queryProp(XML_ATTR_NAME);
  2612. StringBuffer xpath;
  2613. if (!strcmp(pszCompName, "Directories"))
  2614. xpath.append(pszCompName);
  2615. else
  2616. xpath.appendf("%s[@name='%s']", pszCompType, pszCompName);
  2617. IPropertyTree* pComp = pEnvSoftware->queryPropTree(xpath.str());
  2618. if (!pComp)
  2619. continue;
  2620. if (!strcmp(pszCompType, XML_TAG_ESPSERVICE) || !strcmp(pszCompType, XML_TAG_PLUGINPROCESS))
  2621. xpath.clear().appendf("./Programs/Build/BuildSet[@name=\"%s\"]", pComp->queryProp(XML_ATTR_BUILDSET));
  2622. else
  2623. xpath.clear().appendf("./Programs/Build/BuildSet[@processName=\"%s\"]", pszCompType);
  2624. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(xpath.str());
  2625. buildSetIter->first();
  2626. IPropertyTree* pBuildSet = NULL;
  2627. if (buildSetIter->isValid())
  2628. pBuildSet = &buildSetIter->query();
  2629. else if (!strcmp(pszCompName, "Directories"))
  2630. {
  2631. pBuildSet = createPTree(XML_TAG_BUILDSET);
  2632. pBuildSet->addProp(XML_ATTR_NAME, pszCompName);
  2633. pBuildSet->addProp(XML_ATTR_SCHEMA, "directories.xsd");
  2634. pBuildSet->addProp(XML_ATTR_PROCESS_NAME, "Directories");
  2635. }
  2636. if (!pBuildSet)
  2637. throw MakeStringException(-1, "Cannot determine buildset for component in environment: '%s' named '%s'.", pszCompType, pszCompName);
  2638. const char* buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  2639. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  2640. if ( m_pService->m_configHelper.isInBuildSet(pszCompType,buildSetName) == false )
  2641. {
  2642. throw MakeStringException(-1, "Component '%s' named '%s' not in build set. Component may be incompatible with the current version.", pszCompType, pszCompName);
  2643. }
  2644. StringBuffer buildSetPath;
  2645. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  2646. if (!strcmp(processName, XML_TAG_ESPSERVICE) || !strcmp(processName, XML_TAG_PLUGINPROCESS))
  2647. getDefnString(pEnvRoot, pSchema, pComp->queryProp(XML_ATTR_BUILDSET), sbDefn, sbViewChildNodes, sbMultiRowNodes);
  2648. else if (!strcmp(processName, XML_TAG_TOPOLOGY))
  2649. generateHeaderForTopology(pEnvRoot, sbDefn);
  2650. else
  2651. getDefnString(pEnvRoot, pSchema, processName, sbDefn, sbViewChildNodes, sbMultiRowNodes);
  2652. resp.setCompDefn(sbDefn.str());
  2653. resp.setViewChildNodes(sbViewChildNodes.str());
  2654. resp.setMultiRowNodes(sbMultiRowNodes.str());
  2655. StringBuffer xml;
  2656. toXML(pComp, xml, false);
  2657. xml.replaceString("\\","\\\\");
  2658. //add any missing parameters
  2659. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xml);
  2660. Owned<IPropertyTree> pNewCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName(), true, false, 0, true);
  2661. if (pNewCompTree)
  2662. {
  2663. StringBuffer sbxml;
  2664. toXML(pNewCompTree, sbxml);
  2665. Owned<IAttributeIterator> iAttr = pNewCompTree->getAttributes();
  2666. ForEach(*iAttr)
  2667. {
  2668. const char* attrName = iAttr->queryName();
  2669. if (!pSrcTree->hasProp(attrName))
  2670. {
  2671. pSrcTree->addProp(attrName, iAttr->queryValue());
  2672. const char* prop = "@_notInEnv";
  2673. StringBuffer sbVal;
  2674. if (pSrcTree->hasProp(prop))
  2675. sbVal.append(pSrcTree->queryProp(prop));
  2676. pSrcTree->setProp(prop, sbVal.append(";").append(attrName).append(";").str());
  2677. }
  2678. }
  2679. //Add subelements that occur only once
  2680. Owned<IPropertyTreeIterator> iterElems = pNewCompTree->getElements("*");
  2681. ForEach (*iterElems)
  2682. {
  2683. IPropertyTree* pElem = &iterElems->query();
  2684. Owned<IPropertyTreeIterator> srcElems = pSrcTree->getElements(pElem->queryName());
  2685. IPropertyTree* pSrcElem = NULL;
  2686. ForEach(*srcElems)
  2687. {
  2688. pSrcElem = &srcElems->query();
  2689. Owned<IAttributeIterator> iAttrElem = pElem->getAttributes();
  2690. ForEach(*iAttrElem)
  2691. {
  2692. const char* attrName = iAttrElem->queryName();
  2693. if (!pSrcElem->hasProp(attrName))
  2694. {
  2695. pSrcElem->addProp(attrName, iAttrElem->queryValue());
  2696. const char* prop = "@_notInEnv";
  2697. StringBuffer sbVal;
  2698. if (pSrcElem->hasProp(prop))
  2699. sbVal.append(pSrcElem->queryProp(prop));
  2700. pSrcElem->setProp(prop, sbVal.append(";").append(attrName).append(";").str());
  2701. }
  2702. }
  2703. Owned<IPropertyTreeIterator> iterSubElems = pElem->getElements("*");
  2704. ForEach (*iterSubElems)
  2705. {
  2706. IPropertyTree* pSubElem = &iterSubElems->query();
  2707. Owned<IPropertyTreeIterator> srcSubElems = pSrcElem->getElements(pSubElem->queryName());
  2708. IPropertyTree* pSrcSubElem = NULL;
  2709. ForEach(*srcSubElems)
  2710. {
  2711. pSrcSubElem = &srcSubElems->query();
  2712. Owned<IAttributeIterator> iAttrElem = pSubElem->getAttributes();
  2713. ForEach(*iAttrElem)
  2714. {
  2715. const char* attrName = iAttrElem->queryName();
  2716. if (!pSrcSubElem->hasProp(attrName))
  2717. pSrcSubElem->addProp(attrName, iAttrElem->queryValue());
  2718. }
  2719. }
  2720. if (!pSrcSubElem)
  2721. pSrcSubElem = pSrcElem->addPropTree(pSubElem->queryName(), createPTreeFromIPT(pSubElem));
  2722. }
  2723. }
  2724. }
  2725. Owned<IPropertyTreeIterator> iterNotes = pSrcTree->getElements("Notes");
  2726. ForEach (*iterNotes)
  2727. {
  2728. IPropertyTree* pNotes = &iterNotes->query();
  2729. Owned<IPropertyTreeIterator> iterNote = pNotes->getElements("Note");
  2730. ForEach (*iterNote)
  2731. {
  2732. IPropertyTree* pNote = &iterNote->query();
  2733. StringBuffer sbVal(pNotes->queryProp(pNote->queryName()));
  2734. sbVal.replaceString("\r\n", "&#13;&#10;");
  2735. pNotes->setProp(pNote->queryName(), sbVal.str());
  2736. }
  2737. }
  2738. xml.clear();
  2739. toXML(pSrcTree, xml, false);
  2740. }
  2741. if (!strcmp(pszCompType, "Directories"))
  2742. {
  2743. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xml);
  2744. Owned<IPropertyTreeIterator> iterCats = pSrcTree->getElements("Category");
  2745. ForEach (*iterCats)
  2746. {
  2747. IPropertyTree* pCat = &iterCats->query();
  2748. const char* pszName = pCat->queryProp(XML_ATTR_NAME);
  2749. if (!strcmp(pszName, "lock") || !strcmp(pszName, "run") || !strcmp(pszName, "conf"))
  2750. {
  2751. pSrcTree->removeTree(pCat);
  2752. (*iterCats).first();
  2753. }
  2754. else
  2755. {
  2756. IPropertyTree* pOver = pCat->queryPropTree("Override[1]");
  2757. if (!pOver)
  2758. pOver = pCat->addPropTree("Override", createPTree());
  2759. if (!pOver->queryProp("@component"))
  2760. pOver->addProp("@component", "");
  2761. if (!pOver->queryProp("@dir"))
  2762. pOver->addProp("@dir", "");
  2763. if (!pOver->queryProp("@instance"))
  2764. pOver->addProp("@instance", "");
  2765. }
  2766. }
  2767. xml.clear();
  2768. toXML(pSrcTree, xml, false);
  2769. }
  2770. else if (!strcmp(pszCompType, XML_TAG_THORCLUSTER))
  2771. {
  2772. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xml);
  2773. IPropertyTree* pTopoNode = pSrcTree->queryPropTree(XML_TAG_TOPOLOGY);
  2774. if (!pTopoNode)
  2775. {
  2776. pTopoNode = pSrcTree->addPropTree(XML_TAG_TOPOLOGY, createPTree());
  2777. IPropertyTree* pMaster = pSrcTree->queryPropTree(XML_TAG_THORMASTERPROCESS);
  2778. if (pMaster)
  2779. {
  2780. IPropertyTree* pMasterNode = createPTree(XML_TAG_NODE);
  2781. pMasterNode->addProp(XML_ATTR_PROCESS, pMaster->queryProp(XML_ATTR_NAME));
  2782. pTopoNode->addPropTree(XML_TAG_NODE, pMasterNode);
  2783. Owned<IPropertyTreeIterator> iterSlaves = pSrcTree->getElements(XML_TAG_THORSLAVEPROCESS);
  2784. ForEach (*iterSlaves)
  2785. {
  2786. IPropertyTree* pSlave = &iterSlaves->query();
  2787. IPropertyTree* pNode = createPTree(XML_TAG_NODE);
  2788. pNode->addProp(XML_ATTR_PROCESS, pSlave->queryProp(XML_ATTR_NAME));
  2789. pMasterNode->addPropTree(XML_TAG_NODE, pNode);
  2790. }
  2791. }
  2792. Owned<IPropertyTreeIterator> iterSpares = pSrcTree->getElements(XML_TAG_THORSPAREPROCESS);
  2793. ForEach (*iterSpares)
  2794. {
  2795. IPropertyTree* pSpare = &iterSpares->query();
  2796. IPropertyTree* pNode = createPTree(XML_TAG_NODE);
  2797. pNode->addProp(XML_ATTR_PROCESS, pSpare->queryProp(XML_ATTR_NAME));
  2798. pTopoNode->addPropTree(XML_TAG_NODE, pNode);
  2799. }
  2800. }
  2801. xpath.clear().append("Topology/Node");
  2802. Owned<IPropertyTreeIterator> iterMNodes = pSrcTree->getElements(xpath.str());
  2803. ForEach (*iterMNodes)
  2804. {
  2805. IPropertyTree* pMasterNode = &iterMNodes->query();
  2806. const char* pszMName = pMasterNode->queryProp(XML_ATTR_PROCESS);
  2807. pMasterNode->addProp("@_processId", pszMName);
  2808. if (pszMName)
  2809. {
  2810. xpath.clear().appendf(XML_TAG_THORMASTERPROCESS"/[@name='%s']", pszMName);
  2811. IPropertyTree* pMasterNodeTree = pComp->queryPropTree(xpath);
  2812. //if not master, then spare
  2813. if (!pMasterNodeTree)
  2814. {
  2815. xpath.clear().appendf(XML_TAG_THORSPAREPROCESS"/[@name='%s']", pszMName);
  2816. IPropertyTree* pSpareNodeTree = pComp->queryPropTree(xpath);
  2817. const char* pszComputer = pSpareNodeTree->queryProp(XML_ATTR_COMPUTER);
  2818. if (pszComputer)
  2819. {
  2820. xpath.clear().appendf("Hardware/Computer/[@name='%s']", pszComputer);
  2821. IPropertyTree* pComputer= pEnvRoot->queryPropTree(xpath.str());
  2822. const char* pszNetAddr = pComputer->queryProp(XML_ATTR_NETADDRESS);
  2823. if (pszNetAddr)
  2824. pMasterNode->addProp(XML_ATTR_NETADDRESS, pszNetAddr);
  2825. pMasterNode->addProp(XML_ATTR_NAME, pszComputer);
  2826. pMasterNode->addProp(XML_ATTR_PROCESS, "Spare");
  2827. }
  2828. }
  2829. else
  2830. {
  2831. const char* pszComputer = pMasterNodeTree->queryProp(XML_ATTR_COMPUTER);
  2832. if (pszComputer)
  2833. {
  2834. xpath.clear().appendf("Hardware/Computer/[@name='%s']", pszComputer);
  2835. IPropertyTree* pComputer= pEnvRoot->queryPropTree(xpath.str());
  2836. if (pComputer == NULL)
  2837. throw MakeStringException(-1, "XPATH: %s is invalid. (Did you add the Hardware?)",xpath.str());
  2838. const char* pszNetAddr = pComputer->queryProp(XML_ATTR_NETADDRESS);
  2839. if (pszNetAddr)
  2840. pMasterNode->addProp(XML_ATTR_NETADDRESS, pszNetAddr);
  2841. pMasterNode->addProp(XML_ATTR_NAME, pszComputer);
  2842. pMasterNode->addProp(XML_ATTR_PROCESS, "Master");
  2843. }
  2844. xpath.clear().appendf("Node");
  2845. Owned<IPropertyTreeIterator> iterSNodes = pMasterNode->getElements(xpath);
  2846. ForEach (*iterSNodes)
  2847. {
  2848. IPropertyTree* pSlaveNode = &iterSNodes->query();
  2849. const char* pszSName = pSlaveNode->queryProp(XML_ATTR_PROCESS);
  2850. pSlaveNode->addProp("@_processId", pszSName);
  2851. if (pszMName)
  2852. {
  2853. xpath.clear().appendf("ThorSlaveProcess/[@name='%s']", pszSName);
  2854. IPropertyTree* pSlaveNodeTree = pSrcTree->queryPropTree(xpath);
  2855. const char* pszComputer = pSlaveNodeTree->queryProp(XML_ATTR_COMPUTER);
  2856. if (pszComputer)
  2857. {
  2858. xpath.clear().appendf("Hardware/Computer/[@name='%s']", pszComputer);
  2859. IPropertyTree* pComputer= pEnvRoot->queryPropTree(xpath.str());
  2860. const char* pszNetAddr = pComputer->queryProp(XML_ATTR_NETADDRESS);
  2861. if (pszNetAddr)
  2862. pSlaveNode->addProp(XML_ATTR_NETADDRESS, pszNetAddr);
  2863. pSlaveNode->addProp(XML_ATTR_NAME, pszComputer);
  2864. pSlaveNode->addProp(XML_ATTR_PROCESS, "Slave");
  2865. }
  2866. }
  2867. }
  2868. }
  2869. }
  2870. }
  2871. xml.clear();
  2872. toXML(pSrcTree, xml, false);
  2873. }
  2874. else if (!strcmp(pszCompType, "RoxieCluster"))
  2875. {
  2876. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xml);
  2877. pNewCompTree.setown(generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName()));
  2878. if (!strcmp(pszCompType, "RoxieCluster"))
  2879. {
  2880. xpath.clear().append("RoxieFarmProcess/RoxieServerProcess");
  2881. Owned<IPropertyTreeIterator> iterRoxieServers = pSrcTree->getElements(xpath.str());
  2882. ForEach (*iterRoxieServers )
  2883. {
  2884. IPropertyTree* pRoxieServer = &iterRoxieServers->query();
  2885. const char* pszComputer = pRoxieServer->queryProp(XML_ATTR_COMPUTER);
  2886. if (pszComputer)
  2887. {
  2888. xpath.clear().appendf("Hardware/Computer/[@name='%s']", pszComputer);
  2889. IPropertyTree* pComputer= pEnvRoot->queryPropTree(xpath.str());
  2890. const char* pszNetAddr = pComputer->queryProp(XML_ATTR_NETADDRESS);
  2891. if (pszNetAddr)
  2892. pRoxieServer->addProp(XML_ATTR_NETADDRESS, pszNetAddr);
  2893. }
  2894. }
  2895. xpath.clear().append(XML_TAG_ROXIE_ONLY_SLAVE);
  2896. Owned<IPropertyTreeIterator> iterSlaves = pSrcTree->getElements(xpath.str());
  2897. ForEach (*iterSlaves)
  2898. {
  2899. IPropertyTree* pRoxieSlave = &iterSlaves->query();
  2900. const char* pszComputer = pRoxieSlave->queryProp(XML_ATTR_COMPUTER);
  2901. if (pszComputer)
  2902. {
  2903. xpath.clear().appendf("Hardware/Computer/[@name='%s']", pszComputer);
  2904. IPropertyTree* pComputer= pEnvRoot->queryPropTree(xpath.str());
  2905. const char* pszNetAddr = pComputer->queryProp(XML_ATTR_NETADDRESS);
  2906. if (pszNetAddr)
  2907. pRoxieSlave->addProp(XML_ATTR_NETADDRESS, pszNetAddr);
  2908. }
  2909. }
  2910. }
  2911. xml.clear();
  2912. toXML(pSrcTree, xml, false);
  2913. xml.replaceString("<RoxieFarmProcess ", "<RoxieFarmProcess process=\"Farm\" ");
  2914. xml.replaceString("<RoxieServerProcess ", "<RoxieServerProcess process=\"Server\" ");
  2915. xml.replaceString("<RoxieSlave ", "<RoxieSlave itemType=\"Roxie Agent\" ");
  2916. xml.replaceString("<RoxieChannel ", "<RoxieChannel itemType=\"Channel\" ");
  2917. }
  2918. else if (!strcmp(pszCompType, XML_TAG_ESPPROCESS))
  2919. {
  2920. Owned<IPropertyTree> pTree = createPTreeFromXMLString(xml);
  2921. Owned<IPropertyTreeIterator> iterBindings = pTree->getElements(XML_TAG_ESPBINDING);
  2922. ForEach (*iterBindings)
  2923. {
  2924. IPropertyTree* pBinding = &iterBindings->query();
  2925. bool flag = false;
  2926. Owned<IPropertyTreeIterator> iterUrl = pBinding->getElements("AuthenticateFeature");
  2927. ForEach (*iterUrl)
  2928. {
  2929. flag = true;
  2930. break;
  2931. }
  2932. if (!flag)
  2933. {
  2934. IPropertyTree* pAuthFeature = pBinding->addPropTree( "AuthenticateFeature", createPTree() );
  2935. pAuthFeature->addProp("@authenticate", "");
  2936. pAuthFeature->addProp("@description", "");
  2937. pAuthFeature->addProp("@path", "");
  2938. pAuthFeature->addProp("@resource", "");
  2939. pAuthFeature->addProp("@service", "");
  2940. }
  2941. flag = false;
  2942. Owned<IPropertyTreeIterator> iterFeature = pBinding->getElements("Authenticate");
  2943. ForEach (*iterFeature)
  2944. {
  2945. flag = true;
  2946. break;
  2947. }
  2948. if (!flag)
  2949. {
  2950. IPropertyTree* pAuth = pBinding->addPropTree( "Authenticate", createPTree() );
  2951. pAuth->addProp("@access", "");
  2952. pAuth->addProp("@description", "");
  2953. pAuth->addProp("@method", "");
  2954. pAuth->addProp("@path", "");
  2955. pAuth->addProp("@resource", "");
  2956. }
  2957. }
  2958. Owned<IPropertyTreeIterator> iterInst = pTree->getElements(XML_TAG_INSTANCE);
  2959. ForEach (*iterInst)
  2960. {
  2961. IPropertyTree* pInst = &iterInst->query();
  2962. Owned<IPropertyTreeIterator> iterNode = pInst->getElements("*");
  2963. if (iterNode->first() && iterNode->isValid())
  2964. {
  2965. ForEach (*iterNode)
  2966. {
  2967. IPropertyTree* pNode = &iterNode->query();
  2968. if (!strcmp(pNode->queryName(), "CSR") || !strcmp(pNode->queryName(), "Certificate") || !strcmp(pNode->queryName(), "PrivateKey"))
  2969. {
  2970. StringBuffer sbVal(pInst->queryProp(pNode->queryName()));
  2971. sbVal.replaceString("\r\n", "&#13;&#10;");
  2972. pInst->setProp(pNode->queryName(), sbVal.str());
  2973. }
  2974. }
  2975. }
  2976. if (!pInst->hasProp("CSR"))
  2977. pInst->addPropTree("CSR", createPTree());
  2978. if (!pInst->hasProp("Certificate"))
  2979. pInst->addPropTree("Certificate", createPTree());
  2980. if (!pInst->hasProp("PrivateKey"))
  2981. pInst->addPropTree("PrivateKey", createPTree());
  2982. }
  2983. xml.clear();
  2984. toXML(pTree, xml, false);
  2985. }
  2986. const char* pszBldSet = pComp->queryProp(XML_ATTR_BUILDSET);
  2987. if (strcmp(pszCompName, "Directories") && !pszBldSet)
  2988. throw MakeStringException(-1, "Cannot determine buildset for component in environment: '%s' named '%s'.", pszCompType, pszCompName);
  2989. if (!strcmp(pszCompType, XML_TAG_ESPSERVICE) || !strcmp(pszCompType, XML_TAG_PLUGINPROCESS))
  2990. resp.setComponent(pszBldSet);
  2991. else
  2992. resp.setComponent(pszCompType);
  2993. resp.setXmlArgs( xml.str() );
  2994. }
  2995. }
  2996. else if (pHardwareFolder)
  2997. {
  2998. IPropertyTree* pEnvHardware = pEnvRoot->queryPropTree(XML_TAG_HARDWARE);
  2999. generateHardwareHeaders(pEnvRoot, sbDefn);
  3000. resp.setCompDefn(sbDefn.str());
  3001. StringBuffer sb;
  3002. Owned<IPropertyTree> multiRowNodes = createPTree("multiRowNodes");
  3003. multiRowNodes->addProp("Node", "ComputerType");
  3004. multiRowNodes->addProp("Node", "Domain");
  3005. multiRowNodes->addProp("Node", "Computer");
  3006. multiRowNodes->addProp("Node", "Switch");
  3007. multiRowNodes->addProp("Node", "NAS");
  3008. toXML(multiRowNodes, sb);
  3009. resp.setMultiRowNodes(sb.str());
  3010. StringBuffer xml;
  3011. toXML(pEnvHardware, xml, false);
  3012. xml.replaceString("switch=","Switch=");
  3013. //add any missing parameters
  3014. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xml);
  3015. StringBuffer sbTemp;
  3016. Owned<IPropertyTree> pNewCompTree = createPTree(XML_TAG_HARDWARE);
  3017. generateHardwareHeaders(pEnvRoot, sbTemp, false, pNewCompTree);
  3018. const char* pElemNames[] = {XML_TAG_COMPUTER};
  3019. bool modified = false;
  3020. for (int i = 0; i < sizeof(pElemNames)/sizeof(char*); i++)
  3021. {
  3022. IPropertyTree* pSrcElem = pNewCompTree->queryPropTree(pElemNames[i]);
  3023. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements(pElemNames[i]);
  3024. ForEach (*iter)
  3025. {
  3026. IPropertyTree* pElem = &iter->query();
  3027. Owned<IAttributeIterator> iAttr = pSrcElem->getAttributes();
  3028. ForEach(*iAttr)
  3029. {
  3030. const char* attrName = iAttr->queryName();
  3031. if (strcmp(attrName, "@state") && strcmp(attrName, "@switch") &&!pElem->hasProp(attrName))
  3032. {
  3033. pElem->addProp(attrName, iAttr->queryValue());
  3034. modified = true;
  3035. }
  3036. }
  3037. }
  3038. }
  3039. if (modified)
  3040. {
  3041. xml.clear();
  3042. toXML(pSrcTree, xml, false);
  3043. }
  3044. resp.setComponent(XML_TAG_HARDWARE);
  3045. resp.setXmlArgs( xml.str() );
  3046. }
  3047. else if (pBuildFolder)
  3048. {
  3049. IPropertyTree* pEnvPrograms = pEnvRoot->queryPropTree(XML_TAG_PROGRAMS);
  3050. generateBuildHeaders(pEnvRoot, true, sbDefn, false);
  3051. resp.setCompDefn(sbDefn.str());
  3052. StringBuffer xml;
  3053. toXML(pEnvPrograms, xml, false);
  3054. xml.replaceString(" url="," path=");
  3055. resp.setComponent(XML_TAG_PROGRAMS);
  3056. resp.setXmlArgs( xml.str() );
  3057. }
  3058. else if (pBuildSet)
  3059. {
  3060. generateBuildHeaders(pEnvRoot, false, sbDefn, false);
  3061. resp.setCompDefn(sbDefn.str());
  3062. IPropertyTree* pEnvPrograms = pEnvRoot->queryPropTree(XML_TAG_PROGRAMS);
  3063. Owned<IPropertyTreeIterator> iter = pParamTree->getElements(XML_TAG_BUILDSET);
  3064. ForEach (*iter)
  3065. {
  3066. IPropertyTree* pFolder = &iter->query();
  3067. const char* pszBuild = pFolder->queryProp(XML_ATTR_BUILD);
  3068. const char* pszBuildPath = pFolder->queryProp("@buildpath");
  3069. const char* pszBuildSet = pFolder->queryProp(XML_ATTR_NAME);
  3070. const char* pszBuildSetPath = pFolder->queryProp("@path");
  3071. StringBuffer xpath;
  3072. xpath.appendf("Build[@name='%s']/BuildSet[@name='%s']", pszBuild, pszBuildSet);
  3073. IPropertyTree* pComp = pEnvPrograms->queryPropTree(xpath.str());
  3074. if (!pComp)
  3075. throw MakeStringException(-1, "No such build and buildset in environment: '%s' named '%s'.", pszBuild, pszBuildSet);
  3076. StringBuffer s;
  3077. s.append("./Programs/Build[@name=\"").append(pszBuild).append("\"]");
  3078. IPropertyTree *b = pEnvRoot->queryPropTree(s.str());
  3079. IPropertyTree *bs = NULL;
  3080. IPropertyTree* pParentNode = NULL;
  3081. IPropertyTree* pFiles = NULL;
  3082. if (b)
  3083. {
  3084. s.clear().append("BuildSet[@name=\"").append(pszBuildSet).append("\"]");
  3085. bs = b->queryPropTree(s.str());
  3086. StringBuffer fileName;
  3087. connectBuildSet(b, bs, fileName, m_Environment);
  3088. fileName.append(bs->queryProp("@installSet"));
  3089. pParentNode = createPTreeFromXMLFile(fileName.str());
  3090. pFiles = pParentNode->queryPropTree("File");
  3091. }
  3092. StringBuffer xml;
  3093. toXML(pFiles, xml, false);
  3094. resp.setComponent(XML_TAG_BUILDSET);
  3095. resp.setXmlArgs( xml.str() );
  3096. }
  3097. }
  3098. else if (pEnvSettings)
  3099. {
  3100. IPropertyTree* pEnvSettings = pEnvRoot->queryPropTree("EnvSettings");
  3101. generateHeadersForEnvSettings(pEnvRoot, sbDefn);
  3102. resp.setCompDefn(sbDefn.str());
  3103. StringBuffer xml;
  3104. toXML(pEnvSettings, xml, false);
  3105. resp.setComponent("EnvSettings");
  3106. resp.setXmlArgs( xml.str() );
  3107. }
  3108. else if (pEnvironment)
  3109. {
  3110. generateHeadersForEnvXmlView(pEnvRoot, sbDefn);
  3111. resp.setCompDefn(sbDefn.str());
  3112. StringBuffer xml;
  3113. toXML(pEnvRoot, xml, false);
  3114. resp.setComponent("Environment");
  3115. resp.setXmlArgs( xml.str() );
  3116. }
  3117. return true;
  3118. }
  3119. bool CWsDeployFileInfo::startDeployment(IEspContext &context, IEspStartDeploymentRequest &req, IEspStartDeploymentResponse &resp)
  3120. {
  3121. synchronized block(m_mutex);
  3122. checkForRefresh(context, &req.getReqInfo(), true);
  3123. const char* selComps = req.getSelComps();
  3124. CDeployOptions& depOptions = dynamic_cast<CDeployOptions&>(req.getOptions());
  3125. CDeployInfo depInfo("wsDeploy", "true");
  3126. StringBuffer deployResult;
  3127. CWsDeployEngine depEngine(*m_pService, &context, depInfo, selComps, 2);
  3128. depEngine.deploy(depOptions);
  3129. Owned<IPropertyTree> pDeployResult = depEngine.getDeployResult();
  3130. if (pDeployResult)
  3131. {
  3132. IPropertyTree* pComponents = pDeployResult->queryPropTree("SelectedComponents");
  3133. toXML(pComponents, deployResult, false);
  3134. }
  3135. IPropertyTree* pOptions = pDeployResult->queryPropTree("Options");
  3136. if (pOptions)
  3137. toXML(pOptions, deployResult, false);
  3138. resp.setStatus( depEngine.getDeployStatus() );
  3139. if (depEngine.GetErrorCount() == 0)
  3140. resp.setStatus(deployResult.str());
  3141. return true;
  3142. }
  3143. bool CWsDeployFileInfo::getDeployableComps(IEspContext &context, IEspGetDeployableCompsRequest &req, IEspGetDeployableCompsResponse &resp)
  3144. {
  3145. synchronized block(m_mutex);
  3146. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3147. Owned<IPropertyTreeIterator> iter = pEnvRoot->getElements("Software/*");
  3148. Owned<IPropertyTree> pDeploy = createPTree("Deploy");
  3149. ForEach(*iter)
  3150. {
  3151. IPropertyTree* pComponent = &iter->query();
  3152. const char* type = pComponent->queryName();
  3153. if (stricmp(type, "Topology")!=0)
  3154. {
  3155. const char* name = pComponent->queryProp(XML_ATTR_NAME);
  3156. const char* build = pComponent->queryProp(XML_ATTR_BUILD);
  3157. const char* buildSet= pComponent->queryProp(XML_ATTR_BUILDSET);
  3158. StringBuffer sXPath;
  3159. sXPath.appendf("Programs/Build[@name='%s']/BuildSet[@name='%s']/@deployable", build, buildSet);
  3160. const char* szDeployable = pEnvRoot->queryProp(sXPath.str());
  3161. bool bDeployable = !szDeployable ||
  3162. (stricmp(szDeployable, "no") != 0 &&
  3163. stricmp(szDeployable, "false") != 0 &&
  3164. strcmp(szDeployable, "0") != 0);
  3165. if (name && *name && build && *build && bDeployable)
  3166. {
  3167. IPropertyTree* pCompNode = pDeploy->addPropTree( XML_TAG_COMPONENT, createPTree() );
  3168. pCompNode->addProp(XML_ATTR_NAME, name);
  3169. pCompNode->addProp(XML_ATTR_BUILD, build);
  3170. pCompNode->addProp(XML_ATTR_BUILDSET, type);
  3171. Owned<IPropertyTreeIterator> iter = pComponent->getElements("*", iptiter_sort);
  3172. ForEach(*iter)
  3173. {
  3174. IPropertyTree* pNode = &iter->query();
  3175. const char* nodeName = pNode->queryName();
  3176. const char* computer = pNode->queryProp(XML_ATTR_COMPUTER);
  3177. const char* instanceName = pNode->queryProp(XML_ATTR_NAME);
  3178. if (computer && *computer)
  3179. {
  3180. const char* instanceNodeNames[] = { XML_TAG_INSTANCE, XML_TAG_ROXIE_SERVER, XML_TAG_ROXIE_SLAVE };
  3181. for (UINT i=0; i<sizeof(instanceNodeNames) / sizeof(instanceNodeNames[0]); i++)
  3182. if (!strcmp(nodeName, instanceNodeNames[i]))
  3183. {
  3184. if (*nodeName != 'R')// || //neither RoxieServerProcess nor RoxieSlaveProcess
  3185. {
  3186. IPropertyTree* pInstanceNode = pCompNode->addPropTree(XML_TAG_INSTANCES, createPTree());
  3187. const char* directory = pNode->queryProp(*nodeName == 'R' ? XML_ATTR_DATADIRECTORY : XML_ATTR_DIRECTORY);
  3188. if (directory && *directory)
  3189. pInstanceNode->addProp(XML_ATTR_BUILD, directory);
  3190. pInstanceNode->addProp("@nodeName", computer);
  3191. pInstanceNode->addProp(XML_ATTR_BUILDSET, XML_TAG_INSTANCE);
  3192. pInstanceNode->addProp("@instanceName", instanceName);
  3193. }
  3194. }
  3195. }
  3196. }
  3197. }
  3198. }
  3199. }
  3200. StringBuffer xml, outputXml;
  3201. toXML(pDeploy, xml, false);
  3202. resp.setComponent( "Deploy" );
  3203. resp.setXmlArgs( xml.str() );
  3204. return true;
  3205. }
  3206. bool CWsDeployFileInfo::getComputersForRoxie(IEspContext &context, IEspGetComputersForRoxieRequest &req, IEspGetComputersForRoxieResponse &resp)
  3207. {
  3208. synchronized block(m_mutex);
  3209. checkForRefresh(context, &req.getReqInfo(), true);
  3210. const char* cmd = req.getCmd();
  3211. const char* xmlArg = req.getXmlArgs();
  3212. StringBuffer sbC, sbF;
  3213. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3214. getComputersListWithUsage(pEnvRoot, sbC, sbF);
  3215. resp.setComputers(sbC.str());
  3216. resp.setFilters( sbF.str() );
  3217. return true;
  3218. }
  3219. bool CWsDeployFileInfo::handleRoxieOperation(IEspContext &context, IEspHandleRoxieOperationRequest &req, IEspHandleRoxieOperationResponse &resp)
  3220. {
  3221. synchronized block(m_mutex);
  3222. checkForRefresh(context, &req.getReqInfo(), true);
  3223. const char* cmd = req.getCmd();
  3224. const char* xmlArg = req.getXmlArgs();
  3225. StringBuffer sbC, sbF;
  3226. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3227. bool retVal = ::handleRoxieOperation(pEnvRoot, cmd, xmlArg);
  3228. resp.setStatus(retVal? "true" : "false");
  3229. return true;
  3230. }
  3231. bool CWsDeployFileInfo::getBuildSetInfo(IEspContext &context, IEspGetBuildSetInfoRequest &req, IEspGetBuildSetInfoResponse &resp)
  3232. {
  3233. synchronized block(m_mutex);
  3234. checkForRefresh(context, &req.getReqInfo(), true);
  3235. const char* cmd = req.getCmd();
  3236. const char* xmlArg = req.getXmlArgs();
  3237. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3238. Owned<IPropertyTree> pSettings = createPTree("Settings");
  3239. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  3240. IPropertyTree* pBuildSet = pSrcTree->queryPropTree(XML_TAG_BUILDSET);
  3241. if (pBuildSet)
  3242. {
  3243. IPropertyTree* pEnvPrograms = pEnvRoot->queryPropTree(XML_TAG_PROGRAMS);
  3244. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements(XML_TAG_BUILDSET);
  3245. ForEach (*iter)
  3246. {
  3247. IPropertyTree* pFolder = &iter->query();
  3248. const char* pszBuild = pFolder->queryProp(XML_ATTR_BUILD);
  3249. const char* pszBuildPath = pFolder->queryProp("@buildpath");
  3250. const char* pszBuildSet = pFolder->queryProp(XML_ATTR_NAME);
  3251. const char* pszBuildSetPath = pFolder->queryProp("@path");
  3252. StringBuffer xpath;
  3253. xpath.appendf("Build[@name='%s']/BuildSet[@name='%s']", pszBuild, pszBuildSet);
  3254. IPropertyTree* pComp = pEnvPrograms->queryPropTree(xpath.str());
  3255. if (!pComp)
  3256. throw MakeStringException(-1, "No such build and buildset in environment: '%s' named '%s'.", pszBuild, pszBuildSet);
  3257. StringBuffer s;
  3258. s.append("./Programs/Build[@name=\"").append(pszBuild).append("\"]");
  3259. IPropertyTree *b = pEnvRoot->queryPropTree(s.str());
  3260. IPropertyTree *bs = NULL;
  3261. IPropertyTree* pParentNode = NULL;
  3262. IPropertyTree* pFiles = NULL;
  3263. if (b)
  3264. {
  3265. s.clear().append("BuildSet[@name=\"").append(pszBuildSet).append("\"]");
  3266. bs = b->queryPropTree(s.str());
  3267. StringBuffer fileName;
  3268. connectBuildSet(b, bs, fileName, m_Environment);
  3269. fileName.append(bs->queryProp("@installSet"));
  3270. pParentNode = createPTreeFromXMLFile(fileName.str());
  3271. pFiles = pParentNode->queryPropTree("File");
  3272. }
  3273. StringBuffer xml;
  3274. toXML(pParentNode, xml, false);
  3275. resp.setComponent(XML_TAG_BUILDSET);
  3276. resp.setXmlArgs( xml.str() );
  3277. }
  3278. }
  3279. return true;
  3280. }
  3281. bool CWsDeployFileInfo::importBuild(IEspContext &context, IEspImportBuildRequest &req, IEspImportBuildResponse &resp)
  3282. {
  3283. synchronized block(m_mutex);
  3284. checkForRefresh(context, &req.getReqInfo(), true);
  3285. const char* xmlArg = req.getBuildSets();
  3286. IPropertyTree* buildSets = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<BuildSets/>");
  3287. IPropertyTree* buildNode = createPTree(XML_TAG_BUILD);
  3288. const char* buildName = buildSets->queryProp(XML_ATTR_NAME);
  3289. const char* buildUrl = buildSets->queryProp("@path");
  3290. buildNode->setProp(XML_ATTR_NAME, buildName);
  3291. buildNode->setProp(XML_ATTR_URL, buildUrl);
  3292. Owned<IPropertyTreeIterator> iBuildSet = buildSets->getElements("*");
  3293. ForEach(*iBuildSet)
  3294. {
  3295. IPropertyTree* pBuildSet = &iBuildSet->query();
  3296. const char* bsName = pBuildSet->queryProp(XML_ATTR_NAME);
  3297. const char* bsPath = pBuildSet->queryProp("@path");
  3298. IPropertyTree* pBuildsetNode = createPTree();
  3299. pBuildsetNode->addProp(XML_ATTR_NAME, bsName);
  3300. pBuildsetNode->addProp(XML_ATTR_PATH, bsPath);
  3301. pBuildsetNode->addProp(XML_ATTR_INSTALLSET, "deploy_map.xml");
  3302. try
  3303. {
  3304. Owned<IPropertyTree> installSet = loadInstallSet(buildNode, pBuildsetNode, m_Environment);
  3305. if (strcmp(installSet->queryName(), XML_TAG_INSTALLSET) == 0)
  3306. {
  3307. pBuildsetNode->setProp(XML_ATTR_PROCESS_NAME, installSet->queryProp(XML_ATTR_PROCESS_NAME));
  3308. pBuildsetNode->setProp(XML_ATTR_SCHEMA, installSet->queryProp(XML_ATTR_SCHEMA));
  3309. if (installSet->hasProp(XML_ATTR_NAME))
  3310. pBuildsetNode->setProp(XML_ATTR_NAME, installSet->queryProp(XML_ATTR_NAME));
  3311. const char* szDeployable = installSet->queryProp("@deployable");
  3312. if (szDeployable)
  3313. pBuildsetNode->setProp("@deployable", szDeployable);
  3314. IPropertyTree* pProperties = installSet->getPropTree("Properties");
  3315. if (pProperties)
  3316. pBuildsetNode->addPropTree("Properties", pProperties);
  3317. buildNode->addPropTree(XML_TAG_BUILDSET, pBuildsetNode);
  3318. }
  3319. }
  3320. catch(...)
  3321. {
  3322. }
  3323. }
  3324. Owned<IPropertyTree> pEnvRoot = &m_Environment->getPTree();
  3325. IPropertyTree* pEnvPrograms = pEnvRoot->queryPropTree(XML_TAG_PROGRAMS);
  3326. if (!pEnvPrograms)
  3327. pEnvPrograms = pEnvRoot->addPropTree(XML_TAG_PROGRAMS, createPTree() );
  3328. pEnvPrograms->addPropTree(XML_TAG_BUILD, buildNode);
  3329. resp.setStatus("true");
  3330. return true;
  3331. }
  3332. bool CWsDeployFileInfo::getBuildServerDirs(IEspContext &context, IEspGetBuildServerDirsRequest &req, IEspGetBuildServerDirsResponse &resp)
  3333. {
  3334. synchronized block(m_mutex);
  3335. checkForRefresh(context, &req.getReqInfo(), true);
  3336. const char* cmd = req.getCmd();
  3337. const char* xmlArg = req.getXmlArgs();
  3338. StringBuffer sourceDir;
  3339. if (xmlArg && *xmlArg)
  3340. {
  3341. if (xmlArg[0] != '\\' && xmlArg[1] != '\\')
  3342. sourceDir.append("\\\\127.0.0.1\\");
  3343. sourceDir.append(xmlArg);
  3344. }
  3345. if (!strcmp(cmd, "SubDirs"))
  3346. {
  3347. Owned<IFile> inFiles = NULL;
  3348. IPropertyTree* pParentNode = createPTree("BuildServerDirs");
  3349. try
  3350. {
  3351. inFiles.setown(createIFile(sourceDir));
  3352. if(!inFiles->exists())
  3353. {
  3354. resp.setXmlArgs("Input directory %s does not exist");
  3355. return false;
  3356. }
  3357. }
  3358. catch(IException* e)
  3359. {
  3360. StringBuffer errmsg;
  3361. e->errorMessage(errmsg);
  3362. e->Release();
  3363. resp.setXmlArgs("Error when trying to access source directory.");
  3364. return false;
  3365. }
  3366. Owned<IDirectoryIterator> di = inFiles->directoryFiles(NULL, 0, true);
  3367. CIArrayOf<CDirectoryEntry> sortedfiles;
  3368. StringArray dispfiles;
  3369. bool bDirChosen = false;
  3370. sortDirectory(sortedfiles, *di, SD_bydate, true, true);
  3371. StringBuffer lastDirName;
  3372. int index = 0;
  3373. ForEachItemIn(idx, sortedfiles)
  3374. {
  3375. CDirectoryEntry *de = &sortedfiles.item(idx);
  3376. if (de->isdir)
  3377. {
  3378. StringBuffer sb;
  3379. de->modifiedTime.getString(sb);
  3380. IPropertyTree* pCompNode = pParentNode->addPropTree( "Directory", createPTree() );
  3381. pCompNode->addProp(XML_ATTR_NAME, de->name.get());
  3382. pCompNode->addProp("@modified", sb.str());
  3383. }
  3384. }
  3385. StringBuffer xml;
  3386. toXML(pParentNode, xml, false);
  3387. resp.setComponent("BuildServerDirs");
  3388. resp.setXmlArgs( xml.str() );
  3389. }
  3390. else
  3391. {
  3392. Owned<IFile> inFiles = NULL;
  3393. IPropertyTree* pParentNode = createPTree("BuildServerComps");
  3394. if (!strcmp(cmd, "Release"))
  3395. sourceDir.append(PATHSEPCHAR).append("release");
  3396. else if (!strcmp(cmd, "Debug"))
  3397. sourceDir.append(PATHSEPCHAR).append("debug");
  3398. try
  3399. {
  3400. inFiles.setown(createIFile(sourceDir));
  3401. if(!inFiles->exists())
  3402. {
  3403. resp.setXmlArgs("Input directory %s does not exist");
  3404. return false;
  3405. }
  3406. }
  3407. catch(IException* e)
  3408. {
  3409. StringBuffer errmsg;
  3410. e->errorMessage(errmsg);
  3411. e->Release();
  3412. resp.setXmlArgs("Error when trying to access source directory.");
  3413. return false;
  3414. }
  3415. if(inFiles.get() != NULL && inFiles->isDirectory())
  3416. {
  3417. Owned<IDirectoryIterator> di = inFiles->directoryFiles(NULL, 0, true);
  3418. bool bCompFound = false;
  3419. StringBuffer dirName, compName, fileName;
  3420. if(di.get())
  3421. {
  3422. ForEach(*di)
  3423. {
  3424. IFile &file = di->query();
  3425. if (!file.isFile())
  3426. {
  3427. dirName.clear();
  3428. di->getName(dirName);
  3429. compName.clear().append(dirName);
  3430. Owned<IFile> dirFiles = NULL;
  3431. StringBuffer sbPath(cmd);
  3432. sbPath.toLowerCase();
  3433. dirName.clear().append(sourceDir);
  3434. if(dirName.charAt(dirName.length() - 1) != PATHSEPCHAR)
  3435. dirName.append(PATHSEPCHAR);
  3436. dirName.append(compName);
  3437. sbPath.append(PATHSEPCHAR).append(compName);
  3438. fileName.clear().append(dirName).append(PATHSEPCHAR).append("deploy_map.xml");
  3439. Owned<IFile> depfile(createIFile(fileName));
  3440. if(depfile->exists())
  3441. {
  3442. IPropertyTree* pCompNode = pParentNode->addPropTree("Comp", createPTree() );
  3443. pCompNode->addProp(XML_ATTR_NAME, compName.str());
  3444. pCompNode->addProp("@path", sbPath.str());
  3445. }
  3446. }
  3447. }
  3448. }
  3449. StringBuffer xml;
  3450. toXML(pParentNode, xml, false);
  3451. resp.setComponent("BuildServerComps");
  3452. resp.setXmlArgs( xml.str() );
  3453. }
  3454. }
  3455. return true;
  3456. }
  3457. bool CWsDeployFileInfo::handleAttributeAdd(IEspContext &context, IEspHandleAttributeAddRequest &req, IEspHandleAttributeAddResponse &resp)
  3458. {
  3459. synchronized block(m_mutex);
  3460. const char* xmlArg = req.getXmlArgs();
  3461. if (!xmlArg || !*xmlArg)
  3462. return false;
  3463. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xmlArg);
  3464. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements("Setting[@operation='add']");
  3465. if (iter->first() == false)
  3466. return false;
  3467. IPropertyTree* pSetting = &iter->query();
  3468. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3469. StringBuffer xpath = pSetting->queryProp(XML_ATTR_PARAMS);
  3470. StringBuffer attribName = pSetting->queryProp(XML_ATTR_ATTRIB);
  3471. if (attribName.length() == 0)
  3472. throw MakeStringException(-1,"Attribute name can't be empty!");
  3473. IPropertyTree* pComp = pEnvRoot->getPropTree(xpath.str());
  3474. if (pComp != NULL)
  3475. pComp->addProp(attribName.str(), "");
  3476. resp.setStatus("true");
  3477. resp.setCompName(XML_TAG_SOFTWARE);
  3478. return true;
  3479. }
  3480. bool CWsDeployFileInfo::handleAttributeDelete(IEspContext &context, IEspHandleAttributeDeleteRequest &req, IEspHandleAttributeDeleteResponse &resp)
  3481. {
  3482. synchronized block(m_mutex);
  3483. const char* xmlArg = req.getXmlArgs();
  3484. if (!xmlArg || !*xmlArg)
  3485. return false;
  3486. Owned<IPropertyTree> pSrcTree = createPTreeFromXMLString(xmlArg);
  3487. Owned<IPropertyTreeIterator> iter = pSrcTree->getElements("Setting[@operation='delete']");
  3488. if (iter->first() == false)
  3489. return false;
  3490. IPropertyTree* pSetting = &iter->query();
  3491. Owned<IPropertyTree> pEnvRoot = &m_Environment->getPTree();
  3492. StringBuffer xpath2 = pSetting->queryProp("@params");
  3493. IPropertyTree* pComp = pEnvRoot->queryPropTree(xpath2.str());
  3494. if (pComp == NULL)
  3495. throw MakeStringException(-1,"Bad XPath %s (Try refreshing the browser?)", xpath2.str());
  3496. StringBuffer xml;
  3497. StringBuffer attrib;
  3498. int count = xpath2.length()-2;
  3499. if (count <= 0)
  3500. throw MakeStringException(-1,"Bad XPath %s (Try refreshing the browser?)", xpath2.str());
  3501. while (xpath2[count] != '=' || xpath2[count+1] != '\'')
  3502. count--;
  3503. count--;
  3504. for (int i=count; i >= 0 && xpath2[i] != '['; i--)
  3505. attrib.insert(0,xpath2[i]);
  3506. int index = xpath2.length()-1;
  3507. while (index > 0)
  3508. {
  3509. if (xpath2[index] == '/')
  3510. break;
  3511. index--;
  3512. }
  3513. char *pRootXPath = new char[index+2];
  3514. memset(pRootXPath,0,sizeof(char) * (index+2));
  3515. xpath2.getChars(0,index+1,pRootXPath);
  3516. if (req.getBLeaf() == true)
  3517. pComp->removeProp(attrib);
  3518. else if (strlen(pRootXPath) >= 14 && strncmp(pRootXPath,"./EnvSettings/",14) == 0)
  3519. pEnvRoot->queryPropTree("./EnvSettings")->removeTree(pComp);
  3520. else
  3521. pEnvRoot->queryPropTree(pRootXPath)->removeTree(pComp);
  3522. delete[] pRootXPath;
  3523. resp.setStatus("true");
  3524. resp.setCompName(XML_TAG_SOFTWARE);
  3525. return true;
  3526. }
  3527. bool CWsDeployFileInfo::handleComponent(IEspContext &context, IEspHandleComponentRequest &req, IEspHandleComponentResponse &resp)
  3528. {
  3529. synchronized block(m_mutex);
  3530. checkForRefresh(context, &req.getReqInfo(), true);
  3531. const char* xmlArg = req.getXmlArgs();
  3532. Owned<IPropertyTree> pComponents = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<Components/>");
  3533. const char* operation = req.getOperation();
  3534. StringBuffer sbNewName;
  3535. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3536. if (!strcmp(operation, "Add"))
  3537. {
  3538. Owned<IPropertyTreeIterator> iterComp = pComponents->getElements("*");
  3539. ForEach(*iterComp)
  3540. {
  3541. IPropertyTree& pComp = iterComp->query();
  3542. const char* buildSet = pComp.queryProp(XML_ATTR_BUILDSET);
  3543. StringBuffer xpath;
  3544. xpath.appendf("./Programs/Build/BuildSet[@name=\"%s\"]", buildSet);
  3545. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(xpath.str());
  3546. buildSetIter->first();
  3547. IPropertyTree* pBuildSet = &buildSetIter->query();
  3548. const char* buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  3549. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  3550. StringBuffer buildSetPath;
  3551. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  3552. xpath.clear().appendf("./Software/%s[@name='%s']", processName, buildSetName);
  3553. IPropertyTree* pCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName(), false);
  3554. IPropertyTree* pInstTree = pCompTree->queryPropTree(XML_TAG_INSTANCE);
  3555. if (pInstTree)
  3556. pCompTree->removeTree(pInstTree);
  3557. addComponentToEnv(pEnvRoot, buildSet, sbNewName, pCompTree);
  3558. }
  3559. resp.setCompName(sbNewName.str());
  3560. resp.setStatus("true");
  3561. }
  3562. else if (!strcmp(operation, "Delete"))
  3563. {
  3564. StringBuffer xpath;
  3565. StringBuffer xpathSoftware;
  3566. StringBuffer xpathFull;
  3567. StringBuffer errMsg;
  3568. Owned<IPropertyTreeIterator> iterComp = pComponents->getElements("*");
  3569. xpathSoftware.appendf("./%s", XML_TAG_SOFTWARE);
  3570. ForEach(*iterComp)
  3571. {
  3572. IPropertyTree& pComp = iterComp->query();
  3573. const char* compName = pComp.queryProp(XML_ATTR_NAME);
  3574. const char* compType = pComp.queryProp(XML_ATTR_COMPTYPE);
  3575. xpath.clear().appendf("%s/%s", xpathSoftware.str(), compType);
  3576. Owned<IPropertyTreeIterator> iterComp2 = pEnvRoot->getElements(xpath.str());
  3577. ForEach(*iterComp2)
  3578. {
  3579. xpathFull.clear().appendf("%s[%s=\"%s\"]", xpath.str(), XML_ATTR_NAME, compName);
  3580. unsigned short numElements = pEnvRoot->getCount(xpathFull.str());
  3581. if (strcmp(iterComp2->query().queryProp(XML_ATTR_NAME), compName) == 0)
  3582. {
  3583. IPropertyTree* pCompTree = pEnvRoot->queryPropTree(xpathSoftware.str());
  3584. StringBuffer sbMsg;
  3585. // only check for component dependencies if the componenet to be deleted is the last instance with the same name
  3586. if (pCompTree != NULL && (pEnvRoot->getCount(xpathFull.str()) > 1 ? true : checkComponentReferences(pEnvRoot, pEnvRoot->queryPropTree(xpathFull.str()), compName, sbMsg)))
  3587. pEnvRoot->queryPropTree(xpathSoftware.str())->removeTree(&(iterComp2->query()));
  3588. if (sbMsg.length() > 0)
  3589. errMsg.appendf("\n%s", sbMsg.str());
  3590. break;
  3591. }
  3592. }
  3593. resp.setCompName(compName);
  3594. }
  3595. resp.setStatus(errMsg.length() > 1 ? errMsg.str() : "true");
  3596. }
  3597. else if (!strcmp(operation, "Duplicate"))
  3598. {
  3599. StringBuffer sbNewName;
  3600. StringBuffer xpath;
  3601. Owned<IPropertyTreeIterator> iterComp = pComponents->getElements("*");
  3602. if (iterComp->first() && iterComp->isValid())
  3603. {
  3604. IPropertyTree& pComp = iterComp->query();
  3605. const char* compName = pComp.queryProp(XML_ATTR_NAME);
  3606. const char* compType = pComp.queryProp(XML_ATTR_COMPTYPE);
  3607. sbNewName = compName;
  3608. xpath = compType;
  3609. getUniqueName(pEnvRoot, sbNewName, xpath.str(), XML_TAG_SOFTWARE);
  3610. xpath.clear().appendf("./%s/%s[%s=\"%s\"]", XML_TAG_SOFTWARE, compType, XML_ATTR_NAME, compName);
  3611. IPropertyTree* pCompTree = pEnvRoot->queryPropTree(xpath.str());
  3612. if (pCompTree == NULL)
  3613. throw MakeStringException(-1,"XPATH: %s is invalid.", xpath.str());
  3614. StringBuffer xml;
  3615. toXML(pCompTree, xml);
  3616. IPropertyTree *dupTree = createPTreeFromXMLString(xml.str());
  3617. dupTree->setProp(XML_ATTR_NAME, sbNewName.str());
  3618. xpath.clear().appendf("./%s/%s[%s=\"%s\"]", XML_TAG_SOFTWARE, compType, XML_ATTR_NAME, sbNewName.str());
  3619. if (pEnvRoot->addPropTree(xpath, dupTree))
  3620. resp.setStatus("true");
  3621. else
  3622. resp.setStatus("false");
  3623. }
  3624. else
  3625. {
  3626. resp.setStatus("false");
  3627. }
  3628. resp.setCompName(XML_TAG_SOFTWARE);
  3629. }
  3630. else if (!strcmp(operation, "CopySW"))
  3631. {
  3632. if (handleComponentCopy(pComponents, pEnvRoot.get()) == true)
  3633. resp.setStatus("true");
  3634. else
  3635. resp.setStatus("false");
  3636. }
  3637. else if (!strcmp(operation, "CopyHW"))
  3638. {
  3639. if (handleHardwareCopy(pComponents, pEnvRoot->queryPropTree("Hardware"))== true)
  3640. resp.setStatus("true");
  3641. else
  3642. resp.setStatus("false");
  3643. }
  3644. return true;
  3645. }
  3646. bool CWsDeployFileInfo::addCopyToPropTree(IPropertyTree* pPropTree, IPropertyTree* pDupTree, const char* tag_name)
  3647. {
  3648. StringBuffer strTag;
  3649. strTag.clear().appendf("%s/%s", XML_TAG_HARDWARE, tag_name);
  3650. return pPropTree->addPropTree(strTag.str(), pDupTree) != NULL;
  3651. }
  3652. bool CWsDeployFileInfo::handleHardwareCopy(IPropertyTree *pComponents, IPropertyTree *pEnvRoot)
  3653. {
  3654. StringBuffer xpath;
  3655. StringBuffer xpath3;
  3656. StringBuffer filePath;
  3657. xpath.clear().appendf("%s", XML_TAG_HARDWARE);
  3658. Owned<IPropertyTreeIterator> iterComp = pComponents->getElements("*");
  3659. Owned<IPropertyTreeIterator> iter = pEnvRoot->getElements("*");
  3660. if (!iterComp->first())
  3661. return false;
  3662. CWsDeployFileInfo::setFilePath(filePath, iterComp->query().queryProp(XML_ATTR_TARGET));
  3663. Owned<CWsDeployFileInfo> fi = new CWsDeployFileInfo(m_pService, filePath, false);
  3664. fi->m_skipEnvUpdateFromNotification = false;
  3665. fi->initFileInfo(false,false);
  3666. Owned<IPropertyTree> pEnvRoot2 = &(fi->m_Environment->getPTree());
  3667. bool bWrite = false;
  3668. StringArray elems;
  3669. ForEach(*iter)
  3670. {
  3671. IPropertyTree& pComp = iter->query();
  3672. const char* name = pComp.queryProp(XML_ATTR_NAME);
  3673. const char* tag_name = pComp.queryName();
  3674. StringBuffer xpath2;
  3675. xpath2.appendf("./%s/%s[%s = \"%s\"]", XML_TAG_HARDWARE, tag_name, XML_ATTR_NAME, name);
  3676. if (pEnvRoot2->queryPropTree(xpath2.str()) != NULL) // check if target configuration has same named element
  3677. {
  3678. elems.append(name);
  3679. continue;
  3680. }
  3681. StringBuffer xml;
  3682. xml.appendf("<%s", tag_name);
  3683. Owned<IAttributeIterator> pAttribIter = pComp.getAttributes();
  3684. ForEach(*pAttribIter)
  3685. {
  3686. const char* name = &(pAttribIter->queryName()[1]);
  3687. const char* value = pAttribIter->queryValue();
  3688. xml.appendf(" %s=\"%s\" ", name, value);
  3689. }
  3690. xml.append("/>");
  3691. IPropertyTree *dupTree = NULL;
  3692. if (iterComp->query().queryProp(XML_ATTR_HWXPATH) && strlen(iterComp->query().queryProp(XML_ATTR_HWXPATH)) > 0)
  3693. {
  3694. xpath3.clear().appendf("<%s/>", iterComp->query().queryProp(XML_ATTR_HWXPATH));
  3695. dupTree = createPTreeFromXMLString((xpath3.replace('\'','\"')).str());
  3696. String strTagName(xpath3);
  3697. strTagName = *strTagName.substring(1,strTagName.indexOf(' '));
  3698. if (CWsDeployFileInfo::addCopyToPropTree(pEnvRoot2, dupTree, strTagName.toCharArray()) == false)
  3699. return false;
  3700. bWrite = true;
  3701. break;
  3702. }
  3703. else
  3704. dupTree = createPTreeFromXMLString(xml.str());
  3705. if (CWsDeployFileInfo::addCopyToPropTree(pEnvRoot2, dupTree, tag_name) == false)
  3706. return false;
  3707. bWrite = true;
  3708. }
  3709. if (bWrite == true)
  3710. {
  3711. StringBuffer err;
  3712. fi->saveEnvironment(NULL, NULL, err);
  3713. if (elems.ordinality() > 0 && !(iterComp->query().queryProp(XML_ATTR_HWXPATH) && strlen(iterComp->query().queryProp(XML_ATTR_HWXPATH)) > 0))
  3714. {
  3715. StringBuffer errMsg;
  3716. errMsg.appendf("Saved succeeded but some some element(s) could not be copied. Element(s) may already exist in the target configuration.\n[");
  3717. ForEachItemIn(i, elems)
  3718. {
  3719. errMsg.appendf("%s, ",elems.item(i));
  3720. }
  3721. errMsg.setCharAt(errMsg.length()-2 , ']');
  3722. throw MakeStringException(-1, "%s", errMsg.str());
  3723. }
  3724. }
  3725. else
  3726. {
  3727. throw MakeStringException(-1, "Copy failed. All elements may already exist in the target configuration.");
  3728. }
  3729. return true;
  3730. }
  3731. bool CWsDeployFileInfo::handleComponentCopy(IPropertyTree *pComponents, IPropertyTree *pEnvRoot)
  3732. {
  3733. Owned<IPropertyTreeIterator> iterComp = pComponents->getElements("*");
  3734. bool bError = false;
  3735. StringBuffer errMsg;
  3736. char targetName[255] = "";
  3737. iterComp->first();
  3738. strncpy(targetName, iterComp->query().queryProp("@target"), 255); //get the copy target configuration file name
  3739. StringBuffer filePath;
  3740. CWsDeployFileInfo::setFilePath(filePath, targetName);
  3741. Owned<CWsDeployFileInfo> fi = new CWsDeployFileInfo(m_pService, filePath, false);
  3742. fi->m_skipEnvUpdateFromNotification = false;
  3743. fi->initFileInfo(false,false);
  3744. Owned<IPropertyTree> pEnvRoot2 = &(fi->m_Environment->getPTree());
  3745. Owned<IPropertyTreeIterator> iterComp2 = pComponents->getElements("*");
  3746. StringBuffer xpath;
  3747. ForEach(*iterComp)
  3748. {
  3749. IPropertyTree& pComp = iterComp->query();
  3750. const char* compName = pComp.queryProp(XML_ATTR_NAME);
  3751. if (compName == NULL)
  3752. {
  3753. if (bError == false)
  3754. {
  3755. bError = true;
  3756. errMsg.clear().appendf("Faild to query for @name attribute, continuing...");
  3757. }
  3758. continue;
  3759. }
  3760. const char* compType = pComp.queryProp("@compType");
  3761. StringBuffer sbNewName = compName;
  3762. xpath.clear().appendf("%s", compType);
  3763. getUniqueName(pEnvRoot2, sbNewName, xpath.str(), XML_TAG_SOFTWARE);
  3764. xpath.clear().appendf("./%s/%s[%s=\"%s\"]", XML_TAG_SOFTWARE, compType, XML_ATTR_NAME, compName);
  3765. IPropertyTree* pCompTree = pEnvRoot->queryPropTree(xpath.str());
  3766. if ( pCompTree == NULL)
  3767. throw MakeStringException(-1,"XPATH: %s is invalid in source configuration. Copy failed.", xpath.str());
  3768. xpath.clear().appendf("./%s/%s[%s=\"%s\"]", XML_TAG_SOFTWARE, compType, XML_ATTR_NAME, sbNewName.str());
  3769. StringBuffer xml;
  3770. toXML(pCompTree, xml);
  3771. IPropertyTree *dupTree = createPTreeFromXMLString(xml.str());
  3772. dupTree->setProp(XML_ATTR_NAME, sbNewName.str());
  3773. if (pEnvRoot2->addPropTree(xpath, dupTree) == NULL)
  3774. throw MakeStringException(-1,"XPATH: %s is invalid in target. Copy failed.", xpath.str());
  3775. }
  3776. StringBuffer err;
  3777. fi->saveEnvironment(NULL, NULL, err);
  3778. if (bError == true)
  3779. throw MakeStringException(-1,"Save succeeded but an error was encountered with message: %s", errMsg.str());
  3780. return true;
  3781. }
  3782. bool CWsDeployFileInfo::handleInstance(IEspContext &context, IEspHandleInstanceRequest &req, IEspHandleInstanceResponse &resp)
  3783. {
  3784. synchronized block(m_mutex);
  3785. checkForRefresh(context, &req.getReqInfo(), true);
  3786. const char* operation = req.getOperation();
  3787. const char* xmlArg = req.getXmlArgs();
  3788. Owned<IPropertyTree> instances = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<Instances/>");
  3789. const char* buildSet = instances->queryProp(XML_ATTR_BUILDSET);
  3790. const char* compName = instances->queryProp("@compName");
  3791. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3792. StringBuffer xpath;
  3793. xpath.appendf("./Programs/Build/BuildSet[@name=\"%s\"]", buildSet);
  3794. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(xpath.str());
  3795. buildSetIter->first();
  3796. IPropertyTree* pBuildSet = &buildSetIter->query();
  3797. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  3798. StringBuffer dups, reqdComps, reqdCompNames;
  3799. if (!strcmp(operation, "Add"))
  3800. {
  3801. StringBuffer buildSetPath;
  3802. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  3803. xpath.clear().appendf("./Software/%s[@name=\"%s\"]", processName, compName);
  3804. IPropertyTree* pCompTree = pEnvRoot->queryPropTree(xpath.str());
  3805. Owned<IPropertyTreeIterator> iterInst = instances->getElements("*");
  3806. bool bAdded = false;
  3807. ForEach(*iterInst)
  3808. {
  3809. IPropertyTree& pComputer = iterInst->query();
  3810. xpath.clear().appendf("./Hardware/Computer[@name=\"%s\"]", pComputer.queryProp(XML_ATTR_NAME));
  3811. IPropertyTree* pComputerNode = pEnvRoot->queryPropTree(xpath.str());
  3812. xpath.clear().appendf("Instance[@netAddress=\"%s\"]", pComputerNode->queryProp(XML_ATTR_NETADDRESS));
  3813. if (pCompTree->queryPropTree(xpath.str()))
  3814. {
  3815. dups.appendf("\n%s", pComputerNode->queryProp(XML_ATTR_NETADDRESS));
  3816. continue;
  3817. }
  3818. IPropertyTree* pNode = pCompTree->addPropTree(XML_TAG_INSTANCE, createPTree());
  3819. if (pSchema)
  3820. {
  3821. Owned<IPropertyTreeIterator> iter = pSchema->getElements("xs:element/xs:complexType/xs:sequence/xs:element[@name=\"Instance\"]/xs:complexType/xs:attribute");
  3822. ForEach(*iter)
  3823. {
  3824. IPropertyTree &attr = iter->query();
  3825. StringBuffer attrName("@");
  3826. attrName.append(attr.queryProp(XML_ATTR_NAME));
  3827. // we try to pull @computer and @netAddress from computerNode. Others come from default values in schema (if supplied)
  3828. const char *szAttrib;
  3829. StringBuffer sb;
  3830. if (!strcmp(attrName.str(), XML_ATTR_COMPUTER))
  3831. {
  3832. szAttrib = pComputerNode->queryProp(XML_ATTR_NAME);
  3833. if (!bAdded)
  3834. {
  3835. bAdded = true;
  3836. resp.setNewName(szAttrib);
  3837. }
  3838. }
  3839. else if (!strcmp(attrName.str(), XML_ATTR_NETADDRESS))
  3840. szAttrib = pComputerNode->queryProp(XML_ATTR_NETADDRESS);
  3841. else if (!strcmp(attrName.str(), XML_ATTR_DIRECTORY))
  3842. {
  3843. StringBuffer rundir;
  3844. if (!getConfigurationDirectory(pEnvRoot->queryPropTree("Software/Directories"),"run",buildSet,compName,rundir))
  3845. sb.clear().appendf(RUNTIME_DIR"/%s", compName);
  3846. else
  3847. sb.clear().append(rundir);
  3848. szAttrib = sb.str();
  3849. }
  3850. else
  3851. szAttrib = attr.queryProp("@default");
  3852. pNode->addProp(attrName.str(), szAttrib);
  3853. }
  3854. Owned<IPropertyTree> pNewCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSet, m_pService->getCfg(), m_pService->getName(), true);
  3855. if (pNewCompTree)
  3856. {
  3857. StringBuffer sbxml;
  3858. toXML(pNewCompTree, sbxml);
  3859. Owned<IPropertyTreeIterator> iterElems = pNewCompTree->getElements("Instance/*");
  3860. ForEach (*iterElems)
  3861. {
  3862. IPropertyTree* pElem = &iterElems->query();
  3863. if (!pNode->queryProp(pElem->queryName()))
  3864. pNode->addPropTree(pElem->queryName(), createPTreeFromIPT(pElem));
  3865. }
  3866. }
  3867. }
  3868. if (!checkForRequiredComponents(pEnvRoot, pComputerNode->queryProp(XML_ATTR_NETADDRESS), reqdCompNames, buildSet))
  3869. reqdComps.appendf("\n%s", pComputerNode->queryProp(XML_ATTR_NETADDRESS));
  3870. }
  3871. resp.setReqdCompNames(reqdCompNames.str());
  3872. resp.setAddReqdComps(reqdComps.str());
  3873. resp.setDuplicates(dups.str());
  3874. }
  3875. else if (!strcmp(operation, "Delete"))
  3876. {
  3877. Owned<IPropertyTreeIterator> iterInst = instances->getElements("*");
  3878. ForEach(*iterInst)
  3879. {
  3880. IPropertyTree& pInst = iterInst->query();
  3881. StringBuffer decodedParams( pInst.queryProp("@params") );
  3882. decodedParams.replaceString("::", "\n");
  3883. Owned<IProperties> pParams = createProperties();
  3884. pParams->loadProps(decodedParams.str());
  3885. const char* pszCompType = pParams->queryProp("pcType");
  3886. const char* pszCompName = pParams->queryProp("pcName");
  3887. const char* pszSubType = pParams->queryProp("subType");
  3888. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  3889. xpath.clear().appendf("./Software/%s[@name=\"%s\"]", pszCompType, pszCompName);
  3890. IPropertyTree* pInstParent = pEnvRoot->queryPropTree(xpath.str());
  3891. if (pszSubTypeKey[0] == '[' && pszSubTypeKey[strlen(pszSubTypeKey) - 1] == ']')
  3892. xpath.clear().appendf("%s%s", pszSubType, pszSubTypeKey);
  3893. else
  3894. xpath.clear().appendf("%s[@name=\"%s\"]", pszSubType, pszSubTypeKey);
  3895. IPropertyTree* pInstTree = pInstParent->queryPropTree(xpath.str());
  3896. if (pInstParent && pInstTree)
  3897. pInstParent->removeTree(pInstTree);
  3898. }
  3899. }
  3900. //rename instance names
  3901. int nCount = 1;
  3902. xpath.clear().appendf("./Software/%s[@name=\"%s\"]/Instance", processName, compName);
  3903. Owned<IPropertyTreeIterator> iter = pEnvRoot->getElements(xpath.str());
  3904. StringBuffer sName;
  3905. ForEach(*iter)
  3906. {
  3907. sName.clear().append("s").append(nCount);
  3908. iter->query().setProp(XML_ATTR_NAME, sName.str());
  3909. nCount++;
  3910. }
  3911. resp.setStatus("true");
  3912. return true;
  3913. }
  3914. bool CWsDeployFileInfo::addReqdComps(IEspContext &context, IEspAddReqdCompsRequest &req, IEspAddReqdCompsResponse &resp)
  3915. {
  3916. synchronized block(m_mutex);
  3917. checkForRefresh(context, &req.getReqInfo(), true);
  3918. const char* xmlArg = req.getXmlArgs();
  3919. Owned<IPropertyTree> instances = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<ReqdComps/>");
  3920. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3921. Owned<IPropertyTreeIterator> iterComp = instances->getElements("*");
  3922. bool bAdded = false;
  3923. StringBuffer reqCompNames, failed;
  3924. ForEach(*iterComp)
  3925. {
  3926. IPropertyTree& pComputer = iterComp->query();
  3927. if (!checkForRequiredComponents(pEnvRoot, pComputer.queryProp(XML_ATTR_NETADDRESS), reqCompNames, NULL, true))
  3928. failed.appendf("\n%s", pComputer.queryProp(XML_ATTR_NETADDRESS));
  3929. }
  3930. resp.setFailures(failed.str());
  3931. resp.setStatus("true");
  3932. return true;
  3933. }
  3934. bool CWsDeployFileInfo::handleEspServiceBindings(IEspContext &context, IEspHandleEspServiceBindingsRequest &req, IEspHandleEspServiceBindingsResponse &resp)
  3935. {
  3936. synchronized block(m_mutex);
  3937. checkForRefresh(context, &req.getReqInfo(), true);
  3938. const char* xmlArg = req.getXmlArgs();
  3939. Owned<IPropertyTree> pBindings = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<EspServiceBindings/>");
  3940. const char* type = pBindings->queryProp(XML_ATTR_TYPE);
  3941. const char* espName = pBindings->queryProp("@compName");
  3942. const char* operation = req.getOperation();
  3943. StringBuffer sbNewName;
  3944. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  3945. StringBuffer xpath;
  3946. if (!strcmp(operation, "Add"))
  3947. {
  3948. xpath.append("./Programs/Build/BuildSet[@processName=\"EspProcess\"]");
  3949. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(xpath.str());
  3950. buildSetIter->first();
  3951. IPropertyTree* pBuildSet = &buildSetIter->query();
  3952. const char* buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  3953. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  3954. StringBuffer buildSetPath;
  3955. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  3956. xpath.clear().appendf("./Software/%s[@name='%s']", processName, espName);
  3957. Owned<IPropertyTreeIterator> iterItems = pBindings->getElements("Item");
  3958. bool flag = false;
  3959. ForEach (*iterItems)
  3960. {
  3961. flag = true;
  3962. IPropertyTree* pItem = &iterItems->query();
  3963. const char* bindingName = pItem->queryProp(XML_ATTR_NAME);
  3964. const char* params = pItem->queryProp("@params");
  3965. StringBuffer decodedParams(params);
  3966. decodedParams.replaceString("::", "\n");
  3967. Owned<IProperties> pParams = createProperties();
  3968. pParams->loadProps(decodedParams.str());
  3969. const char* pszCompType = pParams->queryProp("pcType");
  3970. const char* pszCompName = pParams->queryProp("pcName");
  3971. const char* pszSubType = pParams->queryProp("subType");
  3972. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  3973. if (strcmp(type, XML_TAG_ESPBINDING) && bindingName)
  3974. xpath.appendf("/EspBinding[@name='%s']", bindingName);
  3975. else if (pszSubType && *pszSubType)
  3976. {
  3977. String subType(pszSubType);
  3978. int idx = subType.lastIndexOf('/');
  3979. if (idx > 0)
  3980. {
  3981. String* tmpstr = subType.substring(0, idx);
  3982. xpath.append("/").append(*tmpstr);
  3983. delete tmpstr;
  3984. }
  3985. }
  3986. IPropertyTree* pEspService = pEnvRoot->queryPropTree(xpath.str());
  3987. IPropertyTree* pCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName());
  3988. StringBuffer sb(type);
  3989. if (!strncmp(sb.str(), "_", 1))
  3990. sb.remove(0, 1);
  3991. if (!strcmp(type, XML_TAG_ESPBINDING))
  3992. {
  3993. StringBuffer sbNewName(XML_TAG_ESPBINDING);
  3994. xpath.clear().appendf("%s[@name='%s']/EspBinding", processName, espName);
  3995. getUniqueName(pEnvRoot, sbNewName, xpath.str(), XML_TAG_SOFTWARE);
  3996. xpath.clear().append(sb.str()).append("/").append(XML_ATTR_NAME);
  3997. pCompTree->setProp(xpath.str(), sbNewName);
  3998. resp.setNewName(sbNewName);
  3999. }
  4000. if (pEspService && pCompTree)
  4001. pEspService->addPropTree(sb.str(), pCompTree->queryPropTree(sb.str()));
  4002. //If we are adding, just consider the first selection.
  4003. break;
  4004. }
  4005. if (!flag)
  4006. {
  4007. IPropertyTree* pEspService = pEnvRoot->queryPropTree(xpath.str());
  4008. IPropertyTree* pCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName());
  4009. StringBuffer sbNewName(XML_TAG_ESPBINDING);
  4010. xpath.clear().appendf("%s[@name='%s']/EspBinding", processName, espName);
  4011. getUniqueName(pEnvRoot, sbNewName, xpath.str(), XML_TAG_SOFTWARE);
  4012. xpath.clear().append(XML_TAG_ESPBINDING).append("/").append(XML_ATTR_NAME);
  4013. pCompTree->setProp(xpath.str(), sbNewName);
  4014. resp.setNewName(sbNewName);
  4015. if (pEspService && pCompTree)
  4016. pEspService->addPropTree(XML_TAG_ESPBINDING, pCompTree->queryPropTree(XML_TAG_ESPBINDING));
  4017. }
  4018. resp.setStatus("true");
  4019. }
  4020. else if (!strcmp(operation, "Delete"))
  4021. {
  4022. Owned<IPropertyTreeIterator> iterItems = pBindings->getElements("Item");
  4023. bool deleteAll = true;
  4024. IPropertyTreePtrArray bindings;
  4025. ForEach (*iterItems)
  4026. {
  4027. IPropertyTree* pItem = &iterItems->query();
  4028. const char* bindingName = pItem->queryProp(XML_ATTR_NAME);
  4029. const char* params = pItem->queryProp("@params");
  4030. StringBuffer decodedParams(params);
  4031. decodedParams.replaceString("::", "\n");
  4032. Owned<IProperties> pParams = createProperties();
  4033. pParams->loadProps(decodedParams.str());
  4034. const char* pszCompType = pParams->queryProp("pcType");
  4035. const char* pszCompName = pParams->queryProp("pcName");
  4036. const char* pszSubType = pParams->queryProp("subType");
  4037. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  4038. xpath.clear().appendf("./Software/%s[@name='%s']", XML_TAG_ESPPROCESS, espName);
  4039. if (!strcmp(type, XML_TAG_ESPBINDING))
  4040. {
  4041. if (bindingName)
  4042. xpath.appendf("/EspBinding[@name='%s']", bindingName);
  4043. IPropertyTree* pEspBinding = pEnvRoot->queryPropTree(xpath.str());
  4044. StringBuffer sbMsg;
  4045. StringBuffer sbFullName(espName);
  4046. sbFullName.append("/").append(bindingName);
  4047. bool ret = checkComponentReferences(pEnvRoot, pEspBinding, sbFullName.str(), sbMsg);
  4048. if (ret)
  4049. bindings.push_back(pEspBinding);
  4050. else
  4051. {
  4052. deleteAll = false;
  4053. resp.setStatus(sbMsg.str());
  4054. break;
  4055. }
  4056. }
  4057. else
  4058. {
  4059. if (pszSubType && *pszSubType)
  4060. xpath.append("/").append(pszSubType);
  4061. const char* resource = pItem->queryProp("@resource");
  4062. if (resource)
  4063. xpath.appendf("[@resource='%s']", resource);
  4064. IPropertyTree* pSubType = pEnvRoot->queryPropTree(xpath.str());
  4065. String subType(xpath.str());
  4066. int idx = subType.lastIndexOf('/');
  4067. if (idx > 0)
  4068. {
  4069. String* tmpstr = subType.substring(0, idx);
  4070. xpath.clear().append(*tmpstr);
  4071. delete tmpstr;
  4072. }
  4073. if (pSubType)
  4074. pEnvRoot->queryPropTree(xpath.str())->removeTree(pSubType);
  4075. }
  4076. }
  4077. if (deleteAll)
  4078. {
  4079. xpath.clear().appendf("./Software/%s[@name='%s']", XML_TAG_ESPPROCESS, espName);
  4080. IPropertyTree* pEspService = pEnvRoot->queryPropTree(xpath.str());
  4081. int nBindings = bindings.size();
  4082. for (int i=0; i < nBindings; i++)
  4083. {
  4084. IPropertyTree* pBinding = bindings[i];
  4085. pEspService->removeTree(pBinding);
  4086. }
  4087. resp.setStatus("true");
  4088. }
  4089. }
  4090. return true;
  4091. }
  4092. bool CWsDeployFileInfo::handleComputer(IEspContext &context, IEspHandleComputerRequest &req, IEspHandleComputerResponse &resp)
  4093. {
  4094. synchronized block(m_mutex);
  4095. checkForRefresh(context, &req.getReqInfo(), true);
  4096. const char* xmlArg = req.getXmlArgs();
  4097. Owned<IPropertyTree> pParams = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  4098. const char* type = pParams->queryProp(XML_ATTR_TYPE);
  4099. const char* operation = req.getOperation();
  4100. StringBuffer sbNewName;
  4101. StringBuffer xpath;
  4102. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  4103. if (!strcmp(operation, "New"))
  4104. {
  4105. StringBuffer sbTemp;
  4106. IPropertyTree* pCompTree = createPTree(XML_TAG_HARDWARE);
  4107. generateHardwareHeaders(pEnvRoot, sbTemp, false, pCompTree, true);
  4108. StringBuffer sbNewName(type);
  4109. xpath.clear().appendf("%s", type);
  4110. getUniqueName(pEnvRoot, sbNewName, xpath.str(), XML_TAG_HARDWARE);
  4111. xpath.clear().append(type).append("/").append(XML_ATTR_NAME);
  4112. pCompTree->setProp(xpath.str(), sbNewName);
  4113. pEnvRoot->queryPropTree(XML_TAG_HARDWARE)->addPropTree(type, pCompTree->queryPropTree(type));
  4114. resp.setCompName(sbNewName.str());
  4115. resp.setStatus("true");
  4116. }
  4117. else if (!strcmp(operation, "NewRange"))
  4118. {
  4119. const char* prefix = pParams->queryProp("@prefix");
  4120. const char* domain = pParams->queryProp(XML_ATTR_DOMAIN);
  4121. const char* cType = pParams->queryProp(XML_ATTR_COMPUTERTYPE);
  4122. const char* startIP = pParams->queryProp("@startIP");
  4123. const char* endIP = pParams->queryProp("@endIP");
  4124. IPropertyTree* pComps = getNewRange(pEnvRoot, prefix, domain, cType, startIP, endIP);
  4125. if (m_bCloud)
  4126. {
  4127. StringBuffer sbMsg;
  4128. CCloudActionHandler lockCloud(this, CLOUD_LOCK_ENV, CLOUD_UNLOCK_ENV, m_userWithLock.str(), "8015", pComps);
  4129. bool ret = lockCloud.start(sbMsg);
  4130. if (!ret || sbMsg.length())
  4131. {
  4132. resp.setStatus("false");
  4133. throw MakeStringException(-1, "Cannot add new range of computers as environment lock could not be obtained. Reason(s):\n%s", sbMsg.str());
  4134. }
  4135. }
  4136. if (pComps)
  4137. {
  4138. mergePTree(pEnvRoot->queryPropTree(XML_TAG_HARDWARE), pComps);
  4139. resp.setCompName(pComps->queryPropTree("Computer[1]")->queryProp(XML_ATTR_NAME));
  4140. }
  4141. resp.setStatus("true");
  4142. }
  4143. else if (!strcmp(operation, "Delete"))
  4144. {
  4145. StringBuffer refs;
  4146. StringBuffer refName;
  4147. Owned<IPropertyTreeIterator> iterComputers = pParams->getElements("Item");
  4148. ForEach (*iterComputers)
  4149. {
  4150. IPropertyTree* pComp = &iterComputers->query();
  4151. const char* name = pComp->queryProp(XML_ATTR_NAME);
  4152. if (!strcmp(type, XML_TAG_COMPUTER))
  4153. xpath.clear().appendf(XML_TAG_SOFTWARE"//["XML_ATTR_COMPUTER"=\"%s\"]", name);
  4154. else if (!strcmp(type, XML_TAG_COMPUTERTYPE))
  4155. xpath.clear().appendf(XML_TAG_HARDWARE"//["XML_ATTR_COMPUTERTYPE"=\"%s\"]", name);
  4156. else if (!strcmp(type, XML_TAG_DOMAIN))
  4157. xpath.clear().appendf(XML_TAG_HARDWARE"//["XML_ATTR_DOMAIN"=\"%s\"]", name);
  4158. else if (!strcmp(type, XML_TAG_SWITCH))
  4159. xpath.clear().appendf(XML_TAG_HARDWARE"//["XML_ATTR_SWITCH"=\"%s\"]", name);
  4160. Owned<IPropertyTreeIterator> iter = pEnvRoot->getElements(xpath.str());
  4161. ForEach(*iter)
  4162. {
  4163. IPropertyTree& pComp = iter->query();
  4164. const char* compName = pComp.queryProp(XML_ATTR_NAME);
  4165. const char* parentName = pComp.queryName();
  4166. if (compName != NULL)
  4167. refs.append("\n").append(parentName).append(" name=").append(compName);
  4168. }
  4169. if (refs.length())
  4170. {
  4171. refName.clear().append(name);
  4172. break;
  4173. }
  4174. }
  4175. if (refs.length())
  4176. throw MakeStringException(-1, "Cannot delete %s with name %s as it is being referenced by components: %s.", type, refName.str(), refs.str());
  4177. else
  4178. {
  4179. if (m_bCloud && !strcmp(type, XML_TAG_COMPUTER))
  4180. {
  4181. StringBuffer sb, sbMsg;
  4182. sb.append("<Computers>");
  4183. ForEach (*iterComputers)
  4184. {
  4185. IPropertyTree* pComp = &iterComputers->query();
  4186. xpath.clear().appendf(XML_TAG_HARDWARE"/%s["XML_ATTR_NAME"=\"%s\"]", type, pComp->queryProp(XML_ATTR_NAME));
  4187. IPropertyTree* pTree = pEnvRoot->queryPropTree(xpath.str());
  4188. sb.appendf("<Computer netAddress='%s'/>", pTree->queryProp(XML_ATTR_NETADDRESS));
  4189. }
  4190. sb.append("</Computers>");
  4191. Owned<IPropertyTree> pComputers = createPTreeFromXMLString(sb.str());
  4192. CCloudActionHandler unlockCloud(this, CLOUD_UNLOCK_ENV, CLOUD_LOCK_ENV, m_userWithLock.str(), "8015", pComputers);
  4193. bool ret = unlockCloud.start(sbMsg);
  4194. if (!ret || sbMsg.length())
  4195. throw MakeStringException(-1, "Cannot delete computers as they cannot be unlocked. Reason(s):\n%s", sbMsg.str());
  4196. }
  4197. ForEach (*iterComputers)
  4198. {
  4199. IPropertyTree* pComp = &iterComputers->query();
  4200. xpath.clear().appendf(XML_TAG_HARDWARE"/%s["XML_ATTR_NAME"=\"%s\"]", type, pComp->queryProp(XML_ATTR_NAME));
  4201. IPropertyTree* pTree = pEnvRoot->queryPropTree(xpath.str());
  4202. pEnvRoot->queryPropTree(XML_TAG_HARDWARE)->removeTree(pTree);
  4203. }
  4204. resp.setStatus("true");
  4205. }
  4206. }
  4207. return true;
  4208. }
  4209. bool CWsDeployFileInfo::handleTopology(IEspContext &context, IEspHandleTopologyRequest &req, IEspHandleTopologyResponse &resp)
  4210. {
  4211. synchronized block(m_mutex);
  4212. checkForRefresh(context, &req.getReqInfo(), true);
  4213. const char* xmlArg = req.getXmlArgs();
  4214. Owned<IPropertyTree> pParams = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  4215. const char* compType = pParams->queryProp("@compType");
  4216. const char* name = pParams->queryProp(XML_ATTR_NAME);
  4217. const char* newType = pParams->queryProp("@newType");
  4218. const char* operation = req.getOperation();
  4219. StringBuffer decodedParams( pParams->queryProp("@params") );
  4220. decodedParams.replaceString("::", "\n");
  4221. Owned<IProperties> pTopParams = createProperties();
  4222. pTopParams->loadProps(decodedParams.str());
  4223. StringBuffer buf("Software/Topology");
  4224. for (int i = 3; i >= 0; i--)
  4225. {
  4226. StringBuffer sb;
  4227. sb.appendf("inner%d_name", i);
  4228. const char* sbName = pTopParams->queryProp(sb.str());
  4229. if (sbName)
  4230. {
  4231. if (strstr(sbName, "EclCCServerProcess") == sbName ||
  4232. strstr(sbName, "EclServerProcess") == sbName ||
  4233. strstr(sbName, "EclAgentProcess") == sbName ||
  4234. strstr(sbName, "EclSchedulerProcess") == sbName)
  4235. {
  4236. StringBuffer sbEcl(sbName);
  4237. if (strstr(sbName, " - "))
  4238. sbEcl.replaceString(" - ", "[@process='").append("']");
  4239. else if (strstr(sbName, " -"))
  4240. sbEcl.replaceString(" -", "[@process='").append("']");
  4241. buf.append("/").append(sbEcl);
  4242. }
  4243. else if (strstr(sbName, "Cluster") == sbName)
  4244. {
  4245. StringBuffer sbCl(sbName);
  4246. if (strstr(sbName, " - "))
  4247. sbCl.replaceString(" - ", "[@name='").append("']");
  4248. else if (strstr(sbName, " -"))
  4249. sbCl.replaceString(" -", "[@name='").append("']");
  4250. buf.append("/").append(sbCl);
  4251. }
  4252. else if (strstr(sbName, XML_TAG_THORCLUSTER) == sbName)
  4253. buf.append("/ThorCluster");
  4254. else if (strstr(sbName, XML_TAG_ROXIECLUSTER) == sbName)
  4255. buf.append("/RoxieCluster");
  4256. else if (buf.str()[buf.length() - 1] != ']')
  4257. buf.appendf("[@%s='%s']", sbName, pTopParams->queryProp(sb.replaceString("_name", "_value").str()));
  4258. }
  4259. }
  4260. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  4261. if (!strcmp(operation, "Add"))
  4262. {
  4263. StringBuffer sbNewType(newType);
  4264. if (!strcmp(newType, "EclCCServer"))
  4265. sbNewType.clear().append(XML_TAG_ECLCCSERVERPROCESS);
  4266. else if (!strcmp(newType, "EclServer"))
  4267. sbNewType.clear().append(XML_TAG_ECLSERVERPROCESS);
  4268. else if (!strcmp(newType, "EclAgent"))
  4269. sbNewType.clear().append(XML_TAG_ECLAGENTPROCESS);
  4270. else if (!strcmp(newType, "EclScheduler"))
  4271. sbNewType.clear().append(XML_TAG_ECLSCHEDULERPROCESS);
  4272. else if (!strcmp(newType, "Thor"))
  4273. sbNewType.clear().append(XML_TAG_THORCLUSTER);
  4274. else if (!strcmp(newType, "Roxie"))
  4275. sbNewType.clear().append(XML_TAG_ROXIECLUSTER);
  4276. IPropertyTree* pNode = createPTree(sbNewType.str());
  4277. if (!strcmp(sbNewType.str(), XML_TAG_ECLCCSERVERPROCESS) ||
  4278. !strcmp(sbNewType.str(), XML_TAG_ECLSERVERPROCESS) ||
  4279. !strcmp(sbNewType.str(), XML_TAG_ECLAGENTPROCESS) ||
  4280. !strcmp(sbNewType.str(), XML_TAG_ECLSCHEDULERPROCESS) ||
  4281. !strcmp(sbNewType.str(), XML_TAG_THORCLUSTER) ||
  4282. !strcmp(sbNewType.str(), XML_TAG_ROXIECLUSTER))
  4283. pNode->addProp(XML_ATTR_PROCESS, "");
  4284. else if (!strcmp(sbNewType.str(), XML_TAG_CLUSTER))
  4285. {
  4286. pNode->addProp(XML_ATTR_NAME, "");
  4287. pNode->addProp(XML_ATTR_PREFIX, "");
  4288. }
  4289. IPropertyTree* pTopology = pEnvRoot->queryPropTree(buf.str());
  4290. if (pTopology)
  4291. pTopology->addPropTree(sbNewType.str(), pNode);
  4292. resp.setStatus("true");
  4293. }
  4294. else if (!strcmp(operation, "Delete"))
  4295. {
  4296. String sParent(buf.str());
  4297. StringBuffer sbParent(XML_TAG_SOFTWARE"/"XML_TAG_TOPOLOGY);
  4298. int idx = sParent.lastIndexOf('/');
  4299. if (idx > 0)
  4300. {
  4301. String* tmpstr = sParent.substring(0, idx);
  4302. sbParent.clear().append(*tmpstr);
  4303. delete tmpstr;
  4304. }
  4305. IPropertyTree* pTopology = pEnvRoot->queryPropTree(sbParent);
  4306. IPropertyTree* pDel = pEnvRoot->queryPropTree(buf.str());
  4307. if (pTopology && pDel)
  4308. pTopology->removeTree(pDel);
  4309. resp.setStatus("true");
  4310. }
  4311. return true;
  4312. }
  4313. bool CWsDeployFileInfo::handleThorTopology(IEspContext &context, IEspHandleThorTopologyRequest &req, IEspHandleThorTopologyResponse &resp)
  4314. {
  4315. synchronized block(m_mutex);
  4316. checkForRefresh(context, &req.getReqInfo(), true);
  4317. const char* xmlArg = req.getXmlArgs();
  4318. const char* operation = req.getOperation();
  4319. StringBuffer xpath;
  4320. StringBuffer sMsg;
  4321. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  4322. bool retVal = handleThorTopologyOp(pEnvRoot, operation, xmlArg, sMsg);
  4323. resp.setStatus(retVal? "true" : sMsg.str());
  4324. return true;
  4325. }
  4326. bool CWsDeployFileInfo::handleAccessRules(IEspContext &context, IEspHandleAccessRulesRequest &req, IEspHandleAccessRulesResponse &resp)
  4327. {
  4328. synchronized block(m_mutex);
  4329. checkForRefresh(context, &req.getReqInfo(), true);
  4330. StringBuffer buildSetPath;
  4331. IPropertyTree *pEnvRoot = getEnvTree(context,&req.getReqInfo());
  4332. const char* xmlArg = req.getXmlArgs();
  4333. const char* operation = req.getOperation();
  4334. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements("./Programs/Build/BuildSet[@name=\"roxie\"]");
  4335. buildSetIter->first();
  4336. IPropertyTree* pBuildSet = &buildSetIter->query();
  4337. Owned<IPropertyTree> pParams = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  4338. const char* buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  4339. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  4340. const char* xpath = pParams->queryProp("@XPath");
  4341. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  4342. Owned<IPropertyTree> pNewCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName());
  4343. if (stricmp("Add",operation) == 0)
  4344. {
  4345. StringBuffer sbNewName("ACLrule");
  4346. getUniqueName(pEnvRoot, sbNewName, "Access", xpath);
  4347. IPropertyTree* pTempTree = createPTreeFromIPT(pNewCompTree->queryPropTree("Access"));
  4348. pTempTree->setProp(XML_ATTR_NAME, sbNewName.str());
  4349. (pEnvRoot->queryPropTree(xpath))->addPropTree("Access",pTempTree);
  4350. }
  4351. else if (stricmp("Delete", operation) == 0)
  4352. pEnvRoot->removeProp(xpath);
  4353. return true;
  4354. }
  4355. bool CWsDeployFileInfo::handleRows(IEspContext &context, IEspHandleRowsRequest &req, IEspHandleRowsResponse &resp)
  4356. {
  4357. synchronized block(m_mutex);
  4358. checkForRefresh(context, &req.getReqInfo(), true);
  4359. const char* xmlArg = req.getXmlArgs();
  4360. Owned<IPropertyTree> pParams = createPTreeFromXMLString(xmlArg && *xmlArg ? xmlArg : "<XmlArgs/>");
  4361. const char* buildSet = pParams->queryProp(XML_ATTR_BUILDSET);
  4362. const char* name = pParams->queryProp("@compName");
  4363. const char* rowType = pParams->queryProp("@rowType");
  4364. const char* operation = req.getOperation();
  4365. StringBuffer sbNewName;
  4366. StringBuffer xpath;
  4367. Owned<IPropertyTreeIterator> buildSetIter;
  4368. IPropertyTree* pBuildSet = NULL;
  4369. const char* buildSetName = NULL;
  4370. const char* processName = NULL;
  4371. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  4372. if (strcmp(name, "Directories"))
  4373. {
  4374. xpath.appendf("./Programs/Build/BuildSet[@name=\"%s\"]", buildSet);
  4375. buildSetIter.setown(pEnvRoot->getElements(xpath.str()));
  4376. buildSetIter->first();
  4377. pBuildSet = &buildSetIter->query();
  4378. buildSetName = pBuildSet->queryProp(XML_ATTR_NAME);
  4379. processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  4380. }
  4381. StringBuffer buildSetPath;
  4382. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  4383. IPropertyTree* pCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName());
  4384. if (!strcmp(operation, "Add"))
  4385. {
  4386. if (!strcmp(name, "Directories"))
  4387. {
  4388. xpath.clear().appendf("Software/Directories/Category[@name='%s']", rowType);
  4389. IPropertyTree* pCat = pEnvRoot->queryPropTree(xpath.str());
  4390. if (pCat)
  4391. {
  4392. IPropertyTree* pOver = pCat->queryPropTree("Override[@component=''][@dir=''][@instance='']");
  4393. if (!pOver)
  4394. {
  4395. pOver = pCat->addPropTree("Override", createPTree());
  4396. pOver->addProp("@component", "");
  4397. pOver->addProp("@dir", "");
  4398. pOver->addProp("@instance", "");
  4399. }
  4400. }
  4401. }
  4402. else
  4403. {
  4404. xpath.clear().appendf("./Software/%s[@name='%s']", processName, name);
  4405. Owned<IPropertyTreeIterator> rows = pParams->getElements("Row");
  4406. bool flag = false;
  4407. ForEach (*rows)
  4408. {
  4409. flag = true;
  4410. IPropertyTree* pRow = &rows->query();
  4411. const char* params = pRow->queryProp("@params");
  4412. StringBuffer decodedParams(params);
  4413. decodedParams.replaceString("::", "\n");
  4414. Owned<IProperties> pParams = createProperties();
  4415. pParams->loadProps(decodedParams.str());
  4416. const char* pszCompType = pParams->queryProp("pcType");
  4417. const char* pszCompName = pParams->queryProp("pcName");
  4418. const char* pszSubType = pParams->queryProp("subType");
  4419. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  4420. StringBuffer sbParent;
  4421. if (pszSubType && *pszSubType)
  4422. {
  4423. String subType(pszSubType);
  4424. int idx = subType.lastIndexOf('/');
  4425. if (idx > 0)
  4426. {
  4427. String* tmpstr = subType.substring(0, idx);
  4428. xpath.append("/").append(*tmpstr);
  4429. sbParent.append(*tmpstr);
  4430. delete tmpstr;
  4431. }
  4432. else
  4433. {
  4434. xpath.append("/").append(pszSubType);
  4435. sbParent.append(pszSubType);
  4436. if (pszSubTypeKey && *pszSubTypeKey)
  4437. xpath.append(pszSubTypeKey);
  4438. }
  4439. }
  4440. IPropertyTree* pComponent = pEnvRoot->queryPropTree(xpath.str());
  4441. IPropertyTree* pCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, buildSetName, m_pService->getCfg(), m_pService->getName());
  4442. StringBuffer sb(rowType);
  4443. if (!strncmp(sb.str(), "_", 1))
  4444. sb.remove(0, 1);
  4445. StringBuffer s;
  4446. s.appendf("xs:element//*[@name=\"%s\"]//*[@name=\"%s\"]//xs:attribute[@name='name']", sbParent.str(), rowType);
  4447. IPropertyTree* pt = pSchema->queryPropTree(s.str());
  4448. if (pt && pt->hasProp("@type"))
  4449. {
  4450. const char* px = pt->queryProp("@type");
  4451. if (!strcmp(px, "xs:string"))
  4452. {
  4453. StringBuffer sbNewName(rowType);
  4454. xpath.clear().appendf("%s[@name='%s']/%s", processName, name, sbParent.str());
  4455. getUniqueName(pEnvRoot, sbNewName, xpath.str(), XML_TAG_SOFTWARE);
  4456. pCompTree->setProp(sb.str(), sbNewName);
  4457. resp.setCompName(sbNewName);
  4458. }
  4459. }
  4460. if (pComponent && pCompTree)
  4461. pComponent->addPropTree(rowType, pCompTree->queryPropTree(rowType));
  4462. //If we are adding, just consider the first selection.
  4463. break;
  4464. }
  4465. if (!flag)
  4466. {
  4467. if (pCompTree->queryPropTree(rowType))
  4468. {
  4469. if (strcmp(rowType, "Notes"))
  4470. {
  4471. StringBuffer sbNewName(rowType);
  4472. xpath.clear().appendf("%s[@name]", rowType);
  4473. if (pCompTree->hasProp(xpath.str()))
  4474. {
  4475. xpath.clear().appendf("%s[@name='%s']/%s", processName, name, rowType);
  4476. getUniqueName(pEnvRoot, sbNewName, xpath.str(), XML_TAG_SOFTWARE);
  4477. pCompTree->queryPropTree(rowType)->setProp(XML_ATTR_NAME, sbNewName);
  4478. resp.setCompName(sbNewName.str());
  4479. }
  4480. }
  4481. else
  4482. {
  4483. IPropertyTree* pNotes = pCompTree->queryPropTree(rowType);
  4484. if (pNotes->hasProp("@computer"))
  4485. pNotes->setProp("@computer", m_userIp.str());
  4486. if (pNotes->hasProp("@user"))
  4487. pNotes->setProp("@user", "");
  4488. if (pNotes->hasProp("@date"))
  4489. {
  4490. CDateTime dt;
  4491. StringBuffer tmp;
  4492. dt.setNow();
  4493. tmp.clear();
  4494. unsigned mo, da, yr;
  4495. dt.getDate(yr, mo, da, true);
  4496. tmp.appendf("%d/%d/%d ", mo, da, yr);
  4497. dt.getTimeString(tmp, true);
  4498. pNotes->setProp("@date", tmp.str());
  4499. resp.setCompName(tmp.str());
  4500. }
  4501. }
  4502. xpath.clear().appendf("./Software/%s[@name='%s']", processName, name);
  4503. IPropertyTree* pComponent = pEnvRoot->queryPropTree(xpath.str());
  4504. if (pComponent)
  4505. pComponent->addPropTree(rowType, pCompTree->queryPropTree(rowType));
  4506. }
  4507. }
  4508. }
  4509. resp.setStatus("true");
  4510. }
  4511. else if (!strcmp(operation, "Delete"))
  4512. {
  4513. if (!strcmp(name, "Directories"))
  4514. xpath.clear().appendf("./Software/Directories/Category[@name='%s']", rowType);
  4515. else
  4516. xpath.clear().appendf("./Software/%s[@name='%s']", processName, name);
  4517. IPropertyTree* pComponent = pEnvRoot->queryPropTree(xpath.str());
  4518. Owned<IPropertyTreeIterator> iterRows = pParams->getElements("Row");
  4519. ForEach (*iterRows)
  4520. {
  4521. IPropertyTree* pRow = &iterRows->query();
  4522. const char* rowName = pRow->queryProp("@rowName");
  4523. if (!strcmp(name, "Directories"))
  4524. {
  4525. const char* compType = pRow->queryProp("@compType");
  4526. xpath.clear().appendf("Override[@component='%s'][@instance='%s']", compType, rowName);
  4527. }
  4528. else
  4529. {
  4530. if (!strcmp(rowType, "Notes"))
  4531. {
  4532. const char* rowDate = pRow->queryProp("@rowDate");
  4533. if (!rowDate || !*rowDate)
  4534. continue;
  4535. xpath.clear().appendf("%s[@date='%s']", rowType, rowDate);
  4536. }
  4537. else if (rowName && *rowName)
  4538. xpath.clear().appendf("%s[@name='%s']", rowType, rowName);
  4539. else
  4540. {
  4541. const char* params = pRow->queryProp("@params");
  4542. StringBuffer decodedParams(params);
  4543. decodedParams.replaceString("::", "\n");
  4544. Owned<IProperties> pParams = createProperties();
  4545. pParams->loadProps(decodedParams.str());
  4546. const char* pszCompType = pParams->queryProp("pcType");
  4547. const char* pszCompName = pParams->queryProp("pcName");
  4548. const char* pszSubType = pParams->queryProp("subType");
  4549. const char* pszSubTypeKey = pParams->queryProp("subTypeKey");
  4550. StringBuffer sbParent;
  4551. if (pszSubType && *pszSubType)
  4552. {
  4553. String subType(pszSubType);
  4554. xpath.clear().append(pszSubType);
  4555. if (pszSubTypeKey && *pszSubTypeKey)
  4556. xpath.append(pszSubTypeKey);
  4557. }
  4558. }
  4559. }
  4560. if (pComponent)
  4561. pComponent->removeTree(pComponent->queryPropTree(xpath.str()));
  4562. }
  4563. resp.setCompName("");
  4564. resp.setStatus("true");
  4565. }
  4566. return true;
  4567. }
  4568. IPropertyTree* CWsDeployFileInfo::findComponentForFolder(IPropertyTree* pFolder, IPropertyTree* pEnvSoftware)
  4569. {
  4570. //Folder's @params has string of the form:
  4571. //"comp=EspProcess&name=esp&inst=s1&computer=2wd20"
  4572. //
  4573. StringBuffer decodedParams( pFolder->queryProp("@params") );
  4574. decodedParams.replace('&', '\n');
  4575. Owned<IProperties> pParams = createProperties();
  4576. pParams->loadProps(decodedParams.str());
  4577. const char* comp = pParams->queryProp("comp");
  4578. const char* name = pParams->queryProp("name");
  4579. if (!(comp && *comp && name && *name))
  4580. throw MakeStringException(-1, "Invalid parameters");
  4581. StringBuffer xpath;
  4582. xpath.appendf("%s[@name='%s']", comp, name);
  4583. IPropertyTree* pComp = pEnvSoftware->queryPropTree(xpath.str());
  4584. if (!pComp)
  4585. throw MakeStringException(-1, "No such component in environment: '%s' named '%s'.", comp, name);
  4586. return pComp;
  4587. }
  4588. void CWsDeployFileInfo::addDeployableComponentAndInstances(IPropertyTree* pEnvRoot, IPropertyTree* pComp,
  4589. IPropertyTree* pDst, IPropertyTree* pFolder,
  4590. const char* displayType)
  4591. {
  4592. const char* comp = pComp->queryName();
  4593. const char* name = pComp->queryProp(XML_ATTR_NAME);
  4594. if (!name || !*name)
  4595. throw MakeStringException(-1, "The environment has an incomplete definition for a '%s'!", comp);
  4596. const char* build= pComp->queryProp(XML_ATTR_BUILD);
  4597. const char* buildSet= pComp->queryProp(XML_ATTR_BUILDSET);
  4598. if (!build || !*build)
  4599. throw MakeStringException(-1, "%s '%s' does not have any build defined!", comp, name);
  4600. if (!buildSet || !*buildSet)
  4601. throw MakeStringException(-1, "%s '%s' does not have any build set defined!", comp, name);
  4602. StringBuffer xpath;
  4603. xpath.appendf("Programs/Build[@name='%s']/BuildSet[@name='%s']", build, buildSet);
  4604. IPropertyTree* pBuildSetNode = pEnvRoot->queryPropTree(xpath.str());
  4605. if (!pBuildSetNode)
  4606. throw MakeStringException(-1, "Build %s or build set %s is not defined!", build, buildSet);
  4607. const char* deployable = pBuildSetNode->queryProp("@deployable");
  4608. if (!deployable || (0!=strcmp(deployable, "no") && 0!=strcmp(deployable, "false")))
  4609. {
  4610. char achDisplayType[132];//long enough to hold any expanded type whatsoever
  4611. if (!displayType)
  4612. {
  4613. GetDisplayProcessName(pComp->queryName(), achDisplayType);
  4614. displayType = achDisplayType;
  4615. }
  4616. const bool bDeployAllInstances = !pFolder || pFolder->getPropBool("@selected", false);
  4617. if (bDeployAllInstances)
  4618. {
  4619. //add its instances
  4620. Owned<IPropertyTreeIterator> iInst = pComp->getElements("*");
  4621. ForEach(*iInst)
  4622. {
  4623. IPropertyTree* pInstance = &iInst->query();
  4624. const char* instType = pInstance->queryName();
  4625. if (instType && (!strcmp(instType, XML_TAG_INSTANCE) || !strcmp(instType, XML_TAG_ROXIE_SERVER)))
  4626. {
  4627. const char* instName = pInstance->queryProp(XML_ATTR_NAME);
  4628. const char* computer = pInstance->queryProp(XML_ATTR_COMPUTER);
  4629. if (instName && *instName && computer && *computer)
  4630. addInstance(pDst, comp, displayType, name, build, instType, instName, computer);
  4631. }
  4632. }//ForEach(*iInst)
  4633. }
  4634. else
  4635. {
  4636. //pFolder exists and is not selected so deploy selected instances
  4637. Owned<IPropertyTreeIterator> iLink = pFolder->getElements("*[@selected='true']");
  4638. ForEach(*iLink)
  4639. {
  4640. IPropertyTree* pLink = &iLink->query();
  4641. const char* params = pLink->queryProp("@params");
  4642. if (params)
  4643. {
  4644. // pFolder's @params has string of the form: "comp=EspProcess&amp;name=esp&amp;instType=Instance&amp;inst=s1&amp;computer=2wd20"
  4645. //
  4646. StringBuffer decodedParams( params );
  4647. decodedParams.replace('&', '\n');
  4648. Owned<IProperties> pParams = createProperties();
  4649. pParams->loadProps( decodedParams.str() );
  4650. const char* instType = pParams->queryProp("instType");
  4651. const char* instName = pParams->queryProp("inst");
  4652. const char* computer = pParams->queryProp(TAG_COMPUTER);
  4653. if (instType && *instType && instName && *instName && computer && *computer)
  4654. {
  4655. StringBuffer xpath;
  4656. xpath.appendf("%s[@name='%s']", instType, instName);
  4657. IPropertyTree* pInstNode = pComp->queryPropTree(xpath.str());
  4658. if (!pInstNode)
  4659. throw MakeStringException(-1, "%s '%s' does not have any '%s' named %s!", displayType, comp, instType, instName);
  4660. addInstance(pDst, comp, displayType, name, build, instType, instName, computer);
  4661. }
  4662. }
  4663. }
  4664. }
  4665. }
  4666. }
  4667. void CWsDeployFileInfo::addInstance(IPropertyTree* pDst, const char* comp, const char* displayType,
  4668. const char* compName, const char* build, const char* instType,
  4669. const char* instName, const char* computer)
  4670. {
  4671. IPropertyTree* pCompNode = pDst->addPropTree( XML_TAG_COMPONENT, createPTree() );
  4672. pCompNode->addProp("Type", comp);
  4673. pCompNode->addProp("DisplayType", displayType);
  4674. pCompNode->addProp("Name", compName);
  4675. pCompNode->addProp("Build", build);
  4676. pCompNode->addProp("InstanceType", instType);
  4677. pCompNode->addProp("Instance", instName);
  4678. pCompNode->addProp("Computer", computer);
  4679. }
  4680. //---------------------------------------------------------------------------
  4681. // GetDisplayProcessName
  4682. //---------------------------------------------------------------------------
  4683. const char* CWsDeployFileInfo::GetDisplayProcessName(const char* processName, char* buf) const
  4684. {
  4685. //produces "LDAPServerProcess" as "LDAP Server" and "EspService" as "Esp Service", etc.
  4686. if (!strcmp(processName, XML_TAG_ESPPROCESS))
  4687. return strcpy(buf, "ESP Server");
  4688. else
  4689. {
  4690. const char* begin = buf;
  4691. const char* end = strstr(processName, "Process");
  4692. if (!end)
  4693. end = processName + strlen(processName);
  4694. *buf++ = *processName++;
  4695. bool bLower = false;
  4696. while (processName < end)
  4697. {
  4698. char ch = *processName;
  4699. if (isupper(ch))
  4700. {
  4701. if (bLower || //last char was uppercase or the following character is lowercase?
  4702. ((processName+1 < end) && islower(*(processName+1))))
  4703. {
  4704. *buf++ = ' ';
  4705. }
  4706. bLower = false;
  4707. }
  4708. else
  4709. bLower = true;
  4710. *buf++ = *processName++;
  4711. }
  4712. *buf = '\0';
  4713. return begin;
  4714. }
  4715. }
  4716. void CWsDeployFileInfo::setFilePath(StringBuffer &filePath, const char* targetName)
  4717. {
  4718. filePath.clear().append(CONFIG_SOURCE_DIR);
  4719. if (filePath.charAt(filePath.length() - 1) != PATHSEPCHAR)
  4720. filePath.append(PATHSEPCHAR);
  4721. filePath.append(targetName);
  4722. }
  4723. void CWsDeployFileInfo::updateConfigFromFile()
  4724. {
  4725. StringBuffer sbxml;
  4726. synchronized block(m_mutex);
  4727. if (m_pFileIO.get() != NULL)
  4728. {
  4729. m_pFileIO.clear();
  4730. }
  4731. if (m_lastSaved.isNull())
  4732. {
  4733. m_lastSaved.setNow();
  4734. }
  4735. m_pFileIO.setown(m_pFile->open(IFOread));
  4736. Owned <IPropertyTree> pTree = createPTree(*m_pFileIO);
  4737. toXML(pTree, sbxml.clear());
  4738. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  4739. m_constEnvRdOnly.clear();
  4740. m_constEnvRdOnly.setown(factory->loadLocalEnvironment(sbxml.str()));
  4741. m_lastSaved.clear();
  4742. m_lastSaved.setNow();
  4743. }
  4744. bool CWsDeployFileInfo::deploy(IEspContext &context, IEspDeployRequest& req, IEspDeployResponse& resp)
  4745. {
  4746. synchronized block(m_mutex);
  4747. checkForRefresh(context, &req.getReqInfo(), true);
  4748. resp.setComponent("WsDeploy");
  4749. resp.setCommand("Deploy");
  4750. StringBuffer deployResult;
  4751. IConstDeployInfo& depInfo = req.getDeploy();
  4752. IArrayOf<IConstComponent>& components = depInfo.getComponents();
  4753. unsigned int nComps = components.ordinality();
  4754. if (nComps == 0)
  4755. {
  4756. resp.setStatus( "Please select at least one component to deploy!" );
  4757. CDeployOptions& depOptions = dynamic_cast<CDeployOptions&>( depInfo.getOptions() );
  4758. depOptions.serializeStruct(&context,deployResult, "Options");
  4759. }
  4760. else
  4761. {
  4762. CWsDeployEngine depEngine(*m_pService, req.getDeploy(),&context);
  4763. depEngine.deploy();
  4764. Owned<IPropertyTree> pDeployResult = depEngine.getDeployResult();
  4765. IPropertyTree* pComponents = pDeployResult->queryPropTree("Components");
  4766. toXML(pComponents, deployResult, false);
  4767. IPropertyTree* pOptions = pDeployResult->queryPropTree("Options");
  4768. toXML(pOptions, deployResult, false);
  4769. resp.setStatus( depEngine.getDeployStatus() );
  4770. }
  4771. resp.setDeploy( deployResult.str() );
  4772. return true;
  4773. }
  4774. bool CWsDeployExCE::onInit(IEspContext &context, IEspEmptyRequest& req, IEspInitResponse& resp)
  4775. {
  4776. resp.setComponent("WsDeploy");
  4777. resp.setCommand("Init");
  4778. return true;
  4779. }
  4780. //the following method must be called with ownership of m_mutex
  4781. //
  4782. void CWsDeployFileInfo::generateGraph(IEspContext &context, IConstWsDeployReqInfo *reqInfo)
  4783. {
  4784. {
  4785. synchronized block(m_mutex);
  4786. checkForRefresh(context, reqInfo, true);
  4787. }
  4788. if (!m_pEnvXml)
  4789. {
  4790. Owned<IPropertyTree> pEnvTree = getEnvTree(context, reqInfo);
  4791. m_pEnvXml.set(new SCMStringBuffer());
  4792. toXML(pEnvTree, m_pEnvXml->s, false);
  4793. }
  4794. m_pGraphXml.set(new SCMStringBuffer());
  4795. xsltTransform(m_pEnvXml->str(), StringBuffer(getCFD()).append("xslt/graph_env.xslt").str(), NULL, m_pGraphXml->s);
  4796. }
  4797. //---------------------------------------------------------------------------
  4798. // onGraph
  4799. //---------------------------------------------------------------------------
  4800. bool CWsDeployFileInfo::graph(IEspContext &context, IEspEmptyRequest& req, IEspGraphResponse& resp)
  4801. {
  4802. synchronized block(m_mutex);
  4803. if (!m_pGraphXml)
  4804. generateGraph(context, NULL);
  4805. resp.setGraphContainer(m_pGraphXml->str());
  4806. return true;
  4807. }
  4808. void CWsDeployFileInfo::getNavigationData(IEspContext &context, IPropertyTree* pData)
  4809. {
  4810. try
  4811. {
  4812. synchronized block(m_mutex);
  4813. if (m_envFile.length())
  4814. {
  4815. if (!m_userWithLock.length())
  4816. {
  4817. context.getUserID(m_userWithLock);
  4818. context.getPeer(m_userIp);
  4819. }
  4820. else
  4821. {
  4822. StringBuffer sbName, sbUserIp;
  4823. context.getUserID(sbName);
  4824. context.getPeer(sbUserIp);
  4825. if (strcmp(sbName.str(), m_userWithLock.str()) || strcmp(sbUserIp.str(), m_userIp.str()))
  4826. throw MakeStringException(-1, "A user on machine %s is accessing the file. Please try again later.", m_userIp.str());
  4827. }
  4828. initFileInfo(false);
  4829. }
  4830. if (!m_pNavTree)
  4831. {
  4832. if (!m_pEnvXml)
  4833. {
  4834. Owned<IPropertyTree> pEnvTree = getEnvTree(context, NULL);
  4835. m_pEnvXml.set(new SCMStringBuffer());
  4836. toXML(pEnvTree, m_pEnvXml->s, false);
  4837. }
  4838. m_pNavTree.setown(getEnvTree(context, NULL));
  4839. }
  4840. pData->setProp("@viewType", "tree");
  4841. mergePTree(pData, m_pNavTree);
  4842. }
  4843. catch(IException*e)
  4844. {
  4845. StringBuffer sErrMsg;
  4846. e->errorMessage(sErrMsg);
  4847. e->Release();
  4848. }
  4849. catch(...)
  4850. {
  4851. }
  4852. }
  4853. void CWsDeployFileInfo::saveEnvironment(IEspContext* pContext, IConstWsDeployReqInfo *reqInfo, StringBuffer& errMsg, bool saveAs)
  4854. {
  4855. if (m_envFile.length())
  4856. {
  4857. Owned<IPropertyTree> pEnvRoot;
  4858. StringBuffer valerrs;
  4859. try
  4860. {
  4861. if (!saveAs || (saveAs && m_Environment))
  4862. {
  4863. pEnvRoot.setown(&m_Environment->getPTree());
  4864. validateEnv((IConstEnvironment*)m_Environment, false);
  4865. }
  4866. else if (saveAs)
  4867. {
  4868. setSkipNotification(true);
  4869. pEnvRoot.setown(&m_constEnvRdOnly->getPTree());
  4870. validateEnv(m_constEnvRdOnly, false);
  4871. }
  4872. }
  4873. catch(IException* e)
  4874. {
  4875. e->errorMessage(valerrs);
  4876. e->Release();
  4877. }
  4878. //save and write to backup
  4879. StringBuffer sXML;
  4880. StringBuffer tmp;
  4881. StringBuffer dtStr;
  4882. CDateTime dt;
  4883. dt.setNow();
  4884. dt.getString(tmp.clear());
  4885. sXML.appendf("<"XML_HEADER">\n<!-- Edited with ConfigMgr on ip %s on %s -->\n", m_userIp.str(), tmp.str());
  4886. toXML(pEnvRoot, sXML, 0, XML_SortTags | XML_Format);
  4887. if (m_bCloud && pContext)
  4888. {
  4889. StringBuffer sbName, sbUserIp, sbMsg;
  4890. if (reqInfo)
  4891. sbName.clear().append(reqInfo->getUserId());
  4892. pContext->getPeer(sbUserIp);
  4893. CCloudActionHandler saveCloud(this, CLOUD_SAVE_ENV, CLOUD_ROLLBACK_ENV, sbName.str(), "8015", NULL);
  4894. StringBuffer tick;
  4895. tick.appendf("%d", msTick());
  4896. saveCloud.setSaveActionParams(sXML.str(), tick.str());
  4897. bool ret = saveCloud.start(sbMsg);
  4898. if (!ret || sbMsg.length())
  4899. throw MakeStringException(0, "Environment could not be successfully saved. Reason(s):\n%s", sbMsg.str());
  4900. }
  4901. try
  4902. {
  4903. if (m_pFile.get())
  4904. {
  4905. StringBuffer sb;
  4906. if (!checkDirExists(m_pService->getBackupDir()))
  4907. recursiveCreateDirectory(m_pService->getBackupDir());
  4908. while(true)
  4909. {
  4910. String strEnvFile(m_envFile);
  4911. int idx = strEnvFile.lastIndexOf('/');
  4912. if (idx <= 0)
  4913. idx = strEnvFile.lastIndexOf('\\');
  4914. String* tmpstr = strEnvFile.substring(idx+1);
  4915. sb.clear().append(m_pService->getBackupDir()).append(PATHSEPCHAR).append(*tmpstr);
  4916. delete tmpstr;
  4917. dt.setNow();
  4918. tmp.clear();
  4919. dtStr.clear();
  4920. dt.getDateString(tmp, true);
  4921. tmp.append("_");
  4922. dt.getTimeString(tmp, true);
  4923. dtStr.append(".").append(tmp);
  4924. dtStr.replaceString("-","_");
  4925. dtStr.replaceString(":","_");
  4926. String ext(sb);
  4927. idx = ext.lastIndexOf(PATHSEPCHAR);
  4928. if(ext.indexOf('.', idx > 0 ? idx : 0) != -1)
  4929. sb.insert(ext.lastIndexOf('.'), dtStr.str());
  4930. else
  4931. sb.append(dtStr.str());
  4932. if (checkFileExists(sb))
  4933. continue;
  4934. else
  4935. {
  4936. Owned<IFile> pFile(createIFile(sb.str()));
  4937. setSkipNotification(true);
  4938. copyFile(pFile, m_pFile, 0x100000);
  4939. break;
  4940. }
  4941. }
  4942. }
  4943. }
  4944. catch(IException* e)
  4945. {
  4946. //ignore any attempts to create the backup
  4947. e->Release();
  4948. }
  4949. if (!m_pFile.get())
  4950. m_pFile.setown(createIFile(m_envFile));
  4951. m_pFileIO.clear();
  4952. m_pFileIO.setown(m_pFile->open(IFOcreaterw));
  4953. m_pFileIO->write(0, sXML.length(), sXML.str());
  4954. m_lastSaved.clear();
  4955. m_lastSaved.setNow();
  4956. //reset the readonly tree
  4957. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  4958. m_constEnvRdOnly.setown(factory->loadLocalEnvironment(sXML.str()));
  4959. if (valerrs.length())
  4960. errMsg.appendf("CWsDeployFileInfo::saveEnvironment:Save operation was successful. However the following exceptions were raised.\n%s", valerrs.str());
  4961. }
  4962. else
  4963. {
  4964. // JAKESMITH->SMEDA - apparently this code is legacy and can be deleted, please do + clearup related code if any
  4965. try
  4966. {
  4967. m_Environment->commit();
  4968. StringBuffer response;
  4969. initClusterGroups(false, response, NULL);
  4970. if (response.length())
  4971. PROGLOG("CWsDeployFileInfo::saveEnvironment: %s", response.str());
  4972. }
  4973. catch (IException* e)
  4974. {
  4975. StringBuffer sErrMsg;
  4976. e->errorMessage(sErrMsg);
  4977. e->Release();
  4978. /*typical error message when lock fails is as follows:
  4979. SDS: Lock timeout
  4980. SDS Reply Error : SDS: Lock timeout
  4981. Failed to establish lock to NewEnvironment/
  4982. Existing lock status: Locks on path: /NewEnvironment/
  4983. Endpoint |SessionId |ConnectionId |mode
  4984. 172.16.48.175:7254 |c00000038 |c0000003b |653
  4985. */
  4986. //if we can extract IP address of computer holding the lock then
  4987. //show a customized message.
  4988. //
  4989. //Retrieve IP address of computer holding the lock...
  4990. char achHost[128] = "";
  4991. const char* p = strstr(sErrMsg.str(), "\n\n");
  4992. if (p && *(p+=2))
  4993. {
  4994. const char* q = strchr(p, ':');
  4995. if (q)
  4996. {
  4997. const int len = q-p;
  4998. strncpy(achHost, p, len);
  4999. achHost[len] = '\0';
  5000. }
  5001. }
  5002. //resolve hostname for this IP address
  5003. unsigned int addr = inet_addr(achHost);
  5004. struct hostent* hp = gethostbyaddr((const char*)&addr, sizeof(addr), AF_INET);
  5005. if (hp)
  5006. strcpy(achHost, hp->h_name);
  5007. StringBuffer sMsg;
  5008. sMsg.appendf("The environment definition in dali server "
  5009. "could not be opened for write access");
  5010. if (achHost[0])
  5011. sMsg.appendf(" \nbecause it is locked by computer '%s'.", achHost);
  5012. else
  5013. sMsg.append(":\n\n").append(sErrMsg);
  5014. throw MakeStringException(0, "%s", sMsg.str());
  5015. }
  5016. }
  5017. CConfigFileMonitorThread::getInstance()->addObserver(*this);
  5018. }
  5019. void CWsDeployFileInfo::unlockEnvironment(IEspContext* context, IConstWsDeployReqInfo *reqInfo, const char* xmlArg, StringBuffer& sbErrMsg, bool saveEnv)
  5020. {
  5021. if (m_bCloud)
  5022. {
  5023. StringBuffer sbMsg;
  5024. Owned<IPropertyTree> pComputers = createPTreeFromXMLString(xmlArg);
  5025. Owned<IPropertyTree> unlockComputers = createPTree("ComputerList");
  5026. Owned<IPropertyTree> lockComputers = createPTree("ComputerList");
  5027. Owned<IPropertyTreeIterator> iter;
  5028. StringBuffer xpath;
  5029. if (pComputers && pComputers->numChildren() && m_lockedNodesBeforeEnv.get() != NULL)
  5030. {
  5031. expandRange(pComputers);
  5032. iter.setown(pComputers->getElements("Computer"));
  5033. ForEach (*iter)
  5034. {
  5035. IPropertyTree* pComputer = &iter->query();
  5036. xpath.clear().appendf(XML_TAG_COMPUTER"["XML_ATTR_NETADDRESS"='%s']", pComputer->queryProp(XML_ATTR_NETADDRESS));
  5037. if (!m_lockedNodesBeforeEnv->queryPropTree(xpath.str()))
  5038. lockComputers->addPropTree(XML_TAG_COMPUTER, createPTreeFromIPT(pComputer));
  5039. }
  5040. }
  5041. if (!pComputers && m_lockedNodesBeforeEnv.get() != NULL)
  5042. unlockComputers.set(m_lockedNodesBeforeEnv);
  5043. else if (m_lockedNodesBeforeEnv.get() != NULL)
  5044. {
  5045. iter.setown(m_lockedNodesBeforeEnv->getElements("Computer"));
  5046. ForEach (*iter)
  5047. {
  5048. IPropertyTree* pComputer = &iter->query();
  5049. xpath.clear().appendf(XML_TAG_COMPUTER"["XML_ATTR_NETADDRESS"='%s']", pComputer->queryProp(XML_ATTR_NETADDRESS));
  5050. if (!pComputers->queryPropTree(xpath.str()))
  5051. unlockComputers->addPropTree(XML_TAG_COMPUTER, createPTreeFromIPT(pComputer));
  5052. }
  5053. }
  5054. CCloudActionHandler unlockCloud(this, CLOUD_UNLOCK_ENV, CLOUD_NONE, m_userWithLock.str(), "8015", unlockComputers->numChildren() ? unlockComputers : NULL);
  5055. bool ret = unlockCloud.start(sbMsg);
  5056. if (!ret || sbMsg.length())
  5057. {
  5058. if (saveEnv)
  5059. sbErrMsg.append("Save operation is successful. However, ");
  5060. sbErrMsg.appendf("Write access to the Environment cannot be revoked. Reason(s):\n%s", sbMsg.str());
  5061. return;
  5062. }
  5063. else
  5064. {
  5065. Owned<IPropertyTreeIterator> iter = unlockComputers->getElements("Computer");
  5066. StringBuffer xpath;
  5067. ForEach (*iter)
  5068. {
  5069. IPropertyTree* pComputer = &iter->query();
  5070. xpath.clear().appendf(XML_TAG_COMPUTER"["XML_ATTR_NETADDRESS"='%s']", pComputer->queryProp(XML_ATTR_NETADDRESS));
  5071. IPropertyTree* pDelComputer = m_lockedNodesBeforeEnv->queryPropTree(xpath.str());
  5072. m_lockedNodesBeforeEnv->removeTree(pDelComputer);
  5073. }
  5074. }
  5075. if (lockComputers->numChildren())
  5076. {
  5077. CCloudActionHandler lockCloud(this, CLOUD_LOCK_ENV, CLOUD_NONE, m_userWithLock.str(), "8015", lockComputers);
  5078. ret = lockCloud.start(sbMsg.clear());
  5079. if (!ret || sbMsg.length())
  5080. {
  5081. if (saveEnv)
  5082. sbErrMsg.append("Save operation is successful. However, ");
  5083. sbErrMsg.appendf("Write access to the Environment could not be obtained. Reason(s):\n%s", sbMsg.str());
  5084. return;
  5085. }
  5086. }
  5087. }
  5088. m_Environment.clear();
  5089. StringBuffer sb(m_userWithLock);
  5090. sb.append(m_userIp);
  5091. CClientAliveThread* th = m_keepAliveHTable.getValue(sb.str());
  5092. if (th)
  5093. {
  5094. th->Release();
  5095. m_keepAliveHTable.remove(sb.str());
  5096. }
  5097. if (m_envFile.length() == 0)
  5098. {
  5099. Owned<IGroup> serverGroup = createIGroup(m_daliServer.str(), m_daliServerPort);
  5100. if (!serverGroup)
  5101. throw MakeStringException(0, "Could not instantiate IGroup");
  5102. if (!initClientProcess(serverGroup, DCR_Config, 0, NULL, NULL, 10000))
  5103. throw MakeStringException(0, "Could not initialize the client process");
  5104. m_pSubscription.clear();
  5105. m_pSubscription.setown( new CSdsSubscription(this) );
  5106. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  5107. m_constEnvRdOnly.setown(factory->openEnvironment());
  5108. }
  5109. m_constEnvRdOnly->clearCache();
  5110. m_userWithLock.clear();
  5111. m_userIp.clear();
  5112. Owned<IPropertyTree> pNavTree(getEnvTree(*context, reqInfo));
  5113. if (!areMatchingPTrees(pNavTree, m_pNavTree))
  5114. {
  5115. m_pEnvXml.clear();
  5116. m_pGraphXml.clear();
  5117. m_pNavTree.clear();
  5118. m_pNavTree.setown(getEnvTree(*context, reqInfo));
  5119. }
  5120. }
  5121. void CWsDeployFileInfo::checkForRefresh(IEspContext &context, IConstWsDeployReqInfo *reqInfo, bool checkWriteAccess)
  5122. {
  5123. StringBuffer sbUser, sbIp;
  5124. if (reqInfo)
  5125. sbUser.clear().append(reqInfo->getUserId());
  5126. context.getPeer(sbIp);
  5127. if (checkWriteAccess)
  5128. {
  5129. if (!m_Environment || m_userWithLock.length() == 0 || m_userIp.length() == 0)
  5130. throw MakeStringException(-1, "Cannot modify environment as it is currently in readonly mode");
  5131. else if (m_userWithLock.length() != 0 && m_userIp.length() != 0 && (strcmp(m_userWithLock.str(), sbUser.str()) || strcmp(m_userIp.str(), sbIp.str())))
  5132. throw MakeStringException(-1, "Cannot modify setting as environment is currently in use on machine '%s'", m_userIp.str());
  5133. }
  5134. }
  5135. IPropertyTree* CWsDeployFileInfo::queryComputersForCloud()
  5136. {
  5137. Owned<IPropertyTree> pEnvTree = m_Environment?&m_Environment->getPTree():&m_constEnvRdOnly->getPTree();
  5138. return pEnvTree->queryPropTree(XML_TAG_HARDWARE);
  5139. }
  5140. void CCloudTaskThread::main()
  5141. {
  5142. static Mutex m;
  5143. m.lock();
  5144. try
  5145. {
  5146. m_pTask->makeSoapCall();
  5147. }
  5148. catch(IException* e)
  5149. {
  5150. e->Release();
  5151. }
  5152. m.unlock();
  5153. }
  5154. CCloudTask* createCloudTask(CCloudActionHandler* pHandler, EnvAction eA, const char* ip)
  5155. {
  5156. return new CCloudTask(pHandler, eA, ip);
  5157. }
  5158. bool CWsDeployFileInfo::updateEnvironment(const char* xml)
  5159. {
  5160. if (!xml || !*xml)
  5161. return false;
  5162. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  5163. m_constEnvRdOnly.setown(factory->loadLocalEnvironment(xml));
  5164. return true;
  5165. }
  5166. bool CWsDeployFileInfo::isLocked(StringBuffer& sbUser, StringBuffer& sbIp)
  5167. {
  5168. if (m_userIp.length() != 0 && m_userWithLock.length() != 0)
  5169. {
  5170. sbUser.clear().append(m_userWithLock);
  5171. sbIp.clear().append(m_userIp);
  5172. return true;
  5173. }
  5174. return false;
  5175. }
  5176. bool CWsDeployFileInfo::buildEnvironment(IEspContext &context, IEspBuildEnvironmentRequest &req, IEspBuildEnvironmentResponse &resp)
  5177. {
  5178. synchronized block(m_mutex);
  5179. resp.setStatus("false");
  5180. const char* xml = req.getXmlArgs();
  5181. StringBuffer sbName, sbUserIp, msg, envXml;
  5182. sbName.clear().append(req.getReqInfo().getUserId());
  5183. context.getPeer(sbUserIp);
  5184. if(m_userWithLock.length() > 0)
  5185. {
  5186. if(!strcmp(sbName.str(), m_userWithLock.str()) || !strcmp(sbUserIp.str(), m_userIp.str()))
  5187. {
  5188. buildEnvFromWizard(xml, m_pService->getName(), m_pService->getCfg(), envXml);
  5189. setSkipNotification(true);
  5190. if(envXml.length())
  5191. {
  5192. resp.setStatus("true");
  5193. if(m_Environment != NULL)
  5194. {
  5195. m_Environment.clear();
  5196. }
  5197. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  5198. m_Environment.setown(factory->loadLocalEnvironment(envXml.str()));
  5199. }
  5200. else
  5201. resp.setMessage("Failed to generated the environment xml for unknown reason");
  5202. }
  5203. else{
  5204. sbName.append("Cannot generate environment, As environment is locked by ").append(m_userWithLock);
  5205. resp.setMessage(sbName.str());
  5206. }
  5207. }
  5208. else
  5209. resp.setMessage("Environment has not been locked.");
  5210. return true;
  5211. }
  5212. bool CWsDeployFileInfo::getSubnetIPAddr(IEspContext &context, IEspGetSubnetIPAddrRequest &req, IEspGetSubnetIPAddrResponse &resp)
  5213. {
  5214. synchronized block(m_mutex);
  5215. resp.setIPList("");
  5216. resp.setMessage("");
  5217. StringBuffer ipList, msg, script;
  5218. StringBuffer xpath ;
  5219. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalConfFile",m_pService->getName());
  5220. const char* pConfFile = m_pService->getCfg()->queryProp(xpath.str());
  5221. if( pConfFile && *pConfFile)
  5222. {
  5223. Owned<IProperties> pParams = createProperties(pConfFile);
  5224. Owned<IPropertyIterator> iter = pParams->getIterator();
  5225. pParams->getProp("autodetectipscript", script);
  5226. if( script.length())
  5227. {
  5228. runScript(ipList, msg, script.str());
  5229. if( ipList.length())
  5230. {
  5231. try {
  5232. ipList.replace('\n', ';');
  5233. validateIPS(ipList.str());
  5234. resp.setIPList(ipList);
  5235. }
  5236. catch(IException* e)
  5237. {
  5238. StringBuffer sb;
  5239. e->errorMessage(sb);
  5240. e->Release();
  5241. resp.setMessage(sb.str());
  5242. }
  5243. }
  5244. else if( msg.length())
  5245. {
  5246. resp.setMessage(msg);
  5247. }
  5248. }
  5249. else
  5250. resp.setMessage("Could not find the autodetectipscript entry in configmgr.conf");
  5251. }
  5252. else
  5253. resp.setMessage("Unknown Exception. Could not get the List of IPAddresses");
  5254. return true;
  5255. }
  5256. void CWsDeployFileInfo::CLockerAliveThread::main()
  5257. {
  5258. while (!m_quitThread)
  5259. {
  5260. try
  5261. {
  5262. StringBuffer sbMsg;
  5263. CCloudActionHandler checkLocker(this->m_pFileInfo, CLOUD_CHECK_LOCKER, CLOUD_NONE, m_user.str(), "8015", m_pComputers);
  5264. bool ret = checkLocker.start(sbMsg);
  5265. String str(sbMsg.str());
  5266. if (str.startsWith("SOAP Connection error"))
  5267. {
  5268. m_pFileInfo->activeUserNotResponding();
  5269. m_quitThread = true;
  5270. break;
  5271. }
  5272. m_sem.wait(m_brokenConnTimeout);
  5273. }
  5274. catch(IException* e)
  5275. {
  5276. if (m_pFileInfo && m_quitThread != true)
  5277. m_pFileInfo->activeUserNotResponding();
  5278. m_quitThread = true;
  5279. e->Release();
  5280. }
  5281. }
  5282. }
  5283. const char* getFnString(EnvAction ea)
  5284. {
  5285. const char* ret = NULL;
  5286. switch(ea)
  5287. {
  5288. case CLOUD_LOCK_ENV:
  5289. ret = "LockEnvironmentForCloud";
  5290. break;
  5291. case CLOUD_UNLOCK_ENV:
  5292. ret = "UnlockEnvironmentForCloud";
  5293. break;
  5294. case CLOUD_SAVE_ENV:
  5295. ret = "SaveEnvironmentForCloud";
  5296. break;
  5297. case CLOUD_ROLLBACK_ENV:
  5298. ret = "RollbackEnvironmentForCloud";
  5299. break;
  5300. case CLOUD_NOTIFY_INITSYSTEM:
  5301. ret = "NotifyInitSystemSaveEnvForCloud";
  5302. break;
  5303. case CLOUD_CHECK_LOCKER:
  5304. ret = "GetValue";
  5305. break;
  5306. }
  5307. return ret;
  5308. }
  5309. bool CWsDeployFileInfo::getSummary(IEspContext &context, IEspGetSummaryRequest &req, IEspGetSummaryResponse &resp)
  5310. {
  5311. synchronized block(m_mutex);
  5312. StringBuffer respXmlStr;
  5313. resp.setStatus("false");
  5314. bool link = req.getPrepareLinkFlag();
  5315. Owned<IPropertyTree> pEnvRoot = getEnvTree(context, &req.getReqInfo());
  5316. ::getSummary(pEnvRoot, respXmlStr, link);
  5317. if(respXmlStr.length())
  5318. {
  5319. resp.setStatus("true");
  5320. resp.setXmlStr(respXmlStr.str());
  5321. }
  5322. return true;
  5323. }
  5324. void CWsDeployFileInfo::initFileInfo(bool createOrOverwrite, bool bClearEnv)
  5325. {
  5326. StringBuffer xpath;
  5327. m_skipEnvUpdateFromNotification = false;
  5328. m_activeUserNotResp = false;
  5329. bool fileExists = true;
  5330. StringBuffer sbxml;
  5331. if (!checkFileExists(m_envFile) || createOrOverwrite)
  5332. {
  5333. fileExists = false;
  5334. StringBuffer s("<?xml version=\"1.0\" encoding=\"UTF-8\"?><Environment></Environment>");
  5335. Owned<IPropertyTree> pNewTree = createPTreeFromXMLString(s);
  5336. if ( strlen(m_pService->m_configHelper.getBuildSetFilePath()) > 0 )
  5337. {
  5338. try
  5339. {
  5340. Owned<IPropertyTree> pDefBldSet = createPTreeFromXMLFile( m_pService->m_configHelper.getBuildSetFilePath() );
  5341. pNewTree->addPropTree(XML_TAG_PROGRAMS, createPTreeFromIPT(pDefBldSet->queryPropTree("./Programs")));
  5342. pNewTree->addPropTree(XML_TAG_SOFTWARE, createPTreeFromIPT(pDefBldSet->queryPropTree("./Software")));
  5343. }
  5344. catch(IException* e)
  5345. {
  5346. e->Release();
  5347. }
  5348. }
  5349. if(!pNewTree->queryPropTree(XML_TAG_SOFTWARE))
  5350. {
  5351. pNewTree->addPropTree(XML_TAG_SOFTWARE, createPTree());
  5352. pNewTree->addPropTree("./Software/Directories", createPTreeFromXMLString(DEFAULT_DIRECTORIES));
  5353. }
  5354. pNewTree->addPropTree(XML_TAG_HARDWARE, createPTree());
  5355. if (!pNewTree->queryPropTree(XML_TAG_PROGRAMS))
  5356. pNewTree->addPropTree(XML_TAG_PROGRAMS, createPTree());
  5357. toXML(pNewTree, s.clear());
  5358. sbxml.clear().append(s);
  5359. if (createOrOverwrite)
  5360. {
  5361. if (m_pFileIO.get() != NULL)
  5362. m_pFileIO.clear();
  5363. if (m_pFile.get() != NULL)
  5364. {
  5365. m_pFile->remove();
  5366. m_pFile.clear();
  5367. }
  5368. if (m_lastSaved.isNull())
  5369. m_lastSaved.setNow();
  5370. recursiveCreateDirectoryForFile(m_envFile);
  5371. Owned<IFile> f = createIFile(m_envFile);
  5372. Owned<IFileIO> fio = f->open(IFOcreaterw);
  5373. fio->write(0,s.length(),s.str());
  5374. fileExists = true;
  5375. }
  5376. }
  5377. if (fileExists)
  5378. {
  5379. if (m_pFile.get() != NULL)
  5380. m_pFile.clear();
  5381. if (m_pFileIO.get() != NULL)
  5382. m_pFileIO.clear();
  5383. if (m_lastSaved.isNull())
  5384. m_lastSaved.setNow();
  5385. m_pFile.setown(createIFile(m_envFile));
  5386. m_pFileIO.setown(m_pFile->open(IFOread));
  5387. {
  5388. Owned <IPropertyTree> pTree = createPTree(*m_pFileIO);
  5389. toXML(pTree, sbxml.clear());
  5390. }
  5391. }
  5392. Owned<IEnvironmentFactory> factory = getEnvironmentFactory();
  5393. m_Environment.setown(factory->loadLocalEnvironment(sbxml.str()));
  5394. //add env
  5395. bool modified = false;
  5396. Owned<IPropertyTree> pEnvRoot = &m_Environment->getPTree();
  5397. IPropertyTree* pSettings = pEnvRoot->queryPropTree(XML_TAG_ENVSETTINGS);
  5398. if (!pSettings)
  5399. {
  5400. pSettings = pEnvRoot->addPropTree(XML_TAG_ENVSETTINGS, createPTree());
  5401. modified = true;
  5402. }
  5403. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalEnvConfFile", m_pService->getName());
  5404. const char* tmp = m_pService->getCfg()->queryProp(xpath.str());
  5405. if (tmp && *tmp)
  5406. {
  5407. Owned<IProperties> pParams = createProperties(tmp);
  5408. Owned<IPropertyIterator> iter = pParams->getIterator();
  5409. ForEach(*iter)
  5410. {
  5411. StringBuffer prop;
  5412. pParams->getProp(iter->getPropKey(), prop);
  5413. const char* val = pSettings->queryProp(iter->getPropKey());
  5414. if (!val || strcmp(val, prop.str()))
  5415. {
  5416. pSettings->setProp(iter->getPropKey(), prop.length() ? prop.str():"");
  5417. modified = true;
  5418. }
  5419. }
  5420. if (updateDirsWithConfSettings(pEnvRoot, pParams))
  5421. modified = true;
  5422. }
  5423. try
  5424. {
  5425. StringBuffer err;
  5426. if (modified && fileExists)
  5427. saveEnvironment(NULL, NULL, err);
  5428. }
  5429. catch (IErrnoException* e)
  5430. {
  5431. //Don't ignore file access exceptions
  5432. throw e;
  5433. }
  5434. catch(IException* e)
  5435. {
  5436. //ignore any exceptions at this point like validation errors e.t.c
  5437. e->Release();
  5438. }
  5439. if (!fileExists)
  5440. toXML(pEnvRoot, sbxml.clear());
  5441. if ( bClearEnv == true )
  5442. m_Environment.clear();
  5443. if (m_constEnvRdOnly.get() == NULL)
  5444. {
  5445. if (fileExists)
  5446. {
  5447. sbxml.clear();
  5448. Owned <IPropertyTree> pTree = createPTree(*m_pFileIO);
  5449. toXML(pTree, sbxml);
  5450. }
  5451. m_constEnvRdOnly.setown(factory->loadLocalEnvironment(sbxml.str()));
  5452. }
  5453. }
  5454. void CWsDeployFileInfo::CSdsSubscription::notify(SubscriptionId id, const char *xpath, SDSNotifyFlags flags, unsigned valueLen, const void *valueData)
  5455. {
  5456. DBGLOG("Environment was updated by another client of Dali server. Invalidating cache.\n");
  5457. //if (id != sub_id)
  5458. m_pFileInfo->environmentUpdated();
  5459. }
  5460. void CWsDeployExCE::getLastStarted(StringBuffer& sb)
  5461. {
  5462. synchronized block(m_mutexSrv);
  5463. m_lastStarted.getString(sb);
  5464. }
  5465. CWsDeployFileInfo::~CWsDeployFileInfo()
  5466. {
  5467. if (m_bCloud && m_userWithLock.length() && m_userIp.length())
  5468. {
  5469. StringBuffer sbMsg;
  5470. CCloudActionHandler unlockCloud(this, CLOUD_UNLOCK_ENV, CLOUD_NONE, m_userWithLock.str(), "8015", m_lockedNodesBeforeEnv.get()? m_lockedNodesBeforeEnv.get(): NULL);
  5471. unlockCloud.start(sbMsg);
  5472. }
  5473. CWsDeployFileInfo::CConfigFileMonitorThread::getInstance()->removeObserver(*this);
  5474. m_pNavTree.clear();
  5475. m_pGraphXml.clear();
  5476. m_Environment.clear();
  5477. m_constEnvRdOnly.clear();
  5478. m_pSubscription.clear();
  5479. m_pEnvXml.clear();
  5480. m_pFile.clear();
  5481. m_pFileIO.clear();
  5482. m_lockedNodesBeforeEnv.clear();
  5483. m_pGenJSFactoryThread.clear();
  5484. m_keepAliveHTable.kill();
  5485. }
  5486. bool CWsDeployEx::onNavMenuEvent(IEspContext &context,
  5487. IEspNavMenuEventRequest &req,
  5488. IEspNavMenuEventResponse &resp)
  5489. {
  5490. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true);
  5491. const char* cmd = req.getCmd();
  5492. if (!strcmp(cmd, "ValidateEnvironment") || !strcmp(cmd, "SaveEnvironment") || !strcmp(cmd, "SaveEnvironmentAs"))
  5493. {
  5494. synchronized block(m_mutexSrv);
  5495. return fi->navMenuEvent(context, req, resp);
  5496. }
  5497. else
  5498. return fi->navMenuEvent(context, req, resp);
  5499. }
  5500. bool CWsDeployEx::onSaveSetting(IEspContext &context, IEspSaveSettingRequest &req, IEspSaveSettingResponse &resp)
  5501. {
  5502. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true);
  5503. return fi->saveSetting(context, req, resp);
  5504. }
  5505. bool CWsDeployEx::onGetNavTreeDefn(IEspContext &context, IEspGetNavTreeDefnRequest &req, IEspGetNavTreeDefnResponse &resp)
  5506. {
  5507. const char* xmlArg = req.getXmlArgs();
  5508. StringBuffer decodedParams(xmlArg);
  5509. decodedParams.replaceString("::", "\n");
  5510. Owned<IProperties> pParams = createProperties();
  5511. pParams->loadProps(decodedParams.str());
  5512. const char* create = pParams->queryProp("createFile");
  5513. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true, create && *create ? true : false);
  5514. return fi->getNavTreeDefn(context, req, resp);
  5515. }
  5516. bool CWsDeployEx::onLockEnvironmentForCloud(IEspContext &context, IEspLockEnvironmentForCloudRequest &req, IEspLockEnvironmentForCloudResponse &resp)
  5517. {
  5518. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5519. return fi->lockEnvironmentForCloud(context, req, resp);
  5520. }
  5521. bool CWsDeployEx::onUnlockEnvironmentForCloud(IEspContext &context, IEspUnlockEnvironmentForCloudRequest &req, IEspUnlockEnvironmentForCloudResponse &resp)
  5522. {
  5523. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5524. return fi->unlockEnvironmentForCloud(context, req, resp);
  5525. }
  5526. bool CWsDeployEx::onSaveEnvironmentForCloud(IEspContext &context, IEspSaveEnvironmentForCloudRequest &req, IEspSaveEnvironmentForCloudResponse &resp)
  5527. {
  5528. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5529. return fi->saveEnvironmentForCloud(context, req, resp);
  5530. }
  5531. bool CWsDeployEx::onRollbackEnvironmentForCloud(IEspContext &context, IEspRollbackEnvironmentForCloudRequest &req, IEspRollbackEnvironmentForCloudResponse &resp)
  5532. {
  5533. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5534. return fi->rollbackEnvironmentForCloud(context, req, resp);
  5535. }
  5536. bool CWsDeployEx::onNotifyInitSystemSaveEnvForCloud(IEspContext &context, IEspNotifyInitSystemSaveEnvForCloudRequest &req, IEspNotifyInitSystemSaveEnvForCloudResponse &resp)
  5537. {
  5538. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5539. return fi->notifyInitSystemSaveEnvForCloud(context, req, resp);
  5540. }
  5541. bool CWsDeployExCE::onGetValue(IEspContext &context, IEspGetValueRequest &req, IEspGetValueResponse &resp)
  5542. {
  5543. //Check for common properties here
  5544. StringBuffer decodedParams(req.getParams());
  5545. if (decodedParams.length() == 0)
  5546. {
  5547. resp.setReqValue("");
  5548. resp.setStatus("true");
  5549. return true;
  5550. }
  5551. decodedParams.replaceString("::", "\n");
  5552. Owned<IProperties> pParams = createProperties();
  5553. pParams->loadProps(decodedParams.str());
  5554. const char* pszQueryType = pParams->queryProp("queryType");
  5555. const char* pszparams = pParams->queryProp("params");
  5556. const char* pszAttrValue = pParams->queryProp("attrValue");
  5557. StringBuffer xpath;
  5558. const char* pszValue = NULL;
  5559. StringBuffer sbMultiple;
  5560. bool allHandled = true;
  5561. if (pszQueryType && !strcmp(pszQueryType, "customType"))
  5562. {
  5563. sbMultiple.clear();
  5564. if(pszparams && *pszparams)
  5565. {
  5566. StringArray sArray;
  5567. sArray.appendList(pszparams, ",");
  5568. for(unsigned i = 0; i < sArray.ordinality() ; i++)
  5569. {
  5570. if(!strcmp(sArray.item(i), "environment"))
  5571. {
  5572. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalEnvFile", getName());
  5573. const char* pEnvFile = getCfg()->queryProp(xpath.str());
  5574. if (pEnvFile && *pEnvFile)
  5575. {
  5576. if (checkFileExists(pEnvFile))
  5577. sbMultiple.append(sArray.item(i)).append("=true");
  5578. else
  5579. sbMultiple.append(sArray.item(i)).append("=false");
  5580. if(sbMultiple.length())
  5581. sbMultiple.append(",");
  5582. }
  5583. }
  5584. else if(!strcmp(sArray.item(i), "username"))
  5585. {
  5586. StringBuffer sbName;
  5587. sbName.clear().append(msTick());
  5588. sbMultiple.append(sArray.item(i)).append("=").append(sbName);
  5589. if(sbMultiple.length())
  5590. sbMultiple.append(",");
  5591. }
  5592. else if(!strcmp(sArray.item(i), "defenvfile"))
  5593. {
  5594. if (strstr(m_envFile.str(), m_sourceDir.str()))
  5595. {
  5596. StringBuffer sb(m_envFile.str() + m_sourceDir.length() + 1);
  5597. sbMultiple.append(sArray.item(i)).append("=").append(sb.str());
  5598. if(sbMultiple.length())
  5599. sbMultiple.append(",");
  5600. }
  5601. }
  5602. else if(!strcmp(sArray.item(i), "checklock"))
  5603. {
  5604. //StringBuffer sb(m_sourceDir);
  5605. //if (sb.charAt[sb.length() - 1] != PATHSEPCHAR)
  5606. // sb.append(PATHSEPCHAR);
  5607. //sb.append(req.getFileName());
  5608. //if (checkFileExists(sb.str()))
  5609. allHandled = false;
  5610. }
  5611. else if(!strcmp(sArray.item(i), "encryptpassword"))
  5612. {
  5613. if(pszAttrValue && *pszAttrValue)
  5614. {
  5615. StringArray sArray;
  5616. sArray.appendList(pszAttrValue, ",");
  5617. ForEachItemIn(x, sArray)
  5618. {
  5619. StringBuffer encryptedPasswd ;
  5620. encrypt(encryptedPasswd , sArray.item(x));
  5621. sbMultiple.append(encryptedPasswd.str());
  5622. if(sbMultiple.length())
  5623. sbMultiple.append(",");
  5624. }
  5625. }
  5626. }
  5627. else if(!strcmp(sArray.item(i), "lastsaved"))
  5628. {
  5629. allHandled = false;
  5630. }
  5631. else if(!strcmp(sArray.item(i), "laststarted"))
  5632. {
  5633. StringBuffer lastStarted;
  5634. getLastStarted(lastStarted);
  5635. if(lastStarted.length())
  5636. sbMultiple.append(sArray.item(i)).append("=").append(lastStarted);
  5637. else
  5638. sbMultiple.append(sArray.item(i)).append("=''");
  5639. if(sbMultiple.length())
  5640. sbMultiple.append(",");
  5641. }
  5642. else if(!strcmp(sArray.item(i), "wizops"))
  5643. {
  5644. StringBuffer sbOps;
  5645. this->getWizOptions(sbOps);
  5646. sbMultiple.append(sArray.item(i)).append("=").append(sbOps);
  5647. if(sbMultiple.length())
  5648. sbMultiple.append(",");
  5649. }
  5650. }
  5651. }
  5652. pszValue = sbMultiple.str();
  5653. }
  5654. else if (pszQueryType && !strcmp(pszQueryType, "sourceEnvironments"))
  5655. {
  5656. sbMultiple.clear();
  5657. Owned<IFile> pDir = createIFile(getSourceDir());
  5658. StringBuffer activeConfig_md5sum, config_md5sum;
  5659. md5_filesum(STANDARD_CONFIG_STAGED_PATH, activeConfig_md5sum);
  5660. if (pDir->exists())
  5661. {
  5662. if (pDir->isDirectory())
  5663. {
  5664. Owned<IDirectoryIterator> it = pDir->directoryFiles(NULL, false, true);
  5665. ForEach(*it)
  5666. {
  5667. StringBuffer name;
  5668. it->getName(name);
  5669. String str(name.toLowerCase());
  5670. if (str.endsWith(".xml"))
  5671. {
  5672. StringBuffer sb(getSourceDir());
  5673. sb.append(PATHSEPCHAR).append(it->getName(name.clear()));
  5674. try
  5675. {
  5676. Owned<IPropertyTree> pTree = createPTreeFromXMLFile(sb.str());
  5677. StringBuffer testFile;
  5678. testFile.clear().appendf("%s/%s",getSourceDir(),it->getName(name.clear()).str());
  5679. md5_filesum(testFile.str(),config_md5sum.clear());
  5680. if (pTree && pTree->queryName() && !strcmp(XML_TAG_ENVIRONMENT, pTree->queryName()))
  5681. {
  5682. if(strcmp(config_md5sum.str(),activeConfig_md5sum.str())==0)
  5683. {
  5684. sbMultiple.append("<StagedConfiguration>").append(";");
  5685. sbMultiple.append(it->getName(name.clear())).append(";");
  5686. sbMultiple.append("</StagedConfiguration>").append(";");
  5687. }
  5688. else
  5689. {
  5690. sbMultiple.append(it->getName(name.clear())).append(";");
  5691. }
  5692. }
  5693. }
  5694. catch(IException* e)
  5695. {
  5696. e->Release();
  5697. //add any files already in use
  5698. CWsDeployFileInfo* fi = m_fileInfos.getValue(name.str());
  5699. if (fi)
  5700. sbMultiple.append(name).append(";");
  5701. }
  5702. }
  5703. }
  5704. }
  5705. }
  5706. pszValue = sbMultiple.str();
  5707. }
  5708. else if (pszQueryType && *pszQueryType)
  5709. allHandled = false;
  5710. if (allHandled)
  5711. {
  5712. resp.setReqValue(pszValue);
  5713. resp.setStatus("true");
  5714. return true;
  5715. }
  5716. else
  5717. {
  5718. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true);
  5719. bool ret = fi->getValue(context, req, resp);
  5720. if (ret)
  5721. {
  5722. const char* val = resp.getReqValue();
  5723. StringBuffer sb;
  5724. if (pszValue)
  5725. sb.append(pszValue);
  5726. sb.append(val);
  5727. resp.setReqValue(sb.str());
  5728. resp.setStatus("true");
  5729. }
  5730. return ret;
  5731. }
  5732. }
  5733. bool CWsDeployExCE::onUnlockUser(IEspContext &context, IEspUnlockUserRequest &req, IEspUnlockUserResponse &resp)
  5734. {
  5735. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5736. return fi->unlockUser(context, req, resp);
  5737. }
  5738. bool CWsDeployExCE::onClientAlive(IEspContext &context, IEspClientAliveRequest &req, IEspClientAliveResponse &resp)
  5739. {
  5740. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true);
  5741. return fi->clientAlive(context, req, resp);
  5742. }
  5743. bool CWsDeployExCE::onGetEnvironment(IEspContext &context, IEspGetEnvironmentRequest &req, IEspGetEnvironmentResponse &resp)
  5744. {
  5745. CWsDeployFileInfo* fi = getFileInfo(m_envFile.str());
  5746. return fi->getEnvironment(context, req, resp);
  5747. }
  5748. bool CWsDeployExCE::onSetEnvironment(IEspContext &context, IEspSetEnvironmentRequest &req, IEspSetEnvironmentResponse &resp)
  5749. {
  5750. CWsDeployFileInfo* fi = getFileInfo(m_envFile.str());
  5751. return fi->setEnvironment(context, req, resp);
  5752. }
  5753. bool CWsDeployEx::onDisplaySettings(IEspContext &context, IEspDisplaySettingsRequest &req, IEspDisplaySettingsResponse &resp)
  5754. {
  5755. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5756. return fi->displaySettings(context, req, resp);
  5757. }
  5758. bool CWsDeployEx::onStartDeployment(IEspContext &context, IEspStartDeploymentRequest &req, IEspStartDeploymentResponse &resp)
  5759. {
  5760. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5761. return fi->startDeployment(context, req, resp);
  5762. }
  5763. bool CWsDeployEx::onGetDeployableComps(IEspContext &context, IEspGetDeployableCompsRequest &req, IEspGetDeployableCompsResponse &resp)
  5764. {
  5765. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5766. return fi->getDeployableComps(context, req, resp);
  5767. }
  5768. bool CWsDeployEx::onGetComputersForRoxie(IEspContext &context, IEspGetComputersForRoxieRequest &req, IEspGetComputersForRoxieResponse &resp)
  5769. {
  5770. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5771. return fi->getComputersForRoxie(context, req, resp);
  5772. }
  5773. bool CWsDeployEx::onHandleRoxieOperation(IEspContext &context, IEspHandleRoxieOperationRequest &req, IEspHandleRoxieOperationResponse &resp)
  5774. {
  5775. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5776. return fi->handleRoxieOperation(context, req, resp);
  5777. }
  5778. bool CWsDeployEx::onGetBuildSetInfo(IEspContext &context, IEspGetBuildSetInfoRequest &req, IEspGetBuildSetInfoResponse &resp)
  5779. {
  5780. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5781. return fi->getBuildSetInfo(context, req, resp);
  5782. }
  5783. bool CWsDeployEx::onImportBuild(IEspContext &context, IEspImportBuildRequest &req, IEspImportBuildResponse &resp)
  5784. {
  5785. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5786. return fi->importBuild(context, req, resp);
  5787. }
  5788. bool CWsDeployEx::onGetBuildServerDirs(IEspContext &context, IEspGetBuildServerDirsRequest &req, IEspGetBuildServerDirsResponse &resp)
  5789. {
  5790. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5791. return fi->getBuildServerDirs(context, req, resp);
  5792. }
  5793. bool CWsDeployEx::onHandleComponent(IEspContext &context, IEspHandleComponentRequest &req, IEspHandleComponentResponse &resp)
  5794. {
  5795. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5796. return fi->handleComponent(context, req, resp);
  5797. }
  5798. bool CWsDeployEx::onHandleAttributeAdd(IEspContext &context, IEspHandleAttributeAddRequest &req, IEspHandleAttributeAddResponse &resp)
  5799. {
  5800. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5801. return fi->handleAttributeAdd(context, req, resp);
  5802. }
  5803. bool CWsDeployEx::onHandleAttributeDelete(IEspContext &context, IEspHandleAttributeDeleteRequest &req, IEspHandleAttributeDeleteResponse &resp)
  5804. {
  5805. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5806. return fi->handleAttributeDelete(context, req, resp);
  5807. }
  5808. bool CWsDeployEx::onHandleInstance(IEspContext &context, IEspHandleInstanceRequest &req, IEspHandleInstanceResponse &resp)
  5809. {
  5810. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5811. return fi->handleInstance(context, req, resp);
  5812. }
  5813. bool CWsDeployEx::onHandleEspServiceBindings(IEspContext &context, IEspHandleEspServiceBindingsRequest &req, IEspHandleEspServiceBindingsResponse &resp)
  5814. {
  5815. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5816. return fi->handleEspServiceBindings(context, req, resp);
  5817. }
  5818. bool CWsDeployEx::onHandleComputer(IEspContext &context, IEspHandleComputerRequest &req, IEspHandleComputerResponse &resp)
  5819. {
  5820. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5821. return fi->handleComputer(context, req, resp);
  5822. }
  5823. bool CWsDeployEx::onHandleTopology(IEspContext &context, IEspHandleTopologyRequest &req, IEspHandleTopologyResponse &resp)
  5824. {
  5825. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5826. return fi->handleTopology(context, req, resp);
  5827. }
  5828. bool CWsDeployEx::onHandleThorTopology(IEspContext &context, IEspHandleThorTopologyRequest &req, IEspHandleThorTopologyResponse &resp)
  5829. {
  5830. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5831. return fi->handleThorTopology(context, req, resp);
  5832. }
  5833. bool CWsDeployEx::onHandleRows(IEspContext &context, IEspHandleRowsRequest &req, IEspHandleRowsResponse &resp)
  5834. {
  5835. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5836. return fi->handleRows(context, req, resp);
  5837. }
  5838. bool CWsDeployEx::onHandleAccessRules(IEspContext &context, IEspHandleAccessRulesRequest &req, IEspHandleAccessRulesResponse &resp)
  5839. {
  5840. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5841. return fi->handleAccessRules(context, req, resp);
  5842. }
  5843. bool CWsDeployEx::onGraph(IEspContext &context, IEspEmptyRequest& req, IEspGraphResponse& resp)
  5844. {
  5845. CWsDeployFileInfo* fi = getFileInfo(m_envFile.str());
  5846. return fi->graph(context, req, resp);
  5847. }
  5848. void CWsDeployExCE::getNavigationData(IEspContext &context, IPropertyTree* pData)
  5849. {
  5850. CWsDeployFileInfo* fi = getFileInfo(m_envFile.str());
  5851. return fi->getNavigationData(context, pData);
  5852. }
  5853. bool CWsDeployExCE::onBuildEnvironment(IEspContext &context, IEspBuildEnvironmentRequest &req, IEspBuildEnvironmentResponse &resp)
  5854. {
  5855. String sb(req.getReqInfo().getFileName());
  5856. StringBuffer sbnew(req.getReqInfo().getFileName());
  5857. String* tmp = sb.toLowerCase();
  5858. if (!tmp->endsWith(".xml"))
  5859. sbnew.appendf(".xml");
  5860. delete tmp;
  5861. CWsDeployFileInfo* fi = getFileInfo(sbnew.str());
  5862. return fi->buildEnvironment(context, req, resp);
  5863. }
  5864. bool CWsDeployExCE::onGetSubnetIPAddr(IEspContext &context, IEspGetSubnetIPAddrRequest &req, IEspGetSubnetIPAddrResponse &resp)
  5865. {
  5866. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5867. return fi->getSubnetIPAddr(context, req, resp);
  5868. }
  5869. bool CWsDeployExCE::onGetSummary(IEspContext &context, IEspGetSummaryRequest &req, IEspGetSummaryResponse &resp)
  5870. {
  5871. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true);
  5872. return fi->getSummary(context, req, resp);
  5873. }
  5874. bool CWsDeployExCE::onAddReqdComps(IEspContext &context, IEspAddReqdCompsRequest &req, IEspAddReqdCompsResponse &resp)
  5875. {
  5876. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true);
  5877. return fi->addReqdComps(context, req, resp);
  5878. }
  5879. bool CWsDeployEx::onDeploy(IEspContext &context, IEspDeployRequest& req, IEspDeployResponse& resp)
  5880. {
  5881. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName());
  5882. return fi->deploy(context, req, resp);
  5883. }
  5884. CWsDeployFileInfo* CWsDeployExCE::getFileInfo(const char* fileName, bool addIfNotFound, bool createFile)
  5885. {
  5886. synchronized block(m_mutexSrv);
  5887. if (!fileName || !*fileName)
  5888. throw MakeStringException(-1, "File name required for operation");
  5889. CWsDeployFileInfo* fi = m_fileInfos.getValue(fileName);
  5890. if (!fi)
  5891. {
  5892. if (addIfNotFound)
  5893. {
  5894. StringBuffer filePath(m_sourceDir);
  5895. if (filePath.charAt(filePath.length() - 1) != PATHSEPCHAR)
  5896. filePath.append(PATHSEPCHAR);
  5897. filePath.append(fileName);
  5898. fi = new CWsDeployFileInfo(this, filePath, m_bCloud);
  5899. const char* psz = strrchr(fileName, PATHSEPCHAR);
  5900. if (!psz)
  5901. psz = strrchr(fileName, PATHSEPCHAR == '\\' ? '/' : '\\');
  5902. StringBuffer sb;
  5903. if (!psz)
  5904. sb.append(fileName);
  5905. else
  5906. sb.append(psz + 1);
  5907. if (!sb.length())
  5908. sb.append(fileName);
  5909. try
  5910. {
  5911. fi->initFileInfo(createFile);
  5912. CWsDeployFileInfo::CConfigFileMonitorThread::getInstance()->addObserver(*fi);
  5913. }
  5914. catch (IException* e)
  5915. {
  5916. delete fi;
  5917. throw e;
  5918. }
  5919. m_fileInfos.setValue(sb.str(), fi);
  5920. }
  5921. else
  5922. throw MakeStringException(-1, "File information not found for %s", fileName);
  5923. }
  5924. else if (createFile)
  5925. {
  5926. StringBuffer sbuser, sbip;
  5927. if (fi->getUserWithLock(sbuser, sbip))
  5928. throw MakeStringException(-1, "Cannot overwrite file '%s' as it is currently locked by user '%s' on machine '%s'", fileName, sbuser.str(), sbip.str());
  5929. else
  5930. {
  5931. try
  5932. {
  5933. fi->initFileInfo(createFile);
  5934. }
  5935. catch (IException* e)
  5936. {
  5937. m_fileInfos.remove(fileName);
  5938. delete fi;
  5939. throw e;
  5940. }
  5941. }
  5942. }
  5943. return fi;
  5944. }
  5945. bool CWsDeployFileInfo::getUserWithLock(StringBuffer& sbUser, StringBuffer& sbIp)
  5946. {
  5947. if (m_userWithLock.length() && m_userIp.length())
  5948. {
  5949. sbUser.clear().append(m_userWithLock);
  5950. sbIp.clear().append(m_userIp);
  5951. return true;
  5952. }
  5953. return false;
  5954. }
  5955. bool CWsDeployExCE::onNavMenuEvent(IEspContext &context,
  5956. IEspNavMenuEventRequest &req,
  5957. IEspNavMenuEventResponse &resp)
  5958. {
  5959. CWsDeployFileInfo* fi = getFileInfo(req.getReqInfo().getFileName(), true);
  5960. const char* cmd = req.getCmd();
  5961. if (!strcmp(cmd, "LockEnvironment") || !strcmp(cmd, "UnlockEnvironment"))
  5962. return fi->navMenuEvent(context, req, resp);
  5963. else
  5964. return supportedInEEOnly();
  5965. }
  5966. bool CWsDeployExCE::onSaveSetting(IEspContext &context, IEspSaveSettingRequest &req, IEspSaveSettingResponse &resp)
  5967. {
  5968. return supportedInEEOnly();
  5969. }
  5970. bool CWsDeployExCE::onGetNavTreeDefn(IEspContext &context, IEspGetNavTreeDefnRequest &req, IEspGetNavTreeDefnResponse &resp)
  5971. {
  5972. return supportedInEEOnly();
  5973. }
  5974. bool CWsDeployExCE::onLockEnvironmentForCloud(IEspContext &context, IEspLockEnvironmentForCloudRequest &req, IEspLockEnvironmentForCloudResponse &resp)
  5975. {
  5976. return supportedInEEOnly();
  5977. }
  5978. bool CWsDeployExCE::onUnlockEnvironmentForCloud(IEspContext &context, IEspUnlockEnvironmentForCloudRequest &req, IEspUnlockEnvironmentForCloudResponse &resp)
  5979. {
  5980. return supportedInEEOnly();
  5981. }
  5982. bool CWsDeployExCE::onSaveEnvironmentForCloud(IEspContext &context, IEspSaveEnvironmentForCloudRequest &req, IEspSaveEnvironmentForCloudResponse &resp)
  5983. {
  5984. return supportedInEEOnly();
  5985. }
  5986. bool CWsDeployExCE::onRollbackEnvironmentForCloud(IEspContext &context, IEspRollbackEnvironmentForCloudRequest &req, IEspRollbackEnvironmentForCloudResponse &resp)
  5987. {
  5988. return supportedInEEOnly();
  5989. }
  5990. bool CWsDeployExCE::onNotifyInitSystemSaveEnvForCloud(IEspContext &context, IEspNotifyInitSystemSaveEnvForCloudRequest &req, IEspNotifyInitSystemSaveEnvForCloudResponse &resp)
  5991. {
  5992. return supportedInEEOnly();
  5993. }
  5994. bool CWsDeployExCE::onDisplaySettings(IEspContext &context, IEspDisplaySettingsRequest &req, IEspDisplaySettingsResponse &resp)
  5995. {
  5996. return supportedInEEOnly();
  5997. }
  5998. bool CWsDeployExCE::onStartDeployment(IEspContext &context, IEspStartDeploymentRequest &req, IEspStartDeploymentResponse &resp)
  5999. {
  6000. return supportedInEEOnly();
  6001. }
  6002. bool CWsDeployExCE::onGetDeployableComps(IEspContext &context, IEspGetDeployableCompsRequest &req, IEspGetDeployableCompsResponse &resp)
  6003. {
  6004. return supportedInEEOnly();
  6005. }
  6006. bool CWsDeployExCE::onGetBuildServerDirs(IEspContext &context, IEspGetBuildServerDirsRequest &req, IEspGetBuildServerDirsResponse &resp)
  6007. {
  6008. return supportedInEEOnly();
  6009. }
  6010. bool CWsDeployExCE::onImportBuild(IEspContext &context, IEspImportBuildRequest &req, IEspImportBuildResponse &resp)
  6011. {
  6012. return supportedInEEOnly();
  6013. }
  6014. bool CWsDeployExCE::onGetComputersForRoxie(IEspContext &context, IEspGetComputersForRoxieRequest &req, IEspGetComputersForRoxieResponse &resp)
  6015. {
  6016. return supportedInEEOnly();
  6017. }
  6018. bool CWsDeployExCE::onHandleRoxieOperation(IEspContext &context, IEspHandleRoxieOperationRequest &req, IEspHandleRoxieOperationResponse &resp)
  6019. {
  6020. return supportedInEEOnly();
  6021. }
  6022. bool CWsDeployExCE::onHandleThorTopology(IEspContext &context, IEspHandleThorTopologyRequest &req, IEspHandleThorTopologyResponse &resp)
  6023. {
  6024. return supportedInEEOnly();
  6025. }
  6026. bool CWsDeployExCE::onHandleComponent(IEspContext &context, IEspHandleComponentRequest &req, IEspHandleComponentResponse &resp)
  6027. {
  6028. return supportedInEEOnly();
  6029. }
  6030. bool CWsDeployExCE::onHandleAttributeAdd(IEspContext &context, IEspHandleAttributeAddRequest &req, IEspHandleAttributeAddResponse &resp)
  6031. {
  6032. return supportedInEEOnly();
  6033. }
  6034. bool CWsDeployExCE::onHandleAttributeDelete(IEspContext &context, IEspHandleAttributeDeleteRequest &req, IEspHandleAttributeDeleteResponse &resp)
  6035. {
  6036. return supportedInEEOnly();
  6037. }
  6038. bool CWsDeployExCE::onHandleInstance(IEspContext &context, IEspHandleInstanceRequest &req, IEspHandleInstanceResponse &resp)
  6039. {
  6040. return supportedInEEOnly();
  6041. }
  6042. bool CWsDeployExCE::onHandleEspServiceBindings(IEspContext &context, IEspHandleEspServiceBindingsRequest &req, IEspHandleEspServiceBindingsResponse &resp)
  6043. {
  6044. return supportedInEEOnly();
  6045. }
  6046. bool CWsDeployExCE::onHandleComputer(IEspContext &context, IEspHandleComputerRequest &req, IEspHandleComputerResponse &resp)
  6047. {
  6048. return supportedInEEOnly();
  6049. }
  6050. bool CWsDeployExCE::onHandleTopology(IEspContext &context, IEspHandleTopologyRequest &req, IEspHandleTopologyResponse &resp)
  6051. {
  6052. return supportedInEEOnly();
  6053. }
  6054. bool CWsDeployExCE::onHandleRows(IEspContext &context, IEspHandleRowsRequest &req, IEspHandleRowsResponse &resp)
  6055. {
  6056. return supportedInEEOnly();
  6057. }
  6058. bool CWsDeployExCE::onHandleAccessRules(IEspContext &context, IEspHandleAccessRulesRequest &req, IEspHandleAccessRulesResponse &resp)
  6059. {
  6060. return supportedInEEOnly();
  6061. }
  6062. bool CWsDeployExCE::onGraph(IEspContext &context, IEspEmptyRequest& req, IEspGraphResponse& resp)
  6063. {
  6064. return supportedInEEOnly();
  6065. }
  6066. bool CWsDeployExCE::onDeploy(IEspContext &context, IEspDeployRequest& req, IEspDeployResponse& resp)
  6067. {
  6068. return supportedInEEOnly();
  6069. }
  6070. bool CWsDeployExCE::onGetBuildSetInfo(IEspContext &context, IEspGetBuildSetInfoRequest &req, IEspGetBuildSetInfoResponse &resp)
  6071. {
  6072. return supportedInEEOnly();
  6073. }
  6074. bool CWsDeployEx::onGetValue(IEspContext &context, IEspGetValueRequest &req, IEspGetValueResponse &resp)
  6075. {
  6076. //Check for common properties here
  6077. StringBuffer decodedParams(req.getParams());
  6078. if (decodedParams.length() == 0)
  6079. {
  6080. resp.setReqValue("");
  6081. resp.setStatus("true");
  6082. return true;
  6083. }
  6084. decodedParams.replaceString("::", "\n");
  6085. Owned<IProperties> pParams = createProperties();
  6086. pParams->loadProps(decodedParams.str());
  6087. const char* pszQueryType = pParams->queryProp("queryType");
  6088. const char* pszparams = pParams->queryProp("params");
  6089. const char* pszAttrValue = pParams->queryProp("attrValue");
  6090. StringBuffer xpath;
  6091. const char* pszValue = NULL;
  6092. StringBuffer sbMultiple;
  6093. bool allHandled = true;
  6094. if (pszQueryType && !strcmp(pszQueryType, "customType"))
  6095. {
  6096. sbMultiple.clear();
  6097. if(pszparams && *pszparams)
  6098. {
  6099. StringArray sArray;
  6100. sArray.appendList(pszparams, ",");
  6101. for(unsigned i = 0; i < sArray.ordinality() ; i++)
  6102. {
  6103. if(!strcmp(sArray.item(i), "wizops"))
  6104. {
  6105. StringBuffer sbOps;
  6106. this->getWizOptions(sbOps);
  6107. sbMultiple.append(sArray.item(i)).append("=").append(sbOps);
  6108. if(sbMultiple.length())
  6109. sbMultiple.append(",");
  6110. }
  6111. else
  6112. allHandled = false;
  6113. }
  6114. }
  6115. pszValue = sbMultiple.str();
  6116. }
  6117. else if (pszQueryType && *pszQueryType)
  6118. allHandled = false;
  6119. if (allHandled)
  6120. {
  6121. resp.setReqValue(pszValue);
  6122. resp.setStatus("true");
  6123. return true;
  6124. }
  6125. else
  6126. {
  6127. bool ret = CWsDeployExCE::onGetValue(context, req, resp);
  6128. if (ret)
  6129. {
  6130. const char* val = resp.getReqValue();
  6131. StringBuffer sb;
  6132. if (pszValue)
  6133. sb.append(pszValue);
  6134. sb.append(val);
  6135. resp.setReqValue(sb.str());
  6136. resp.setStatus("true");
  6137. }
  6138. return ret;
  6139. }
  6140. }
  6141. void CWsDeployExCE::getWizOptions(StringBuffer& sb)
  6142. {
  6143. sb.clear().append("1");
  6144. }
  6145. void CWsDeployEx::getWizOptions(StringBuffer& sb)
  6146. {
  6147. sb.clear().append("3");
  6148. }
  6149. CWsDeployExCE* createWsDeployEE(IPropertyTree *cfg, const char* name)
  6150. {
  6151. return new CWsDeployEx;
  6152. }
  6153. CWsDeployExCE* createWsDeployCE(IPropertyTree *cfg, const char* name)
  6154. {
  6155. StringBuffer sb;
  6156. sb.append(XML_TAG_SOFTWARE"/"XML_TAG_ESPPROCESS"/"XML_TAG_ESPBINDING"/");
  6157. sb.appendf("["XML_ATTR_SERVICE"='%s']", name);
  6158. IPropertyTree* pTree = cfg->queryPropTree(sb.str());
  6159. const char* ver = "CE";
  6160. if (pTree)
  6161. ver = pTree->queryProp(XML_ATTR_VERSION);
  6162. if (ver && *ver && !strcmp(ver, "EE"))
  6163. return new CWsDeployEx;
  6164. return new CWsDeployExCE;
  6165. }
  6166. bool CWsDeployFileInfo::checkForRequiredComponents(IPropertyTree* pEnvRoot, const char* ip,
  6167. StringBuffer& reqdCompNames, const char* buildSet, bool autoadd/*=false*/)
  6168. {
  6169. StringBuffer prop, prop2, xpath, genEnvConf;
  6170. Owned<IProperties> algProps;
  6171. StringArray compOnAllNodes,compExcludeOnAllNodes;
  6172. bool retVal = true;
  6173. bool bExclude = false;
  6174. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalConfFile", m_pService->getName());
  6175. const char* pConfFile = m_pService->getCfg()->queryProp(xpath.str());
  6176. xpath.clear().appendf("Software/EspProcess/EspService[@name='%s']/LocalEnvConfFile", m_pService->getName());
  6177. const char* pEnvConfFile = m_pService->getCfg()->queryProp(xpath.str());
  6178. if (pConfFile && *pConfFile && pEnvConfFile && *pEnvConfFile)
  6179. {
  6180. Owned<IProperties> pParams = createProperties(pConfFile);
  6181. Owned<IProperties> pEnvParams = createProperties(pEnvConfFile);
  6182. const char* genenv = pParams->queryProp("wizardalgorithm");
  6183. if (genenv && *genenv)
  6184. {
  6185. const char* cfgpath = pEnvParams->queryProp("configs");
  6186. if (!cfgpath || !*cfgpath)
  6187. cfgpath = CONFIG_DIR;
  6188. genEnvConf.clear().append(cfgpath);
  6189. if (genEnvConf.charAt(genEnvConf.length() - 1) != PATHSEPCHAR)
  6190. genEnvConf.append(PATHSEPCHAR);
  6191. genEnvConf.append(genenv);
  6192. if(checkFileExists(genEnvConf.str()))
  6193. algProps.setown(createProperties(genEnvConf.str()));
  6194. else
  6195. throw MakeStringException( -1 , "The algorithm file %s does not exists", genEnvConf.str());
  6196. algProps->getProp("comps_on_all_nodes", prop);
  6197. algProps->getProp("exclude_from_comps_on_all_nodes", prop2);
  6198. compOnAllNodes.appendList(prop.str(), ",");
  6199. compExcludeOnAllNodes.appendList(prop2.str(), ",");
  6200. for (unsigned i = 0; buildSet != NULL && i < compExcludeOnAllNodes.ordinality(); i++)
  6201. {
  6202. if (strcmp(compExcludeOnAllNodes.item(i),buildSet) == 0)
  6203. {
  6204. bExclude = true;
  6205. break;
  6206. }
  6207. }
  6208. const char* flag = pParams->queryProp("autoaddallnodescomp");
  6209. if (!autoadd)
  6210. autoadd = (flag && *flag == '1') ? true : false;
  6211. }
  6212. }
  6213. for(unsigned i = 0; bExclude == false && i < compOnAllNodes.ordinality(); i++)
  6214. {
  6215. xpath.clear().appendf("./Programs/Build/BuildSet[@name=\"%s\"]", compOnAllNodes.item(i));
  6216. Owned<IPropertyTreeIterator> buildSetIter = pEnvRoot->getElements(xpath.str());
  6217. buildSetIter->first();
  6218. IPropertyTree* pBuildSet;
  6219. if (buildSetIter->isValid())
  6220. pBuildSet = &buildSetIter->query();
  6221. else
  6222. continue;
  6223. const char* processName = pBuildSet->queryProp(XML_ATTR_PROCESS_NAME);
  6224. xpath.clear().appendf("./Software/%s[1]", processName);
  6225. IPropertyTree* pCompTree = pEnvRoot->queryPropTree(xpath.str());
  6226. if (!pCompTree)
  6227. {
  6228. if (autoadd)
  6229. {
  6230. StringBuffer buildSetPath, sbNewName;
  6231. Owned<IPropertyTree> pSchema = loadSchema(pEnvRoot->queryPropTree("./Programs/Build[1]"), pBuildSet, buildSetPath, m_Environment);
  6232. xpath.clear().appendf("./Software/%s[@name='%s']", processName, compOnAllNodes.item(i));
  6233. pCompTree = generateTreeFromXsd(pEnvRoot, pSchema, processName, pBuildSet->queryProp(XML_ATTR_NAME), m_pService->getCfg(), m_pService->getName(), false);
  6234. IPropertyTree* pInstTree = pCompTree->queryPropTree(XML_TAG_INSTANCE);
  6235. if (pInstTree)
  6236. pCompTree->removeTree(pInstTree);
  6237. addComponentToEnv(pEnvRoot, compOnAllNodes.item(i), sbNewName, pCompTree);
  6238. }
  6239. else
  6240. {
  6241. reqdCompNames.appendf("%s\n", compOnAllNodes.item(i));
  6242. retVal = false;
  6243. continue;
  6244. }
  6245. }
  6246. xpath.clear().appendf(XML_TAG_INSTANCE"["XML_ATTR_NETADDRESS"='%s']", ip);
  6247. IPropertyTree* pInst = pCompTree->queryPropTree(xpath.str());
  6248. if (!pInst)
  6249. {
  6250. if (autoadd)
  6251. {
  6252. StringBuffer sb, sbl, compName, nodeName;
  6253. xpath.clear().appendf("./%s/%s[%s=\"%s\"]", XML_TAG_HARDWARE, XML_TAG_COMPUTER,
  6254. XML_ATTR_NETADDRESS, ip);
  6255. IPropertyTree* computer = pEnvRoot->queryPropTree(xpath.str());
  6256. if(computer)
  6257. {
  6258. nodeName.clear().append(computer->queryProp(XML_ATTR_NAME));
  6259. xpath.clear().appendf("./%s/%s[%s=\"%s\"]", XML_TAG_SOFTWARE, processName, XML_ATTR_BUILDSET, compOnAllNodes.item(i));
  6260. sb.clear().appendf("<Instance buildSet=\"%s\" compName=\"%s\" ><Instance name=\"%s\" /></Instance>",
  6261. compOnAllNodes.item(i), pCompTree->queryProp(XML_ATTR_NAME), nodeName.str());
  6262. Owned<IPropertyTree> pInstance = createPTreeFromXMLString(sb.str());
  6263. addInstanceToCompTree(pEnvRoot, pInstance, sbl.clear(), sb.clear(), NULL);
  6264. }
  6265. }
  6266. else
  6267. {
  6268. reqdCompNames.appendf("%s\n", compOnAllNodes.item(i));
  6269. retVal = false;
  6270. continue;
  6271. }
  6272. }
  6273. }
  6274. return retVal;
  6275. }